Asp.Net Core WebAPI+PostgreSQL部署在Docker中

潤羲發表於2019-08-13

   PostgreSQL是一個功能強大的開源資料庫系統。它支援了大多數的SQL:2008標準的資料型別,包括整型、數值值、布林型、位元組型、字元型、日期型、時間間隔型和時間型,它也支援儲存二進位制的大對像,包括圖片、聲音和視訊。PostgreSQL對很多高階開發語言有原生的程式設計介面,如C/C++、Java、.Net、Perl、Python、Ruby、Tcl 和ODBC以及其他語言等,也包含各種文件。我用PostgreSQL結合.Net Core WebAPI構建並部署在Docker中做了一個Demo構建:

一、VS2017構建Asp.Net Core WebApi專案

二、在NuGet包管理器中新增 Npgsql.EntityFrameworkCore.PostgreSQL

三、編寫DbContext類,以及實體類。也可以直接通過命令列自動生成:
dotnet ef dbcontext scaffold "Server=localhost;port=5432;Database=Todo;Username=postgres;Password=111111" Npgsql.EntityFrameworkCore.PostgreSQL -o Models -p postgreSQL.Demo

如果需要對實體進行約束,實現IEntityTypeConfiguration介面

四、注入PostgreSQL在Asp.Net Core中

五、編寫業務邏輯,由於資料庫中有資料,我直接寫一個讀取資料的API方法

控制檯執行後指定api/todo路徑後,顯示如下結果:

六、接下來,在VS2017專案WebApi中新增Docker Compose,Docker Compose是一個用來定義和執行復雜應用的Docker工具。一個使用Docker容器的應用,通常由多個容器組成。使用Docker Compose不再需要使用shell指令碼來啟動容器,在VS2017中,選中專案右擊-》新增-》容器業務流程協調程式支援,當然你也可以選擇Docker支援,不過需要自己手動輸入命令列構建映象。

接下來,會發現專案中出現了一個Docker Compose的一個專案節點:

yml檔案對Docker容器進行了專案配置,另外在WebAPI專案中多了一個Dockerfile檔案,檔案中描述的是構建Docker映象的構建命令:

七、在Docker-Compose專案的yml檔案中是Docker的一些配置:

生成Docker-Compose專案,自動進行Docker映象構建,不需要手動輸入命令列:

最後執行Docker-Compose,啟動後,開啟Docker視覺化工具Kitematic可以看到部署的webapi站點在執行中:

點選右邊的Hostname/Ports選項,下面是Docker 的埠對映,可以修改

點選localhost:64629,訪問路徑api/todo,會看到和控制檯執行一樣的效果

另外要注意:PostgreSQL不要用localhost地址,改用IP地址,具體的PostgreSQL的IP地址配置看如下連結:
https://www.bbsmax.com/A/n2d9Xw605D/

 

相關文章