.NET Core 3.1使用docker打包并部署
简介
本文主要说明使用.NET Core 3.1搭建的站点如何使用docker打包并运行容器供外网访问。
环境介绍
开发环境
Windows 10
Visual Studio 2019
.NET Core 3.1
部署环境
CentOS 8
Docker 1.19.03
编写Dockerfile文件
将编写好的.NET Core项目发布至指定文件夹,在发布文件夹下添加名为Dokcerfile文件,需要注意此文件没有后缀,同时需要注意文件名的大小写,如下图所示:

对应的Dockerfile文件如下所示:
#引入镜像,低版本 docker 去掉 AS base
#换成别人做的阿里镜像
#FROM registry.cn-hangzhou.aliyuncs.com/newbe36524
FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
#配置工作目录 相当于cd
WORKDIR /app
#暴露容器端口,此端口与程序运行路径一致,可
EXPOSE 5000
#复制文件到工作目录
COPY . .
#ENV :配置系统环境变量,比如程序环境环境等在这里配置(开发、预发、线上环境)
#这里是配置程序运行端口,如果程序不使用默认的80端口这里一定要设置(程序运行端口)
ENV ASPNETCORE_URLS http://+:5000
#设置时间为中国上海,默认为UTC时间
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
#启动程序
ENTRYPOINT ["dotnet", "DotNetCore.API.dll"]
生成Docker镜像
Dockerfile文件编写完成后,上传至CentOS目录下,如下所示:
[root@localhost web]# ll
total 376
-rw-r--r--. 1 root root 162 Aug 25 13:56 appsettings.Development.json
-rw-r--r--. 1 root root 192 Aug 25 13:56 appsettings.json
-rw-r--r--. 1 root root 850 Aug 27 00:55 Dockerfile
-rw-r--r--. 1 root root 106577 Aug 27 2020 DotNetCore.API.deps.json
-rw-r--r--. 1 root root 8192 Aug 27 2020 DotNetCore.API.dll
-rw-r--r--. 1 root root 174592 Aug 27 2020 DotNetCore.API.exe
-rw-r--r--. 1 root root 19480 Aug 27 2020 DotNetCore.API.pdb
-rw-r--r--. 1 root root 224 Aug 25 14:04 DotNetCore.API.runtimeconfig.json
-rw-r--r--. 1 root root 25088 Aug 27 2020 DotNetCore.API.Views.dll
-rw-r--r--. 1 root root 20032 Aug 27 2020 DotNetCore.API.Views.pdb
-rw-r--r--. 1 root root 558 Aug 27 2020 web.config
drwxr-xr-x. 5 root root 57 Aug 25 14:04 wwwroot
在此目录下执行构建docker镜像命令。
# 构建docker image
docker build -t apitest:v1 .
# 执行结果
Sending build context to Docker daemon 4.755MB
Step 1/8 : FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS base
3.1-buster-slim: Pulling from dotnet/core/aspnet
bf5952930446: Pull complete
95f9f5484a21: Pull complete
ebc43d54b0d9: Pull complete
eb8b3fc30ae1: Pull complete
c42d79623507: Pull complete
Digest: sha256:3209fc5e97bcc9d4137d603baf7971475435a3760fbcbba13a4a13ecb973bdb8
Status: Downloaded newer image for mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim
---> bdca989bc8d3
Step 2/8 : WORKDIR /app
---> Running in e1bc2cdcce7e
Removing intermediate container e1bc2cdcce7e
---> d115392570f1
Step 3/8 : EXPOSE 8001
---> Running in 7329d738bc32
Removing intermediate container 7329d738bc32
---> facb418c8e93
Step 4/8 : COPY . .
---> db32752819a7
Step 5/8 : ENV ASPNETCORE_URLS http://+:5000
---> Running in aa6129a3c24d
Removing intermediate container aa6129a3c24d
---> 26dbc37969a1
Step 6/8 : ENV TZ=Asia/Shanghai
---> Running in 5972afb49e7b
Removing intermediate container 5972afb49e7b
---> 8ba512fe33ac
Step 7/8 : RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
---> Running in 7af56acee843
Removing intermediate container 7af56acee843
---> 6063c7efb5e3
Step 8/8 : ENTRYPOINT ["dotnet", "DotNetCore.API.dll"]
---> Running in a5747e363825
Removing intermediate container a5747e363825
---> 490d51c5dfb0
Successfully built 490d51c5dfb0
Successfully tagged apitest:v1
此时,Docker镜像已经构建完成,可以查看下构建结果。
# 查看构建后的docker image
docker images
# 执行结果
REPOSITORY TAG IMAGE ID CREATED SIZE
apitest v1 490d51c5dfb0 9 seconds ago 212MB
mcr.microsoft.com/dotnet/core/aspnet 3.1-buster-slim bdca989bc8d3 2 weeks ago 207MB
运行容器
执行下面命令运行生成的容器,需要注意一下几点:
- 挂载目录,映射容器内目录到宿主机,如文件下载、上传等
- 端口,宿主机与容器内端口号映射,容器内端口号要保证与Dockerfile文件内一致
- 自动重启,设置restart属性为always,防止宿主机或者docker重启后容器停止
# 启动容器
docker run -d -p 8001:5000 --restart=always --name api.test api.test:v1
# 查看已经启动的容器
docker ps 或者 docker container ls
# 执行结果
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
306917290c1c api.test:v1 "dotnet DotNetCore.A…" 6 seconds ago Up 4 seconds 0.0.0.0:8001->5000/tcp api.test
访问接口
在网内其他终端或者宿主机访问http://192.168.43.131:8001/api/test/getstr即可查看运行效果,运行效果如下:

结语
此时,已将基于.NET Core 3.1的Web API站点打包、部署至Linux平台。
.NET Core 3.1使用docker打包并部署的更多相关文章
- 使用.NET 6开发TodoList应用(30)——实现Docker打包和部署
系列导航及源代码 使用.NET 6开发TodoList应用文章索引 需求 .NET 6 Web API应用使用最多的场景是作为后端微服务应用,在实际的项目中,我们一般都是通过将应用程序打包成docke ...
- ASP.NET Core 实战:使用 Docker 容器化部署 ASP.NET Core + MySQL + Nginx
一.前言 在之前的文章(ASP.NET Core 实战:Linux 小白的 .NET Core 部署之路)中,我介绍了如何在 Linux 环境中安装 .NET Core SDK / .NET Core ...
- docker打包项目部署
1.首先在本地安装docker,步骤可参考https://www.cnblogs.com/conswin/p/11055853.html 2.在对应项目目录下增加Dockerfile文件,其内容可参考 ...
- .net core 微服务架构-docker的部署-包括网关服务(Ocelot)+认证服务(IdentityServer4)+应用服务(asp.net core web api)
本文主要介绍通过Docker来部署通过.Net Core开发的微服务架构,部署的微服务主要包括统一网关(使用Ocelot开发).统一认证(IdentityServer4).应用服务(asp.net c ...
- .NET Core 微服务架构-Docker部署
本文主要介绍通过Docker来部署通过.NET Core开发的微服务架构,部署的微服务主要包括统一网关(使用Ocelot开发).统一认证(IdentityServer4).应用服务(ASP.NET C ...
- Linux下自动化部署ASP.NET CORE 3.1(Docker+Jenkins+Nginx)
1.先配置好Docker阿里云加速,可以使用阿里云容器服务 (可自己在阿里云申请,要不然安装东西直接很慢)注意:https://XXXX.mirror.aliyuncs.com为阿里云加速服务分配地址 ...
- Docker 打包 部署
Docker 打包 部署 一贯的开场白,大家好: 开始学习Spring Boot ,同时也再学习 Maven 自动化构建. 项目的部署环境是 Linux 服务器,Docker容器. 之所以写这篇博客 ...
- Gitlab CI 自动部署 asp.net core web api 到Docker容器
为什么要写这个? 在一个系统长大的过程中会经历不断重构升级来满足商业的需求,而一个严谨的商业系统需要高效.稳定.可扩展,有时候还不得不考虑成本的问题.我希望能找到比较完整的开源解决方案来解决持续集成. ...
- Ubuntu 16.04+.Net Core+Docker+Uginx安装部署
前言 最近公司的项目打算移植到.Net Core平台,所以调研了一下.Net Core在Linux下的安装部署.本篇文章会一步步的描述从安装到配置到部署的全部过程.在文章的结构和内容里,笔者借鉴了很多 ...
- .NET Core微服务之基于Jenkins+Docker实现持续部署(Part 1)
Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.CI, CD 与Jenkins 互联网软件的开发和发布,已经形成了一套标准流程,最重要的组成部分就是持续集成(Continuous i ...
随机推荐
- Linux环境变量及其配置
为什么要说这个呢? 本人喜欢使用Linux开发(工作是个硬要求,有些时候不能使用Linux,比如我上一个工作.但是有些时候呢,工作环境比较开放,我可以选择我喜欢的系统进行工作:比如我现在的工作.红红火 ...
- 【谷粒商城】(一)docker搭建以及项目的创建
网络地址转换-端口转发 VmWare网络配置可以参考这篇:VMWare虚拟机网络连接设置_santirenpc的博客-CSDN博客_vmware 上网设置,真的是被折磨到了.. Docker 虚拟化容 ...
- Ubuntu20.04 Docker搭建远程xfce桌面以及ssh教程
简介:本文主要介绍ubuntu20.04容器中搭建xfce远程桌面.C++.Go环境.容器内docker操作配置. 一.创建容器1.创建容器 docker pull ubuntu:20.04docke ...
- 【ACM组合数学 | 错排公式】写信
题目链接:https://ac.nowcoder.com/acm/contest/54484/B 题意很简单,但是数据范围偏大. 错排公式 首先来推导一下错排公式: \[D(n) = n!\sum_{ ...
- 09-devserver
const {resolve} = require('path') const HtmlWebpackPlugin = require('html-webpack-plugin') module.ex ...
- vue3的setup语法糖
https://blog.csdn.net/weixin_44922480/article/details/127337914 https://blog.csdn.net/m0_63108819/ar ...
- vue将页面(dom元素)转换成图片,并保存到本地
1 npm install html2canvas --save <template> <div class="QRCode-box"> <img i ...
- 数据结构(DataStructure)-01
数据结构-01 **数据结构与算法** **算法概述** **时间复杂度概述** **时间复杂度 - 计算规则** **数据结构概述** **抽象数据类型** **线性表 - 顺序表** **线性表 ...
- Vite-WeGPT聊天AI实例|vue3+pinia仿ChatGPT聊天界面
基于vue3.x+vite4+pinia2仿chatgpt聊天模拟实例Vue3-WeGPT. 基于Vite4.x+Vue3+Pinia2+VEPlus+Vue3-Markdown等技术实现仿ChatG ...
- flutter中使用pubspec.yaml更改package name
在flutter 项目中使用pubspec.yaml文件进行依赖资源相关配置是常有的事 但是刚发现它可以修改name来控制项目包名称,当初创建了不同的项目名git后还到每个文件里去修改import(麻 ...