yaml文件詳解


一、yaml文件詳解

Kubernetes支持YAML 和JSON 格式管理資源對象

JSON格式:主要用於api 接口之間消息的傳遞

YAML格式:用於配置和管理,YAML 是一種簡潔的非標記性語言,內容格式人性化,較易讀

YAML語法格式:

●大小寫敏感
●使用縮進表示層級關系
●不支持Tab鍵制表符縮進,只使用空格縮進
●縮進的空格數目不重要,只要相同層級的元素左側對齊即可,通常開頭縮進兩個空格:
●字符后縮進一 個空格,如冒號,逗號,短橫桿(-)等
●"—"表示YAML格式, 一個文件的開始,用於分隔文件間
●“#"表示注釋

//查看api資源版本標簽

kubectl api-versions
admissionregistration.k8s.io/vlbeta1
apiextensions.k8s.io/v1beta1
apiregistration.k8s.io/v1
apiregistration.k8s.io/v1beta1
apps/v1
#如果是業務場景一般首選使用apps/v1
apps/v1beta1
#帶有beta字樣的代表的是測試版本,不用在生產環境中
apps/v1beta2
authentication.k8s.io/v1
authentication.k8s.io/v1beta1
authorization.k8s.io/v1
authorization.k8s.io/vlbeta1
autoscaling/v1
autoscaling/v2beta1
autoscaling/v2beta2
batch/v1
batch/v1beta1
certificates.k8s.io/vlbeta1
coordination.k8s.io/vlbeta1
events.k8s.io/vlbeta1
extensions/v1beta1
networking.k8s.io/v1
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

  

//寫一個yaml文件demo

mkdir /opt/demo
cd demo/

vim nginx-deployment.yaml
apiVersion: apps/v1 #指定api版本標簽
kind: Deployment #定義資源的類型/角色,deployment 為副本控制器,此處資源類型可以是Deployment、Job、 Ingress、 Service等
metadata: #定義資源的元數據信息,比如資源的名稱、namespace、標簽等信息
name: nginx-deployment #定義資源的名稱,在同一個namespace空間中必須是唯一的
labels: #定義資源標簽(Pod的標簽)
app: nginx
spec: #定義deployment資源需要的參數屬性,諸如是否在容器失敗時重新啟動容器的屬性
replicas: 3 #定義副本數量
selector : #定義標簽選擇器
matchLabels: #定義匹配標簽
app: nginx #匹配上面的標簽,需與上面的標簽定義的app保持一致
template: #定義業務模板,如果有多個副本,所有副本的屬性會按照模板的相關配置進行匹配
metadata:
labels:
app: nginx
spec:
containers: #定義容器屬性
- name: nginx #定義一個容器名,一個- name: 定義一個容器
image: nginx:1.15.4 #定義容器使用的鏡像以及版本
ports:
- containerPort: 80 #定義容器的對外的端口

kubectl apply -f nginx-demo1.yaml

kubectl get deploy -n kube-public

  



//創建service服務對外提供訪問並測試

vim nginx-service.yaml
apiVersion: v1
kind: Service
metadata :
name: nginx-service
labels:
app: nginx 
spec:
type: NodePort
ports :
- port: 80
targetPort: 80
selector :
app: nginx

  

//創建資源對象

kubectl create -f nginx-service.yaml

  

//查看創建的:service

kubectl get svc

  

//在瀏覽器輸入nodeIP: nodePort 即可訪問

http://192.168.229.90:35680
http://192.168.229.80:35680  

----------------------------------------------
詳解k8s中的port:

●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 對象而不執行創建

kubectl run nginx-test --image=nginx --port=80 --replicas=3 --dry-run  

//查看生成yaml格式

kubectl run nginx-test --image=nginx --port=80 --replicas=3 --dry-run -o yaml  

//查看生成json格式

kubectl run nginx-test --image=nginx --port=80 --replicas=3 --dry-run -o json 

//使用yaml格式導出生成模板,並進行修改以及刪除一些不必要的參數

kubectl run nginx-test --image=nginx --port=80 --replicas=3 --dry-run -o yaml > Inginx-test.yaml  

//將現有的資源生成模板導出I

kubectl get deployment/ nginx-deployment --export -o yaml  

//保存到文件中

kubectl get deploy/nginx-deployment --export -o yaml > my-deploy.yaml  

//查看字段幫助信息,可一層層的查看相關資源對象的幫助信息

kubectl explain deployments.spec.template.spec.ontainers
或
kubectl explain pods.spec.containers

  

//寫yaml太累怎么辦?
●用run命令生成

kubectl run my-deploy --image=nginx --dry-run -o yaml > my-deploy.yaml  

●用get命令導出

kubectl get deploy/nginx-deployment --export -o=yaml > new.yaml

//yaml文件的學習方法:

(1)多看別人(官方)寫的,能讀懂
(2)能照着現場的文件改着用
(3)遇到不懂的,善用kubectl explain ...命令查


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM