国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

k8s yaml

這篇具有很好參考價(jià)值的文章主要介紹了k8s yaml。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

一 yaml 基本語(yǔ)法

Kubernetes 支持 YAML 和 JSON 格式管理資源對(duì)象
JSON 格式:主要用于 api 接口之間消息的傳遞
YAML 格式:用于配置和管理,YAML 是一種簡(jiǎn)潔的非標(biāo)記性語(yǔ)言,內(nèi)容格式人性化,較易讀

YAML 語(yǔ)法格式:
●大小寫敏感
●使用縮進(jìn)表示層級(jí)關(guān)系
●不支持Tab鍵制表符縮進(jìn),只使用空格縮進(jìn)
●縮進(jìn)的空格數(shù)目不重要,只要相同層級(jí)的元素左側(cè)對(duì)齊即可,通常開頭縮進(jìn)兩個(gè)空格
●符號(hào)字符后縮進(jìn)一個(gè)空格,如冒號(hào),逗號(hào),短橫桿(-)等
●“---”表示YAML格式,一個(gè)文件的開始,用于分隔文件間
●“#”表示注釋

//查看 api 資源版本標(biāo)簽
kubectl api-versions
admissionregistration.k8s.io/v1beta1
apiextensions.k8s.io/v1beta1
apiregistration.k8s.io/v1
apiregistration.k8s.io/v1beta1
apps/v1?? ??? ??? ??? ??? ??? ??? ??? ?#如果是業(yè)務(wù)場(chǎng)景一般首選使用 apps/v1
apps/v1beta1?? ??? ??? ??? ??? ??? ?#帶有beta字樣的代表的是測(cè)試版本,不用在生產(chǎn)環(huán)境中
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


//寫一個(gè)yaml文件demo
mkdir /opt/demo
cd demo/

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

//創(chuàng)建資源對(duì)象
kubectl create -f nginx-deployment.yaml

//查看創(chuàng)建的pod資源
kubectl get pods -o wide
NAME ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?READY ? STATUS ? ?RESTARTS ? AGE ? ?IP ? ? ? ? ? ?NODE ? ? ? ? ? ?NOMINATED NODE
nginx-deployment-d55b94fd-29qk2 ? 1/1 ? ? Running ? 0 ? ? ? ? ?7m9s ? 172.17.36.4 ? 192.168.80.12 ? <none>
nginx-deployment-d55b94fd-9j42r ? 1/1 ? ? Running ? 0 ? ? ? ? ?7m9s ? 172.17.36.3 ? 192.168.80.12 ? <none>
nginx-deployment-d55b94fd-ksl6l ? 1/1 ? ? Running ? 0 ? ? ? ? ?7m9s ? 172.17.26.3 ? 192.168.80.11 ? <none>


//創(chuàng)建service服務(wù)對(duì)外提供訪問并測(cè)試
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

//創(chuàng)建資源對(duì)象
kubectl create -f nginx-service.yaml?

//查看創(chuàng)建的service
kubectl get svc
NAME ? ? ? ? ? ?TYPE ? ? ? ?CLUSTER-IP ? EXTERNAL-IP ? PORT(S) ? ? ? ?AGE
kubernetes ? ? ?ClusterIP ? 10.0.0.1 ? ? <none> ? ? ? ?443/TCP ? ? ? ?16d
nginx-service ? NodePort ? ?10.0.0.119 ? <none> ? ? ? ?80:35680/TCP ? 14s

//在瀏覽器輸入 nodeIP:nodePort 即可訪問
http://192.168.80.11:35680
http://192.168.80.12:35680

------------------------------------------------------------------------------------------
詳解k8s中的port:
●port
port 是 k8s 集群內(nèi)部訪問service的端口,即通過 clusterIP: port 可以從 Pod 所在的 Node 上訪問到 service

●nodePort
nodePort 是外部訪問 k8s 集群中 service 的端口,通過 nodeIP: nodePort 可以從外部訪問到某個(gè) service。

●targetPort
targetPort 是 Pod 的端口,從 port 或 nodePort 來(lái)的流量經(jīng)過 kube-proxy 反向代理負(fù)載均衡轉(zhuǎn)發(fā)到后端 Pod 的 targetPort 上,最后進(jìn)入容器。

●containerPort
containerPort 是 Pod 內(nèi)部容器的端口,targetPort 映射到 containerPort。
------------------------------------------------------------------------------------------

//kubectl run --dry-run=client 打印相應(yīng)的 API 對(duì)象而不執(zhí)行創(chuàng)建
kubectl run nginx-test --image=nginx --port=80 --dry-run=client
kubectl create deployment nginx-deploy --image=nginx --port=80 --replicas=3 --dry-run=client

//查看生成yaml格式
kubectl run nginx-test --image=nginx --port=80 --dry-run=client -o yaml
kubectl create deployment nginx-deploy --image=nginx --port=80 --replicas=3 --dry-run=client -o yaml

//查看生成json格式
kubectl run nginx-test --image=nginx --port=80 --dry-run=client -o json
kubectl create deployment nginx-deploy --image=nginx --port=80 --replicas=3 --dry-run=client -o json

//使用yaml格式導(dǎo)出生成模板,并進(jìn)行修改以及刪除一些不必要的參數(shù)
kubectl run nginx-test --image=nginx --port=80 --dry-run=client -o yaml > nginx-test.yaml
kubectl create deployment nginx-deploy --image=nginx --port=80 --replicas=3 --dry-run=client -o yaml ?> nginx-deploy.yaml

vim nginx-test.yaml
apiVersion: v1
kind: Pod
metadata:
? creationTimestamp: null ? ? #刪除
? labels:
? ? run: nginx-test
? name: nginx-test
spec:
? containers:
? - image: nginx
? ? name: nginx-test
? ? ports:
? ? - containerPort: 80
? ? resources: {} ? ? ? ? ? ? #刪除
? dnsPolicy: ClusterFirst
? restartPolicy: Always
status: {} ? ? ? ? ? ? ? ? ? ?#刪除


//將現(xiàn)有的資源生成模板導(dǎo)出
kubectl get svc nginx-service -o yaml

//保存到文件中
kubectl get svc nginx-service -o yaml > my-svc.yaml

//查看字段幫助信息,可一層層的查看相關(guān)資源對(duì)象的幫助信息
kubectl explain deployments.spec.template.spec.containers

kubectl explain pods.spec.containers


//寫yaml太累怎么辦?
●用 --dry-run 命令生成
kubectl run my-deploy --image=nginx --dry-run=client -o yaml > my-deploy.yaml

●用get命令導(dǎo)出
kubectl get svc nginx-service -o yaml > my-svc.yaml

kubectl edit svc nginx-service ?#復(fù)制配置,再粘貼到新文件

//yaml文件的學(xué)習(xí)方法:
(1)多看別人(官方)寫的,能讀懂
(2)能照著現(xiàn)場(chǎng)的文件改著用
(3)遇到不懂的,善用kubectl explain ... 命令查

二 pod yaml文件

//Pod yaml文件詳解

apiVersion: v1?? ??? ??? ?#必選,版本號(hào),例如v1
kind: Pod?? ??? ??? ??? ?#必選,Pod
metadata:?? ??? ??? ??? ?#必選,元數(shù)據(jù)
? name: string?? ??? ??? ? ?#必選,Pod名稱
? namespace: string?? ??? ? ?#必選,Pod所屬的命名空間
? labels:?? ??? ??? ??? ? ?#自定義標(biāo)簽
? ? - name: string?? ??? ? ? ?#自定義標(biāo)簽名字
? annotations:?? ??? ??? ? ? ?#自定義注釋列表
? ? - name: string
spec:?? ??? ??? ??? ??? ?#必選,Pod中容器的詳細(xì)定義
? containers:?? ??? ??? ? ?#必選,Pod中容器列表
? - name: string?? ??? ? ? ?#必選,容器名稱
? ? image: string?? ??? ? ? ?#必選,容器的鏡像名稱
? ? imagePullPolicy: [Always | Never | IfNotPresent]?? ?#獲取鏡像的策略:Alawys表示總是下載鏡像,IfnotPresent表示優(yōu)先使用本地鏡像,否則下載鏡像,Nerver表示僅使用本地鏡像
? ? command: [string]?? ??? ?#容器的啟動(dòng)命令列表,如不指定,使用打包時(shí)使用的啟動(dòng)命令
? ? args: [string]?? ??? ??? ?#容器的啟動(dòng)命令參數(shù)列表
? ? workingDir: string?? ??? ?#容器的工作目錄
? ? volumeMounts:?? ??? ??? ?#掛載到容器內(nèi)部的存儲(chǔ)卷配置
? ? - name: string?? ??? ??? ? ?#引用pod定義的共享存儲(chǔ)卷的名稱,需用volumes[]部分定義的的卷名
? ? ? mountPath: string?? ??? ? ?#存儲(chǔ)卷在容器內(nèi)mount的絕對(duì)路徑,應(yīng)少于512字符
? ? ? readOnly: boolean?? ??? ? ?#是否為只讀模式
? ? ports:?? ??? ??? ??? ??? ?#需要暴露的端口庫(kù)號(hào)列表
? ? - name: string?? ??? ??? ? ?#端口號(hào)名稱
? ? ? containerPort: int?? ? ?#容器需要監(jiān)聽的端口號(hào)
? ? ? hostPort: int?? ??? ??? ? ?#容器所在主機(jī)需要監(jiān)聽的端口號(hào),默認(rèn)與Container相同
? ? ? protocol: string?? ??? ? ?#端口協(xié)議,支持TCP和UDP,默認(rèn)TCP
? ? env:?? ??? ??? ??? ??? ?#容器運(yùn)行前需設(shè)置的環(huán)境變量列表
? ? - name: string?? ??? ??? ? ?#環(huán)境變量名稱
? ? ? value: string?? ??? ??? ? ?#環(huán)境變量的值
? ? resources:?? ??? ??? ??? ?#資源限制和請(qǐng)求的設(shè)置
? ? ? limits:?? ??? ??? ??? ? ?#資源限制的設(shè)置
? ? ? ? cpu: string?? ??? ??? ? ? ?#Cpu的限制,單位為core數(shù),將用于docker run --cpu-shares參數(shù)
? ? ? ? memory: string?? ??? ??? ?#內(nèi)存限制,單位可以為Mib/Gib,將用于docker run --memory參數(shù)
? ? ? requests:?? ??? ??? ??? ? ?#資源請(qǐng)求的設(shè)置
? ? ? ? cpu: string?? ??? ??? ? ? ?#Cpu請(qǐng)求,容器啟動(dòng)的初始可用數(shù)量
? ? ? ? memory: string?? ??? ? ? ?#內(nèi)存清楚,容器啟動(dòng)的初始可用數(shù)量
? ? livenessProbe: ? ? ?? ??? ?#對(duì)Pod內(nèi)個(gè)容器健康檢查的設(shè)置,當(dāng)探測(cè)無(wú)響應(yīng)幾次后將自動(dòng)重啟該容器,檢查方法有exec、httpGet和tcpSocket,對(duì)一個(gè)容器只需設(shè)置其中一種方法即可
? ? ? exec:?? ??? ??? ??? ??? ?#對(duì)Pod容器內(nèi)檢查方式設(shè)置為exec方式
? ? ? ? command: [string]?? ? ?#exec方式需要制定的命令或腳本
? ? ? httpGet:?? ??? ??? ??? ?#對(duì)Pod內(nèi)個(gè)容器健康檢查方法設(shè)置為HttpGet,需要制定Path、port
? ? ? ? path: string
? ? ? ? port: number
? ? ? ? host: string
? ? ? ? scheme: string
? ? ? ? HttpHeaders:
? ? ? ? - name: string
? ? ? ? ? value: string
? ? ? tcpSocket:?? ??? ??? ?#對(duì)Pod內(nèi)個(gè)容器健康檢查方式設(shè)置為tcpSocket方式
? ? ? ? ?port: number
? ? ? ?initialDelaySeconds: 0?? ?#容器啟動(dòng)完成后首次探測(cè)的時(shí)間,單位為秒
? ? ? ?timeoutSeconds: 0?? ??? ?#對(duì)容器健康檢查探測(cè)等待響應(yīng)的超時(shí)時(shí)間,單位秒,默認(rèn)1秒
? ? ? ?periodSeconds: 0?? ??? ??? ?#對(duì)容器監(jiān)控檢查的定期探測(cè)時(shí)間設(shè)置,單位秒,默認(rèn)10秒一次
? ? ? ?successThreshold: 0
? ? ? ?failureThreshold: 0
? ? ? ?securityContext:
? ? ? ? ?privileged:false
? ? restartPolicy: [Always | Never | OnFailure]?? ??? ?#Pod的重啟策略,Always表示一旦不管以何種方式終止運(yùn)行,kubelet都將重啟,OnFailure表示只有Pod以非0退出碼退出才重啟,Nerver表示不再重啟該P(yáng)od
? ? nodeSelector: obeject?? ??? ?#設(shè)置NodeSelector表示將該P(yáng)od調(diào)度到包含這個(gè)label的node上,以key:value的格式指定
? ? imagePullSecrets:?? ??? ??? ?#Pull鏡像時(shí)使用的secret名稱,以key:secretkey格式指定
? ? - name: string
? ? hostNetwork:false?? ??? ??? ?#是否使用主機(jī)網(wǎng)絡(luò)模式,默認(rèn)為false,如果設(shè)置為true,表示使用宿主機(jī)網(wǎng)絡(luò)
? ? volumes:?? ??? ??? ??? ??? ?#在該pod上定義共享存儲(chǔ)卷列表
? ? - name: string?? ??? ??? ??? ? ?#共享存儲(chǔ)卷名稱 (volumes類型有很多種)
? ? ? emptyDir: {}?? ??? ??? ??? ? ?#類型為emtyDir的存儲(chǔ)卷,與Pod同生命周期的一個(gè)臨時(shí)目錄。為空值
? ? ? hostPath: string?? ??? ??? ? ?#類型為hostPath的存儲(chǔ)卷,表示掛載Pod所在宿主機(jī)的目錄
? ? ? ? path: string?? ??? ??? ? ? ?#Pod所在宿主機(jī)的目錄,將被用于同期中mount的目錄
? ? ? secret:?? ??? ??? ??? ??? ?#類型為secret的存儲(chǔ)卷,掛載集群與定義的secre對(duì)象到容器內(nèi)部
? ? ? ? scretname: string ?
? ? ? ? items: ? ??
? ? ? ? - key: string
? ? ? ? ? path: string
? ? ? configMap:?? ??? ??? ??? ?#類型為configMap的存儲(chǔ)卷,掛載預(yù)定義的configMap對(duì)象到容器內(nèi)部
? ? ? ? name: string
? ? ? ? items:
? ? ? ? - key: string

三 deployment yaml

deployment.yaml文件詳解

apiVersion: extensions/v1beta1 ? #接口版本
kind: Deployment ? ? ? ? ? ? ? ? #接口類型
metadata:
? name: cango-demo ? ? ? ? ? ? ? #Deployment名稱
? namespace: cango-prd ? ? ? ? ? #命名空間
? labels:
? ? app: cango-demo ? ? ? ? ? ? ?#標(biāo)簽
spec:
? replicas: 3
? strategy:
? ? rollingUpdate: ?##由于replicas為3,則整個(gè)升級(jí),pod個(gè)數(shù)在2-4個(gè)之間
? ? ? maxSurge: 1 ? ? ?#滾動(dòng)升級(jí)時(shí)會(huì)先啟動(dòng)1個(gè)pod
? ? ? maxUnavailable: 1 #滾動(dòng)升級(jí)時(shí)允許的最大Unavailable的pod個(gè)數(shù)
? template: ? ? ? ??
? ? metadata:
? ? ? labels:
? ? ? ? app: cango-demo ?#模板名稱必填
? ? sepc: #定義容器模板,該模板可以包含多個(gè)容器
? ? ? containers: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ??
? ? ? ? - name: cango-demo ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #鏡像名稱
? ? ? ? ? image: swr.cn-east-2.myhuaweicloud.com/cango-prd/cango-demo:0.0.1-SNAPSHOT #鏡像地址
? ? ? ? ? command: [ "/bin/sh","-c","cat /etc/config/path/to/special-key" ] ? ?#啟動(dòng)命令
? ? ? ? ? args: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#啟動(dòng)參數(shù)
? ? ? ? ? ? - '-storage.local.retention=$(STORAGE_RETENTION)'
? ? ? ? ? ? - '-storage.local.memory-chunks=$(STORAGE_MEMORY_CHUNKS)'
? ? ? ? ? ? - '-config.file=/etc/prometheus/prometheus.yml'
? ? ? ? ? ? - '-alertmanager.url=http://alertmanager:9093/alertmanager'
? ? ? ? ? ? - '-web.external-url=$(EXTERNAL_URL)'
? ? #如果command和args均沒有寫,那么用Docker默認(rèn)的配置。
? ? #如果command寫了,但args沒有寫,那么Docker默認(rèn)的配置會(huì)被忽略而且僅僅執(zhí)行.yaml文件的command(不帶任何參數(shù)的)。
? ? #如果command沒寫,但args寫了,那么Docker默認(rèn)配置的ENTRYPOINT的命令行會(huì)被執(zhí)行,但是調(diào)用的參數(shù)是.yaml中的args。
? ? #如果如果command和args都寫了,那么Docker默認(rèn)的配置被忽略,使用.yaml的配置。
? ? ? ? ? imagePullPolicy: IfNotPresent ?#如果不存在則拉取
? ? ? ? ? livenessProbe: ? ? ? #表示container是否處于live狀態(tài)。如果LivenessProbe失敗,LivenessProbe將會(huì)通知kubelet對(duì)應(yīng)的container不健康了。隨后kubelet將kill掉container,并根據(jù)RestarPolicy進(jìn)行進(jìn)一步的操作。默認(rèn)情況下LivenessProbe在第一次檢測(cè)之前初始化值為Success,如果container沒有提供LivenessProbe,則也認(rèn)為是Success;
? ? ? ? ? ? httpGet:
? ? ? ? ? ? ? path: /health #如果沒有心跳檢測(cè)接口就為/
? ? ? ? ? ? ? port: 8080
? ? ? ? ? ? ? scheme: HTTP
? ? ? ? ? ? initialDelaySeconds: 60 ##啟動(dòng)后延時(shí)多久開始運(yùn)行檢測(cè)
? ? ? ? ? ? timeoutSeconds: 5
? ? ? ? ? ? successThreshold: 1
? ? ? ? ? ? failureThreshold: 5
? ? ? ? ? readinessProbe:
? ? ? ? ? ? httpGet:
? ? ? ? ? ? ? path: /health #如果沒有心跳檢測(cè)接口就為/
? ? ? ? ? ? ? port: 8080
? ? ? ? ? ? ? scheme: HTTP
? ? ? ? ? ? initialDelaySeconds: 30 ##啟動(dòng)后延時(shí)多久開始運(yùn)行檢測(cè)
? ? ? ? ? ? timeoutSeconds: 5
? ? ? ? ? ? successThreshold: 1
? ? ? ? ? ? failureThreshold: 5
? ? ? ? ? resources: ? ? ? ? ? ? ?##CPU內(nèi)存限制
? ? ? ? ? ? requests:
? ? ? ? ? ? ? cpu: 2
? ? ? ? ? ? ? memory: 2048Mi
? ? ? ? ? ? limits:
? ? ? ? ? ? ? cpu: 2
? ? ? ? ? ? ? memory: 2048Mi
? ? ? ? ? env: ? ? ? ? ? ? ? ? ? ?##通過環(huán)境變量的方式,直接傳遞pod=自定義Linux OS環(huán)境變量
? ? ? ? ? ? - name: LOCAL_KEY ? ? #本地Key
? ? ? ? ? ? ? value: value
? ? ? ? ? ? - name: CONFIG_MAP_KEY ?#局策略可使用configMap的配置Key,
? ? ? ? ? ? ? valueFrom:
? ? ? ? ? ? ? ? configMapKeyRef:
? ? ? ? ? ? ? ? ? name: special-config ? #configmap中找到name為special-config
? ? ? ? ? ? ? ? ? key: special.type ? ? ?#找到name為special-config里data下的key
? ? ? ? ? ports:
? ? ? ? ? ? - name: http
? ? ? ? ? ? ? containerPort: 8080 #對(duì)service暴露端口
? ? ? ? ? volumeMounts: ? ? #掛載volumes中定義的磁盤
? ? ? ? ? - name: log-cache
? ? ? ? ? ? mount: /tmp/log
? ? ? ? ? - name: sdb ? ? ? #普通用法,該卷跟隨容器銷毀,掛載一個(gè)目錄
? ? ? ? ? ? mountPath: /data/media ? ?
? ? ? ? ? - name: nfs-client-root ? ?#直接掛載硬盤方法,如掛載下面的nfs目錄到/mnt/nfs
? ? ? ? ? ? mountPath: /mnt/nfs
? ? ? ? ? - name: example-volume-config ?#高級(jí)用法第1種,將ConfigMap的log-script,backup-script分別掛載到/etc/config目錄下的一個(gè)相對(duì)路徑path/to/...下,如果存在同名文件,直接覆蓋。
? ? ? ? ? ? mountPath: /etc/config ? ? ??
? ? ? ? ? - name: rbd-pvc ? ? ? ? ? ? ? ?#高級(jí)用法第2中,掛載PVC(PresistentVolumeClaim)
?
#使用volume將ConfigMap作為文件或目錄直接掛載,其中每一個(gè)key-value鍵值對(duì)都會(huì)生成一個(gè)文件,key為文件名,value為內(nèi)容,
? volumes: ?# 定義磁盤給上面volumeMounts掛載
? - name: log-cache
? ? emptyDir: {}
? - name: sdb ?#掛載宿主機(jī)上面的目錄
? ? hostPath:
? ? ? path: /any/path/it/will/be/replaced
? - name: example-volume-config ?# 供ConfigMap文件內(nèi)容到指定路徑使用
? ? configMap:
? ? ? name: example-volume-config ?#ConfigMap中名稱
? ? ? items:
? ? ? - key: log-script ? ? ? ? ? #ConfigMap中的Key
? ? ? ? path: path/to/log-script ?#指定目錄下的一個(gè)相對(duì)路徑path/to/log-script
? ? ? - key: backup-script ? ? ? ?#ConfigMap中的Key
? ? ? ? path: path/to/backup-script ?#指定目錄下的一個(gè)相對(duì)路徑path/to/backup-script
? - name: nfs-client-root ? ? ? ? #供掛載NFS存儲(chǔ)類型
? ? nfs:
? ? ? server: 10.42.0.55 ? ? ? ? ?#NFS服務(wù)器地址
? ? ? path: /opt/public ? ? ? ? ? #showmount -e 看一下路徑
? - name: rbd-pvc ? ? ? ? ? ? ? ? #掛載PVC磁盤
? ? persistentVolumeClaim:
? ? ? claimName: rbd-pvc1 ? ? ? ? #掛載已經(jīng)申請(qǐng)的pvc磁盤

四 service yaml

Service yaml文件詳解

apiVersion: v1
kind: Service
matadata: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#元數(shù)據(jù)
? name: string ? ? ? ? ? ? ? ? ? ? ? ? ? #service的名稱
? namespace: string ? ? ? ? ? ? ? ? ? ? ?#命名空間 ?
? labels: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#自定義標(biāo)簽屬性列表
? ? - name: string
? annotations: ? ? ? ? ? ? ? ? ? ? ? ? ? #自定義注解屬性列表 ?
? ? - name: string
spec: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#詳細(xì)描述
? selector: [] ? ? ? ? ? ? ? ? ? ? ? ? ? #label selector配置,將選擇具有l(wèi)abel標(biāo)簽的Pod作為管理?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#范圍
? type: string ? ? ? ? ? ? ? ? ? ? ? ? ? #service的類型,指定service的訪問方式,默認(rèn)為?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#clusterIp
? clusterIP: string ? ? ? ? ? ? ? ? ? ? ?#虛擬服務(wù)地址 ? ? ?
? sessionAffinity: string ? ? ? ? ? ? ? ?#是否支持session
? ports: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? #service需要暴露的端口列表
? - name: string ? ? ? ? ? ? ? ? ? ? ? ? #端口名稱
? ? protocol: string ? ? ? ? ? ? ? ? ? ? #端口協(xié)議,支持TCP和UDP,默認(rèn)TCP
? ? port: int ? ? ? ? ? ? ? ? ? ? ? ? ? ?#服務(wù)監(jiān)聽的端口號(hào)
? ? targetPort: int ? ? ? ? ? ? ? ? ? ? ?#需要轉(zhuǎn)發(fā)到后端Pod的端口號(hào)
? ? nodePort: int ? ? ? ? ? ? ? ? ? ? ? ?#當(dāng)type = NodePort時(shí),指定映射到物理機(jī)的端口號(hào)
? status: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?#當(dāng)spce.type=LoadBalancer時(shí),設(shè)置外部負(fù)載均衡器的地址
? ? loadBalancer: ? ? ? ? ? ? ? ? ? ? ? ?#外部負(fù)載均衡器 ? ?
? ? ? ingress: ? ? ? ? ? ? ? ? ? ? ? ? ? #外部負(fù)載均衡器?
? ? ? ? ip: string ? ? ? ? ? ? ? ? ? ? ? #外部負(fù)載均衡器的Ip地址值
? ? ? ? hostname: string ? ? ? ? ? ? ? ? #外部負(fù)載均衡器的主機(jī)名

五 業(yè)務(wù)發(fā)布策略:


藍(lán)綠發(fā)布
滾動(dòng)發(fā)布
金絲雀發(fā)布/灰度發(fā)布


聲明式管理方法:
離線修改: ?[ kubectl delete -f XXX.yaml && ] ?kubectl apply -f XXX.yaml
在線修改: ? kubectl edit ?資源類型 資源名稱 -n 命名空間 ? ? ?#注:部分字段配置不支持在線修改

六? 如何生成一個(gè)資源配置清單(yaml配置文件)


1)結(jié)合 kubectl explain 資源類型.第一層字段.第二層字段... ?可一層層查看相關(guān)資源對(duì)象的字段解析幫助信息,手打yaml配置文件
? ? ? ? kubectl explain deployment.spec.template.containers
?? ??? ?kubectl explain svc.spec.pods

2)用 kubectl get 或 kubectl edit 查看資源對(duì)象的配置生成配置模板文件
kubectl get 資源類型 資源名稱 -n 命名空間 -o yaml > XXX.yaml
kubectl get deployment nginx-ky27 -o yaml > nginx-ky27-deploy.yaml

kubectl edit 資源類型 資源名稱 -n 命名空間 ? ? #手動(dòng)復(fù)制配置內(nèi)容,再粘貼內(nèi)容到新文件

3)去官網(wǎng)查找資源的配置案例

4)用 --dry-run=client 參數(shù)選項(xiàng)生成配置模板
kubectl create 資源類型 資源名稱 [選項(xiàng)] ?--dry-run=client -o yaml > XXX.yaml
kubectl create deployment nginx-ky27 --image=nginx:1.16 --port=80 --replicas=3 --dry-run=client -o yaml > nginx-ky27-deploy.yaml
kubectl create svc svc類型 資源名稱 --tcp=<port>:<targetPort> ?--node-port=<nodeport> --dry-run=client -o yaml > svc.yaml
?文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-547236.html

到了這里,關(guān)于k8s yaml的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • Kubernetes技術(shù)--k8s核心技術(shù)yaml資源編排

    (1).引入 ? ? ? ?我們可以使用kubectl實(shí)現(xiàn)單行指令的操作,但是這樣做的壞處是不復(fù)用,所以為了更好的實(shí)現(xiàn)對(duì)一系列資源的編排工作。kuberntes中使用一種叫做 資源清單文件(yaml)來(lái)實(shí)現(xiàn)對(duì)資源管理和資源對(duì)象編排部署 。 (2).概述 ? ? yaml是一 種標(biāo)記語(yǔ)言 。為了強(qiáng)調(diào)這種語(yǔ)言以

    2024年02月10日
    瀏覽(26)
  • 云原生Kubernetes:K8S集群實(shí)現(xiàn)容器運(yùn)行時(shí)遷移(docker → containerd) 與 版本升級(jí)(v1.23.14 → v1.24.1)

    云原生Kubernetes:K8S集群實(shí)現(xiàn)容器運(yùn)行時(shí)遷移(docker → containerd) 與 版本升級(jí)(v1.23.14 → v1.24.1)

    目錄 一、理論 1.K8S集群升級(jí) 2.環(huán)境 3.升級(jí)策略 4.master1節(jié)點(diǎn)遷移容器運(yùn)行時(shí)(docker → containerd)? 5.master2節(jié)點(diǎn)遷移容器運(yùn)行時(shí)(docker → containerd)? 6.node1節(jié)點(diǎn)容器運(yùn)行時(shí)遷移(docker → containerd)? 7.升級(jí)集群計(jì)劃(v1.23.14 →?v1.24.1) 8.升級(jí)master1節(jié)點(diǎn)版本(v1.24.1) 9.升級(jí)master2節(jié)點(diǎn)版本

    2024年02月03日
    瀏覽(38)
  • k8s(Kubernetes)中yaml文件快速閱讀理解

    k8s(Kubernetes)中yaml文件快速閱讀理解

    簡(jiǎn)言 ????????k8s yaml中文件內(nèi)容一般有kind類型之分,每種類型有不同的功能(一般用---符號(hào)隔開) 常見的kind類型: ????????(1)Endpoints:Endpoints可以把外部的鏈接到k8s系統(tǒng)中(可以理解為引用外部資源,如將一個(gè)外部mysql連接到k8s中) ????????(2)Service:部署一

    2024年02月21日
    瀏覽(18)
  • 云上攻防-云原生篇&;Kubernetes&;K8s安全&;API&;Kubelet未授權(quán)訪問&;容器執(zhí)行

    云上攻防-云原生篇&;Kubernetes&;K8s安全&;API&;Kubelet未授權(quán)訪問&;容器執(zhí)行

    curl -XPOST -k “https://192.168.139.132:10250/run///” -d “cmd=id” 執(zhí)行的命令是test03容器里的命令,需要進(jìn)行容器逃逸。 1、攻擊8080端口:API Server(Master)未授權(quán)訪問 舊版本的k8s的API Server默認(rèn)會(huì)開啟兩個(gè)端口:8080和6443。 6443是安全端口,安全端口使用TLS加密;但是8080端口無(wú)需認(rèn)證,

    2024年04月22日
    瀏覽(71)
  • 【云原生--K8S】 yaml文件部署Mysql數(shù)據(jù)庫(kù)(一)

    【云原生--K8S】 yaml文件部署Mysql數(shù)據(jù)庫(kù)(一)

    在Linux系統(tǒng)下部署Mysql數(shù)據(jù)庫(kù),大家都比較熟悉,輕車熟路。但是如何在K8S環(huán)境部署Mysql數(shù)據(jù)庫(kù),卻是一個(gè)全新的課題,涉及到數(shù)據(jù)的存儲(chǔ)與同步,遠(yuǎn)比想像的復(fù)雜,下面我們將花幾篇文章來(lái)詳細(xì)探討一下這個(gè)問題。本篇主要介紹如何通過yaml文件部署mysql,如何進(jìn)入docker容器操

    2023年04月23日
    瀏覽(565)
  • 【云原生-K8s】檢查yaml文件安全配置kubesec部署及使用

    【云原生-K8s】檢查yaml文件安全配置kubesec部署及使用

    基礎(chǔ)描述 Kubesec 是一個(gè)開源項(xiàng)目,旨在為 Kubernetes 提供安全特性。它提供了一組工具和插件,用于保護(hù)和管理在 Kubernetes 集群中的工作負(fù)載和基礎(chǔ)設(shè)施。Kubesec 的目標(biāo)是幫助開發(fā)人員和運(yùn)維人員在 Kubernetes 環(huán)境中實(shí)現(xiàn)安全性、可靠性和合規(guī)性。 特點(diǎn) 自動(dòng)化的安全策略:Kubes

    2024年02月05日
    瀏覽(97)
  • 人人都會(huì)Kubernetes(一):告別手寫K8s yaml,運(yùn)維效率提升500%

    人人都會(huì)Kubernetes(一):告別手寫K8s yaml,運(yùn)維效率提升500%

    隨著云計(jì)算的迅速發(fā)展,容器化技術(shù)已成為構(gòu)建和運(yùn)行分布式應(yīng)用程序的關(guān)鍵。而Kubernetes作為容器編排領(lǐng)域的佼佼者,已經(jīng)成為了云原生應(yīng)用的標(biāo)準(zhǔn)。它不僅簡(jiǎn)化了應(yīng)用程序的部署和管理,而且為開發(fā)者和運(yùn)維人員提供了一套全面的工具集,從容器編排、自動(dòng)擴(kuò)縮容、服務(wù)發(fā)

    2024年01月22日
    瀏覽(23)
  • 云原生Kubernetes:K8S概述

    云原生Kubernetes:K8S概述

    目錄 一、理論 1.云原生 2.K8S 3.k8s集群架構(gòu)與組件 4.K8S網(wǎng)絡(luò) 二、總結(jié) (1)概念 云原生是一種基于容器、微服務(wù)和自動(dòng)化運(yùn)維的軟件開發(fā)和部署方法。它可以使應(yīng)用程序更加高效、可靠和可擴(kuò)展,適用于各種不同的云平臺(tái)。 如果要更直接通俗的來(lái)解釋下上面的概念,云原生更

    2024年02月10日
    瀏覽(34)
  • 【云原生 ? Kubernetes】認(rèn)識(shí) k8s、k8s 架構(gòu)、核心概念點(diǎn)介紹

    【云原生 ? Kubernetes】認(rèn)識(shí) k8s、k8s 架構(gòu)、核心概念點(diǎn)介紹

    目錄 一、Kubernetes 簡(jiǎn)介 二、Kubernetes 架構(gòu) 三、Kunbernetes 有哪些核心概念? 1. 集群 Cluster 2. 容器 Container 3. POD 4. 副本集 ReplicaSet 5. 服務(wù) service 6. 發(fā)布 Deployment 7. ConfigMap/Secret 8. DaemonSet 9. 核心概念總結(jié) Kubernetes 簡(jiǎn)稱 k8s,是支持云原生部署的一個(gè)平臺(tái),起源于谷歌。谷歌早在十幾

    2024年02月03日
    瀏覽(859)
  • 【云原生 ? Kubernetes】認(rèn)識(shí) k8s 網(wǎng)絡(luò)、外部網(wǎng)絡(luò)訪問 k8s 內(nèi)部服務(wù)

    【云原生 ? Kubernetes】認(rèn)識(shí) k8s 網(wǎng)絡(luò)、外部網(wǎng)絡(luò)訪問 k8s 內(nèi)部服務(wù)

    目錄 一、認(rèn)識(shí) Kubernetes 網(wǎng)絡(luò) 二、外部網(wǎng)絡(luò)如何訪問 k8s 內(nèi)部服務(wù) 1. NodePort 2. Load Balancer 3. Ingress Kubernetes 最底層的網(wǎng)絡(luò)為節(jié)點(diǎn)網(wǎng)絡(luò),用來(lái)保證 k8s 集群的節(jié)點(diǎn)(master 和 worker、worker 節(jié)點(diǎn)之間)能夠做正常的 IP 尋址和通訊。 Kubernetes 第二層網(wǎng)絡(luò)就是 Pod 網(wǎng)絡(luò),構(gòu)建于節(jié)點(diǎn)網(wǎng)絡(luò)之上

    2024年01月16日
    瀏覽(106)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包