This project is an extension of the project "Hipster Shop: Cloud-Native Microservices Demo Application" from Google, available here: https://github.com/GoogleCloudPlatform/microservices-demo
The main focus here is to be able to deploy that demo project to Azure Kubernetes Service using best practices.
Hipster Shop is a demo project to test a microservices architecture on Kubernetes. It comprises an online shop powered by 10 different microservices, written in different programming languages (Java, Go, C#, Python, JavaScript/NodeJS). It is not a functional service or optimized, and its purpose is only for learning and testing. It comes with Locust preconfigured, a load generator that will start to run simulated traffic on the shop as soon as it boots up.
The original Hipster Shop demo is intended for use in a local kubernetes cluster or deployed to Google Kubernetes Engine. As Kubernetes is a standard, to add value to this demo we will explain how to deploy it on Azure Kubernetes Services (AKS) using Terraform, with a special focus on specific requirements for this cloud provider.
We will also deploy Prometheus as a metric extractor and Grafana as a visualization tool for those metrics into the Kubernetes cluster using Helm.
This instructions comes with some optional, alternative and improvement parts. You can skip them if you like for a straigh forward procedure. The improvements will suggest additional task that you could investigate on your own to improve this excercise.
We will assume we use a bash shell environment. Whenever an example script starts with $, it means you should type what is beyond the symbol in your terminal. Sometimes the expected output of a command is shown, to make it easier to identify output information.
If you are using Windows, most of the explanations here could be used in cmd.exe, but you can achieve full compatibily by using Windows Subsystem for Linux.
Improvement: Adapt the explanations and scripts to be able to use them from Windows's cmd.exe or Powershell.
- 0. Getting started
- 1. Prerequisites
- 2. Initial Azure resources setup
- 3. Provision infrastructure with Terraform
- 4. Get credentials
- 5. Create cluster with Skaffold
- 6. Create cluster with Skaffold
- 7. Terminate and free resources
- Appendix: Troubleshooting