Releases: litmuschaos/litmus
3.0-beta1
Release Notes (3.0-beta1)
-
Improved scalability in the execution of network & stress experiments via helper pod optimization (one helper per node).
-
Introduction of new experiment category for chaos on springboot applications.
-
Enhanced K8s probe which allows filter by resource names (in addition to label and field selectors).
-
Fixes regression caused in experiment helper base images which prevents execution of privileged tasks.
-
Simplification of chaos candidate selection process - via removal of annotation checks.
-
Fixes a bug (race condition) in installation of execution plane components (workflow controller/configmap).
2.14.0
Release Notes (2.14.0)
Core Component Updates -
-
Adds the containerd CRI support to the DNS experiments litmuschaos/litmus-go#577
-
Adds support for execution of http-chaos experiments in service-mesh environments litmuschaos/litmus-go#578
-
Enhances the network experiments to support port specification in source and destination FQDN/IPs for faults injection litmuschaos/litmus-go#570
-
Adds an option to provide the custom labels to the chaos-runner pod. It can be defined at
spec.components.runner.labels
inside the chaosengine litmuschaos/chaos-operator#427 -
Enhances the cmdprobe-source pods to inherit the experiment pod spec attributes. It allows the source pod to inherit the ENVs, volumes, and volumeMounts litmuschaos/chaos-operator#421
-
Enhances the probe status schema representation inside the chaos-result to add the probe verdict, description, and mode litmuschaos/chaos-operator#419 litmuschaos/litmus-go#566
-
Upgraded the operator-sdk version from 0.15.2 to 1.19.0 to remove the indirect unlicensed dependencies litmuschaos/chaos-operator#420
-
Enhance the HTTP probe to use the global probe timeout as response timeout. litmuschaos/chaos-operator#422
-
Adds the probe retry as an optional parameter inside the probe to support 0 retries(single iteration) and rename the defaultAppHealthCheck to defaultHealthCheck litmuschaos/chaos-operator#424
-
Refactored the chaos-operator for better logging and event creation litmuschaos/chaos-operator#428
-
Fixes chaosresult update conflict issue in abort scenarios litmuschaos/litmus-go#567
-
Fixes the probeSuccessPercentage evaluation inconsistency for the probe failures litmuschaos/litmus-go#568
-
Fixes the stress experiments to clean all the stress-ng child processes during abort litmuschaos/litmus-go#569
-
Adds the steady state checks as tunables based on appHealthChecks parameter inside the chaosengine and removed the AUT status checks from the node and infra experiments litmuschaos/litmus-go#576
ChaosCenter Updates -
-
Enhances MyHub to clone a single branch with one depth #3776 #3792
-
Updates the httpProbe UI screens to remove responseTimeout parameters from the httpProbes/inputs and uses the global timeout #3796
-
Adds the probe retry parameter to an optional field #3797
Shoutouts!
Thanks to our existing and new contributors for this release
@asashiskumarnaik @chinmaym07 @SaptarshiSarkar12 @amityt @avaakash @imrajdas @ispeakc0de @Jonsy13 @neelanjan00 @uditgaurav
Installation
Litmus-2.14.0 (Stable) cluster scope manifest
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.14.0/mkdocs/docs/2.14.0/litmus-2.14.0.yaml
Or
Litmus-2.14.0 (Stable) namespace scope manifest.
#Create a namespace eg: litmus
kubectl create ns litmus
#Install CRDs, if SELF_AGENT env is set to TRUE
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.14.0/litmus-portal-crds-2.14.0.yml
#Install ChaosCenter
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.14.0/litmus-namespaced-2.14.0.yaml -n litmus
Upgrading from 2.13.0 to 2.14.0
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.14.0/mkdocs/docs/2.14.0/upgrade-agent.yaml
Full Changelog: 2.13.0...2.14.0
3.0-beta0
Release Notes (3.0-beta0)
-
Introduction of HTTP Chaos experiment suite
-
Support for network & stress experiments on new versions of Kubernetes (1.21+) & OpenShift (>4.x)
-
Support for network chaos experiments (Latency, Packet Loss, HTTP, DNS) on service-mesh enabled environments
-
Randomization (across range) support for fault inputs
-
Redundancy (HA) for the Chaos Operator
-
Chaos Workflow trigger, list and delete support using CLI (litmusctl)
-
Improved support for containerd & CRIO runtime (DNS, HTTP)
-
More powerful experiment bootstrapping with Litmus SDK
-
Newer faults centered on Kubernetes Nodes (targeting storage volumes)
-
Enabling more powerful hypothesis validation (by widening the scope of command probes)
-
Refactoring of Chaos Server APIs to make them more user-friendly
-
Improvements to the automated e2e test suite
-
Creation of GoogleCodeLabs based Litmus usage tutorials
-
Improvement of security posture (optimization of execution privileges, simplifying docs)
2.13.0
Release Notes (2.13.0)
Core Component Updates -
-
Enhance network experiments to derive IPs of the pods for Kubernetes service if the target pod has a service mesh sidecar. This will enable us to run all network chaos experiments with service mesh enabled effectively. litmuschaos/litmus-go#558
-
Adds Chaos SDK Templates for non-Kubernetes experiments (that is aws, gcp, vmware, azure) this will help us to speed up the experiment development process with a proper template for non-k8s services. To know more refer to the developer docs. litmuschaos/litmus-go#560
-
Fixes the stress-chaos experiments to run chaos (helper pod) with minimum capabilities. This will allow running the stress experiments in a restricted environment (like Openshift) with lesser capabilities as mentioned in SCC docs. litmuschaos/litmus-go#557
-
Enhance the HTTP status code experiment to have the ability to modify the response body. Also, it adds support to provide the content type and encoding for the body in modify body and status code experiment. litmuschaos/litmus-go#556
-
Adds the ability to provide custom Service Account value for helper pod using
CHAOS_SERVICE_ACCOUNT
Env. It is optional, if not provided the helper pod will run with the same service account as the experiment pod. litmuschaos/chaos-runner#178 -
Enhance chaos-operator to enable the leader-elect this ensures with multiple replicas a leader is elected and is the only one actively reconciling the set.litmuschaos/chaos-operator#417
-
Refactor chaos operator code to convert the History field in ChaosResult spec as a Go pointer. litmuschaos/chaos-operator#416
-
Enhance the chaos (helper pod) status check when waiting for completion with proper error handling. litmuschaos/litmus-go#552
-
Adds document content for a better understanding of new HTTP chaos experiments and tunables. #3755
ChaosCenter Updates -
-
Adds enhancement in chaos-scenarios replacing instance-id label with workflow-run-id, which is generated at runtime resulting in unique scenario/run creation on any scenario CRUD operations #3758
-
Upgraded chaos operator go-pkg to 2.12.0 in gql-server & subscriber introducing support for source imagePullSecrets in chaosEngine & along with updates in core components based on 2.12.0. #3759
-
Updated CRDs for ChaosEngines with source attributes updates in 2.12.0 CRD manifest #3742
-
Adds support for providing service-type & makes clusterIP as default service-type for all services in helm-chart litmuschaos/litmus-helm#257
LitmusCTL Updates -
-
Adds changes for Error handling in litmusctl apply manifest logic for better debugging & Usability. litmuschaos/litmusctl#97
-
Adds .exe extension to binaries on Windows litmuschaos/litmusctl#96
-
Upgrades gopkgs for argo-workflows to
v3.3.1
and chaos-operator to2.12.0
versions reducing vulnerabilities. litmuschaos/litmusctl#98
Shoutouts!
Thanks to our existing and new contributors for this release- @chandra-dixit-hcl @alebcay @Jasstkn @amityt @Saranya-jena @SarthakJain26 @Adarshkumar14 @Jonsy13 @ispeakc0de @avaakash @uditgaurav
Installation
Litmus-2.13.0 (Stable) cluster scope manifest
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.13.0/mkdocs/docs/2.13.0/litmus-2.13.0.yaml
Or
Litmus-2.13.0 (Stable) namespace scope manifest.
#Create a namespace eg: litmus
kubectl create ns litmus
#Install CRDs, if SELF_AGENT env is set to TRUE
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.13.0/litmus-portal-crds-2.13.0.yml
#Install ChaosCenter
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.13.0/litmus-namespaced-2.13.0.yaml -n litmus
Upgrading from 2.12.0 to 2.13.0
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.13.0/mkdocs/docs/2.13.0/upgrade-agent.yaml
New Contributors
- @chandra-dixit-hcl made their first contribution in #3752
Full Changelog: 2.12.0...2.13.0
2.12.0
Release Notes (2.12.0)
Core Component Updates:
-
Adds toxicity support in HTTP Chaos experiments. Toxicity can be used to define the percentage of HTTP requests that should be affected for example 50% toxicity will mean only half of the HTTP requests will be affected. litmuschaos/litmus-go#544
-
Introduce randomized status code selection when multiple status code is provided as a fault in input for HTTP status code chaos experiment. litmuschaos/litmus-go#545
-
Adds support for experiments with helper pod in chaoslib in litmus SDK with this, the user can create a chaos template with helper pod model using the same litmus SDK. litmuschaos/litmus-go#546
-
Adds support for imagePullSecret in source cmd Probe this will enable the user run cmd probe pod with private image. litmuschaos/chaos-operator#415
-
Fixes litmus-e2e pipeline and unit test pipeline by specifying version for creating k3s cluster. litmuschaos/litmus-e2e#391
-
Fixes chaos execution on openshift-4.x by providing finalizer permission to chaos-operator service account, with the new operator upgrade in litmus 2.11.0 brings down this requirement. litmuschaos/chaos-operator#413
-
Fixes chaos-operator vulnerabilities detected by snyc and trivy in the build pipeline. litmuschaos/chaos-operator#414
ChaosCenter Updates -
-
Adds an advanced tuning feature for experiments individually with more supported configurations #3715
-
Adds a new feature for connecting a remote ChaosHub to ChaosCenter #3722
-
Adds a new API
getServerVersion
for fetching GQL server version #3721 -
Makes
clusterIP
to be used by default for generating endpoints for internal delegates/self-agent #3709 -
Adds an additional permission required for execution plane to be deployed in openshift clusters #3708
-
Upgrades gopkgs for Chaos-Operator to
v2.11.0
& Argo tov3.3.1
reducing some of the vulnerabilities in Graphql-server & Subscriber. #3718 -
Removes the support for dashboards & datasources configuration from UI. #3716
-
Fixes a bug of workflow getting failed when using dex/ providing email as username #3705
-
Fixes a bug of frontend crashing when providing invalid cron-syntax #3714
-
Fixes a bug when editing schedule for first time due to state not getting cleaned up #3727
-
Adds fix for workflows comparison plot not coming #3729
-
Adds fix for logs not coming for install experiments step #3729
-
Adds fix for UI not getting updated for
deactivate user
andcreated_at
column showinginvalid date
in Users Table in admin-account #3733
Litmusctl Updates -
-
With litmusctl
0.12.0
release, we have updated some commands with the new terminologies ✨:litmusctl connect agent
is nowlitmusctl connect chaos-delegate
litmusctl disconnect agent
is nowlitmusctl disconnect chaos-delegate
litmusctl get agents
is nowlitmusctl get chaos-delegates
litmusctl create workflow
is nowlitmusctl create chaos-scenario
litmusctl delete workflow
is nowlitmusctl delete chaos-scenario
litmusctl describe workflow
is nowlitmusctl describe chaos-scenario
litmusctl get workflows
is nowlitmusctl get chaos-scenarios
litmusctl get workflowruns
is nowlitmusctl get chaos-scenario-runs
litmusctl upgrade agent
is nowlitmusctl upgrade chaos-delegate
-
Improves error handling logic for
upgrade chaos-delegate
,describe chaos-scenario
anddisconnect agent
commands. litmuschaos/litmusctl#81 -
Adds
--kubeconfig
flag inupgrade chaos-delegate
command. litmuschaos/litmusctl#89 -
Adds fix for passing namespace in the SelfSubjectAccessReviews function. litmuschaos/litmusctl#82
-
litmusctl will now prompt if installed version of litmusctl is not compatible with installed litmus control plane. litmuschaos/litmusctl#84
-
Users can check the compatibility matrix in the readme or by using
litmusctl version
command. litmuschaos/litmusctl#84
Users can also find the commands in readme: https://github.com/litmuschaos/litmusctl#readme
NOTE: - Along with above terminologies updates, we will also be updating directory structure of ChaosHub for better readability and scalability of experiments and scenarios. With upcoming release, the charts
directory will be renamed to experiments
directory and workflows
will be renamed to scenarios
directory. Same changes have been already done in 2.11.0 branch/version of ChaosHub. So, Users are requested to upgrade their ChaosHub directory structure with provided changes before upgrading to upcoming release - 2.13.0 version of ChaosCenter.
Shoutouts!
Thanks to our existing and new contributors for this release- @dnielsen @deividMatos @amityt @Saranya-jena @SarthakJain26 @Adarshkumar14 @imrajdas @Jonsy13
Full Changelog: 2.11.0...2.12.0
Installation
Litmus-2.12.0 (Stable) cluster scope manifest
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.12.0/mkdocs/docs/2.12.0/litmus-2.12.0.yaml
Or
Litmus-2.12.0 (Stable) namespace scope manifest.
#Create a namespace eg: litmus
kubectl create ns litmus
#Install CRDs, if SELF_AGENT env is set to TRUE
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.12.0/litmus-portal-crds-2.12.0.yml
#Install ChaosCenter
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.12.0/litmus-namespaced-2.12.0.yaml -n litmus
Upgrading from 2.11.0 to 2.12.0
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.12.0/mkdocs/docs/2.12.0/upgrade-agent.yaml
2.11.0
Release Notes (2.11.0)
Core Component Updates -
-
Introduce different new HTTP chaos experiments for Kubernetes targets, this will allow users to introduce the following faults:
- pod-http-status-code (modifies the status code of the response)
- pod-http-modify-body (modifies the body of the response)
- pod-http-modify-header (modify headers of incoming requests or the response from the service targetted)
- pod-http-reset-peer (stops outgoing http requests by resetting the TCP connection)
To know more checkout the experiment-docs.
-
Upgrade the operator SDK version to 1.14.0 for chaos operator and code refator for other litmus components to achieve compatibility.
-
Adds support for non-default vpc for the AWS ELB az-down experiment. As earlier the experiment only targets the ELB(s) that are associated with default vpc, so this will also allow the user to target the ELB(s) that are not associated with default vpc.
-
Enhance cmd probe spec to support different configuration for probe pod and containers like imagePullPolicy, cmd, args and so on. This will allow the user to run the cmd probe in more controlled way when used in source mode.
-
Fixes the error handling for application status check with litmus annotation for pod-level experiments.
-
Adds litmusctl docker image which will allow the users to install the agents (delegates) from a pod/container.
ChaosCenter Updates -
-
Updates terminologies for different entities -
- Agents --> Chaos Delegates
- Workflows --> Chaos Scenarios
- Charts --> Chaos Experiments
-
Reduces the permissions in namespaced mode for execution plane components
-
Fixes an issue in SyncHub API when there is an error in communication between graphql-server and MongoDB and all hubs were getting deleted while trying to reclone current chaoshub.
NOTE: - Along with above terminologies updates, we will also be updating directory structure of ChaosHub for better readability and scalability of experiments and scenarios. With upcoming release, the charts will be renamed to experiments
directory and workflows will be renamed to scenarios
. Same changes have been already done in 2.11.0 version of ChaosHub. So, Users are requested to upgrade their ChaosHub directory structure with provided changes before upgrading to upcoming release - 2.12.0 version of ChaosCenter.
Installation
Litmus-2.11.0 (Stable) cluster scope manifest
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.11.0/mkdocs/docs/2.11.0/litmus-2.11.0.yaml
Or
Litmus-2.11.0 (Stable) namespace scope manifest.
#Create a namespace eg: litmus
kubectl create ns litmus
#Install CRDs, if SELF_AGENT env is set to TRUE
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.11.0/litmus-portal-crds-2.11.0.yml
#Install ChaosCenter
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.11.0/litmus-namespaced-2.11.0.yaml -n litmus
Upgrading from 2.10.0 to 2.11.0
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.11.0/mkdocs/docs/2.11.0/upgrade-agent.yaml
2.10.0
Release Notes (2.10.0)
Core Component Updates -
-
Adds HTTP chaos experiment for Kubernetes applications using toxiproxy. This will allow you to introduce latency in the target application service and check the application availability.
-
Introduces the first Beta version for m-agent (machine-agent) which enable us to run chaos on non-k8s target. It also includes a new cpu-stress experiment that can run CPU chaos on the target VM(s).
-
Adds the missing –stress-image parameter for the pod-io-stress experiment that enables us to add a custom stress image for the experiment when using Pumba lib.
-
Enhanced the recovery of node cordon experiment when app status check fails during the chaos.
-
Fixes the chaos result verdict update for GCP disk loss by label experiment during the different stages of chaos.
-
Fixes node level e2e check for every build on a pull request for the litmus-go repository.
-
Adds docs for the new HTTP chaos experiment, updates the GCP experiment docs, and introduces some more examples in docs for pod network latency experiment with jitter.
-
Adds chaos charts for AWS AZ down experiment in the hub this will help to get the manifest for the experiment workflow preparation.
-
Fixes the GCP and m-agent e2e pipeline to run the automated tests seamlessly.
ChaosCenter Updates -
-
Refactored graphql-server for extracting queries, mutations, and subscriptions to the respective schema files
-
Added support for Envoy proxy when using frontend nginx.
-
Added UI enhancement for allowing scrolling to the invitations tab after clicking on the Invitations button.
-
Fixed issues with httpProbe and promProbe in tune workflow section due to the addition of
httpProbe/inputs: {}
when adding multiple probes. -
Added check for invalid schedule type when trying to proceed in workflow construction wizard without selecting schedule type.
-
Fixed issue in GitOps when updating the git repository configuration.
-
Added CHAOS_CENTER_UI_ENDPOINT env for specifying a one-time UI endpoint for the control plane, so that all external agents can be provided with the same (Available for cluster and namespace scope).
-
Added support for automatically adding imagePullSecrets in for Engine, Runner & Experiments pods from configured image registry.
Litmusctl Updates:
-
Added commands like
litmusctl get workflows
,litmusctl create workflow
,litmsuctl describe workflow
,litmusctl delete workflow
andlitmusctl get workflow-runs
for workflow CRUD operations. -
Renamed
litmusctl create agent
command tolitmusctl connect agent
-
Added new command
disconnect agent
for disconnecting agents from the Control plane. -
Enhanced logging for better debugging.
Note:
- For using newly added commands, users will have to download the v0.11.0 version of litmusctl.
- litmusctl v0.11.0 only supports litmus v2.10.0 or higher versions
New Contributors
- @QAInsights made their first contribution in #3612
Full Changelog: 2.9.0...2.10.0
2.9.0
Release Notes (2.9.0)
Core Component Updates -
-
Adds GCP Instance Stop and Disk Fill Experiments by the label that supports multiple target selection using common labels.
-
Refactor the GCP disk loss experiment to remove the device name input and auto-derive it within the experiment.
-
Enhance EC2 Terminate experiment checks when the managed nodegroup env is enabled to validate the node recovery through AWS APIs instead of Kubernetes APIs.
-
Introduces GCP IAM integration through workload identity for keyless authentication in GKE clusters.
-
Fixes Litmus SDK and introduces the default app health check feature in the SDK template.
-
Fixes error handling for an invalid appinfo input. The experiments are now supposed to fail in the pre chaos validation and won’t go to the chaos injection stage.
-
Fixes chaos injection issues on OpenShift due to the helper pod failure caused due to the same IP it was assigned as the experiment pod, it occurs due to the same annotation shared by helper and experiment pods. Now, this can be tuned via an env called SET_HELPER_DATA if we don’t want to use the experiment data inside helper pods we can enable it.
-
Adds chaos charts for process kill experiment which is in beta version and runs with the help of m-agent.
-
Fixes the default value of the chaos tunable in the stress chaos experiment to support the default execution of the experiment.
-
Cleanup the stale workflows from chaos charts and retain the active workflows only.
-
Adds document fixes for stress chaos experiment and introduces docs for GCP IAM integration.
-
Adds m-agent e2e pipeline that includes tests for process kill experiment.
ChaosCenter Updates -
-
Weight and experiments mapping logic has been updated for handling cases where one workflow contains more than one instance of the same experiment. Now chaosengine name will be used for mapping experiment to the corresponding weight.
-
Refactored GQL server APIs for better documentation & following a standard schema.
-
Updated API docs according to new changes and added missing APIs.
-
Added support for using a custom image registry inside the experiment when using a custom image registry.
-
Updated the namespaced scope manifest to reduce the complexity of installation instructions.
-
Fixed permission issue for event-tracker in namespaced mode.
-
Fixed image version in revert-chaos step for using versioned tag instead of latest.
-
Fixed error logging in subscriber for handling error when there are fewer permissions available due to old installation.
-
Fixed error logging in Control-plane upgrade agent when new and current versions are the same by providing a warning instead of the error.
NOTE: As all the APIs on graphql-server have been updated for following a standard schema, Litmusctl has also been updated for supporting the same. So, ChaosCenter v2.9.0 will be compatible with Litmusctl v0.10.0. Please make sure to upgrade the litmusctl before using with ChaosCenter v2.9.0.
Installation
Litmus-2.9.0 (Stable) cluster scope manifest
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.9.0/mkdocs/docs/2.9.0/litmus-2.9.0.yaml
Or
Litmus-2.9.0 (Stable) namespace scope manifest.
#Create a namespace eg: litmus
kubectl create ns litmus
#Install CRDs, if SELF_AGENT env is set to TRUE
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.9.0/litmus-portal-crds-2.9.0.yml
#Install ChaosCenter
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/master/mkdocs/docs/2.9.0/litmus-namespaced-2.9.0.yaml -n litmus
Upgrading from 2.8.0 to 2.9.0
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.9.0/mkdocs/docs/2.9.0/upgrade-agent.yaml
2.8.0
Release Notes (2.8.0)
Core Component Updates
-
Fixes the incorrect target container name passed to the helper pod. This occurs when multiple different applications containing different container names were selected as chaos candidates. litmuschaos/litmus-go#496
-
Fixes the statusCheckTimeout feature for container kill experiment to enable the helper pod to use custom timeouts. The helper pod of the container kill experiment was only using 180sec as a timeout. litmuschaos/litmus-go#498
-
Fixes the default path of the SSM docs (fault template) used in the SSM chaos experiments to support the chaos execution. The SSM docs contain the chaos injection logic, one can also provide their own docs to run this experiment using configmap or secrets. litmuschaos/litmus-go#508
-
Enhance experiment logs to handle warnings like “Neither --kubeconfig nor --master was specified for InClusterConfig” - such warnings were appearing in experiment logs for every run which are now handled properly. litmuschaos/litmus-go#507
-
Fixes litmus-python vulnerability issues by bumping the python version from 3.8 to 3.8.13. litmuschaos/litmus-python#41
-
Enable litmus snyk image to support python libraries which also fixes snyk security scan check on litmus-python.
-
Adds docs examples to show the selection of target pods from a specific node using a NODE_LABEL env.
Chaos Center Updates
-
Migrated FluxCD to ArgoCD and added terraform scripts to provision EKS cluster to deploy LitmusChaos applications (v1-Docs, Docs, Hub)
-
Added ability to configure self-agent component's node selector and tolerations
-
Added support to subscriber and event tracker to store and retrieve CLUSTER_ID and ACCESS_KEY in Kubernetes secrets
-
Added email validation and RBAC check get_user_with_project API
-
Added workflow type filter, pre-defined workflow redirect link, and updated analytics routes
-
Fixed workflow failure issue while adding experiments with the same name
-
Synced the ChaosCenter APIs document with the latest schema changes
-
Upgraded Workflow-controller (v3.2.9), Argo-executor(v3.2.9) and LitmusCore(2.7.0)
Installation
Litmus-2.8.0 (Stable) cluster scope manifest
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.8.0/mkdocs/docs/2.8.0/litmus-2.8.0.yaml
Or
Litmus-2.8.0 (Stable) namespace scope manifest.
export LITMUS_PORTAL_NAMESPACE="<namespace>"
kubectl create ns ${LITMUS_PORTAL_NAMESPACE}
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.8.0/litmus-portal/litmus-portal-crds.yml
curl https://raw.githubusercontent.com/litmuschaos/litmus/2.8.0/mkdocs/docs/2.8.0/litmus-namespaced-2.8.0.yaml --output litmus-portal-namespaced-k8s-template.yml
envsubst '${LITMUS_PORTAL_NAMESPACE}' < litmus-portal-namespaced-k8s-template.yml > ${LITMUS_PORTAL_NAMESPACE}-ns-scoped-litmus-portal-manifest.yml
kubectl apply -f ${LITMUS_PORTAL_NAMESPACE}-ns-scoped-litmus-portal-manifest.yml -n ${LITMUS_PORTAL_NAMESPACE}
Upgrading from 2.7.0 to 2.8.0
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.8.0/mkdocs/docs/2.8.0/upgrade-agent.yaml
2.7.0
Release Updates
Core Component Updates
-
Fixes the higher image vulnerabilities for different litmus components by updating the binaries used in it.
-
Fixes the code scan vulnerabilities (CVEs) by updating the go packages for different litmus components. Also, adds sync actions to get the code vulnerabilities on every code commit.
-
Enhance pod-level experiments by supporting randomized chaos tunables which enable us to provide the range of value in chaos parameter.
-
Adds support for cgroup version 2 in stress chaos experiments(pod cpu/mem/io).This will be backward compatible with the version 1 as well.
-
Adds node label filter for selecting the target pods in pod-level experiments. This helps us to select the pods scheduled on specific nodes as chaos candidates. This feature requires having a node-level permission for filtering pods on a specific node.
-
Adds some more experiment example docs at https://litmuschaos.github.io/litmus/
Chaos Center Updates
-
Added RBAC checks in all the APIs of the chaos center to make it more secure
-
Optimized MyHub APIs to fetch the data more efficiently
-
Added /readiness route for readiness probes
-
Following changes in the deployment manifest and helm charts
- Added resource {limit, request}, automountServiceAccountToken, readOnlyRootFilesystem and securityContexts for all the components
- Separated auth-server container from litmus-server deployment and made it as deployment
- Moved some credentials from configmap to secrets
- Added a headless service to mongo statefulsets
Installation
Litmus-2.7.0 (Stable) cluster scope manifest
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.7.0/mkdocs/docs/2.7.0/litmus-2.7.0.yaml
Or
Litmus-2.7.0 (Stable) namespace scope manifest.
export LITMUS_PORTAL_NAMESPACE="<namespace>"
kubectl create ns ${LITMUS_PORTAL_NAMESPACE}
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.7.0/litmus-portal/litmus-portal-crds.yml
curl https://raw.githubusercontent.com/litmuschaos/litmus/2.7.0/mkdocs/docs/2.7.0/litmus-namespaced-2.7.0.yaml --output litmus-portal-namespaced-k8s-template.yml
envsubst '${LITMUS_PORTAL_NAMESPACE}' < litmus-portal-namespaced-k8s-template.yml > ${LITMUS_PORTAL_NAMESPACE}-ns-scoped-litmus-portal-manifest.yml
kubectl apply -f ${LITMUS_PORTAL_NAMESPACE}-ns-scoped-litmus-portal-manifest.yml -n ${LITMUS_PORTAL_NAMESPACE}
Upgrading from 2.6.0 to 2.7.0
kubectl apply -f https://raw.githubusercontent.com/litmuschaos/litmus/2.7.0/mkdocs/docs/2.7.0/upgrade-agent.yaml