<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          利用阿里云免費(fèi)鏡像倉庫,實(shí)現(xiàn)微服務(wù)的k8s部署

          共 6545字,需瀏覽 14分鐘

           ·

          2021-09-08 00:07


          今天的內(nèi)容給大家介紹下如何利用阿里云提供的免費(fèi)私人容器鏡像服務(wù),來實(shí)現(xiàn)對(duì)個(gè)人項(xiàng)目容器鏡像的管理,以及通過k8s集群來發(fā)布阿里云私人容器鏡像服務(wù)中管理的服務(wù)。本文適合個(gè)人及創(chuàng)業(yè)團(tuán)隊(duì)學(xué)習(xí)/使用基于容器、鏡像倉庫、k8s等云原生技術(shù)時(shí)的參考。



          創(chuàng)建阿里云個(gè)人版容器鏡像實(shí)例


          一般來說大型企業(yè)都會(huì)自己搭建內(nèi)部私有鏡像倉庫(例如Harbor),但對(duì)于小公司來說也可以直接使用云服務(wù)提供的容器鏡像服務(wù)。接下來以阿里云免費(fèi)提供的個(gè)人版容器鏡像服務(wù),演示容器鏡像服務(wù)的具體使用。步驟如下:


          (1)、登錄阿里云,點(diǎn)擊->控制臺(tái)->找到“容器鏡像服務(wù)”,如下圖所示:



          如果入口比較難找,可以直接在阿里云搜索框搜索“容器鏡像服務(wù)”。阿里云提供收費(fèi)的企業(yè)版實(shí)例,也提供限制使用的個(gè)人版實(shí)例。這里選擇個(gè)人版實(shí)例。


          (2)、創(chuàng)建成功后,設(shè)置鏡像倉庫登陸密碼。如下圖所示:



          提示:
          設(shè)置一個(gè)自己能記住的密碼,例如我這里設(shè)置的是“wudimanong”。

          (3)密碼設(shè)置成功后,點(diǎn)擊“創(chuàng)建鏡像倉庫”,最終效果如下圖所示:




          選擇本地倉庫,后面通過本地構(gòu)建直接將Docker鏡像推送至阿里云私有鏡像倉庫。



          之后就可以根據(jù)提示登錄該阿里云鏡像倉庫,并向其中Push鏡像了。



          配置k8s集群與鏡像倉庫的連接


          創(chuàng)建私有鏡像倉庫之后,為了安全設(shè)置了用戶名及密碼,如果k8s集群需要從鏡像倉庫拉取鏡像,則每次都需要登陸是很麻煩的,所以可以進(jìn)行相關(guān)設(shè)置。


          Kubernetes 集群使用 docker-registry 類型的 Secret 來通過容器倉庫的身份驗(yàn)證,進(jìn)而提取私有映像。


          創(chuàng)建Secret,命名為 regcred:


          # kubectl create secret docker-registry regcred  --docker-server=registry.cn-hangzhou.aliyuncs.com --docker-username=jqadmin --docker-password=wudimanong
          secret/regcred created


          提示:
          上述賬號(hào)密碼為你自己創(chuàng)建鏡像倉庫時(shí)設(shè)置的。



          打包Docker鏡像


          打包Docker鏡像需要編寫Dockerfile文件,可以參考相關(guān)資料。這里我寫了一個(gè)Java項(xiàng)目可以參考,通過工程構(gòu)建就能直接將Docker鏡像打包。


          項(xiàng)目地址(GitHub):

          https://github.com/manongwudi/springboot-k8s-demo


          下載項(xiàng)目后本地可以編譯構(gòu)建,完成后打包的本地鏡像如下圖所示:




          將鏡像上傳至阿里云私有鏡像倉庫


          接下來演示登錄阿里云私有鏡像倉庫,并將本地構(gòu)建的Docker容器鏡像上傳。步驟如下:


          (1)本地登陸阿里云鏡像倉庫(本地需要安裝Docker環(huán)境),命令如下:

          $ docker login --username=jqadmin registry.cn-hangzhou.aliyuncs.com
          Password: 
          Login Succeeded


          提示:
          賬號(hào)密碼為創(chuàng)建阿里云倉庫時(shí)設(shè)置的


          (2)將前面構(gòu)建的Docker鏡像上傳至阿里云私有倉庫。命令如下:

          $ docker push registry.cn-hangzhou.aliyuncs.com/wudimanong/springboot-k8s-demo:latest
          The push refers to repository [registry.cn-hangzhou.aliyuncs.com/wudimanong/springboot-k8s-demo]
          500e5779c8d2: Pushed 
          925523484e00: Pushed 
          344fb4b275b7: Pushed 
          bcf2f368fe23: Pushed 
          latest: digest: sha256:ba3930f5374ed4cfd2c39cb590c3f772c89cd73abe7bd321838fd453d11309fe size: 1159


          (3)此時(shí)回到阿里云倉庫的界面,就能看到上傳的鏡像了,如下圖所示:




          將阿里云鏡像倉庫的鏡像發(fā)布至k8s集群


          接下來演示,如何將已經(jīng)上傳阿里云私有鏡像倉庫的服務(wù)發(fā)布至k8s集群,這里需要在k8s發(fā)布文件中進(jìn)行一些配置。具體如下:


          (1)創(chuàng)建發(fā)布文件。

          vim springboot-k8s-demo.yaml

          apiVersion: apps/v1
          kind: Deployment
          metadata:
            name: springboot-k8s-demo
          spec:
            selector:
              matchLabels:
                app: springboot-k8s-demo
            replicas: 1
            #設(shè)置滾動(dòng)升級(jí)策略
            #Kubernetes在等待設(shè)置的時(shí)間后才開始進(jìn)行升級(jí),例如5s
            minReadySeconds: 5
            strategy:
              type: RollingUpdate
              rollingUpdate:
                #在升級(jí)過程中最多可以比原先設(shè)置多出的Pod數(shù)量
                maxSurge: 1
                #在升級(jí)過程中Deployment控制器最多可以刪除多少個(gè)舊Pod,主要用于提供緩沖時(shí)間
                maxUnavailable: 1
            template:
              metadata:
                labels:
                  app: springboot-k8s-demo
              spec:
                #設(shè)置的阿里云私有鏡像倉庫登陸信息的secret(對(duì)應(yīng)2.1.2的設(shè)置)
                imagePullSecrets:
                - name: regcred

                containers:
                  - name: springboot-k8s-demo
                    image: registry.cn-hangzhou.aliyuncs.com/wudimanong/springboot-k8s-demo:latest
                    env:
                      - name: SERVER_PORT
                        value: "8080"
                      - name: SPRING_PROFILES_ACTIVE
                        value: test
          ---
          apiVersion: v1
          kind: Service
          metadata:
            name: springboot-k8s-demo
            labels:
              svc: springboot-k8s-demo
          spec:
            selector:
              app: springboot-k8s-demo
            ports:
              - name: http
                #Service在集群中暴露的端口(用于Kubernetes服務(wù)間的訪問)
                port: 8080
                #Pod上的端口(與制作容器時(shí)暴露的端口一致,在微服務(wù)工程代碼中指定的端口)
                targetPort: 8080
                #K8s集群外部訪問的端口(外部機(jī)器訪問)
                nodePort: 30002
            type: NodePort


          標(biāo)紅的部分,就是設(shè)置k8s對(duì)阿里云容器鏡像倉庫的連接——使用存儲(chǔ)在"secret"資源中的鏡像倉庫的賬號(hào)及密碼。


          (2)執(zhí)行發(fā)布命令。

          # kubectl apply -f springboot-k8s-demo.yaml 
          deployment.apps/springboot-k8s-demo created
          service/springboot-k8s-demo created


          (3)查看并測試應(yīng)用部署是否成功。

          # kubectl get po -o wide
          NAME                                   READY   STATUS    RESTARTS   AGE   IP              NODE       NOMINATED NODE   READINESS GATES
          springboot-k8s-demo-7f7f8db4cc-hd8j2   1/1     Running   0          41s   10.201.17.147   k8s-node   <none>           <none>
          test-ds-nginx-qdj6n                    1/1     Running   0          80m   10.201.17.143   k8s-node   <none>           <none>


          可以看到,部署的Java應(yīng)用已經(jīng)成功啟動(dòng)。接下來模擬調(diào)用下該服務(wù)的測試接口:

          # curl 10.201.17.147:8080/devops/test
          自動(dòng)化發(fā)布示范工程測試接口返回->OK!


          可以成功訪問,說明應(yīng)用部署成功!



          —————END—————



          推薦閱讀

          Kubernetes集群搭建超詳細(xì)總結(jié)(CentOS版)

          干貨|如何步入Service Mesh微服務(wù)架構(gòu)時(shí)代

          實(shí)戰(zhàn)|Service Mesh微服務(wù)架構(gòu)實(shí)現(xiàn)服務(wù)間gRPC通信

          再見Nacos,我要玩Service Mesh了!

          Kubernetes微服務(wù)自動(dòng)化發(fā)布系統(tǒng)

          Kubernetes微服務(wù)監(jiān)控體系

          Kubernetes學(xué)習(xí)環(huán)境難搭建?Mac筆記本上安裝一個(gè)!

          瀏覽 84
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  开心五月激情看看 | 日本东京热综合久久 | 国产精品扒开腿 | 免费看逼片| 性爱无码视频 |