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即完成了配置文件的动态更新

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
4月前
|
JSON Kubernetes API
深入理解Kubernetes配置:编写高效的YAML文件
深入理解Kubernetes配置:编写高效的YAML文件
|
5月前
|
存储 Kubernetes 容器
Kubernetes 存储选项:持久化卷与存储类
【8月更文第29天】随着容器化的普及,越来越多的应用程序需要持久化数据以保持状态信息。Kubernetes 提供了一套完整的解决方案来管理和配置持久化存储,包括持久卷 (Persistent Volume, PV)、持久卷声明 (Persistent Volume Claim, PVC) 和存储类 (StorageClass)。本文将详细介绍这些概念,并通过实际示例来演示如何在 Kubernetes 中配置存储。
412 1
|
2月前
|
Kubernetes 监控 Java
如何在Kubernetes中配置镜像和容器的定期垃圾回收
如何在Kubernetes中配置镜像和容器的定期垃圾回收
|
5月前
|
存储 Kubernetes 容器
k8s创建NFS动态存储
k8s创建NFS动态存储
|
5月前
|
Kubernetes 网络性能优化 调度
在K8S中,Kubernets资源限制是如何配置的,是否根据Qos?
在K8S中,Kubernets资源限制是如何配置的,是否根据Qos?
|
5月前
|
Kubernetes 调度 Perl
在K8S中,Pod多副本配置了硬亲和性,会调度到同⼀个节点上吗?
在K8S中,Pod多副本配置了硬亲和性,会调度到同⼀个节点上吗?
|
5月前
|
存储 Kubernetes Linux
Kubernetes 的配置资源 ConfigMap(01部分)
Kubernetes 的配置资源 ConfigMap(01部分)
|
5月前
|
存储 Kubernetes 数据安全/隐私保护
在K8S中,如果后端nfs存储的ip发生变化如何解决?
在K8S中,如果后端nfs存储的ip发生变化如何解决?
|
5月前
|
存储 缓存 Kubernetes
在K8S中,业务Pod数据如何存储?
在K8S中,业务Pod数据如何存储?
|
5月前
|
存储 JSON Kubernetes
在K8S中,存储敏感信息方式有哪些?
在K8S中,存储敏感信息方式有哪些?

热门文章

最新文章