PostgreSQL是一個功能強大的開源資料庫系統。它支持了大多數的SQL:2008標準的數據類型,包括整型、數值值、布爾型、位元組型、字元型、日期型、時間間隔型和時間型,它也支持存儲二進位的大對像,包括圖片、聲音和視頻。PostgreSQL對很多高級開發語言有原生的編程介面,如C/C++、Java、... ...
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/