.Net Core in Docker極簡入門(下篇)

来源:https://www.cnblogs.com/xhznl/archive/2020/07/27/13357781.html
-Advertisement-
Play Games

Tips:本篇已加入系列文章閱讀目錄,可點擊查看更多相關文章。 前言 上一篇【.Net Core in Docker極簡入門(上篇)】講解了docker的一些基本命令和操作,併成功構建了自己的asp.net core web應用的鏡像,啟動容器。本篇繼續。 開始 上一篇的項目例子非常簡單,通常我們的 ...


Tips:本篇已加入系列文章閱讀目錄,可點擊查看更多相關文章。

目錄

前言

上一篇【.Net Core in Docker極簡入門(上篇)】講解了docker的一些基本命令和操作,併成功構建了自己的asp.net core web應用的鏡像,啟動容器。本篇繼續。

開始

上一篇的項目例子非常簡單,通常我們的實際項目要複雜的多。項目中會依賴各種組件服務,比如資料庫,MQ,緩存等等。這就會涉及到多個容器,如果手動用docker命令去一個一個的啟動就很麻煩了,那麼這時候就可以使用Docker-Compose來完成多個容器的管理。

Docker-Compose

什麼是Docker Compose?

Compose 是用於定義和運行多容器 Docker 應用程式的工具。通過 Compose,您可以使用 YML 文件來配置應用程式需要的所有服務。然後,使用一個命令,就可以從 YML 文件配置中創建並啟動所有服務。

簡單來理解,Compose類似一個批量工具,可以執行一組命令,支持批量構建鏡像,批量啟動容器,批量刪除容器等等功能。

Windows的Docker Desktop中已經包括了Compose,Linux下Compose則需要單獨安裝一下。

下麵在項目中添加一些資料庫操作的相關代碼便於測試,使用EF Core+SQL Server。

代碼修改

安裝EF Code相關的包:

修改代碼:

public class WeatherForecast
{
    [Key]
    public int Id { get; set; }

    public DateTime Date { get; set; }

    public int TemperatureC { get; set; }

    public int TemperatureF { get; set; }

    public string Summary { get; set; }
}
public class DemoContext : DbContext
{
    public DemoContext(DbContextOptions<DemoContext> options)
        : base(options)
    {

    }

    public DbSet<WeatherForecast> WeatherForecasts { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        base.OnModelCreating(modelBuilder);
        //初始化種子數據
        modelBuilder.Entity<WeatherForecast>().HasData(new WeatherForecast
        {
            Id = 1,
            Date = DateTime.Now,
            Summary = "none",
            TemperatureC = 20,
            TemperatureF = 32 + (int)(20 / 0.5556)
        }, new WeatherForecast
        {
            Id = 2,
            Date = DateTime.Now.AddDays(1),
            Summary = "none",
            TemperatureC = 25,
            TemperatureF = 32 + (int)(25 / 0.5556)
        });
    }
}
public class Startup
{
    ......
        
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddControllers();

        services.AddDbContext<DemoContext>(opt => opt.UseSqlServer(Configuration.GetConnectionString("DemoContext")));
    }
    
    public void Configure(IApplicationBuilder app, IWebHostEnvironment env, DemoContext context)
    {
        //自動遷移
        context.Database.Migrate();

        ......
    }
}
public class WeatherForecastController : ControllerBase
{
    private readonly ILogger<WeatherForecastController> _logger;
    private readonly DemoContext _context;

    public WeatherForecastController(ILogger<WeatherForecastController> logger, DemoContext context)
    {
        _logger = logger;
        _context = context;
    }

    [HttpGet]
    public IEnumerable<WeatherForecast> Get()
    {
        return _context.WeatherForecasts.ToArray();
    }
}

appsettings.json添加資料庫連接字元串配置:

{
  ......
  
  "ConnectionStrings": {
    "DemoContext": "Server=sql-server;Database=DemoDB;User Id=sa;Password=Password@2020;"
  }
}

註意:Server=sql-server,這個sql-server是需要在docker-compose.yml中定義的,下麵再說。

添加遷移:

yml file

右鍵項目-添加-容器業務流程協調程式支持

添加後會生成docker-compose相關文件:

其中的docker-compose.yml文件需要修改一下:

version: '3.4'

services:
  webapplication1:
    image: ${DOCKER_REGISTRY-}webapplication1
    build:
      context: .
      dockerfile: WebApplication1/Dockerfile
    ports: 
      - '5000:80'
    networks:
      - my-net
    depends_on:
      - sql-server

  sql-server:
    image: mcr.microsoft.com/mssql/server:2019-CU5-ubuntu-18.04
    ports: 
      - '1434:1433'
    environment: 
      ACCEPT_EULA: Y
      SA_PASSWORD: Password@2020
    networks: 
      - my-net

networks: 
  my-net: 
    driver: bridge 

services下定義了2個服務webapplication1、sql-server,相當於2個容器。webapplication1是基於WebApplication1/Dockerfile構建的鏡像${DOCKER_REGISTRY-}webapplication1來啟動,depends_on用於指定依賴的服務,這裡的webapplication1服務依賴於sql-server服務。networks用於指定網路,因為docker中容器之間預設是無法直接通信的,這裡創建了一個bridge模式的網路my-net,webapplication1和sql-server都在my-net網路中,那麼他們之間就可以通過服務名來通信。所以在上面webapplication1的資料庫連接字元串中就可以寫:Server=sql-server。通常資料庫的數據目錄會掛載到主機上,防止容器發生意外導致數據丟失。

上一篇有小伙伴問容器內能不能訪問容器外的資料庫,這個是可以訪問的。訪問宿主機的話直接用IP訪問就可以,或者用host.docker.internal,這個host.docker.internal是docker安裝時會寫入到你的hosts文件里的一個主機名,實際還是指向你的主機IP。

以上的yml內容還是比較簡單,yml文件是使用Compose必不可少的,語法可以自行學習一下。掌握其語法關鍵字後,你就可以在docker-compose.yml文件中定義更複雜的環境。

up & down

來到項目根目錄,啟動PowerShell或cmd執行docker命令。

執行docker-compose up,也可以加-d參數,讓他在後臺運行

啟動完成後,瀏覽器訪問:http://localhost:5000/weatherforecast

成功。這裡省略了docker-compose build命令,你也可以在up前先執行build。

docker-compose是不是很方便呢,即使你的系統環境部署再複雜,也只需要一個up指令。

如果你想摧毀這個環境只需要執行docker-compose down即可

同樣的,以上操作也可以直接在vs2019中完成,無需手動執行指令,只需要將docker-compose項目設為啟動項,然後直接運行即可,還支持代碼調試哦。不過由於網路等問題,可能會遇到一些坑。。。

鏡像倉庫

我們也可以把自己的鏡像推送到遠程倉庫,然後在其他機器上直接就能通過命令拉取了。國內阿裡雲之類的都有docker鏡像倉庫服務,也可以搭建私有倉庫,本文就推送到docker的官方倉庫docker hub。首先需要在docker官網https://www.docker.com/註冊賬號。

重新構建鏡像:docker build -t xhznl/webapp1 -f ./WebApplication1/Dockerfile .

其中xhznl是我的docker用戶名。

登錄docker: docker login,輸入自己的用戶名密碼。

登錄成功後即可推送鏡像,執行:docker push xhznl/webapp1

推送成功,在docker官網可以查看鏡像:

這樣在其他機器的docker中也可以通過docker pull xhznl/webapp1來拉取這個鏡像。

修改docker-compose.yml文件,將webapplication1服務的image改為xhznl/webapp1,然後把這個docker-compose.yml文件放到任何裝有docker的機器上,只需執行docker-compose up,即可啟動程式的所有環境,是不是很神奇。

services:
  webapplication1:
    image: xhznl/webapp1
    ports: 
      - '5000:80'
    networks:
      - my-net
    depends_on:
      - sql-server

最後推薦一波vs code,安裝docker相關插件,無論是編寫yml文件還是管理docker都很方便, 很多操作都不用手敲命令啦。。。

最後

Docker作為當今最流行的容器技術,是很多技術架構的基礎。它有很多的優點,使用中也會面臨各種問題,希望本篇入門文章能夠幫助到一些初學的小伙伴。


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

-Advertisement-
Play Games
更多相關文章
  • 一、Servlet 1. 什麼是Servlet Servlet 是 JavaEE 規範之一,規範就是介面 Servlet 就 JavaWeb 三大組件之一,三大組件分別是:Servlet 程式、Filter 過濾器、Listener 監聽器 Servlet 是運行在伺服器上的一個 java 小程式, ...
  • 本系列將和大家分享面向對象23種設計模式中常用的幾種設計模式,本章主要簡單介紹下行為型設計模式。 ...
  • 都0202年了,不會還有人在用WPF吧,不會吧不會吧~什麼qt啊,electron啊,flutter啊好多東西要學啊,我還是繼續用WPF吧。因為其它的還不太會;繼續學習吧~ 期待WinUI3和“MAUI”-2021 1.周末沒加班,閑來沒事做;模仿個東西好了;在模仿中學習(各位大佬不要嘲諷我就是~) ...
  • 首次發表,不太會寫,那點乾貨上個分,廢話不多說,不懂多看 1 public void Publist() 2 { 3 ResultListData resultData = new ResultListData(); 4 BLL.basic_project bllspro = new BLL.bas ...
  • .net core 和.net framework上傳文件還是有一些區別的有很多註意的地方 .net framework 上傳文件用httppostedfilebase .net core 上傳文件用 IFormFile 下麵廢話不多說了,直接上代碼 控制器裡面寫 using System; usi ...
  • 一、簡介 ABP vNext 在 v 2.9.x 版本當中添加了 BLOB 系統,主要用於存儲大型二進位文件。ABP 抽象了一套通用的 BLOB 體系,開發人員在存儲或讀取二進位文件時,可以忽略具體實現,直接使用 IBlobContainer 或 IBlobContainer<T> 進行操作。官方的 ...
  • 使用 .NET Core WebAPI 實現一個 VPS 下載中轉(加速)器 VPSDownloader.NET,暨 .NET Core 程式部署到 Linux 系統。 ...
  • 最近想給我的框架加一種功能,就是比如給一個方法加一個事務的特性Attribute,那這個方法就會啟用事務處理。給一個方法加一個緩存特性,那這個方法就會進行緩存。 這個也是網上說的面向切麵編程AOP。 AOP的概念也很好理解,跟中間件差不多,說白了,就是我可以任意地在方法的前面或後面添加代碼,這很適合 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...