日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

.Net Core In Docker 在容器内编译并发布

發布時間:2023/12/4 asp.net 65 豆豆
生活随笔 收集整理的這篇文章主要介紹了 .Net Core In Docker 在容器内编译并发布 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Docker可以說是現在微服務,DevOps的基礎,咱們.Net Core自然也得上Docker。.Net Core發布到Docker容器的教程網上也有不少,但是今天還是想來寫一寫。
你搜.Net core程序發布到Docker網上一般常見的有兩種方案:

  • 1、在本地編譯成Dll文件后通過SCP命令或者WinSCP等工具上傳到服務器上,然后構建Docker鏡像再運行容器。該方案跟傳統的發布很像,麻煩的地方是每次都要打開相關工具往服務器上復制文件。

  • 2、在服務端直接通過Git獲取最新源代碼后編譯成Dll然后構建Docker鏡像再運行容器。該方案免去了往服務器復制文件這步操作,但是服務器環境需要安裝.Net Core SDK 來編譯源代碼。
    自從用了Docker簡直懶的不能自理,我既不想手工復制文件到服務器,也不想在服務器裝.Net Core環境。顯然只要Docker鏡像包含.Net Core SDK環境就可以在Docker內幫我們編譯代碼然后運行,這樣連我們的服務器都不用裝啥.Net Core的環境拉。

在Docker內編譯發布.Net Core程序并運行

新建一個Asp.net Core MVC項目

我們使用一個Asp.net Core MVC程序來演示如何發布到Docker并運行。
使用vs新建一個Asp.net core mvc項目

public class HomeController : Controller{public IActionResult Index(){return Content($"Core for docker , {DateTime.Now} , verson 2");}}

修改HomeController下的index Action,直接輸出一段文字

public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>WebHost.CreateDefaultBuilder(args).UseKestrel(op =>{op.ListenAnyIP(5000);}).UseStartup<Startup>();

修改Program下的CreateWebHostBuilder方法,讓Kestrel監聽5000端口


本地運行一下試試

推送源碼到代碼倉庫

把我們的代碼推送到對應的Git倉庫,方便我們從部署服務器上直接拉取最新的代碼。

X:\workspace\CoreForDocker>git remote add origin https://gitee.com/kklldog/CoreForDocker.git X:\workspace\CoreForDocker>git push -u origin master Username for 'https://gitee.com': xxx@gmail.com Password for 'https://xxx@gmail.com@gitee.com': Counting objects: 88, done. Delta compression using up to 4 threads. Compressing objects: 100% (83/83), done. Writing objects: 100% (88/88), 527.07 KiB | 2.43 MiB/s, done. Total 88 (delta 7), reused 0 (delta 0) remote: Powered By Gitee.com To https://gitee.com/kklldog/CoreForDocker.git* [new branch] master -> master Branch 'master' set up to track remote branch 'master' from 'origin'.

添加Dockerfile文件

在CoreForDocker下新增一個Dockerfile文件,注意沒有任何擴展名。我們需要基于microsoft/dotnet:latest這個鏡像構建一個新的鏡像。并且在構建的過程中直接對源碼進行編譯并發布。

FROM microsoft/dotnet:latest WORKDIR /app COPY /. /app RUN dotnet restore RUN dotnet publish -o /out -c Release EXPOSE 5000 ENTRYPOINT ["dotnet", "/out/CoreForDocker.dll"]

大概解釋下Dockerfile的意思:
FROM microsoft/dotnet:latest:使用dotnet的最新鏡像,這個鏡像其實對應的應該就是2.2-sdk這個鏡像,里面包含了dotnet-core 2.2 sdk
WORKDIR /app:指定工作目錄為app
COPY /. /app:復制宿主機當前目錄的內容到容器的app文件夾
RUN dotnet restore:還原nuget包
RUN dotnet publish -o /out -c Release:編譯并發布程序集到容器的out目錄
EXPOSE 5000:暴露5000端口
ENTRYPOINT ["dotnet", "/out/CoreForDocker.dll"]:容器啟動的時候執行dotnet命令,參數為/out/CoreForDocker.dll

Dockerfile的文件屬性設置為始終復制
新建好Dockerfile后git push到代碼倉庫。

在服務器上構建Docker鏡像

這里以Ubuntu為例,ssh登錄到服務器后使用git clone命令拉取源代碼。

git clone https://gitee.com/kklldog/CoreForDocker.git

進入源碼目錄

cd CodeForDocker\CodeForDocker

使用docker build命令構建新的鏡像,注意不要忘記最后一個'.'

docker build -t image_code4docker .

運行容器

如果以上步驟都沒有報錯,那么恭喜你鏡像已經構建成功了,我們可以使用此鏡像運行Docker容器了。

docker run -d --name code4docker -p 5000:5000 -v /ect/localtime:/ect/localtime image_core4docker

使用image_core4docker鏡像運行一個名為core4docker的容器,綁定宿主機的5000到容器的5000口。其中需要注意的是-v參數映射宿主機的/ect/localtime文件夾到容器的/ect/localtime文件夾,因為經過實踐發現容器中的時區有可能跟宿主機不一致,需要映射宿主機的/ect/localtime讓容器的時區跟宿主機保持一致。


訪問一下服務器的5000端口,發現能夠正確返回數據表示我們的Asp.net Core程序在容器中運行成功了

以后當我們對源碼進行修改,并提交后,我們只需在服務器上拉取最新的代碼然后使用docker build,docker run命令來再次生成鏡像并運行容器。但是手工輸入docker build,docker run的命令好像也很麻煩,參數又那么多,太煩了。

使用shell腳本簡化操作

為了偷懶不想敲那么長的命令,我們可以構建一個腳本,把命令一次性寫好,以后只要運行一次腳本就可以了。
使用vim新建一個publish.sh的文件

vim publish.sh

鍵盤上按i進入編輯模式,輸入以下內容

cd CoreForDocker/CoreForDocker git pull docker stop core4docker docker rm core4docker docker rmi image_core4docker docker build -t image_core4docker . docker run --name core4docker -d -p 5000:5000 -v /etc/localtime:/etc/localtime image_core4docker

以上命令,不光有新建鏡像跟運行容器的命令,還有移除原來的容器跟鏡像的命令
按ecs進入命令模式,退出保存

:wq

讓我們模擬修改一下源代碼,并提交到代碼倉庫

public IActionResult Index(){return Content($"Core for docker , {DateTime.Now} , version 2");}

再次修改homecontroller的index action,輸出內容上新增一個version
ssh登錄到服務器,運行publish.sh文件

/bin/bash publish.sh


跑完之后我們再次訪問下服務器的5000口,數據返回正確,表示服務器上跑的已經是最新的程序了

總結

通過以上演示我們基本了解如何通過git跟docker配合在Ubuntu服務器上不安裝.Net Core SDK來發布.Net Core 程序到容器中運行,并且通過shell腳本的方式再次簡化發布。但是盡管這樣每次發布都需要ssh到服務器上然后運行腳本,特別是開發環境可能經常需要發布,還是覺得麻煩。有沒有什么辦法讓我們push代碼后服務器自動就開始部署最新的代碼的到容器中運行了呢?
后面我會介紹下如何通過jenkins跟webhook來做CICD。

總結

以上是生活随笔為你收集整理的.Net Core In Docker 在容器内编译并发布的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。