时间:2022-03-24 11:36:05 | 栏目:.NET代码 | 点击:次
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"]
安装方法参考:https://www.jb51.net/article/232534.htm
docker pull mcr.microsoft.com/dotnet/aspnet:6.0
构建镜像命令:
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 .
默认网络docker0,它不能用域名访问,所以要创建自定义网络。
docker network create --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet
参数说明:
mynet表示网络名
在docker 中直接 run 创建容器时不加自定义的网络,默认使用网络名为bridge的网络,这是docker0网络,容器之间无法使用容器名相互ping通,只能通过ip相互ping通。
我们自己定义的网络,容器之间是可以直接通过容器名相互ping通的。
查看mynet网络的详细信息:
docker network inspect mynet
创建容器格式:
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
参数说明:
查看正在运行的容器:
docker ps
查看所有容器:
docker ps -a
访问方式:http://宿主机ip:端口号
http://192.168.1.200:8002
docker exec -it my-dotnet6-demo01 /bin/bash
给已有容器设置开机自动启动
docker update --restart=always 容器名字
取消容器开机自动启动
docker update --restart=no 容器名字