/cloud-native-app-simulator

A cloud-native application simulator

Primary LanguageGoApache License 2.0Apache-2.0

Build and upload Docker images

Build docker image for main application

  1. Under model directory, run:
docker build -t app-demo .

After creating the docker images, upload them to each of the clusters 'i' by runnning:

kind load docker-image app-demo --name={cluster$i}

Dependecies

  1. kind
  2. tsung
  3. istioctl
  4. kubectl
  5. go (for installation, configuration and basic testing, follow instructions in e.g. How to Install GoLang (Go Programming Language) in Linux; make sure go environment variables and path are configured accordingly)

Environment Preparation

  1. To generate and deploy microservice-based applications, go to the /generator directory
  2. Make sure the /generator directory is located under path ~/go_projects/src/ and initialize module by executing go mod init
  3. If needed, install go module dependencies, e.g. cobra and yaml
  4. Modify any of the input files under the input directory according to your own requirements (see some json examples under the examples directory).
  5. Generate and deploy kubernetes manifest files by running the 'generator.sh' script. This command can be run under two different modes: (i) 'random' mode which generates a random description file or (ii) 'preset' mode which generates Kubernetes manifest based on a description file in the input directory". Note that this commands generates k8s yaml files which are stored under the k8s directory (see some yaml examples under the examples directory).
./generator.sh {mode} {input file}
  1. Modify the necessary files for request generation with tsung
    • Change the initial field of json files under the tsung directory according the chain configuration.
    • Change the chain_no field of json files under the tsung directory according the chain configuration. For example, for first chain it should be 1
    • Update the request_task_type of json files under the tsung directory for assigning user defined task to each microservice in the chain
    • Change server host ip address in conf.xml file with istio-ingress gateway for first microservice in chain.
    • Change the chain json file under the request section in conf.xml to send request to the desired chain. For example, if first chain is targeted it should be chain1.json
  2. Change Kubernetes context to the main cluster
kubectl config use-context cluster1

Running

After configuring environment correctly, you can just use the following command the start request generator.

tsung -f tsung/conf.xml -k start

You can observe the performance metrics for both istio and chain by using the dashboards on grafana interface. To stop traffic generation use´

tsung stop

For more information see doc folder and masther thesis report.

Contribution Guideline

If you are interested in contribution, please visit the community page to learn about development environment setup.

Need for Logging

To be able to have logging, simply follow the instructions in Logging.