赞
踩
目录
kubectl create -f xxx.yaml
kubectl apply -f xxx.yaml
#区别:使用create创建资源是一次性的,如果使用apply创建,后期修改yaml文件再次执行apply可以实现更新资源
kubectl delete -f xxx.yaml
kubectl get 资源名称 -o yaml
kubectl explain yaml文件中的字段(多级字段用 . 隔开)
直接修改资源对应的yaml文件,并用 kubectl apply -f xxx.yaml 文件使之生效
注意:当apply不生效时,先使用delete清除资源,再使用apply创建资源
kubectl edit 资源名称 #在线编辑资源配置清单并保存退出即时生效
注意:此修改方式不会对yaml文件内容修改
编写yaml文件有三种方式:
- 直接编写:即从零开始写一个yaml文件,可以借用kubectl explain 字段名查看。
- 生成模板:使用kubectl run 资源 --dry-run=client > xxx.yaml 生成yaml模板文件,然后进行编辑。
- 导出模板:将现有资源使用 yaml 格式输出并导入 xxx.yaml 文件,然后进行编辑。
- vim demo1.yaml
- ---
- apiVersion: apps/v1 //指定api版本标签
- kind: Deployment //定义资源的类型/角色,deployment为副本控制器,此处资源类型可以是Deployment、Job、Ingress、Service等
- metadata: //定义资源的元数据信息,比如资源的名称、namespace、标签等信息
- name: nginx-deployment //定义资源的名称,在同一个namespace空间中必须是唯一的
- namespace: kube-public //定义资源所在命名空间
- labels: //定义资源标签
- app: nginx
- name: test01
- spec: //定义资源需要的参数属性,诸如是否在容器失败时重新启动容器的属性
- replicas: 3 //副本数
- selector: //定义标签选择器
- matchLabels: //定义匹配标签
- app: nginx //需与.spec.template.metadata.labels 定义的标签保持一致
- template: //定义业务模板,如果有多个副本,所有副本的属性会按照模板的相关配置进行匹配
- metadata:
- labels: //定义Pod副本将使用的标签,需与.spec.selector.matchLabels 定义的标签保持一致
- app: nginx
- spec:
- containers: //定义容器属性
- - name: nignx //定义一个容器名,一个 - name: 定义一个容器
- image: nginx:1.21 //定义容器使用的镜像以及版本
- ports:
- - name: http
- containerPort: 80 定义容器的对外的端口
- - name: https
- containerPort: 443
- vim demo1_svc.yaml
- ---
- apiVersion: v1
- kind: Service
- metadata:
- name: nginx-svc
- namespace: kube-public
- spec:
- type: NodePort //类型为nodeport,可以对外提供服务
- ports:
- - name: http
- port: 8080 //service端口
- targetPort: 80 //对应pod中的80端口
- nodePort: 30080 //服务映射的node节点端口
- - name: https
- port: 8443
- targetPort: 443
- nodePort: 30443
- selector:
- app: nginx //指定选择器,在pod标签中查看
- vim demo2.yaml
- ---
- apiVersion: v1
- kind: Pod //类型为pod
- metadata:
- name: mynginx
- labels:
- name: mynginx
- spec:
- containers: //指定容器镜像和端口
- - name: nginx
- image: nginx:1.18
- ports:
- - containerPort: 80
- ---
- apiVersion: v1
- kind: Service
- metadata:
- name: nginxpodsvc
- labels:
- name: mynginx
- spec:
- type: NodePort //nodeport类型可以对外服务
- ports:
- - port: 8008 //服务指定8008端口,因为没有指定node端口,会随机生成
- targetPort: 80
- selector:
- name: mynginx
kubectl run pod名称 --image=指定镜像 --port=pod端口 --dry-run=client -o yaml > xxx.yaml
# kubectl run 可以运行一个容器
# --dry-run=client 可以实现空跑一个容器,不会实际创建(用于测试)
# -o yaml 输出yaml格式
# > xxx.yaml 将输出内容导入指定的yaml文件
kubectl expose deployment 服务名称 --port=服务端口 --target-port=pod端口 --type=端口类型 --dry-run=client -o yaml > xxx.yaml
kubectl create deployment 名称 --image=镜像 --port=容器端口 --replicas=n --dry-run=client -o yaml > xxx.yaml
kubectl get 资源类型 资源名称 -o yaml > xxx.yaml #这种方式需要删除改动的地方较多
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。