configmap
字面值创建
kubectl create configmap my-config --from-literal=key1=config1 --from-literal=key2=config2
kubectl get cm
kubectl describe cm my-config
data:image/s3,"s3://crabby-images/238d9/238d9a85989d80f92429c9989463311cf1200c23" alt=""
通过文件创建
kubectl create configmap my-config-2 --from-file=/etc/resolv.conf
kubectl describe cm my-config-2
通过目录创建
mkdir test
cp /etc/passwd test/
cp /etc/fstab test/
ls test/
data:image/s3,"s3://crabby-images/d054f/d054fe9036effcb337d11c0c7726cc36ca54f480" alt=""
kubectl create configmap my-config-3 --from-file=test
kubectl describe cm my-config-3
data:image/s3,"s3://crabby-images/843a1/843a1646a0c0c08765a6dacc17fde7f3e07e6bf8" alt=""
通过yaml文件创建
vim cm1.yaml
apiVersion: v1
kind: ConfigMap
metadata:
name: cm1-config
data:
db_host: "172.25.0.250"
db_port: "3306"
kubectl apply -f cm1.yaml
kubectl describe cm cm1-config
data:image/s3,"s3://crabby-images/5bc0b/5bc0b8d1a007d93f5c50a2be858cc07b8a80583a" alt=""
使用configmap设置环境变量
vim pod1.yaml
apiVersion: v1
kind: Pod
metadata:
name: pod1
spec:
containers:
- name: pod1
image: busybox
command: ["/bin/sh", "-c", "env"]
env:
- name: key1
valueFrom:
configMapKeyRef:
name: cm1-config
key: db_host
- name: key2
valueFrom:
configMapKeyRef:
name: cm1-config
key: db_port
restartPolicy: Never
kubectl apply -f pod1.yaml
kubectl logs pod1
data:image/s3,"s3://crabby-images/e8d10/e8d1006c7c3e0ab294a793979c7b6cce7f9f097d" alt=""
kubectl delete pod pod1
vim pod2.yaml
apiVersion: v1
kind: Pod
metadata:
name: pod2
spec:
containers:
- name: pod2
image: busybox
command: ["/bin/sh", "-c", "env"]
envFrom:
- configMapRef:
name: cm1-config
restartPolicy: Never
kubectl apply -f pod2.yaml
kubectl logs pod2
data:image/s3,"s3://crabby-images/02c29/02c294e751c4901d39f1ed4f0ec0fafe62f3fdd1" alt=""
kubectl delete pod pod2
使用conigmap设置命令行参数
vim pod3.yaml
apiVersion: v1
kind: Pod
metadata:
name: pod3
spec:
containers:
- name: pod3
image: busybox
command: ["/bin/sh", "-c", "echo $(db_host) $(db_port)"]
envFrom:
- configMapRef:
name: cm1-config
restartPolicy: Never
kubectl apply -f pod3.yaml
kubectl logs pod3
data:image/s3,"s3://crabby-images/e57a7/e57a7668b6c2adb46fc1afdc4d66b9d5e105875c" alt=""
kubectl delete pod pod3
通过数据卷使用configmap
vim pod4.yaml
apiVersion: v1
kind: Pod
metadata:
name: pod4
spec:
containers:
- name: pod4
image: busybox
command: ["/bin/sh", "-c", "cat /config/db_host"]
volumeMounts:
- name: config-volume
mountPath: /config
volumes:
- name: config-volume
configMap:
name: cm1-config
restartPolicy: Never
kubectl apply -f pod4.yaml
kubectl logs pod4
data:image/s3,"s3://crabby-images/30860/30860eee4042348dc8c0894750ed28782e203d8b" alt=""
kubectl delete pod pod4
configmap热更新
vim nginx.conf
server {
listen 8000;
server_name _;
location / {
root /usr/share/nginx/html;
index index.html index.htm;
}
}
kubectl create configmap nginxconf --from-file=nginx.conf
kubectl describe cm nginxconf
data:image/s3,"s3://crabby-images/0e17a/0e17a06fbef1aa2d09c9fa0e86e93cd86946ed91" alt=""
vim my-nginx.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
name: my-nginx
spec:
replicas: 1
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx
volumeMounts:
- name: config-volume
mountPath: /etc/nginx/conf.d
volumes:
- name: config-volume
configMap:
name: nginxconf
kubectl apply -f my-nginx.yaml
kubectl get pod -o wide
data:image/s3,"s3://crabby-images/dbcce/dbcce0b4b25345bf06ba8c80cdb0be9f4330fe0b" alt=""
kubectl exec my-nginx-85fb986977-87dff -- cat /etc/nginx/conf.d/nginx.conf
data:image/s3,"s3://crabby-images/bed52/bed52327c84405cb89682f13116b06def3390657" alt=""
curl 10.244.219.17:8000
data:image/s3,"s3://crabby-images/2d850/2d850b31eb142ecb360b67e03622ef0c92686518" alt=""
编辑cm,修改端口
kubectl edit cm nginxconf
data:image/s3,"s3://crabby-images/f0d5a/f0d5af5f0771cde315da3df555bb124162fd387f" alt=""
kubectl exec my-nginx-85fb986977-87dff -- cat /etc/nginx/conf.d/nginx.conf
data:image/s3,"s3://crabby-images/39d4f/39d4f9d3c081f64532764f09b418db9eac02ae3e" alt=""
修改cm后,过上几秒配置信息会同步到容器,但是容器内运行的服务并不会加载生效,需要手动刷新
方式一:(推荐)
kubectl delete pod my-nginx-85fb986977-87dff
方式二:(手动触发版本更新,会新建一个replicaset)
kubectl patch deployments.apps my-nginx --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "20231103"}}}}}'
kubectl get pod -o wide
data:image/s3,"s3://crabby-images/45f9c/45f9c5990c4effa0659c01d1c0d909003518b960" alt=""
curl 10.244.106.133
secrets
从文件创建
echo -n 'admin' > ./username.txt
echo -n 'westos' > ./password.txt
kubectl create secret generic db-user-pass --from-file=./username.txt --from-file=./password.txt
kubectl get secrets db-user-pass -o yaml
data:image/s3,"s3://crabby-images/4ff2b/4ff2b3c31aa8cd90a90f24469f3fe8bb7577dc9c" alt=""
编写yaml文件
echo -n 'admin' | base64
echo -n 'westos' | base64
data:image/s3,"s3://crabby-images/98a23/98a2399048a5f7fadec489f3b40e6aa09f631f2f" alt=""
vim mysecret.yaml
apiVersion: v1
kind: Secret
metadata:
name: mysecret
type: Opaque
data:
username: YWRtaW4= #必须编码后的值
password: d2VzdG9z
kubectl apply -f mysecret.yaml
kubectl get secrets mysecret -o yaml
将Secret挂载到Volume中
vim pod1.yaml
apiVersion: v1
kind: Pod
metadata:
name: mysecret
spec:
containers:
- name: nginx
image: nginx
volumeMounts:
- name: secrets
mountPath: "/secret"
readOnly: true
volumes:
- name: secrets
secret:
secretName: mysecret
kubectl apply -f pod1.yaml
kubectl get pod
data:image/s3,"s3://crabby-images/2d4c3/2d4c36dc43d0be893e0b343ad3bd6bd930f7d566" alt=""
kubectl exec mysecret -- ls /secret
data:image/s3,"s3://crabby-images/12f8b/12f8b8eda16f80f7002d29948c12343d558d5691" alt=""
kubectl delete -f pod1.yaml
向指定路径映射 secret 密钥
vim pod2.yaml
apiVersion: v1
kind: Pod
metadata:
name: mysecret
spec:
containers:
- name: nginx
image: nginx
volumeMounts:
- name: secrets
mountPath: "/secret"
readOnly: true
volumes:
- name: secrets
secret:
secretName: mysecret
items:
- key: username
path: my-group/my-username
kubectl apply -f pod2.yaml
kubectl exec mysecret -- cat /secret/my-group/my-username
data:image/s3,"s3://crabby-images/22827/2282742137ba4e59d4bb65fc8a8a6c6071c7d0c1" alt=""
kubectl delete -f pod2.yaml
将Secret设置为环境变量
vim pod3.yaml
apiVersion: v1
kind: Pod
metadata:
name: secret-env
spec:
containers:
- name: pod3
image: busybox
command: ["/bin/sh", "-c", "env"]
env:
- name: SECRET_USERNAME
valueFrom:
secretKeyRef:
name: mysecret
key: username
- name: SECRET_PASSWORD
valueFrom:
secretKeyRef:
name: mysecret
key: password
restartPolicy: Never
kubectl apply -f pod3.yaml
kubectl logs secret-env
data:image/s3,"s3://crabby-images/9cbf0/9cbf00b35246b35686a2becb62ad9c9a69316818" alt=""
存储docker registry的认证信息
kubectl create secret docker-registry myregistrykey --docker-server=reg.westos.org --docker-username=admin --docker-password=westos --docker-email=hjl@westos.org
新建私有仓库
data:image/s3,"s3://crabby-images/e00f1/e00f13eabc2cf7defd648a94909f0abc8e8deb2b" alt=""
vim pod4.yaml
apiVersion: v1
kind: Pod
metadata:
name: mypod
spec:
containers:
- name: game2048
image: reg.westos.org/westos/game2048
imagePullSecrets:
- name: myregistrykey
kubectl apply -f pod4.yaml
kubectl get pod
data:image/s3,"s3://crabby-images/8c77e/8c77ea77247179b306ce1b99d1c353723cfe54f1" alt=""
推荐把registrykey绑定到sa,这样yaml文件中就可以不用指定,更加安全。
kubectl patch serviceaccount default -p '{"imagePullSecrets": [{"name": "myregistrykey"}]}'
kubectl describe sa default
data:image/s3,"s3://crabby-images/50116/50116f5ca16c19c2a41143a0615e693b3ffedcec" alt=""