翻譯-在10行代碼之內創建容器化的.net core應用

来源:https://www.cnblogs.com/superaloha/archive/2019/07/08/11148867.html
-Advertisement-
Play Games

本文翻譯自Hans Kilian的文章 Creating a containerized .NET core application in less than 10 lines of code https://medium.com/@hkkilian/creating-a-containerized ...


本文翻譯自Hans Kilian的文章

Creating a containerized .NET core application in less than 10 lines of code

https://medium.com/@hkkilian/creating-a-containerized-net-core-application-in-less-than-10-lines-of-code-567f4572ef01

Docker的一個優勢是你可以在別人的容器之上創建你自己的容器。在這片文章我將向你展示怎麼快速得創建一個包含.net core應用的docker容器。

我們需要的僅僅只是一臺安裝了docker的機器,並且能連接上internet。

創建一個目錄並且在該目錄中創建一個文件“Dockerfile”。打開那個文件,粘貼一下的代碼行,並且保存。

FROM microsoft/dotnet:2.1-sdk AS build-env
WORKDIR /app
RUN dotnet new razor
RUN dotnet publish -c Release -o out
FROM microsoft/dotnet:2.1-aspnetcore-runtime-alpine
WORKDIR /app
COPY --from=build-env /app/out ./
ENTRYPOINT ["dotnet", "app.dll"]

在終端中執行命令 “docker build -t myapp .”

這行命令從當前目錄的Dockerfile文件創建了一個docker鏡像並且給這個鏡像取了一個名字叫做“myapp”的標簽。

然後我們就可以通過輸入命令“docker run -d -p 80:80 myapp”運行這個容器化的應用了。

然後當你打開你的瀏覽器並且導航到http://localhost/你將看到下麵顯示的屏幕:

這是怎麼運行的呢?

上邊的那個Dockerfile指定了多級構建,包含有兩個部分,每個部分四行。第一部分為要運行的應用生成並編譯了源碼,第二部分把編譯好的應用打包進一個我們能運行的容器中。多級構建在docker17.05中才開始有介紹,因此如果你要使用該特性的話你需要17.05或者更新的docker版本。

  • 第一行指出了我們將基於微軟提供的.NET core 2.1 SDK來構建我們想要的docker鏡像。我們給.NET core 2.1 SDK取個別名“build-env”,這在後邊會用到。
  • 第二行中我們創建了一個工作目錄“/app”。
  • 第三行中我們在上邊創建的目錄中執行命令“dotnet new razor”,這行命令使用Razor pages創建了一個基本的asp.net應用程式所需要的所有的源代碼。
  • 第四行中我們發佈上邊的應用到“out”目錄。全路徑是“/app/out”。“publish”命令足夠智能,它可以在發佈之前自動還原所需要的Nuget包並且進行編譯。

Dockerfile中的最後四行將發佈了的應用程式打包進一個只包含.net core運行時環境的docker鏡像中。當我們運行這個應用的時候完全沒有必要包含整個的sdk。我們想要運行的鏡像越小越好。

第一行我們首先指定我們想要開始構建一個跟上一個不一樣的docker鏡像。這次我們將會使用基於包含了ASP.NET core運行時環境的Alpine linux分支開始構建。Alpine是一個非常小的linux發行版本,並且被廣泛地使用與docker基礎鏡像中。

然後我們再次創建了一個工作目錄“/app”,這跟第一次創建的“/app”不是同一個目錄,因為我們現在正在構建一個新的docker鏡像。

然後我們從第一個創建的鏡像中複製應用的文件。“--from=build-env”選項指定了我們想要的是從第一個創建的鏡像中複製。我們從第一個創建的鏡像中複製了所有的“/app/out”目錄下的文件到當前的目錄/app

然後我們指定了容器的運行入口是dotnet 命令並且還要跟上參數“app.dll”。

當我們運行這個鏡像的時候,我們指定了幾個運行參數。第一個參數“-d”指定了該鏡像應該在後臺運行。第二個參數“-p 80:80”指定了容器中的80埠應該被映射到運行容器的機器的80埠上。如果你機器上的80埠被占用了,你可以使用其他埠進行映射。比如你想映射到運行docker的機器的8080埠,你可以使用“-p 8080:80”,然後你可以通過“http://localhost:8080/”訪問該應用。不管你映射到機器上的哪個埠,應用程式表現出來的是不變的,就像它一直使用的是80埠一樣。

你可以使用docker命令“docker ps”查看當前運行的docker鏡像。

你也可以使用“docker kill <name>”停止容器。

從這裡我們將要進一步學習些什麼?

當然了這不是一個有用的示例。為了讓示例更加接近實際,你可以很容易地改變這個例子去容器化一個自定義的c#工程項目。假設你有一個子目錄“code”,其中含有你的項目源碼,你可以替換“RUN dotnet new razor” 為“COPY ./code/ ./”,僅僅就改變這一行,你就可以構建你自定義的項目。或者你還可以從使用“git clone”命令從git上拉取項目。

在docker容器中構建你的解決方案的另外一個好處是你不需要擔心你電腦上安裝的sdk的版本衝突。如果你想嘗試NET core 2.2 preview,你可以很簡單地使用下邊的代碼來使用2.2 的SDK和2.2的 ASP.NET 運行時環境:

FROM microsoft/dotnet:2.2.100-preview3-sdk AS build-env
WORKDIR /app
RUN dotnet new razor
RUN dotnet publish -c Release -o out
FROM microsoft/dotnet:2.2.0-preview3-aspnetcore-runtime-alpine
WORKDIR /app
COPY --from=build-env /app/out ./
ENTRYPOINT [“dotnet”, “app.dll”]

如果你不喜歡這樣的結果(2.2 preview現在似乎沒有2.1好用),你不需要卸載任何的2.2的preview SDK,因為你的機器上從來沒有安裝過它。2.2 SDK僅僅只是安裝在docker鏡像之中的,僅僅只是下載下來並沒有運行,除非你要求運行該鏡像的時候。

如果你想查看其他的合適的.NET Docker鏡像,你可以從這裡開始https://hub.docker.com/r/microsoft/dotnet/

我希望這篇文章可以鼓勵你嘗試使用docker或者.NET core,如果你從來沒有嘗試過的話。添加一個類似PostgreSQL 資料庫將會非常簡單,因為這裡已經有構建好的合適的docker鏡像可以使用,你根本不需要任何的定製化。當你有多個需要相互之間進行通信的容器的時候,docker-compose是一個很棒的工具,它可以使用一個簡單的命令加速並接管控制多個容器。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 效果圖: 效果圖: 使用方法 (1)引入 jQuery 包,下載地址 (2)引入 zTree 包,下載地址 (3)引入 tree-select.js (4)$("#id").treeSelect(data); 使用方法 (1)引入 jQuery 包,下載地址 (2)引入 zTree 包,下載地址 ( ...
  • 1.filter() 不會改變原始數組,新數組中的元素是過濾指定數組中符合條件的所有元素 兩種寫法區別:有return 的加了{},否則沒有return不需要加{} var aa = [1, 2, 3, 4, 4, 5, 6, 6]; var bb = aa.filter((item, index, ...
  • 知識不怕舊,關鍵在於在舊知識的基礎上不斷創新與提高! 引入一個問題:打開一個瀏覽器,在地址欄輸入一個網址,按下 enter 鍵到看到整個頁面,中間都經歷了哪些事情? 這是一個前端的面試題,相信很多朋友都知道,知道瞭解的朋友可以略過這一塊。 1、HTTP請求階段:向伺服器發送請求 瀏覽器首先向DNS域 ...
  • 數據綁定最常見的形式就是使用“Mustache”語法 (雙大括弧) 的文本插值,例如:<p>Message: {{ msg }}</p>以後每當msg屬性發生了改變,插值處的內容都會自動更新。 可以給DOM節點添加一個v-once指令,這樣模板只會在第一次更新時顯示數據,此後再次更新該DOM裡面引用 ...
  • 近日看到一篇文章 "99%的程式都沒有考慮的網路異常" ,開篇提到: 絕大多數程式只考慮了介面正常工作的場景,而用戶在使用我們的產品時遇到的各類異常,全都丟在看似 ok 的 try catch 中。如果沒有做好異常的相容和兜底處理,會極大的影響用戶體驗,嚴重的還會帶來安全和資損風險。 於是,筆者分析 ...
  • 很多初學的朋友經常問我,前端JavaScript都需要學習哪些東西呀?哪些是JavaScript的重點知識啊? 其實做前端開發工程師,所有的知識點都是我們學習必備的東西,只有扎實的技術基礎才是高薪的關鍵! 不過JavaScript的知識點比較多,一篇文章的內容沒辦法講完。今天就來點知識點難度乾貨,大 ...
  • CH是由俄羅斯“熊哥”開源的一套用於聯機分析(OLAP)的列式資料庫管理系統(DBMS),它通過針對性的設計,力圖解決海量多維度數據的查詢性能問題。小白程式員輕鬆上手,安裝和操作就像mysql一樣簡單。 ...
  • CSRF(Cross site request forgery)利用了web中用戶身份驗證的一個漏洞:簡單的身份驗證只能保證請求發自某個用戶的瀏覽器,卻不能保證請求本身是用戶自願發出的。 例子 在某個論壇管理頁面,管理員可以在list頁面執行刪除帖子操作,根據URL判斷刪除帖子的id,像這樣的一個U ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...