
目录
kubernetes支持yaml和json文件格式管理资源对象
kubectl api-versions

编写nginx-test。yaml 资源配置清单
- vim nginx-test.yaml
-
- #指定api版本标签
- apiVersion: apps/v1
- #定义资源的类型/角色,deployment为副本控制器
- #此处资源类型可以是Deployment、Job、Ingress、Service等
- kind: Deployment
- #定义资源的元数据信息,比如资源的名称、namespace、标签等信息
- metadata:
- #定义资源的名称,在同一个namespace空间中必须是唯一的
- name: nginx-deployment
- labels:
- app: nginx
- #定义deployment资源需要的参数属性,诸如是否在容器失败时重新启动容器的属性
- spec:
- #定义副本数量
- replicas: 3
- #定义标签选择器
- selector:
- #定义匹配标签
- matchLabels:
- #需与后面的.spec.template.metadata.labels定义的标签保持一致
- app: nginx
- #定义业务模板,如果有多个副本,所有副本的属性会按照模板的相关配置进行匹配
- template:
- metadata:
- #定义Pod副本将使用的标签,需与前面的.spec.selector.matchLabels定义的标签保持一致
- labels:
- app: nginx
- spec:
- #定义容器属性
- containers:
- #定义一个容器名,一个-name:定义一个容器
- - name: nginx
- #定义容器使用的镜像以及版本
- image: nginx:1.15.4
- ports:
- #定义容器对外的端口
- - containerPort: 80
-
- #------------------------------------------------------------------#
- #无注释
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: nginx-deployment
- labels:
- app: nginx
- spec:
- replicas: 3
- selector:
- matchLabels:
- app: nginx
- template:
- metadata:
- labels:
- app: nginx
- spec:
- containers:
- - name: nginx
- image: nginx:1.15.4
- ports:
- - containerPort: 80
-

kubectl create -f nginx-deployment.yaml --validate=false
![]()
kubectl get pods -o wide

- [root@master ~]# vim nginx-svc-test.yaml
-
- apiVersion: v1
- kind: Service
- metadata:
- name: nginx-svc
- labels:
- app: nginx
- spec:
- type: NodePort
- ports:
- - port: 80
- targetPort: 80
- selector:
- #此处定义的selector要与deployment所定义的selector相同
- #service依靠标签选择器来检索提供服务的nodes
- app: nginx

- kubectl apply -f nginx-service.yaml
- kubectl get po,svc




port
port是K8S集群内部访问service的端口,即通过clusterip,port可以从pod所在的node上访问到service
nodeport
nodeport是外部访问K8S集群中service 的端口,通过 nodeip,nodeport 可以从外部访问到service
targetport
targetport是pod的端口,从port或nodeport来的流量经常kube-proxy反向代理负载均衡转发到后端pod的targetport上,最后进入容器
containerport
containerport是pod内部容器的端口,targetport映射到containerport
-dry-run:表示试运行,不真正执行命令(测试命令是否正确,并不会真的创建出pod和deployment实例,去掉该参数后即可真正执行命令。
#kubectl create deployment nginx-nxx --image=nginx:1.21 --replicas=3 --port=80 --dry-run=client

使用 --dry-run 试运行可不触发生成命令,然后通过 -o yaml 可实现对其 yaml 资源配置清单的查看
kubectl create deployment nginx-nxx --image=nginx:1.21 --replicas=3 --port=80 --dry-run=client -o yaml

- [root@master demo]#kubectl apply -f nginxzz.yaml --dry-run=client
- deployment.apps/nginx-deployment configured (dry run)
- [root@master demo]#kubectl apply -f nginxzz.yaml --dry-run=client -o yaml

可通过 -o json 查看该命令产生的 json 配置清单
kubectl create deployment nginx-nxx --image=nginx:1.21 --replicas=3 --port=80 --dry-run=client -o json

[root@master demo]#kubectl create deployment nginx-nxx --image=nginx:1.21 --replicas=3 --port=80 --dry-run=client -o yaml >nxx.yaml


- kubectl apply -f nxx.yaml
-
- kubectl get pod,deploy

- kubectl get deploy/nginx-nxx -o yaml
-
- kubectl get deploy/nginx-nxx -o yaml > nxx.test.yaml


explain 可一层层的查看相关资源对象的帮助信息
[root@master demo]#kubectl explain deployment.spec.template.spec.containers


没有相关资源,使用--dry-run 选项
kubectl run nxx.test --image=nginx --port=80 --replicas=3 --dry-run -o yaml > nxx.test.yaml
已有相关资源,使用get命令-export选项
kubectl get deploy dryrun-test --export -o yaml > export-test.yaml