.NET Core部署到linux(CentOS)最全解决方案,高阶篇(Docker+Nginx 或 Jexus)

原创
01/22 11:19
阅读数 4.2K

在前两篇:

.NET Core部署到linux(CentOS)最全解决方案,常规篇

.NET Core部署到linux(CentOS)最全解决方案,进阶篇(Supervisor+Nginx)

我们对.netcore部署到linux有了一个充分的了解,已经可以满足应用要求了,这篇文章我们继续深入带你了解使用Doker+jexus或Nginx来部署.net core应用。

1、使用Jexus作为web服务器

Jexus是一款Linux平台上的高性能WEB服务器和负载均衡网关服务器,以支持ASP.NET、ASP.NET CORE、PHP为特色,同时具备反向代理、入侵检测等重要功能。可以这样说,Jexus是.NET、.NET CORE跨平台的最优秀的宿主服务器,如果我们认为它是Linux平台的IIS,这并不为过,因为,Jexus不但非常快,而且拥有IIS和其它Web服务器所不具备的高度的安全性。同时,Jexus Web Server 是完全由中国人自主开发的的国产软件,真正做到了“安全、可靠、可控”, 具备我国党政机关和重要企事业单位信息化建设所需要的关键品质。

jexus官网:https://www.jexus.org/

1.1、Jexus的安装

jexus的安装非常简单,执行如下命令:

curl https://jexus.org/release/x64/install.sh|sudo sh

Jexus的安装

注:运行安装命令,需要操作者有root权限。

1.2、Jexus的配置与使用

安装完成后,切换到/usr/jexus目录,修改/usr/jexus/siteconf目录下的default,内容如下所示:

注:因为在前面的章节用了nginx,使用了80端口,因此这儿我使用8099端口。

port=8099 #端口
hosts=*    #域名
AppHost={cmd=dotnet Core50Test.dll; root=/root/app_data/core50test/publish; port=5000}

Jexus的配置
接下来,我们重启jexus,执行如下命令:

/usr/jexus/jws restart

重启jexus
提示Ok后,我们的应用就表示启动起来了。

可以通过执行如下命令,看下执行的结果:

ps -aux

ps
可以看到我们的应用已经启动起来了,到浏览器使用8099端口浏览看下效果。
浏览应用

关于jexus更详细的使用说明,请参考官方文档。

1.3、Jexus的操作命令

Jexus包括如下操作命令(首先 cd /usr/jexus):
启动:sudo ./jws start
停止:sudo ./jws stop
重启:sudo ./jws restart

2、Docker+Nginx或Jexus部署

在前面的文章介绍中,不管是supervisor+nginx还是jexus,都需要在服务器安装 .NET Core的SDK或者运行时,假如咱们多个应用程序,各应用程序所用.net core版本不一样,上面的做法就需要咱们分别安装对应的SDK或者运行时,对于维护还是比较麻烦的。Docker的出现,可以完美解决上述问题。
Docker

2.1、Docker是什么?

  • docker是一个开源的软件部署解决方案;
  • docker也是轻量级的应用容器框架;
  • docker可以打包、发布、运行任何的应用。

Docker有如下优点:

1、快速,一致地交付您的应用程序

Docker 允许开发人员使用您提供的应用程序或服务的本地容器在标准化环境中工作,从而简化了开发的生命周期。

容器非常适合持续集成和持续交付(CI / CD)工作流程,请考虑以下示例方案:

  • 您的开发人员在本地编写代码,并使用 Docker 容器与同事共享他们的工作。
  • 他们使用 Docker 将其应用程序推送到测试环境中,并执行自动或手动测试。
  • 当开发人员发现错误时,他们可以在开发环境中对其进行修复,然后将其重新部署到测试环境中,以进行测试和验证。
  • 测试完成后,将修补程序推送给生产环境,就像将更新的镜像推送到生产环境一样简单。

2、响应式部署和扩展

Docker 是基于容器的平台,允许高度可移植的工作负载。Docker 容器可以在开发人员的本机上,数据中心的物理或虚拟机上,云服务上或混合环境中运行。

Docker 的可移植性和轻量级的特性,还可以使您轻松地完成动态管理的工作负担,并根据业务需求指示,实时扩展或拆除应用程序和服务。

3、在同一硬件上运行更多工作负载

Docker 轻巧快速。它为基于虚拟机管理程序的虚拟机提供了可行、经济、高效的替代方案,因此您可以利用更多的计算能力来实现业务目标。Docker 非常适合于高密度环境以及中小型部署,而您可以用更少的资源做更多的事情。

2.2、docker安装

执行如下命令:

sudo yum install docker

PS:

遇报错 Another app is currentlty holding the yum lock ,waiting for it to exit…

解决方法: rm –r /var/run/yum.pid 这个命令 解锁即可
docker安装1
docker安装2
安装完成后,执行如下命令设置docker开机启动:

systemctl enable docker

执行如下命令启动docker:

systemctl start docker

查看docker启动状态:
查看docker启动状态

ps:安装过程有问题的话,可能直接运行如命令安装。

yum install docker-ce-cli

查看docker版本命令:
查看docker版本

2.3、.net core docker支持

安装docker之后,我们需要在代码里增加dockerfile文件。

通过Visual Studio可以帮我们自动生成,在解决方案中,右击项目名称,依次选择【添加】->【Docker支持】,如下图所示:
net core docker支持
生成的dockerfile文件如下所示:

#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/aspnet:5.0-buster-slim AS base
WORKDIR /app
EXPOSE 80

FROM mcr.microsoft.com/dotnet/sdk:5.0-buster-slim AS build
WORKDIR /src
COPY ["Core50Test.csproj", ""]
RUN dotnet restore "./Core50Test.csproj"
COPY . .
WORKDIR "/src/."
RUN dotnet build "Core50Test.csproj" -c Release -o /app/build

FROM build AS publish
RUN dotnet publish "Core50Test.csproj" -c Release -o /app/publish

FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "Core50Test.dll"]

将代码推送到git仓库,然后再linux服务器中拉取最新代码。

切换到/root/app_data/source/core50test目录,执行如下命令,拉取最新代码:

git pull
  • 1

拉取代码
然后执行如下命令,将代码打包为镜像:

 docker build -f Dockerfile -t core50test .

首次打包镜像涉及到拉取.NET Core的官方镜像,拉取速度可能较慢,请耐心等待。
打包镜像
image-20210118173932286
打包完成后,执行如下命令,可查看当前服务器已存在的镜像:

docker images

查看当前服务器已存在的镜像
镜像打包完成后,我们就可以执行docker run命令启用我们的应用了:

docker run -p 81:80 -dit --restart=always --name core50test core50test

执行结果如下:
docker run命令启用我们的应用
通过浏览器访问:http://ip:81。如无意外,我们可以看到应用已经成功运行。
应用成功运行
**docker run :**创建一个新的容器并运行一个命令

语法

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

OPTIONS说明:

  • -a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
  • -d: 后台运行容器,并返回容器ID;
  • -i: 以交互模式运行容器,通常与 -t 同时使用;
  • -P: 随机端口映射,容器内部端口随机映射到主机的端口
  • -p: 指定端口映射,格式为:主机(宿主)端口:容器端口
  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
  • –name=“nginx-lb”: 为容器指定一个名称;
  • –dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
  • –dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
  • -h “mars”: 指定容器的hostname;
  • -e username=“ritchie”: 设置环境变量;
  • –env-file=[]: 从指定文件读入环境变量;
  • –cpuset=“0-2” or --cpuset=“0,1,2”: 绑定容器到指定CPU运行;
  • **-m 😗*设置容器使用内存最大值;
  • –net=“bridge”: 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
  • –link=[]: 添加链接到另一个容器;
  • –expose=[]: 开放一个端口或一组端口;
  • –volume , -v: 绑定一个卷

2.4、通过shell脚本实现docker一键更新应用

可以通过编写shell脚本,实现一键更新应用。在/root目录中,创建dockerbuild.sh文件,文件内容如下:

# !/bin/bash

cd /root/app_data/source/core50test
git pull
imtag=$(uuidgen |sed 's/-//g')
docker build -f Dockerfile -t core50test:${imtag} .
docker stop core50test
docker rm core50test
docker run -dit --restart=always --name core50test -p 81:80  core50test:${imtag}

docker一键更新应用shell脚本
给dockerbuild.sh文件设置执行权限,命令如下:

chmod 777 dockerbuild.sh

当有新代码推送到git仓库时,进入服务器,执行dockerbuild.sh即可快速更新应用程序。

./dockerbuild.sh
执行dockerbuild.sh快速更新应用程序
image-20210118175843088
至此,.net core使用docker方式部署介绍完成。

2.5、docker常用命令

Docker常用命令,总的来说分为以下几种:

  • Docker环境信息 — docker [info|version]
  • 容器生命周期管理 — docker [create|exec|run|start|stop|restart|kill|rm|pause|unpause]
  • 容器操作运维 — docker [ps|inspect|top|attach|wait|export|port|rename|stat]
  • 容器rootfs命令 — docker [commit|cp|diff]
  • 镜像仓库 — docker [login|pull|push|search]
  • 本地镜像管理 — docker [build|images|rmi|tag|save|import|load]
  • 容器资源管理 — docker [volume|network]
  • 系统日志信息 — docker [events|history|logs]

从docker命令使用出发,梳理出如下命令结构图:
docker常用命令
要查看更详细的命令,可以查看官网或者命令帮助

docker --help

3、总结

通过前面三篇文章的介绍,我们已经对.net core多方案部署到linux下有了非常全面的认识,小型团队已经足够使用。留心的同学会注意到,虽然目前的方案可以实现一键部署更新,但是还是需要登陆到linux服务器去执行相应的命令。

显示,这不是最优的方案,那么还有没有更好的方案呢?比如:当我们提交给git仓库后,自动出发部署命令是不是就更方便了呢?

答案是肯定的,我们可以借助jenkins来实现。如有兴趣,可以自行研究,或者敬请期待后面的讲解。以及在大型项目中基于k8s实现的devops。其实k8s实现devops的原理以上面的介绍差不多,基于就是借助gitlab的runner或者jenkins,监听git仓库的状态,当发现指定的分支发生变化后,打包镜像,然后通过替换k8s的deployment的镜像来实现自动更新。同时,k8s实现了弹性伸缩、滚动更新等功能。


一路走来数个年头,感谢RDIFramework.NET框架的支持者与使用者,大家可以通过下面的地址了解详情。

RDIFramework.NET官方网站:http://www.rdiframework.net/

RDIFramework.NET官方博客:http://blog.rdiframework.net/

特别说明,框架相关的技术文章请以官方网站为准,欢迎大家收藏!

RDIFramework.NET框架由海南国思软件科技有限公司专业团队长期打造、一直在更新、一直在升级,请放心使用!

欢迎关注RDIFramework.NET框架官方微信公众号(微信号:guosisoft),及时了解最新动态。

使用微信扫描二维码立即关注

微信号:**guosisoft**

展开阅读全文
打赏
1
6 收藏
分享
加载中
打赏
0 评论
6 收藏
1
分享
返回顶部
顶部