YAML格式:
"---"
表示YAML格式,一个文件的开始,用于分割文件#
表示注释apiVersion
如果是业务场景,一般首选使用apps/v1
带有beta字样的代表的是测试版本,不用于生产环境
[root@k8s-1 test]# kubectl api-versions
admissionregistration.k8s.io/v1
admissionregistration.k8s.io/v1beta1
apiextensions.k8s.io/v1
apiextensions.k8s.io/v1beta1
apiregistration.k8s.io/v1
apiregistration.k8s.io/v1beta1
apps/v1
authentication.k8s.io/v1
authentication.k8s.io/v1beta1
authorization.k8s.io/v1
authorization.k8s.io/v1beta1
autoscaling/v1
autoscaling/v2beta1
autoscaling/v2beta2
batch/v1
batch/v1beta1
certificates.k8s.io/v1beta1
coordination.k8s.io/v1
coordination.k8s.io/v1beta1
discovery.k8s.io/v1beta1
events.k8s.io/v1beta1
extensions/v1beta1
networking.k8s.io/v1
networking.k8s.io/v1beta1
node.k8s.io/v1beta1
policy/v1beta1
rbac.authorization.k8s.io/v1
rbac.authorization.k8s.io/v1beta1
scheduling.k8s.io/v1
scheduling.k8s.io/v1beta1
storage.k8s.io/v1
storage.k8s.io/v1beta1
v1
可以直接通过 -o yaml
命令导出一个模板,
kubectl get deployments nginx-test1 -0 yaml > /opt/demo/nginx-demo1.yaml
# 部署应用
kubectl create -f app.yaml
kubectl apply -f app.yaml
# 查看deployment
kubectl get deployment -nasp -owide
# 查看pod
kubectl get pod -n asp -owide
# 查看pod详情
kubectl describe pod pod-name
# 查看log
kubectl logs pod-name
# 进入容器终端,-c container-name 可以指定进入哪个容器
kubectl exec -it webguard-app-deployment-994fcf6c5-2gdjn -ngalaxy-asp -- /bin/bash
docker exec -it container_name /bin/bash
# 伸缩扩展副本
kubectl scale deployment test-k8s --replicas=5
# 把集群内部的端口映射到节点,直接将pod的节点映射出来
kubectl port-forward test-k8s-xxxx 8080:8080
# 查看历史版本
kubectl rollout history deployment test-k8s -nasp
# 回退上一个版本
kubectl rollout undo deployment test-k8s
# 回到指定版本
kubectl rollout undo deployment test-k8s --to-revision=2
# 删除部署
kubectl delete -f deployment test-k8s
或者
进入deployment文件目录
kubectl delete -f test-k8s-deployment.yaml
# 查看部署的名字
kubectl get deployment
# 查看全部
kubectl get all
# 重新部署
kubectl rollout restart deployment test-k8s
# 暂停运行,暂停后,对deployment的修改不会立即生效,而是等到恢复后才应用
kubectl rollout pause deployment test-k8s
# 恢复
kubectl rollout resume deployment test-k8s
# 输出到yaml文件
kubectl get deployment test-k8s -o yaml >> app2.yaml
# 删除所有资源
kubectl delete all --all
statefulset 是用来管理有状态的应用,如数据库
前面我们部署的应用,都是不需要存储数据,不需要记住状态的,可以随意扩充副本,每个副本都是一样的,可替代的。
而像数据库、Redis 这类有状态的,则不能随意扩充副本。
StatefulSet 会固定每个 Pod 的名字
使用服务只能通过service名称进行调用
配置有状态的MongoDB
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: mongodb
spec:
serviceName: mongodb
replicas: 3
selector:
matchLabels:
app: mongodb
template:
metadata:
labels:
app: mongodb
spec:
containers:
- name: mongo
image: mongo:4.4
# IfNotPresent 仅本地没有镜像时才远程拉,Always 永远都是从远程拉,Never 永远只用本地镜像,本地没有则报错
imagePullPolicy: IfNotPresent
---
apiVersion: v1
kind: Service
metadata:
name: mongodb
spec:
selector:
app: mongodb
type: ClusterIP
# HeadLess
clusterIP: None
ports:
- port: 27017
targetPort: 27017
kubectl get pod
[root@k8s-1 statefulset]# kubectl get pod
NAME READY STATUS RESTARTS AGE
mongodb-0 1/1 Running 0 5m41s
mongodb-1 1/1 Running 0 5m7s
mongodb-2 1/1 Running 0 4m23s
kubectl get svc
[root@k8s-1 statefulset]# kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.96.0.1 443/TCP 64m
mongodb ClusterIP None 27017/TCP 5m47s
kubernetes 集群不会为你处理数据的存储,我们可以为数据库挂载一个磁盘来确保数据的安全。
你可以选择云存储、本地磁盘、NFS。
hostpath挂载示例
把节点上的一个目录挂载到pod,不推荐使用
配置方式简单,需要手动指定pod跑在某个固定的节点仅供单节点测试,不适用于多节点集群
apiVersion: apps/v1
kind: StatefulSet
metadata:
name: mongodb
spec:
replicas: 1
selector:
matchLabels:
app: mongodb
template:
metadata:
labels:
app: mongodb
spec:
containers:
- name: mongo
image: mongo:4.4
# IfNotPresent 仅本地没有镜像时才远程拉,Always 永远都是从远程拉,Never 永远只用本地镜像,本地没有则报错
imagePullPolicy: IfNotPresent
volumeMounts:
- mountPath: /data/db # 容器里面的挂载路径
name: mongo-data # 卷名字,必须跟下面定义的名字一致
volumes:
- name: mongo-data # 卷名字
hostPath:
path: /data/mongo-data # 节点上的路径
type: DirectoryOrCreate # 指向一个目录,不存在时自动创建
endpoint是k8s集群中的一个资源对象,存储在etcd里面,用来记录一个service对应的所有pod的访问地址
同时,也可以引入外部服务,使得 k8s能够访问外部有状态的服务,比如db等
example:
1、创建一个endpoint,引入外部服务
http-endpoint.yaml
apiVersion: v1
kind: Endpoints
metadata:
name: http
namespace: asp
subsets:
- addresses:
- ip: 101.34.182.36 # 外部服务的ip
ports:
- name: http
port: 5001 # 外部服务的port
protocol: TCP # 网络协议类型
# 多个ip,多个addresses
#- addresses:
# - ip: 101.34.182.36 # 外部服务的ip
# ports:
# - name: http
# port: 5001 # 外部服务的port
# protocol: TCP # 网络协议类型
http-service.yaml
apiVersion: v1
kind: Service
metadata:
name: http
namespace: asp
spec:
ports:
- port: 5000 # 集群内暴露的端口
name: http
protocol: TCP # 网络协议
targetPort: 5000 # pod端口
创建完成后,通过service生成的ip+port就可以访问到外部的服务
k8s 部署项目时,有一个敏感词或者动态变更的参数,不能写死在docker镜像中,
k8s提供了 configmap,用来配置参数
example
test-xj-config.yaml
apiVersion: v1
kind: ConfigMap
metadata:
name: test-xj-config
namespace: asp
data:
NAME: "config-xiaoming"
AGE: "23" # 在configmap中不支持数值,所以所有参数必须是字符串
SEX: "female"
test-xj-deployment.yaml
apiVerson: apps/v1
kind: Deployment
metadata:
name: test-xj-deployment
namespace: asp
spec:
selector:
matchLabels:
app: test-xj-app
replicas: 1
template:
metadata:
labels:
app: test-xj-app
spec:
containers:
- name: test-xj-app
image: 101.34.182.36:10080/test:xj
imagePullPolicy: IfNotPresent
envFrom:
- configMapRef: # configmap 应用
name: test-xj-config # 应用的config的名字
commad: [ "python" ]
args: [ "/opt/asp/api/test.py" ]