十二、kubernetes 核心技术configMap

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: kubernetes 核心技术configMap
  1. ConfigMap 介绍

在Kubernetes 1.2中新添加了功能​​ConfigMap​​,主要功能是为了解决应用程序会从配置文件、环境变量中获取配置信息。

​注意:​ ConfigMap不是属性配置文件的代替品,ConfigMap只是作为多个properties文件的引用。

场景: 配置文件

  1. ConfigMap 项目演示(配置文件)

configmap主要还是方便处理非敏感的数据,比如注册中心地址、数据库地址、nginx地址等。像密码之类需要加密的还是需要使用secrets来进行管理

下方yaml文件中​​data​​一栏包括了配置数据,ConfigMap可以保存单个属性,也可以用来保存一个配置文件。配置数据可以通过很多种方式在Pods里被引用,ConfigMap可以用来:

设置环境变量的值
在容器里设置命令行参数
在数据卷里面创建config文件
用户和系统两者都可以在ConfigMap里存储

2.1 创建配置文件

cat > redis.properties <<-EOF
redis.host=127.0.0.1
redis.port=6379
redis.password=123456
EOF

2.2 创建configmap

$ kubectl create configmap redis-config --from-file=redis.properties 

#查看
[root@k8s-master01 k8s]# kubectl get cm
NAME           DATA   AGE
redis-config   1      30s
[root@k8s-master01 k8s]# kubectl describe cm redis-config 
Name:         redis-config
Namespace:    default
Labels:       <none>
Annotations:  <none>

Data
====
redis.properties:
----
redis.host=127.0.0.1
redis.port=6379
redis.password=123456

Events:  <none>

2.3 以Volume挂载到Pod容器中

apiVersoin: v1
kind: Pod
metadata:
  name: configmap-test
spec:
  containers:
  - name: busybox
    image: busbox
    command: [ "/bin/sh","-c","cat /etc/config/redis.properties" ]
    volumeMounts:
    - name: config-volume
      mountPath: /etc/config
  volumes:
  - name: config-volume
    configMap:       ##
      name: redis-config
  restartPolicy: Never

​创建并验证

[root@k8s-master01 k8s]# kubectl get all 
NAME                                READY   STATUS      RESTARTS   AGE
pod/configmap-test                  0/1     Completed   0          4m36s

[root@k8s-master01 k8s]# kubectl logs configmap-test 
redis.host=127.0.0.1
redis.port=6379
redis.password=123456
  1. ConfigMap 项目演示(变量)

3.1 创建configmap

apiVersion: v1
kind: ConfigMap
metadata:
  name: myconfig
data:
  db.host: localhost
  db.port: "3306"

创建并查看

kubectl apply -f **.yaml
[root@k8s-master01 k8s]# kubectl get configmaps 
NAME           DATA   AGE
myconfig       2      39s

3.2 创建Pod进行引用

apiVersion: v1
kind: Pod
metadata:
  name: configmap-env
spec:
  containers:
    - name: busybox-configmap-env
      image: busybox
      command: [ "/bin/sh","-c","echo $(db.host) $(db.port)" ] 
      env:
        - name: db.host
          valueFrom:
            configMapKeyRef:
              name: myconfig
              key: db.host
        - name: db.port
          valueFrom:
            configMapKeyRef:
              name: myconfig
              key: db.port
  restartPolicy: Never

创建并验证

$ kubectl apply -f **.yaml
[root@k8s-master01 k8s]# kubectl logs configmap-env 
localhost 3306
相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
3月前
|
运维 Kubernetes Docker
深入理解容器化技术:Docker与Kubernetes的协同工作
深入理解容器化技术:Docker与Kubernetes的协同工作
103 14
|
3月前
|
运维 Kubernetes Cloud Native
云原生技术入门:Kubernetes和Docker的协同工作
【10月更文挑战第43天】在云计算时代,云原生技术成为推动现代软件部署和运行的关键力量。本篇文章将带你了解云原生的基本概念,重点探讨Kubernetes和Docker如何协同工作以支持容器化应用的生命周期管理。通过实际代码示例,我们将展示如何在Kubernetes集群中部署和管理Docker容器,从而为初学者提供一条清晰的学习路径。
|
3月前
|
Kubernetes Cloud Native 开发者
云原生技术入门:Kubernetes和Docker的协作之旅
【10月更文挑战第22天】在数字化转型的浪潮中,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,引领读者步入云原生的世界,着重介绍Kubernetes和Docker如何携手打造弹性、可扩展的云环境。我们将从基础概念入手,逐步深入到它们在实际场景中的应用,以及如何简化部署和管理过程。文章不仅为初学者提供入门指南,还为有一定基础的开发者提供实践参考,共同探索云原生技术的无限可能。
77 3
|
3月前
|
Kubernetes 监控 安全
容器化技术:Docker与Kubernetes的实战应用
容器化技术:Docker与Kubernetes的实战应用
|
4月前
|
Kubernetes Cloud Native 云计算
云原生时代的技术演进:Kubernetes与微服务架构的完美融合
随着云计算技术的飞速发展,云原生概念逐渐深入人心。本文将深入探讨云原生技术的核心——Kubernetes,以及它如何与微服务架构相结合,共同推动现代软件架构的创新与发展。文章不仅剖析了Kubernetes的基本工作原理,还通过实际案例展示了其在微服务部署和管理中的应用,为读者提供了一条清晰的云原生技术应用路径。
128 2
|
4月前
|
存储 Kubernetes 开发工具
k8s学习--ConfigMap详细解释与应用
ConfigMap 是 Kubernetes 中用于管理非机密配置数据的 API 对象,可将应用配置与容器分离,便于动态管理和更新。它支持四种创建方式:命令行参数、多个文件、文件内的键值对以及 YAML 资源清单文件。ConfigMap 可通过环境变量或挂载为卷的方式传递给 Pod,并且当通过卷挂载时支持热更新。这使得配置管理更加灵活和安全,无需重新部署应用即可更新配置。
144 0
|
4月前
|
运维 Kubernetes Cloud Native
云原生技术入门:Kubernetes的奇妙之旅
【9月更文挑战第34天】在数字化浪潮中,云原生技术如Kubernetes已经成为IT行业的重要力量。本文旨在通过浅显易懂的方式,向初学者揭示Kubernetes的核心概念、架构设计及其在实际业务中的应用价值,帮助读者快速理解并掌握这一技术,为进一步深入学习和实践打下坚实基础。
98 1
|
5月前
|
Cloud Native 持续交付 Docker
云原生技术入门与实践:Docker容器化部署示例
【9月更文挑战第25天】在数字化转型的浪潮下,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,为初学者揭示云原生技术的核心概念及其应用价值。我们将以Docker容器为例,逐步引导读者了解如何将应用程序容器化,并在云端高效运行。这不仅是对技术趋势的跟随,更是对资源利用和开发效率提升的探索。
87 4
|
4月前
|
Kubernetes Cloud Native 调度
深入探讨容器化技术:Kubernetes 的魅力
【10月更文挑战第6天】深入探讨容器化技术:Kubernetes 的魅力
112 0
|
5月前
|
存储 Kubernetes Docker
深入探索容器化技术:Docker 实战与 Kubernetes 管理
深入探索容器化技术:Docker 实战与 Kubernetes 管理
119 0

热门文章

最新文章