CentOS7的docker中运行.Net 5 API项目
源码形式部署
1、创建WebAPI应用程序,.NET 5中增加了对Open API的支持,勾选。勾选启用Docker,对应的操作系统选择Linux。
2、修改StartUp文件的Swagger配置项,因为默认生成的代码只用于开发环境,当在Docker中执行以后,会在生产环境中运行。
这里是一个坑,如果不修改,在最终访问时会无法访问swagger,显示404。
参考链接:https://stackoverflow.com/questions/59824036/swagger-ui-gives-404-when-app-is-running-in-docker-container
if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } //把Swagger相关的部分移出来 app.UseSwagger(); app.UseSwaggerUI(c => c.SwaggerEndpoint("/swagger/v1/swagger.json", "docketsample v1"));
3、复制整个项目到CentOS中对应的目录
4、切换对项目目录,也就是有Dockerfile的目录。然后执行以下命令
docker build -t aspnetapp . docker run -it --rm -p 5000:80 --name aspnetcore_sample aspnetapp
build
命令参数:
- 将映像命名为 aspnetapp。
- 在当前文件夹(末尾的句点)中查找 Dockerfile。
运行命令参数:
- 分配伪 TTY,即使未附加也使其保持打开状态。 (与
--interactive --tty
的效果相同。) - 容器在退出时自动删除。
- 将本地计算机上的端口 5000 映射到容器中的端口 80。
- 将容器命名为 aspnetcore_sample。
- 指定 aspnetapp 映像。
5、然后在本地浏览器输入http://192.168.1.107:5000/swagger/index.html进行访问,其中IP为CentOS的IP地址,5000为本地映射到Docker的端口。
项目发布部署
1、发布项目,可以使用命令进行发布
dotnet publish -o ./publish
2、在发布后的目录中创建Dockerfile文件,文件与DLL为同一目录。其中Dockerfile文件的内容如下:
FROM mcr.microsoft.com/dotnet/aspnet:5.0-buster-slim WORKDIR /app EXPOSE 80 EXPOSE 443 WORKDIR /app COPY . /app ENTRYPOINT ["dotnet", "web.dll"]
3、将发布后的项目文件+dockerfile文件一起上传到CentOS目录中,上传工具可以使用XFTP。
4、使用源码方式的第4、5步的命令生成镜像、运行容器即可。
相关链接参考:
https://docs.microsoft.com/zh-cn/aspnet/core/host-and-deploy/docker/building-net-docker-images?view=aspnetcore-5.0
https://www.cnblogs.com/sdonian/p/14030636.html
https://www.cnblogs.com/dotnet261010/p/12450488.html
https://www.cnblogs.com/Jerrycjc/p/14529778.html
https://www.cnblogs.com/Jerrycjc/p/15135882.html
https://www.cnblogs.com/tianfengcc/p/14332534.html