往期精彩文章 :
- 提升CKA考试胜算:一文带你全面了解RBAC权限控制!
- 揭秘高效运维:如何用kubectl top命令实时监控K8s资源使用情况?
- CKA认证必备:掌握k8s网络策略的关键要点
- 提高CKA认证成功率,CKA真题中的节点维护全攻略!
- 数据无忧,一学就会:掌握CKA认证必备的etcd备份与还原秘籍!
- 提升你的云技能:深入了解CKA认证之k8s升级秘籍!
- 揭秘CKA认证:Service四层代理的神秘面纱
- 提升CKA认证成功率:Kubernetes Ingress七层代理全攻略!
- CKA考生注意:这些Deployment要点能助你一臂之力!
- 从NodeSelector到NodeAffinity:探索Kubernetes节点亲和性的进化之路
- 提升CKA考试效率:精准统计Ready状态Node节点的实用攻略
在Kubernetes的世界里,Pod是最小的可部署单元,而有时候我们需要在同一个Pod中运行多个容器,以便它们可以紧密协作。本文将深入讲解如何封装多个容器在一个Pod中,释放Kubernetes的强大潜能。
Pod是kubernetes中最小的资源管理组件,Pod也是最小化运行容器化应用的资源对象。一个Pod代表着集群中运行的一个进程。kubernetes中其他大多数组件都是围绕着Pod来进行支撑和扩展Pod功能的。
Pod在Kubrenetes集群中Pod有如下两种使用方式:
每个pod中一个容器的模式是最常见的用法,在这种使用方式中,你可以把pod想象成是单个容器的封装,kuberentes管理的是Pod而不是直接管理容器。
一个Pod中也可以同时封装几个需要紧密耦合互相协作的容器,它们之间共享资源。这些在同一个Pod中的容器可以互相协作成为一个service单位,比如一个容器共享文件,另一个"sidecar"容器来更新这些文件。Pod将这些容器的存储资源作为一个实体来管理。
例如,你可能有一个容器,为共享卷中的文件提供 Web 服务器支持,以及一个单独的 Sidercar 容器负责从远端更新这些文件,如下图所示:
有些 Pod 具有 Init 容器[1]和 应用容器[2]。 Init 容器默认会在启动应用容器之前运行并完成。
下面是一个 Pod 示例,它由一个运行镜像 nginx:1.14.2 的容器组成。这种就是一个Pod中运行一个容器。
apiVersion: v1
kind: Pod
metadata:
name: simple-pod
spec:
containers:
- name: nginx
image: nginx:1.14.2
ports:
- containerPort: 80
要创建上面显示的 Pod,请运行以下命令:
kubectl apply -f simple-pod.yaml
Pod 通常不是直接创建的,而是使用工作负载资源创建的。
下面是一个Pod封装多个容器的示例,它由一个运行镜像 nginx:1.14.2和MYSQL的容器组成。
apiVersion: v1
kind: Pod
metadata:
name: complex-pod
spec:
containers:
- name: nginx
image: nginx:1.14.2
ports:
- containerPort: 80
- name: mysql
image: mysql
env:
- name: MYSQL_ROOT_PASSWORD
value: "@123456@"
ports:
- containerPort: 3306
由于最新版的MySQL容器必须要配置一个环境变量,不然就会启动失败
创建上面显示的 Pod,请运行以下命令:
kubectl apply -f complex-pod.yaml
一个Pod封装多个容器,采用kubectl操作pod里面的容器时,跟一个Pod中运行一个容器不同。例如,要进入nginx容器内。在Pod封装多个容器应该执行如下命令:
kubectl exec -it complex-pod -c nginx /bin/sh
complex-pod
: 是pod的名称-c
指定是pod中容器的名称,例如:nginx
切换 k8s 集群环境:
kubectl config use-context k8s
Task: 创建一个 Pod,名字为kucc1
,这个 Pod 包含 4 个容器,为nginx
、redis
、memcached
、consul
。
Pod封装多个容器[3]
kubectl config use-context k8s
apiVersion: v1
kind: Pod
metadata:
name: kucc1
spec:
containers:
- name: nginx
image: nginx
- name: redis
image: redis
- name: memcached
image: memcached
- name: consul
image: consul
kubectl apply -f kucc1.yaml
kubect get pod
Init 容器: https://kubernetes.io/zh-cn/docs/reference/glossary/?all=true#term-init-container
[2]应用容器: https://kubernetes.io/zh-cn/docs/reference/glossary/?all=true#term-app-container
[3]Pod封装多个容器: https://kubernetes.io/zh-cn/docs/tasks/inject-data-application/define-environment-variable-container/