Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)

本节演示 将.net core 3.1 部署到docker容器当中,并使用 Nginx反向代理,部署平台 CentOS 7.8

1,安装 Nginx 支持 (centos7.8 默认不带Nginx) 、(如果要使用Nginx容器反向代理,可以跳过第一步)

第一步:安装 Nginx

centos系统不像 ubuntu系统,可以直接install安装,需要先添加源:

sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Nginx

上图表示添加成功,接下来执行安装命令

sudo yum install -y nginx

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Nginx_02

安装完毕:

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Docker容器_03

启动 Nginx 服务

sudo systemctl start nginx.service

启动后通过下边脚本验证是否安装成功,这里的IP地址就是你centos系统的ip地址,怎么查看ip地址可以查看前边章节

curl http://172.18.237.116/

出现以下内容说明安装成功。

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Nginx_04

附上一个参考文档:https://www.cnblogs.com/tenghao510/p/11990353.html

第二步:发布项目

接下来开始正文,编译你.net项目,并添加docker支持,项目右键,选择添加docker 支持(这一部分操作必须)

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Docker容器_05

然后选择 linux,主要是为了发布到 centos 上

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Docker容器_06

确定后,项目中会多了一个 Dockerfile 文件

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Nginx_07

默认里面内容是:

#See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS baseWORKDIR /app EXPOSE 80FROM mcr.microsoft.com/dotnet/core/sdk:3.1-buster AS build WORKDIR /src COPY ["myAPI/myAPI.csproj", "myAPI/"] RUN dotnet restore "myAPI/myAPI.csproj"COPY . . WORKDIR "/src/myAPI"RUN dotnet build "myAPI.csproj" -c Release -o /app/build FROM build AS publish RUN dotnet publish "myAPI.csproj" -c Release -o /app/publish FROM base AS final WORKDIR /app COPY --from=publish /app/publish . ENTRYPOINT ["dotnet", "myAPI.dll"]

实际上,生产环境只需要以下内容就可以了。

FROM mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim AS baseWORKDIR /app COPY . /app EXPOSE 80ENTRYPOINT ["dotnet", "myAPI.dll"]

解释:

mcr.microsoft.com/dotnet/core/aspnet:3.1-buster-slim 基础镜像,也就是.net core 的运行时;

EXPOSE 80 是指这个容器对外暴露的端口;

WORKDIR /app 是容器的工作目录;

COPY . /app 是指复制当前目录(其中.即代表当前目录)到容器中的/app目录下;

ENTRYPOINT 指定容器的运行对象

右键项目–>发布–>配置发布内容

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Nginx_08

配置内容:部署模式选择 “依赖框架”,运行时选择 linux-x64,点击,保存–发布

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Docker容器_09

发布成功之后,通过软件Xftp 将项目上传到服务器上

在centOS服务根目录创建一个项目文件夹,存放要上传的项目,

通过Xftp很方便的就可以完成,右键–新建文件夹:netcoredemo,将左边文件上传即可

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Docker容器_10

发布后的项目不包含 Dockerfile,需要单独上传,将Dockerfile也上传到项目netcoredemo文件夹中

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Nginx_11

通过命令 ls 验证是否上传成功,如下图所示,项目已经上传成功

Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)_Docker容器_12

现在项目上传到服务器了,接下来就是部署到Docker中!

原文链接:https://blog.51cto.com/u_15127630/2738692

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享