General
Default DNS service url
<service-name>.<namespace>.svc.cluster.local:<service-port>
Debugging
Find pods that have a string in the definition
k get pods -n prod | awk '{print $1}' | xargs -I@ bash -c "echo '@'; kubectl describe pod -n prod @ | grep mongo; echo -e '\n\n\n'"
Force kill pod 🔪
k delete pod -n NAMESPACE POD_NAME --grace-period=0 --force
Find POD by IP
10.117.14.6810.117.31.63
Run busybox
kubectl run -i --tty busybox --image=busybox --restart=Never -- sh
Run container just to entry bash
k run my-debug --image=<docker image uri> --command sleep -- 3600
# and then
k get pods
k exec -it my-debug-eacae012 bash
and debug...
Configuration
Merge two kubeconfig files
cp ~/.kube/config ~/.kube/config.bak && KUBECONFIG=~/.kube/config:/path/to/new/config kubectl config view --flatten > /tmp/config && mv /tmp/config ~/.kube/config
Secrets
Mount secret value as an environment variable
- Create secret env as string:
apiVersion: v1 kind: Secret metadata: name: mysecret type: Opaque stringData: WSO2_CLOUD_ORG_KEY: "mycompany" WSO2_CLOUD_EMAIL: "sample-email@wso2.com" WSO2_CLOUD_PASSWORD: "password"
kubectl apply -f mysecret.yaml
- Use in
Deployment
:env: - name: WSO2_CLOUD_ORG_KEY valueFrom: secretKeyRef: name: mysecret key: WSO2_CLOUD_ORG_KEY
- For usage in kubeflow pipelines:
some_op.add_env_variable( V1EnvVar( name="WANDB_API_KEY", value_from=V1EnvVarSource( secret_key_ref=V1SecretKeySelector( "WANDB_API_KEY", "wandb-api-key", optional=False ) ), ) )
Switch contexts
kubectl config current-context
kubectl config use-context <context_name>
Helm
Access values of nested helm charts with dash in name
E.g. you have mysub-chart
subchart, then:
mysub-chart:
servicename: mysubchart-service
# Then in Helm Chart
{{ index .Values "mysub-chart" "servicename" }}
# If used multiple times just do:
{{- $flyteValues := index .Values "flyte-binary" }}
# At the top of the file and use this #flyteValues variable
Extensions
CSI driver that makes ReadWriteMany from S3 bucket
Also works with CloudFlare R2 https://github.com/yandex-cloud/k8s-csi-s3/tree/master
Example values:
storageClass:
# Specifies whether the storage class should be created
create: true
# Name
name: csi-s3
# Use a single bucket for all dynamically provisioned persistent volumes
singleBucket: "k8s-csi-scaleway"
# mounter to use - either geesefs, s3fs or rclone (default geesefs)
mounter: geesefs
# GeeseFS mount options
mountOptions: "--memory-limit 1000 --dir-mode 0777 --file-mode 0666"
# Volume reclaim policy
reclaimPolicy: Delete
# Annotations for the storage class
# Example:
# annotations:
# storageclass.kubernetes.io/is-default-class: "true"
annotations: {}
secret:
# Specifies whether the secret should be created
create: true
# Name of the secret
name: csi-s3-secret
# S3 Access Key
accessKey: ""
# S3 Secret Key
secretKey: ""
# Endpoint
endpoint: https://<endpoint>.r2.cloudflarestorage.com
No matches...