引子在此前的一篇文章中,我介紹瞭如何在本地docker環境中運行ASP.NET Core跨平臺應用程式(http://www.cnblogs.com/chenxizhang/p/7148657.html),看起來非常不錯,不是嗎?那麼,如果我們希望真正在實際的生產環境去部署和運行這個應用程式,應該怎... ...
引子
在此前的一篇文章中,我介紹瞭如何在本地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,只是一個邏輯上面的映射,並不會增加本地的存儲占用空間。
3.使用docker login 命令 登陸hub.docker.com
4.使用docker push chenxizhang/mvcapp 這樣的命令,將本地的鏡像推送到hub.docker.com ,這可能需要一定的時間,取決於你的網路配置
如果一切順利的話,你將可以看到如下的結果
備註:如果要創建自己的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
4. 通過這個外部的IP地址就可以訪問到你的應用
其他有意思的信息和控制項
如果將應用部署到ACS只是這樣的功能,當然沒有什麼可以值得稱贊的,實際上ACS的最大價值是提供了一個強大的容器運行平臺,它可以幫助開發人員完成很多細節的工作,包括擴展和收縮容器規模等等。下麵是一些有意思的信息和控制項
1. 通過kubectl get deploy可以查看關於每個部署的一些細節信息
2.通過kubectl get rs 可以獲取到每個部署相關的複製集(replicas)
3.通過kubectl scale 命令可以指定針對某個應用要運行幾個容器
kubectl scale --replicas=3 rs/mvcapp-1456147153
備註:實際上在kubectl run的時候,就可以指定要同時運行的容器數量,同時,如果你願意,也可以設置為autoscale(自動擴展)