前言
1.1:概述
k8s支持使用YAML和JSON格式的文件來創建資源對象,相比較而言:
-
json格式的文件用於接口之間消息的傳遞,更適合二次開發
-
yaml格式的文件只是一種簡潔的非標記性語言,更適合運維
YAML的文件格式和注意事項
1、不支持製表符tab鍵縮進,需要使用空格縮進,使用縮進表示層級關係
2、通常開頭縮進2個空格,縮進的空格數不重要,只要相同層級的元素左對齊即可
3、字符後縮進一個空格,如冒號、逗號、橫杆
4、用#號註釋
5、如果包含特殊字符用單引號引起來
6、布爾值必須用引號括起來7、—表示yaml文件格式的分割
1.2:使用YAML文件創建資源對象
1、查看資源版本標籤
[root@master ~]# kubectl api-versions
admissionregistration.k8s.io/v1beta1
apiextensions.k8s.io/v1beta1
apiregistration.k8s.io/v1
apiregistration.k8s.io/v1beta1
apps/v1
apps/v1beta1
apps/v1beta2
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/v1beta1
events.k8s.io/v1beta1
extensions/v1beta1
networking.k8s.io/v1
policy/v1beta1
rbac.authorization.k8s.io/v1
rbac.authorization.k8s.io/v1beta1
scheduling.k8s.io/v1beta1
storage.k8s.io/v1
storage.k8s.io/v1beta1
v1
例如:寫一個yuml文件
2、創建目錄,編輯測試文件
[root@master ~]# mkdir test
[root@master ~]# cd test/
[root@master test]# vim nginx-test.yaml
apiVersion: apps/v1 '//指定api版本標籤'
kind: Deployment '//定義資源的類型/角色,deployment爲控制器'
metadata: '//定義資源的元數據'
name: nginx-test '//定義資源的名稱,在同一個namespace中必須唯一'
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 '//定義容器的對外端口'
3、創建資源對象
[root@master test]# kubectl create -f nginx-test.yaml
deployment.apps/nginx-test created
[root@master test]# kubectl get pod '//創建成功'
NAME READY STATUS RESTARTS AGE
nginx-dbddb74b8-5s6h7 1/1 Running 1 9d
nginx-test-d55b94fd-9zmdj 1/1 Running 0 55s
nginx-test-d55b94fd-b8lkl 1/1 Running 0 55s
nginx-test-d55b94fd-w4c5k 1/1 Running 0 55s
4、創建service服務對外提供訪問並測試
[root@master test]# vim nginx-service-test.yaml
apiVersion: v1
kind: Service
metadata:
name: nginx-service
labels:
app: nginx
spec:
type: NodePort
ports:
- port: 80
targetPort: 80
selector:
app: nginx
[root@master test]# kubectl create -f nginx-service-test.yaml
service/nginx-service created
[root@master test]# kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.0.0.1 <none> 443/TCP 2d5h
nginx-service NodePort 10.0.0.226 <none> 80:47710/TCP 5s
1.3:使用命令快速生成YAML或者JSON文件
1、測試創建資源對象的命令正確性,並不真正執行創建
[root@master test]# kubectl run nginx-test01 --image=nginx --port=80 --replicas=2 --dry-run
kubectl run -- generator=deployment/apps.v1beta1 is DEPRECATED and will be removed in a future version. Use kubectl create instead.
deployment.apps/nginx-test01 created (dry run)
'//以上提示說明命令是正確的'
2、自動生成yaml格式的文件不保存
[root@master test]# kubectl run nginx-test01 --image=nginx --port=80 --replicas=2 --dry-run -o yaml '//此命令直接生成yaml文件內容展示出來,並不會保存'
[root@master test]# kubectl run nginx-test01 --image=nginx --port=80 --replicas=2 --dry-run -o json '//也可以生成json格式'
3、自動生成yaml格式的文件並保存
[root@master test]# kubectl run nginx-test01 --image=nginx --port=80 --replicas=2 --dry-run -o yaml > nginx-test01.yaml
kubectl run --generator=deployment/apps.v1beta1 is DEPRECATED and will be removed in a future version. Use kubectl create instead.
[root@master test]# ls
nginx-service-test.yaml nginx-test01.yaml nginx-test.yaml '//成功生成,可以在此基礎上修修改改了'
4、將現有的資源生成模板並導出
[root@master test]# kubectl get pod
NAME READY STATUS RESTARTS AGE
nginx-dbddb74b8-5s6h7 1/1 Running 1 9d '//用此nginx來生成模板並導出'
nginx-test-d55b94fd-9zmdj 1/1 Running 0 11m
nginx-test-d55b94fd-b8lkl 1/1 Running 0 11m
nginx-test-d55b94fd-w4c5k 1/1 Running 0 11m
[root@master test]# kubectl get deployment/nginx --export -o yaml > nginx-test02.yaml
[root@master test]# ls
nginx-service-test.yaml nginx-test01.yaml nginx-test02.yaml nginx-test.yaml
5、查看yaml文件某一字段的幫助信息
[root@master test]# kubectl explain pods.spec.containers