/core-dump-handler

Save core dumps from a Kubernetes Service or RedHat OpenShift to an object store such as AWS S3 or IBM Cloud Object Storage

Primary LanguageRustMIT LicenseMIT

IBM Core Dump Handler

This helm chart is designed to deploy functionality that automatically saves core dumps from any public cloud kuberenetes service provider or RedHat OpenShift Kubernetes Service to an S3 compatible storage service.

Prerequisites

The Helm cli to run the chart

An S3 compatible object storage solution such as IBM Cloud Object Storage

A CRIO compatible container runtime on the kubernetes hosts. If you service provider uses something else we will willingly recieve patches to support them.

Installing the Chart

git clone https://github.com/IBM/core-dump-handler
cd core-dump-handler/charts
helm install core-dump-handler . --create-namespace --namespace observe \
--set daemonset.s3AccessKey=XXX --set daemonset.s3Secret=XXX \
--set daemonset.s3BucketName=XXX --set daemonset.s3Region=XXX

Where the --set options are configuration for your S3 compatible provider Details for IBM Cloud are available

OpenShift

As the agent runs in privileged mode the following command is needed on OpenShift. -z is the service account name and -n is the namespace.

oc adm policy add-scc-to-user privileged -z core-dump-admin -n observe

Some OpenShift services run on RHEL7 if that's the case then add the folowing option to the helm command or update the values.yaml. This will be apparent if you see errors relating to glibc in the output.log in the host directory core folder which can be accessed from the agent pod at /core-dump-handler/core

--set daemonset.vendor=rhel7

Verifying the Chart Installation

  1. Create a container
$ kubectl run -i -t busybox --image=busybox --restart=Never
  1. Login to the container
$ kubectl exec -it busybox -- /bin/sh
  1. Generate a core dump by sending SIGSEGV to the terminal process.
# kill -11 $$
  1. View the core dump tar file in the configured Cloud Object Store service instance.

  2. Troubleshoot by looking at the core-dump-composer logs in the observe namespace

Validated Kubernetes Services

This is a matrix of confirmed test targets. Please PR environments that are also known to work

ProviderProductVersionValidated?Working?Notes
IBMIKS1.19YesYes
IBMROKS4.6YesYesMust enable privileged policy See OpenShift Section
MicrosoftAKS1.19YesYes
MicrosoftARO?NoUnknown
AWSEKS1.21YesNo crictl client in the default AMI means that the metadata won't be captured
AWSROSA?NoUnknown
GoogleGKE1.19YesPossibleDefault HostPath Fails A local PV needs to be defined

Background

Core Dumps are a critical part of observability.

As systems become more distributed core dumps offer teams a non-invasive approach to understanding why programs are malfunctioning in any environment they are deployed to.

Core Dumps are useful in a wide number of scenarios but they are very relevant in the following cases:

  • The process exits without a useful stack trace

  • The process runs out of memory

  • An application doesn’t behave as expected

The traditional problems with core dumps are:

  • Overhead of managing the dumps

  • Dump Analysis required specific tooling that wasn't readily available on the developers machine.

  • Managing Access to the dumps as they can contain sensitive information.

This chart aims to tackle the problems surrounding core dumps by leveraging common platforms (K8s, ROKS and Object Storage) in a cloud environment to pick up the heavy lifting.

Chart Details

The chart deploys two processes:

  1. The agent manages the updating of /proc/sys/kernel/* configuration, deploys the composer service and uploads the core dumps zipfile created by the composer to an object storage instance.

  2. The composer handles the processing of a core dump and creating runtime, container coredump and image JSON documents from CRICTL and inserting them into a single zip file. The zip file is stored on the local file system of the node for the agent to upload.

When you install the IBM Cloud Core Dump Handler Helm chart, the following Kubernetes resources are deployed into your Kubernetes cluster:

  • Namespace: A specific namespace is created to install the components into - defaults to ibm-observe

  • Handler Daemonset: The daemonset deploys a pod on every worker node in your cluster. The daemonset contains configuration to enable the elevated process to define the core pattern to place the core dump into object storage as well as gather pod information if available.

  • Privileged Policy: The daemonset configures the host node so priviledges are required.

  • Service Account: Standard Service account to run the daemonset

  • Volume Claims: For copying the composer to the host and enabling access to the generated core dumps

  • Cluster Role: Created with an event resource and create verb and associated with the service account.

Component Diagram

Component Diagram

Permissions

To install the Helm chart in your cluster, you must have the Administrator platform role.

Security implications

This chart deploys privileged kubernetes daemonset with the following implications:

  1. the automatic creation of privileged container per kubernetes node capable of reading core files querying the crictl for pod info.

  2. The daemonset uses hostpath feature interacting with the underlying Linux OS.

  3. The composer binary is deployed and ran on the host server

  4. Core dumps can contain sensitive runtime data and the storage bucket access must be managed accordingly.

  5. Object storage keys are stored as environment variables in the daemonset

Resources Required

The IBM Cloud Core Dump Handler requires the following resources on each worker node to run successfully:

  • CPU: 0.2 vCPU
  • Memory: 128MB

Updating the Chart

  1. Delete the chart. Don't worry this won't impact the data stored in object storage.
$ helm delete coredump-handler . --namespace observe
  1. Ensure the persitent volume forhost-name are deleted before continuing
$ kubectl get pv -n observe
  1. Install the chart using the same bucket name as per the first install but tell the chart not to creat it.
$ helm install coredump-handler . --namespace observe 

Removing the Chart

helm delete coredump-handler -n observe

Build and Deploy a Custom Version

Docker Repository on Quay

The services are written in Rust using rustup.

  1. Build the image docker build -t YOUR_TAG_NAME .

  2. Push the image to your container registry

  3. Update the container in the values.yaml file to use it.

image:
  repository: YOUR_TAG_NAME 

or run the helm install command with the --set image.repository=YOUR_TAG_NAME.