目录
kubernetes支持YAML和JSON文件格式管理资源对象
kubectl api-versions
- vim nginx-deployment.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
- kubectl get pods -o wide -n kube-public
-
- kubectl get deploy -n kube-public
- kubectl apply -f nginx-service.yaml
-
- kubectl get svc -n kube-public
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
kubectl run --dry-run 打印相应的API对象而不执行创建
- --dry-run:试运行
-
- kubectl run nginx-test --image=nginx --port=80 --dry-run
-dry-run表示试运行,不真正执行命令(测试命令是否正确),即并不会真的创建出pod和deployment实例,去掉参数后即可真正执行命令
使用-dry-run试运行可不触发生成命令,然后通过-o yaml资源配置清单的查看
kubectl run nginx-test --image=nginx --port=80 --dry-run -o yaml
kubectl run nginx-test --image-nginx --port=80 --dry-run -o json
- kubectl run nginx-test --image=nginx --port=80 --dry-run -o yaml > nginx-test.yaml
-
-
- kubectl create deployment nginx-test1 --image=nginx --port=80 --replicas=3 --dry-run=client -o yaml > nginx-test.yaml
- kubectl apply -f nginx-test1.yaml
-
-
- kubectl get pod,deploy
- kubectl get deploy/nginx-test1 -o yaml
-
- kubectl get deploy/nginx-test1 -o yaml > nginx-test11.yaml
explain可一层层的查看相关资源对象的帮助信息
- kubectl explain deployments.spec.template.spec.containers
-
-
-
- kubectl explain pods.spec.containers
1、没有相关资源,使用run命令 --dry-run选项
2、已有相关资源,使用get命令 --export选项
- kubectl run dryrun-test --image=nginx --port=80 --replicas=3 --dry-run -o yaml > nginx-test.yaml
-
-
- kubectl get deploy nginx-test --export -o yaml > nginx-test.yaml