一、Pod
Pod是Kubernetes资源类型中最小的单位。它是由一个或多个容器组成的,是云原生应用的基础单元。
Pod中的容器共享相同的网络命名空间和存储卷。在同一个Pod中,这些容器可以相互通信和访问同一个存储卷。Kubernetes中的Pod可以扩展到多个节点上,它包含一个或多个紧密耦合的容器。集合在同一Pod中的这些容器共享相同的计算资源和网络配置。
创建Pod时,需要在容器级别指定容器的运行镜像以及如何运行容器。可以指定Pod需要的资源限制和请求、存储卷、环境变量、指定如何启动容器的命令或参数等详细信息。
apiVersion: v1
kind: Pod
metadata:
name: my-pod
spec:
containers:
- name: nginx
image: nginx
ports:
- containerPort: 80
二、Deployment
Deployment用于管理Pod的创建、更新和删除。通过Deployment配置,客户端将不会看到Pod出现的时间或Pod的删除,而Deployment会使Pod容器的重新部署业务透明。Deployment控制器可以按照用户的要求对正在运行的Pod执行滚动更新或回滚操作,以及按照要求扩展或收缩Pod数量。
Deployment使用自己的控制器来保证Pod数量的准确性,因此Deployment是重新部署的基本单位。
apiVersion: apps/v1
kind: Deployment
metadata:
name: my-deployment
spec:
replicas: 3
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx
ports:
- containerPort: 80
三、Service
Service是面向网络的抽象层,通过label selector和Pod中的容器来提供网络服务。
在Kubernetes中,Pod的IP地址是动态分配的,可以通过Service稳定访问Pod。通过添加一个Service,用户可以对后端Pod提供一个唯一的DNS名称和一个固定的IP地址。
Service控制器可以确保Service对象的访问点随着后端Pod的标签变化而更新。用户定义一个Service时必须指定选择器匹配需要暴露的Pod。Service可以是ClusterIP、NodePort或LoadBalancer类型。
apiVersion: v1
kind: Service
metadata:
name: nginx
labels:
app: nginx
spec:
selector:
app: nginx
ports:
- name: http
port: 80
targetPort: 80
type: ClusterIP
四、ConfigMap
ConfigMap用于将配置数据从容器镜像中分离出来并动态传递给Pod。可以将ConfigMap中的数据插入容器中的文件、环境变量或命令行参数。
ConfigMap提供了一种将配置数据从镜像中分离的方式,这就允许镜像可以更好的重用。Kubernetes可以像管理其他资源一样管理ConfigMap,它支持在配置发生更改时自动重新加载Pod。
apiVersion: v1
kind: ConfigMap
metadata:
name: nginx-config
data:
NGINX_HI: Hello
NGINX_THERE: World
五、Secret
Secret用于存储私密数据,如API密钥和证书等。与ConfigMaps一样,Secrets也可以在多个Pod之间共享和重用。
Secrets可以存储任何类型的信息,如base64编码的字符串、用户名/密码、SSH密钥等。在创建Secret时,需要定义Secret下的数据并提供一个密钥。
apiVersion: v1
kind: Secret
metadata:
name: my-secret
type: Opaque
data:
username: YWRtaW4=
password: MWYyZDFlMmU2N2Rm
六、Volume
Volume是Pod与生俱来的一项功能,用于容器和宿主机之间的数据传输。Volume也可以用于多个Pod之间的数据共享、持久化存储和数据备份等操作。
Kubernetes支持多种Volume类型,包括EmptyDir、HostPath、NFS、GlusterFS、iSCSI等。
apiVersion: v1
kind: Pod
metadata:
name: my-pod
spec:
containers:
- name: nginx
image: nginx
volumeMounts:
- name: my-vol
mountPath: /usr/share/nginx/html
volumes:
- name: my-vol
configMap:
name: nginx-config