Skip to content

Latest commit

 

History

History
129 lines (100 loc) · 6.01 KB

README.md

File metadata and controls

129 lines (100 loc) · 6.01 KB

SRE Stack

This repository provisions sufficiently-complex microservice demo applications such as:

Along with standard observability tooling such as:

Scenarios

sre-stack contains carefully crafted fault injection scenarios to effectively disrupt operations of the demo-applications. Using this repo we create the following feedback-loop:

  • Fault-injection
  • Fault-detection using various o11y tooling
  • Root Cause Analysis using classic / advanced tools
  • Fault mitigation strategies, both long-term and short-term

Available scenarios:

Load-generators:

Prerequisites

Setup & Configuration

The core configuration is stored in the .env file. This is consumed by the makefile to provision infrastructure and deploy applications.

Configuration

Configurations are grouped in the .env file in self-explanatory sections. Most values are set to their sane defaults and would not need changing for initial setup.

Core provisioning and deployment choices are expressed in the following two variables:

  • STACK_MODE = [ eks| local ]
    • Choice of deploying the stack to either aws/eks or using a k3d cluster on local linux systems.
  • APP_STACK=[ robot-shop | hotrod | all ]

Setup

Provisioning lifecycles are controlled by Make commands. Prefix all commands with make keyword.

Example: make setup

AWS - EKS Lifecycle Commands

For EKS based provisioning you need to setup AWS_PROFILE pointing to the correct AWS account.

Following AWS credentials for the said profile should be added to ~/.aws/credentials

[profile-name]
aws_access_key_id=*************
aws_secret_access_key=*********
EKS setup/deploy/cleanup commands:
	setup                               - End-to-end setup on EKS
	start-cluster                       - start EKS Cluster
	setup-cluster-autoscaler            - Setup node auto scaling
	setup-observability                 - Setup monitoring/observability
	setup-optional-otel                 - Setup OpenTelemetry
	setup-istio                         - Setup istio and ingress
	setup-db-rds-mysql                  - Setup RDS - mysql
	setup-rabbitmq-operator             - Setup rabbitmq-operator
	setup-robot-shop                    - Deploy robot-shop app-stack.
	setup-optional-rmq-consumer-scaling - Setup keda to scale dispatch (optional)
	setup-gateway                       - Setup Ingress gateway
	cleanup-cluster                     - Cleanup cluster
	cleanup                             - Clenaup all resources and EKS cluster

Local - k3D Lifecycle Commands

Just make sure k3d is installed, cluster-creation and lifecycle are handled by the following commands:

Local (k3D) setup/deploy/cleanup commands:
	setup-local                         - Setup end-to-end stack on local k8s (k3d)
	setup-local-cluster                 - Setup local k3d cluster
	cleanup-local                       - Cleanup end-to-end stack on local k8s (k3d)

Utility Commands:

  get-service-endpoints               -  Print exposed endpoints (works for both local/eks)

Contribution Guide

We welcome contributions from the community to help improve and expand this repository. Please take a moment to review this guide before getting started.

How to Contribute

Fork the Repository: Start by forking the repository to your own GitHub account.

Make Changes: Ensure that your changes adhere to the project's coding conventions and style guidelines.

Test Your Changes: Test your changes thoroughly to ensure they work as intended and do not introduce any regressions. Here are the steps to test your changes:

  1. Setup: If your changes involve infrastructure setup or deployment, ensure that you test it by creating an EKS or k3d cluster as specified in the above Life Cycle Commands section.

  2. Verification: Verify that the application behaves as expected after your changes. Ensure there are no unexpected side effects.

  3. Logging and Screenshots: Capture logs, screenshots, or any other evidence that demonstrates the effectiveness of your changes. This evidence will help reviewers understand the impact of your contributions.

Submit a Pull Request: Provide a detailed description of your changes in the pull request, including any relevant information that may help reviewers understand the purpose and impact of the changes. Include the evidence of your testing, such as logs and screenshots, to support your changes.

NOTE The pull request may be accepted, rejected, or require further modifications before it can be merged.