Kubernetes----ConfigMap配置存储

简介: Kubernetes----ConfigMap配置存储

【原文链接】

一、ConfigMap实例演示

ConfigMap是一种比较特殊的存储卷,它的主要作用是用来存储配置信息的

1.1 创建configmap

编写configmap.yaml文件,内容如下:

apiVersion: v1
kind: Namespace
metadata:
  name: dev

---

apiVersion: v1
kind: ConfigMap
metadata:
  name: configmap
  namespace: dev
data:
  info: |
    username: admin
    password: admin123

然后使用如下命令创建configmap

[root@master volume]# kubectl apply -f configmap.yaml
namespace/dev created
configmap/configmap created
[root@master volume]#

查看创建的configmap

[root@master volume]# kubectl get configmap -n dev
NAME               DATA   AGE
configmap          1      43s
[root@master volume]# 

通过如下命令查看configmap的详细信息

[root@master volume]# kubectl describe configmap configmap -n dev
Name:         configmap
Namespace:    dev
Labels:       <none>
Annotations:  <none>

Data
====
info:
----
username: admin
password: admin123

Events:  <none>
[root@master volume]#

1.2 configmap挂载到pod上

编辑pod_configmap.yaml文件,内容如下:

apiVersion: v1
kind: Pod
metadata:
  name: pod-configmap
  namespace: dev
spec:
  containers:
  - name: nginx
    image: nginx:1.17.1
    volumeMounts:
    - name: config
      mountPath: /configmap/config
  volumes:
  - name: config
    configMap:
      name: configmap

使用如下命令创建pod

[root@master volume]# kubectl apply -f pod_configmap.yaml
pod/pod-configmap created
[root@master volume]#

查看创建pod资源

[root@master volume]# kubectl get pod -n dev
NAME            READY   STATUS    RESTARTS   AGE
pod-configmap   1/1     Running   0          4m29s
[root@master volume]#

如下进入pod中,查看挂载到的配置文件

[root@master volume]# kubectl exec -it pod-configmap -n dev /bin/sh
kubectl exec [POD] [COMMAND] is DEPRECATED and will be removed in a future version. Use kubectl exec [POD] -- [COMMAND] instead.
# cd /configmap/config
# ls
info
# cat info
username: admin
password: admin123
#

1.3 configmap实现动态更新

编辑configmap.yaml文件,如下,将密码修改为123456

apiVersion: v1
kind: Namespace
metadata:
  name: dev

---

apiVersion: v1
kind: ConfigMap
metadata:
  name: configmap
  namespace: dev
data:
  info: |
    username: admin
    password: 123456

然后使用如下命令更新configmap

[root@master volume]# kubectl apply -f configmap.yaml
namespace/dev unchanged
configmap/configmap configured
[root@master volume]#

稍微等一会,然后继续查看pod中的info文件中的内容,发现此时已经更新了

# cat info
username: admin
password: 123456
#

至此,configmap即完成了配置文件的动态更新

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务&nbsp;ACK 容器服务&nbsp;Kubernetes&nbsp;版(简称&nbsp;ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情:&nbsp;https://www.aliyun.com/product/kubernetes
目录
相关文章
|
25天前
|
缓存 Kubernetes Docker
容器服务ACK常见问题之容器服务ACK ingress websocket配置失败如何解决
容器服务ACK(阿里云容器服务 Kubernetes 版)是阿里云提供的一种托管式Kubernetes服务,帮助用户轻松使用Kubernetes进行应用部署、管理和扩展。本汇总收集了容器服务ACK使用中的常见问题及答案,包括集群管理、应用部署、服务访问、网络配置、存储使用、安全保障等方面,旨在帮助用户快速解决使用过程中遇到的难题,提升容器管理和运维效率。
|
2月前
|
存储 运维 Kubernetes
批处理及有状态等应用类型在 K8S 上应该如何配置?
批处理及有状态等应用类型在 K8S 上应该如何配置?
|
4月前
|
Kubernetes 安全 Cloud Native
云原生|kubernetes|pod或容器的安全上下文配置解析
云原生|kubernetes|pod或容器的安全上下文配置解析
109 0
|
2月前
|
Kubernetes 监控 物联网
IoT 边缘集群基于 Kubernetes Events 的告警通知实现(二):进一步配置
IoT 边缘集群基于 Kubernetes Events 的告警通知实现(二):进一步配置
|
2月前
|
Kubernetes 容器 Perl
K8S 性能优化 - 大型集群 CIDR 配置
K8S 性能优化 - 大型集群 CIDR 配置
|
3月前
|
存储 Kubernetes 安全
Kubernetes Pod配置:从基础到高级实战技巧
Kubernetes Pod配置:从基础到高级实战技巧
129 0
|
4月前
|
存储 Kubernetes 关系型数据库
kubernetes学习之持久化存储StorageClass(4---nfs存储服务)
kubernetes学习之持久化存储StorageClass(4---nfs存储服务)
46 0
|
4月前
|
Kubernetes Cloud Native Linux
云原生|kubernetes|apparmor的配置和使用
云原生|kubernetes|apparmor的配置和使用
253 0
|
4月前
|
JSON Kubernetes Cloud Native
云原生|kubernetes|多集群管理之kubeconfig文件配置和使用(定义,使用方法,合并管理多集群)
云原生|kubernetes|多集群管理之kubeconfig文件配置和使用(定义,使用方法,合并管理多集群)
106 0
|
4月前
|
Kubernetes 容器
按照容器服务ACK向导 配置了 一个应用接入 eBPF,但是没有生效成功,该怎样去排查异常?
按照容器服务ACK向导 配置了 一个应用接入 eBPF,但是没有生效成功,该怎样去排查异常?
35 0

推荐镜像

更多