当前位置:网站首页>kubernetes资源对象介绍及常用命令(五)-(ConfigMap&Secret)
kubernetes资源对象介绍及常用命令(五)-(ConfigMap&Secret)
2022-07-05 20:06:00 【傻啦猫@[email protected]】
一、ConfitMap
配置集,抽取应用配置。
ConfigMap保存在kubernetes的etcd中。
ConfigMap可以将文件直接挂载到Pod内,区别于上篇文章中的PV&PVC挂载目录。
创建ConfigMap
命令行方式
[[email protected] ~]# vi redis.conf
[[email protected] ~]# cat redis.conf
appendonly yes
[[email protected] ~]# kubectl create cm redis-conf --from-file=redis.conf
configmap/redis.conf created
[[email protected] ~]#
首先有redis.conf文件,然后将文件做成ConfigMap。
yaml方式,redis-conf.yml
apiVersion: v1
data:
redis.conf: |
appendonly yes
kind: ConfigMap
metadata:
name: redis-conf
namespace: default
data是所有真正的数据,key:默认是文件名,value:配置文件的内容
[[email protected] ~]# kubectl apply -f redis-conf.yml
configmap/redis-conf created
[[email protected] ~]#
查看ConfigMap
[[email protected] ~]# kubectl get cm
NAME DATA AGE
kube-root-ca.crt 1 2d1h
redis-conf 1 53s
[[email protected] ~]#
扩展: 查看redis-conf的yaml文件
kubectl get cm redis-conf -oyaml
创建pod
redis.yml
apiVersion: v1
kind: Pod
metadata:
name: redis
spec:
containers:
- name: redis
image: redis
command:
- redis-server
- "/redis-master/redis.conf" #指的是redis容器内部的位置
ports:
- containerPort: 6379
volumeMounts:
- mountPath: /data
name: data
- mountPath: /redis-master
name: config
volumes:
- name: data
emptyDir: {}
- name: config
configMap:
name: redis-conf
items:
- key: redis.conf
path: redis.conf
说明:一个ConfigMap文件可能有多个配置,items会遍历每个配置,key中定义这里要取哪个配置,path表示将取出来的配置文件内容放到容器内的哪个文件中。
关系图参考如下:

[[email protected] ~]# kubectl apply -f redis.yml
pod/redis created
[[email protected] ~]#
# 进入到容器内部验证
[[email protected] ~]# kubectl exec -it redis -c redis -- /bin/bash
[email protected]:/data# cd /redis-master/
[email protected]:/redis-master# ls
redis.conf
[email protected]:/redis-master# cat redis.conf
appendonly yes
[email protected]:/redis-master#
修改ConfigMap
[[email protected] ~]# kubectl edit cm redis-conf
configmap/redis-conf edited
[[email protected] ~]#
添加了一行配置requirepass 123456。
[[email protected] ~]# kubectl exec -it redis -c redis -- /bin/bash
[email protected]:/data# cd /redis-master/
[email protected]:/redis-master# ls
redis.conf
[email protected]:/redis-master# cat redis.conf
appendonly yes
requirepass 123456
[email protected]:/redis-master#
ConfigMap被自动更新了。
重点说明:这里的自动更新只是容器内部的文件跟随ConfigMap的改变而改变,但是并不一定真正生效,主要看应用有没有热部署能力,没有热部署能力的应用需要重启才能生效。
删除ConfigMap
kubectl delete cm redis-conf
二、Secret
Secret保存在kubernetes的etcd中。
Secret对象类型用来保存敏感信息,例如密码、OAuth令牌和SSH密钥。将这些信息放在secret中比放在Pod的定义或者容器镜像中来说更加安全和灵活。
创建Secret
# 命令格式
kubectl create secret docker-registry jiangnan \
--docker-server=<你的镜像仓库服务器> \
--docker-username=<你的用户名> \
--docker-password=<你的密码> \
--docker-email=<你的邮箱地址>
查看Secret
[[email protected] ~]# kubectl get secret
NAME TYPE DATA AGE
default-token-ssmvn kubernetes.io/service-account-token 3 2d2h
jiangnan kubernetes.io/dockerconfigjson 1 2m6s
[[email protected] ~]#
删除Secret
[[email protected] ~]# kubectl delete secret jiangnan
secret "jiangnan" deleted
[[email protected] ~]#
本文由 mdnice 多平台发布
版权声明
本文为[傻啦猫@[email protected]]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_45842494/article/details/125610143
边栏推荐
- 解决php无法将string转换为json的办法
- [untitled]
- Leetcode: binary tree 15 (find the value in the lower left corner of the tree)
- Bzoj 3747 poi2015 kinoman segment tree
- Analysis of openh264 decoded data flow
- Four methods of random number generation | random | math | threadlocalrandom | securityrandom
- Tasks in GStreamer
- - Oui. Net Distributed Transaction and Landing Solution
- S7-200smart uses V90 Modbus communication control library to control the specific methods and steps of V90 servo
- Based on vs2017 and cmake GUI configuration, zxing and opencv are used in win10 x64 environment, and simple detection of data matrix code is realized
猜你喜欢

third-party dynamic library (libcudnn.so) that Paddle depends on is not configured correctl

Leetcode skimming: binary tree 16 (path sum)

建立自己的网站(16)

95后阿里P7晒出工资单:狠补了这个,真香...

Go language | 02 for loop and the use of common functions
Android interview classic, 2022 Android interview written examination summary

Hong Kong stocks will welcome the "best ten yuan store". Can famous creative products break through through the IPO?

走入并行的世界

深度学习 卷积神经网络(CNN)基础

Force buckle 1200 Minimum absolute difference
随机推荐
Leetcode skimming: binary tree 16 (path sum)
Autumn byte interviewer asked you any questions? In fact, you have stepped on thunder
线程池参数及合理设置
解决Thinkphp框架应用目录下数据库配置信息修改后依然按默认方式连接
深度学习 卷积神经网络(CNN)基础
Leetcode skimming: binary tree 10 (number of nodes of a complete binary tree)
Leetcode: binary tree 15 (find the value in the lower left corner of the tree)
实操演示:产研团队如何高效构建需求工作流?
. Net distributed transaction and landing solution
sun.misc.BASE64Encoder报错解决方法[通俗易懂]
《乔布斯传》英文原著重点词汇笔记(十二)【 chapter ten & eleven】
Four methods of random number generation | random | math | threadlocalrandom | securityrandom
Leetcode brush questions: binary tree 11 (balanced binary tree)
Debezium series: idea integrates lexical and grammatical analysis ANTLR, and check the DDL, DML and other statements supported by debezium
再忙不能忘安全
How to retrieve the root password of MySQL if you forget it
Analysis of openh264 decoded data flow
C langue OJ obtenir PE, ACM démarrer OJ
ByteDance dev better technology salon was successfully held, and we joined hands with Huatai to share our experience in improving the efficiency of web research and development
计算lnx的一种方式