k8s(two)

1.k8s常用的資源

k8s yaml的主要組成

apiVersion: v1  api版本
kind: pod   資源類型
metadata:   屬性
spec:       詳細(xì)

k8s_pod.yaml

apiVersion: v1
kind: Pod
metadata:
  name: nginx
  labels:
    app: web
spec:
  containers:
    - name: nginx
      image: 10.0.0.11:5000/nginx:1.13
      ports:
        - containerPort: 80
1.構(gòu)建命令
kubectl create -f k8s_pod.yaml
2.查看狀態(tài)
kubectl get pod nginx -o wide
3.描述pod狀態(tài)
kubectl  describe  pod  nginx
4.刪除pod
kubectl  delete   pod  nginx   或者kubectl delete  -f  xxx.yaml
5.編輯pod的配置
kubectl  edit  pod   nginx

這里需要注意的是構(gòu)建會(huì)失敗,因?yàn)閺墓?jié)點(diǎn)下載pod-infrastructure鏡像是從官網(wǎng)衡便,需要紅帽證書,所以我們用下載好的上傳到本地自己的鏡像倉(cāng)庫(kù)谁撼。

改變兩個(gè)從節(jié)點(diǎn)
vim /etc/kubernetes/kubelet
# pod infrastructure container
KUBELET_POD_INFRA_CONTAINER="--pod-infra-container-i
mage=10.0.0.11:5000/pod-infrastructure:latest"

systemctl restart kubelet

pod資源:至少由兩個(gè)容器組成,pod基礎(chǔ)容器和業(yè)務(wù)容器組成

pod配置文件2:

apiVersion: v1
kind: Pod
metadata:
  name: test
  labels:
    app: web
spec:
  containers:
    - name: nginx
      image: 10.0.0.11:5000/nginx:1.13
      ports:
        - containerPort: 80
    - name: busybox
      image: 10.0.0.11:5000/busybox:latest
      command: ["sleep","10000"]

pod是k8s最小的資源單位

2.ReplicationController資源

rc:保證指定數(shù)量的pod始終存活,rc通過(guò)標(biāo)簽選擇器來(lái)關(guān)聯(lián)pod
創(chuàng)建一個(gè)rc.yaml文件

apiVersion: v1
kind: ReplicationController
metadata:
  name: nginx
spec:
  replicas: 5
  selector:
    app: myweb
  template:
    metadata:
      labels:
        app: myweb
    spec:
      containers:
      - name: myweb
        image: 10.0.0.11:5000/nginx:1.13
        ports:
        - containerPort: 80

rc的滾動(dòng)升級(jí) 新建一個(gè)nginx-rc1.15.yaml


image.png
升級(jí)
kubectl rolling-update nginx -f nginx-rc1.15.yaml --update-period=10s

回滾
kubectl rolling-update nginx2 -f nginx-rc.yaml --update-period=1s

3. service資源

image.png

service幫助pod暴露端口

創(chuàng)建一個(gè)service

apiVersion: v1
kind: Service
metadata:
  name: myweb
spec:
  type: NodePort  #ClusterIP
  ports:
    - port: 80          #clusterIP
      nodePort: 30000   #nodeport
      targetPort: 80    #podport
  selector:
    app: myweb
#生成svc
kubectl create -f k8s_svc.yaml 

#查看svc的兩種方法
kubectl get svc 
kubectl get service

#查看所有資源類型
kubectl get all -o wide

#確保標(biāo)簽一樣避咆,修改為myweb
kubectl edit svc myweb
    app: myweb
標(biāo)簽需要確保一樣,必須包竹,很重要Q嗫帷<!
#查看端口是否暴露成功
kubectl describe svc myweb

如何驗(yàn)證它的負(fù)載均衡呢苗缩?

方法一:
#修改副本數(shù)
kubectl scale rc nginx --replicas=2
方法二:
#進(jìn)入容器
kubectl exec -it pod_name /bin/bash
#k8s進(jìn)入容器的方法
[root@k8s-master svc]# kubectl exec -it nginx-5mf4r /bin/bash
root@nginx-5mf4r:/# echo '11111' >/usr/share/nginx/html/index.html 
root@nginx-5mf4r:/# exit

[root@k8s-master svc]# kubectl exec -it nginx-ppjb3 /bin/bash
root@nginx-ppjb3:/# echo '2222' >/usr/share/nginx/html/index.html 
root@nginx-ppjb3:/# exit

添加隨機(jī)端口
[root@k8s-master svc]# vim /etc/kubernetes/apiserver
KUBE_API_ARGS="--service-node-port-range=3000-50000"
[root@k8s-master svc]# systemctl restart kube-apiserver.service

service默認(rèn)使用iptables來(lái)實(shí)現(xiàn)負(fù)載均衡, k8s 1.8新版本中推薦使用lvs(四層負(fù)載均衡)

4.deployment資源

有rc在滾動(dòng)升級(jí)之后,會(huì)造成服務(wù)訪問(wèn)中斷,于是k8s引入了deployment資源

創(chuàng)建deployment

1饵蒂、編輯deploy的yaml文件
cat k8s_deploy.yaml
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 3
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: 10.0.0.11:5000/nginx:1.13
        ports:
        - containerPort: 80
        resources:
          limits:
            cpu: 100m
          requests:
            cpu: 100m
2.編輯實(shí)現(xiàn)負(fù)載的yaml文件
cat k8s_svc.yaml
apiVersion: v1
kind: Service
metadata:
  name: nginx-deployment 
spec:
  type: NodePort  #ClusterIP
  ports:
    - port: 80          #clusterIP
      nodePort: 30001   #nodeport
      targetPort: 80    #podport
  selector:
    app: nginx

方法一:
deployment升級(jí)和回滾

命令行創(chuàng)建deployment

kubectl run   nginx  --image=10.0.0.11:5000/nginx:1.13 --replicas=3 --record

命令行升級(jí)版本

kubectl set image deploy nginx nginx=10.0.0.11:5000/nginx:1.15

查看deployment所有歷史版本

kubectl rollout history deployment nginx

deployment回滾到上一個(gè)版本

kubectl rollout undo deployment nginx

deployment回滾到指定版本

kubectl rollout undo deployment nginx --to-revision=2
方法二:
#修改配置文件中的此行改為nginx 1.15
[root@k8s-master deploy]# kubectl edit deployment nginx-deployment
      - image: 10.0.0.11:5000/nginx:1.15

5.tomcat+mysql練習(xí)

在k8s中容器之間相互訪問(wèn),通過(guò)VIP地址!

1.上傳配置
[root@k8s-master tomcat_demo]# ll
total 16
-rw-r--r-- 1 root root 416 Jan 13 22:46 mysql-rc.yml
-rw-r--r-- 1 root root 145 Jan 13 22:29 mysql-svc.yml
-rw-r--r-- 1 root root 492 Jan 13 23:37 tomcat-rc.yml
-rw-r--r-- 1 root root 162 Jan 13 22:17 tomcat-svc.yml
2.創(chuàng)建
先創(chuàng)建mysql
kubectl create -f mysql-rc.yml
kubectl create -f mysql-svc.yml
kubectl get all -o wide查看mysql虛擬ip
vim tomcat-rc.yml
          - name: MYSQL_SERVICE_HOST
            value: '10.254.146.149'
更改ip
kubectl create -f  tomcat-rc.yml
kubectl create -f tomcat-svc.yml
kubectl get all -o wide
啟動(dòng)成功后登陸
image.png
image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市酱讶,隨后出現(xiàn)的幾起案子退盯,更是在濱河造成了極大的恐慌,老刑警劉巖浴麻,帶你破解...
    沈念sama閱讀 211,817評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件得问,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡软免,警方通過(guò)查閱死者的電腦和手機(jī)宫纬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)膏萧,“玉大人漓骚,你說(shuō)我怎么就攤上這事¢环海” “怎么了蝌蹂?”我有些...
    開封第一講書人閱讀 157,354評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)曹锨。 經(jīng)常有香客問(wèn)我孤个,道長(zhǎng),這世上最難降的妖魔是什么沛简? 我笑而不...
    開封第一講書人閱讀 56,498評(píng)論 1 284
  • 正文 為了忘掉前任齐鲤,我火速辦了婚禮,結(jié)果婚禮上椒楣,老公的妹妹穿的比我還像新娘给郊。我一直安慰自己,他們只是感情好捧灰,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評(píng)論 6 386
  • 文/花漫 我一把揭開白布淆九。 她就那樣靜靜地躺著,像睡著了一般毛俏。 火紅的嫁衣襯著肌膚如雪炭庙。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,829評(píng)論 1 290
  • 那天煌寇,我揣著相機(jī)與錄音焕蹄,去河邊找鬼。 笑死唧席,一個(gè)胖子當(dāng)著我的面吹牛擦盾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播淌哟,決...
    沈念sama閱讀 38,979評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼迹卢,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了徒仓?” 一聲冷哼從身側(cè)響起腐碱,我...
    開封第一講書人閱讀 37,722評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎掉弛,沒(méi)想到半個(gè)月后症见,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,189評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡殃饿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評(píng)論 2 327
  • 正文 我和宋清朗相戀三年谋作,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片乎芳。...
    茶點(diǎn)故事閱讀 38,654評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡遵蚜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出奈惑,到底是詐尸還是另有隱情吭净,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布肴甸,位于F島的核電站寂殉,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏原在。R本人自食惡果不足惜友扰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望晤斩。 院中可真熱鬧焕檬,春花似錦、人聲如沸澳泵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)兔辅。三九已至腊敲,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間维苔,已是汗流浹背碰辅。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留介时,地道東北人没宾。 一個(gè)月前我還...
    沈念sama閱讀 46,382評(píng)論 2 360
  • 正文 我出身青樓凌彬,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親循衰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子铲敛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容

  • 在實(shí)踐之前,必須先學(xué)習(xí)k8s的幾個(gè)重要概念会钝,它們是組成k8s集群的基石伐蒋。 1. Cluster Cluster是計(jì)...
    wangfs閱讀 837評(píng)論 0 0
  • k8s容器編排 [TOC] 1:k8s集群的安裝 1.1 k8s的架構(gòu) 除了核心組件,還有一些推薦的Add-ons...
    Zh_bd92閱讀 904評(píng)論 0 0
  • 1.Pod Pod是k8s的最基本的操作單元迁酸,包含一個(gè)或多個(gè)緊密相關(guān)的容器先鱼,類似于豌豆莢的概念。一個(gè)Pod可以被一...
    jony456123閱讀 7,401評(píng)論 0 5
  • k8s的架構(gòu) kubernetes集群核心組件 k8s集群的安裝 官方文檔 環(huán)境準(zhǔn)備 做一些基礎(chǔ)的優(yōu)化后拍攝快照并...
    酷酷的偉閱讀 1,980評(píng)論 0 15
  • 1. 介紹 Kubernetes(k8s)是自動(dòng)化容器操作的開源平臺(tái)奸鬓,這些操作包括部署焙畔,調(diào)度和節(jié)點(diǎn)集群間擴(kuò)展。 K...
    愛學(xué)習(xí)的ren閱讀 1,240評(píng)論 0 0