好物优选点击查看详情 京东购买

暂无内容

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

上一节演示如何安装Docker,链接:Docker学习笔记之-在CentOS中安装Docker

本节演示 将.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)(一)插图

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

sudo yum install -y nginx

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

安装完毕:

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

启动 Nginx 服务 

sudo systemctl start nginx.service

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

curl http://172.18.237.116/

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

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

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

第二步:发布项目

发布之前:先到项目中设置5000端口

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

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

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

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

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

 确定后,项目中会多了一个 Dockerfile 文件 (选择该文件,右键–>属性–> 设置为始终复制)

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

默认里面内容是:

#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 base WORKDIR /app EXPOSE 80 FROM 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 base WORKDIR /app COPY . /app EXPOSE 80 ENTRYPOINT ["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)(一)插图8

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

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

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

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

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

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

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

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

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

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

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

都演示完篇幅有点太长了,所以后边的放到下一节中演示!

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

原文链接:https://www.cnblogs.com/peterzhang123/p/13858613.html

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