部署.Net6項目到docker
部署.net6項目到docker
【1】新建.net6 mvc或webapi項目;
【2】在mvc或webapi項目的根目錄下創建Dockerfile文件,並設置為始終復制;
Dockerfile文件內容為:
#添加.net6基礎鏡像 FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS base #容器工作目錄 WORKDIR /app #指定項webapi或mvc站點的內部啟動端口,默認是80 #ENV ASPNETCORE_URLS http://+:5001 #暴露docker容器端口 #EXPOSE 8001 #EXPOSE 443 #拷貝發佈目錄下的所有文件到容器的工作根目錄 #COPY . . (這樣寫也可以) COPY ./ ./ # 如果用System.SqlClient.dll訪問數據庫,需要加這一句 RUN sed -i 's/TLSv1.2/TLSv1.0/g' /etc/ssl/openssl.cnf #容器入口點 ENTRYPOINT ["dotnet", "dotnet6Demo.web.dll"]
【3】發佈mvc或webapi項目;
【4】將發佈後的mvc或webapi項目拷貝到centos服務器的某個文件夾,例如拷貝到【/wwwroot/myproject】文件夾;
【5】安裝docker
安裝方法參考:https://www.jb51.net/article/232534.htm
【6】安裝.net6鏡像
docker pull mcr.microsoft.com/dotnet/aspnet:6.0
【7】進入到centos服務器的 /wwwroot/myproject 目錄,構建一個鏡像,鏡像名格式為【鏡像名:版本號】,比如:dotnet6-demo:0.0.1
構建鏡像命令:
cd /wwwroot/myproject docker build -t dotnet6-demo:0.0.1 .
dotnet6-demo 表示構建的鏡像名稱,:0.0.1表示鏡像版本號,註意鏡像名後面有個空格 + 英文點號,表示構建當前路徑下的文件
。
上面這條命令是用默認配置文件名 Dockerfile 構建的鏡像,如果用自定義配置文件名構建鏡像,需要加 -f 參數。
docker build -f Dockerfile02 -t dotnet6-demo:0.0.1 .
【8】創建自定義網絡
默認網絡docker0,它不能用域名訪問,所以要創建自定義網絡。
docker network create --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet
參數說明:
- –driver bridge #表示橋接模式
- –subnet 192.168.0.0/16 #16表示最多支持65535個ip,可以分配192.168.0.2到192.168.255.255,如果沒有指定–subnet參數默認網段為172.17.0.0/16,默認網關為172.17.0.1;
- –subnet 192.168.0.0/24 #24表示最多支持254個ip,可以分配192.168..0.2到192.168.0.255
- –gateway #表示docker容器的網關
mynet表示網絡名
在docker 中直接 run 創建容器時不加自定義的網絡,默認使用網絡名為bridge的網絡,這是docker0網絡,容器之間無法使用容器名相互ping通,隻能通過ip相互ping通。
我們自己定義的網絡,容器之間是可以直接通過容器名相互ping通的。
查看mynet網絡的詳細信息:
docker network inspect mynet
【9】創建並運行容器
創建容器格式:
docker run -d –name 容器名 -p 外部端口號:docker容器端口號 –restart=always -v /宿主機目錄 : /容器目錄 鏡像名
使用默認網絡 docker0 創建容器(生產環境不推薦
):
docker run -d --name my-dotnet6-demo01 -p 8001:80 --restart=always -v /www-appdata/dotnet6-demo/logs:/logs -v /www-appdata/dotnet6-demo/upload:/upload dotnet6-demo:0.0.1
使用自定義網絡創建容器(多瞭個 –net 參數):
docker run -d --name my-dotnet6-demo01 -p 8001:80 --restart=always -v /www-appdata/dotnet6-demo/logs:/logs -v /www-appdata/dotnet6-demo/upload:/upload --net mynet dotnet6-demo:0.0.1
參數說明:
- -d #後臺運行
- -p 8001:80 #縮主機端口號:docker端口號
- -v #數據卷路徑,格式:(-v /宿主機目錄:容器目錄)或者(-v /容器目錄),可以帶多個 -v 參數。
- –restart=always #dokcer重新啟動時也將容器自動啟動
- –net mynet #指定網絡名
查看正在運行的容器:
docker ps
查看所有容器:
docker ps -a
【10】訪問容器
訪問方式:http://宿主機ip:端口號
http://192.168.1.200:8002
進入到容器
【11】進入到容器
docker exec -it my-dotnet6-demo01 /bin/bash
容器設置
給已有容器設置開機自動啟動
docker update --restart=always 容器名字
取消容器開機自動啟動
docker update --restart=no 容器名字
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Docker之自定義網絡實現
- .NET 5 部署在docker上運行的方法
- Gogs+Jenkins+Docker 自動化部署.NetCore的方法步驟
- docker 創建容器時指定容器ip的實現示例
- docker網絡及部署集群和打包鏡像問題