PostgreSQL是一個功能強大的開源數據庫系統。它支持了大多數的SQL:2008標準的數據類型,包括整型、數值值、布爾型、字節型、字符型、日期型、時間間隔型和時間型,它也支持存儲二進制的大對像,包括圖片、聲音和視頻。PostgreSQL對不少高級開發語言有原生的編程接口,如C/C++、Java、.Net、Perl、Python、Ruby、Tcl 和ODBC以及其餘語言等,也包含各類文檔。我用PostgreSQL結合.Net Core WebAPI構建並部署在Docker中作了一個Demo構建:web
1、VS2017構建Asp.Net Core WebApi項目sql
2、在NuGet包管理器中添加 Npgsql.EntityFrameworkCore.PostgreSQLshell
3、編寫DbContext類,以及實體類。也能夠直接經過命令行自動生成:
dotnet ef dbcontext scaffold "Server=localhost;port=5432;Database=Todo;Username=postgres;Password=111111" Npgsql.EntityFrameworkCore.PostgreSQL -o Models -p postgreSQL.Demo數據庫
若是須要對實體進行約束,實現IEntityTypeConfiguration接口編程
4、注入PostgreSQL在Asp.Net Core中api
5、編寫業務邏輯,因爲數據庫中有數據,我直接寫一個讀取數據的API方法工具
控制檯運行後指定api/todo路徑後,顯示以下結果:post
6、接下來,在VS2017項目WebApi中添加Docker Compose,Docker Compose是一個用來定義和運行復雜應用的Docker工具。一個使用Docker容器的應用,一般由多個容器組成。使用Docker Compose再也不須要使用shell腳原本啓動容器,在VS2017中,選中項目右擊-》添加-》容器業務流程協調程序支持,固然你也能夠選擇Docker支持,不過須要本身手動輸入命令行構建鏡像。spa
接下來,會發現項目中出現了一個Docker Compose的一個項目節點:命令行
yml文件對Docker容器進行了項目配置,另外在WebAPI項目中多了一個Dockerfile文件,文件中描述的是構建Docker鏡像的構建命令:
7、在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/