Skip to content

Latest commit

 

History

History
48 lines (34 loc) · 2.89 KB

chaos-recommender.md

File metadata and controls

48 lines (34 loc) · 2.89 KB

Chaos Recommender

This tool profiles an application and gathers telemetry data such as CPU, Memory, and Network usage, analyzing it to suggest probable chaos scenarios. For optimal results, it is recommended to activate the utility while the application is under load.

Run

$ podman run --name=<container_name> --net=host --env-host=true -v <path-to-kube-config>:/home/krkn/.kube/config:Z  -e NAMESPACE=<NAMESPACE> -e PROMETHEUS_ENDPOINT=<PROMETHEUS_ENDPOINT> -e PROMETHEUS_TOKEN=<PROMETHEUS_TOKEN>  quay.io/krkn-chaos/krkn-hub:chaos-recommender

TIP: Because the container runs with a non-root user, ensure the kube config is globally readable before mounting it in the container. You can achieve this with the following commands: kubectl config view --flatten > ~/kubeconfig && chmod 444 ~/kubeconfig && docker run $(./get_docker_params.sh) --name=<container_name> --net=host -v ~kubeconfig:/home/krkn/.kube/config:Z -d quay.io/krkn-chaos/krkn-hub:<scenario>

Supported parameters

See list of variables that apply to all scenarios here that can be used/set in addition to these scenario specific variables

ex.) export <parameter_name>=<value>

Required variables
Parameter Description
NAMESPACE Targeted namespace in the cluster
PROMETHEUS_ENDPOINT Prometheus API endpoint in the cluster to gather telemetry data
PROMETHEUS_TOKEN Prometheus API Token (usually matches with OCP token)
THRESHOLD Threshold to compare and determine the outliers, for example 0.7 i.e 70%
CPU_THRESHOLD CPU threshold to compare with the cpu limits, for example 0.5 i.e 50%
MEMORY_THRESHOLD Memory threshold to compare with the memory limits, for example 0.5 i.e 50%

TIP: to collect prometheus endpoint and token from your OpenShift cluster you can run the following commands:

prometheus_url=$(kubectl get routes -n openshift-monitoring prometheus-k8s --no-headers | awk '{print $2}')

#TO USE YOUR CURRENT SESSION TOKEN
token=$(oc whoami -t)

#TO CREATE A NEW TOKEN
token=$(kubectl create token -n openshift-monitoring prometheus-k8s --duration=6h || oc sa new-token -n openshift-monitoring prometheus-k8s)
Optional variables
Parameter Description Default
SCRAPE_DURATION Prometheus scrap duration 1m
LOG_LEVEL Log Level, supported log levelsDEBUG, INFO, WARNING, ERROR, CRITICAL INFO