在Azure Container Service創建Kubernetes(k8s)群集運行ASP.NET Core跨平台應用程序


引子

在此前的一篇文章中,我介紹了如何在本地docker環境中運行ASP.NET Core跨平台應用程序(http://www.cnblogs.com/chenxizhang/p/7148657.html),看起來非常不錯,不是嗎?那么,如果我們希望真正在實際的生產環境去部署和運行這個應用程序,應該怎么做呢?

通常來說,有兩種方案可以選擇

1. 在目標運行環境(可以是本地的服務器,也可以是雲端)申請虛擬機,然后啟用docker運行這些應用程序,所有的細節都可以(也必須)由你自己控制。

2. 使用雲平台的PaaS服務,尤其是支持容器化的雲平台的PaaS服務,這里面就包括了Azure Container Service,簡稱ACS。這種情況下,你可以將一些底層的細節工作交給Azure,而將你的精力專注在業務應用上面即可。


ACS簡介

Azure 容器服務讓創建、配置和管理預配置來運行容器化應用程序的虛擬機群集變得更簡單。 它使用熱門開源計划和業務流程工具的優化配置。 通過此服務,用戶可使用現有技能或利用不斷增加的大量社區專業知識,在 Microsoft Azure 上部署和管理基於容器的應用程序。請參考下面的鏈接了解一些細節,包括快速進行動手實驗

https://docs.microsoft.com/zh-cn/azure/container-service/ 


發布本地的docker鏡像

其實,不管是你用哪種方案,一個前提條件是將你本地的鏡像發布到一個公共可以訪問的倉庫。你可以發布到hub.docker.com,也可以發布到自己的倉庫。

如果要發布到hub.docker.com,請參考下面的步驟

1. 你需要擁有一個Docker ID。請前往https://hub.docker.com/注冊。

2.在本地將鏡像打上自己的tag。例如我的鏡像是mvcapp,我的Docker ID是chenxizhang,那么要能發布到Docker Hub的話,這個鏡像需要打上一個Tag,名稱為chenxizhang/mvcapp。請通過這個命令來完成此操作:docker tag mvcapp chenxizhang/mvcapp

你無需擔心,其實打上Tag,只是一個邏輯上面的映射,並不會增加本地的存儲占用空間。

image

3.使用docker login 命令 登陸hub.docker.com

4.使用docker push chenxizhang/mvcapp 這樣的命令,將本地的鏡像推送到hub.docker.com ,這可能需要一定的時間,取決於你的網絡配置

如果一切順利的話,你將可以看到如下的結果

image


備注:如果要創建自己的docker 倉庫,可以了解  Azure Container Registry 這個服務。(https://azure.microsoft.com/zh-cn/services/container-registry/),這里不做展開。


在Azure Container Service創建 Kubernetes群集


你可以完全參考這篇入門文章(https://docs.microsoft.com/zh-cn/azure/container-service/container-service-kubernetes-walkthrough),通過幾個簡單的命令創建Kubernetes群集


1. az group create

2.az acs create

3.az acs kubernetes install-cli (這一步是可選的,如果是在azure cloudshell中可以省略)

4.az acs kubernetes get-credentials

5.kubectl get nodes (請等待各個節點的Status值變成Ready)



在k8s群集中部署ASP.NET Core應用程序


我們已經有了一個公共可以訪問的鏡像,同時也有了一個容器的集群。下面就能看看怎么樣讓這個應用在k8s群集中部署和運行起來了。

實際上,很簡單。(當然,這只是入門級的演示,每個命令都還有很多細節可以調整)


1.通過kubectl run 命令指定要拉取的鏡像,並且通過設置一定的參數將其運行起來。k8s的術語將這個過程稱為創建一個部署(deployment)

kubectl run mvcapp --image chenxizhang/mvcapp --env="ASPNETCORE_URLS=http://+:80"


2. 將這個部署通過某種方式暴露給外部可以訪問

kubectl export deployments mvcapp --port=80 --type=LoadBalance


3.查看服務狀態,直到EXTERNAL-IP有返回具體的值,這就表示容器已經創建並且運行起來了。

kubectl get svc

image

4. 通過這個外部的IP地址就可以訪問到你的應用

image


其他有意思的信息和控制項

如果將應用部署到ACS只是這樣的功能,當然沒有什么可以值得稱贊的,實際上ACS的最大價值是提供了一個強大的容器運行平台,它可以幫助開發人員完成很多細節的工作,包括擴展和收縮容器規模等等。下面是一些有意思的信息和控制項

1. 通過kubectl get deploy可以查看關於每個部署的一些細節信息

image

2.通過kubectl get rs 可以獲取到每個部署相關的復制集(replicas)

image

3.通過kubectl scale 命令可以指定針對某個應用要運行幾個容器

kubectl scale --replicas=3 rs/mvcapp-1456147153

image

備注:實際上在kubectl run的時候,就可以指定要同時運行的容器數量,同時,如果你願意,也可以設置為autoscale(自動擴展)


免責聲明!

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



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