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

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

本文为大家介绍使用 .NET Core部署到Linux服务器的方法,通过本文你将了解到Linux在虚拟机下的安装、Xshell,Xftp的使用方法、git在linux下的交互使用以及.net core在linux下的发布与运行全过程,本文皆在总结了一些经验与笔记在部署过程中遇到的一些问题,同时分享给大家,供大家参考,欢迎讨论交流。

操作系统可选择你比较熟悉的Linux发行版,如果你是第一次接触Linux,推荐使用CentOs,因为本文的内容都是在CentOs中进行演示的。

至于系统的安装,你可以选择云服务器,或者使用虚拟机安装。虚拟机安装CentOs的方式可以参考:一网打尽,一文讲通虚拟机安装及Linux使用

我们推荐使用XShell作为连接工具,下载地址:https://www.netsarang.com/zh/xshell-download/

Xshell是一个强大的安全终端模拟软件,它支持SSH1, SSH2, 以及Microsoft Windows 平台的TELNET 协议。Xshell 通过互联网到远程主机的安全连接以及它创新性的设计和特色帮助用户在复杂的网络环境中享受他们的工作。

Xshell可以在Windows界面下用来访问远端不同系统下的服务器,从而比较好的达到远程控制终端的目的。除此之外,其还有丰富的外观配色方案以及样式选择。

安装完成后,打开软件,点击左上角的新建回话按钮,打开新建回话属性,如下图所示:

Xshell新建回话

在【主机】中填写服务器的ip地址,相应的用户与密码设置好,然后点击【连接】按钮。连接成功的界面如下所示:

image-20210113170538768

外部与Linux服务文件交互可以使用Xftp工具上传或git仓库中转等其他方法,本文会演示使用Xftp与git仓库两种方式进行代码文件的中转。Xftp工具,下载地址:https://www.netsarang.com/zh/xftp-download/

Xftp是一个功能强大的SFTP、FTP 文件传输软件。使用了 Xftp 以后,MS Windows 用户能安全地在 UNIX/Linux 和 Windows PC 之间传输文件。

安装完成后,可以通过XShell一键打开Xftp,Xftp打开后,在软件的右侧可以切换要上传文件的目标路径,然后将文件拖到右侧释放后,就会自动上传了。

相对开发来说,使用Git仓库中转的方式是我们推荐的使用方式,在频繁的迭代更新中,先在本地编译发布后,再将文件拷贝到服务器,这个操作流程稍显繁琐。而通过git仓库来中转的方式则相对比较简单,开发者仅需要将开发好的代码推送(push)到git仓库,然后在服务器中执行build,publish等操作,减少了繁琐的拷贝文件的过程,因为build和publish都是在服务器中执行,可以通过编写shell部署脚本的方式,最终实现一键快速部署。

要使用git需要在服务器安装git客户端,并配置ssh公钥(配置公钥的目的是拉取私有的仓库,公开的仓库无需配置公钥)。

下面讲解具体的操作步骤:

首先安装git客户端,执行如下命令:

  1. yum -y install git

在安装过程如果出现错误:Couldn’t resolve host

Could not resolve host

一般是因为DNS服务器没有配置正确,解决办法:
1、打开文件/etc/resolv.conf在其中添加:

resolv.conf

2、退出保存后重启网络:

service network restart

git安装后,通过如下命令生成sshkey:

  1. # 这里的xx@xxx.com只是生成的sshkey的名称,并不约束货要求具体命名为某个邮箱。
  2. ssh-keygen -t rsa -C "xx@xxx.com"

按照提示,按三次回车,即可生成sshkey,如下图所示:
生成sshkey

通过如下命令可查看公钥:

  1. cat ~/.ssh/id_rsa.pub

复制生成后的sshkey,配置到代码仓库的公钥中。

查看公钥

公钥已经生成,如何在代码托管平台进行配置呢?

接下来我们将学习如何在gitee代码托管平台下配置公钥(github类似)。

进入私有仓库的【管理】页面,找到【公钥管理】,点击【添加公钥】,将刚刚生成的公钥复制过去,如下图所示:

添加公钥

出现类似于Hi xxx的字样,则表示git公钥配置成功了。

  1. ssh -T git@gitee.com

次使用需要确认并添加主机到本机SSH可信列表,如下图所示:

添加主机到本机SSH可信列表

输入yes后,出现类似于Hi xxx的字样,则表示git公钥配置成功了。

在前面我们已经做好了部署前的准备工作,安装了xshell、xftp、git、对仓库配置了公钥等。

接下来我们将在linux服务器上安装.net core sdk。

.NET运行时是.NET程序运行的先决条件,而SDK并不是必须的,但如果通过git方式进行文件中转的话,就需要到在服务器端进行编译,所以SDK也需要安装。(注:docker部署方式无需在服务器安装SDK和运行时,在后面的文章中我们介绍

下面一起看看在CentOs中如何安装SDK和运行时(其他环境可参考官方文档:https://docs.microsoft.com/zh-cn/dotnet/core/install/linux)。

在安装 .NET 之前,我们需要将 Microsoft 包签名密钥添加到受信任密钥列表,并添加 Microsoft 包存储库。如果之前安装过.NET Core3.1 ,那么这个步骤可以省略

运行如下命令,将 Microsoft 包签名密钥添加到受信任密钥列表,并添加 Microsoft 包存储库。

  1. sudo rpm -Uvh https://packages.microsoft.com/config/centos/7/packages-microsoft-prod.rpm

将 Microsoft 包签名密钥添加到受信任密钥列表

通过如下命令安装SDK:

  1. sudo yum install -y dotnet-sdk-5.0

安装dotnetsdk50

.NET Core SDK 使你可以通过 .NET Core来 开发我们的应用。

安装完成后,可以验证安装。

dotnet --info

验证net core安装

通过如下命令安装netcore运行时:

  1. sudo yum install -y aspnetcore-runtime-5.0

注:上述命令中的最后的5.0表示的是版本号,如果安装其他版本如:3.1,修改对应的版本号即可。参考资料:https://dotnet.microsoft.com/download/dotnet-core

如果已经安装了安装 .NET Core SDK,则无需安装相应的运行时,在上面我们已经安装了sdk,再安装运行时会提示已经安装,如下图所示。

aspnetcore-runtime

在前面的准备工作中我们介绍了两种将文件发布到服务器的方式,分别为:xftp与git,下面我们分别演示这两种方式的方法与步骤。

首先,准备好要发布的程序,
下图是我创建的一个.NET5.0的示例代码:

image-20210113161511112

image-20210113161527341

可以通过打开vs的程序包管理器控制台,执行如下命令进行发布:

  1. dotnet publish -o ./publish

也可以右键项目发布,发布到文件夹中,如下图所示。

image-20210113162327320

在这儿需要注意的是框架依赖部署模式,因为之前我们已经安装了.NET Core环境,这里就不使用独立部署模式了,默认也就是“框架依赖”。

image-20210113175714504

框架依赖部署:

依赖框架的部署 (FDD) 依赖目标系统上存在共享系统级版本的 .NET Core。 由于已存在 .NET Core,因此应用在 .NET Core 安装程序间也是可移植的。 应用仅包含其自己的代码和任何位于 .NET Core 库外的第三方依赖项。 FDD 包含可通过在命令行中使用 dotnet 实用程序启动的 .dll 文件。 例如,dotnet app.dll 就可以运行一个名为 app 的应用程序。
对于 FDD,仅部署应用程序和第三方依赖项。 不需要部署 .NET Core,因为应用将使用目标系统上存在的 .NET Core 版本。 这是定目标到 .NET Core 的 .NET Core 和 ASP.NET Core 应用程序的默认部署模型

优点:
①、不需要提前定义 .NET Core 应用将在其上运行的目标操作系统。 因为无论什么操作系统,.NET Core 的可执行文件和库都是用通用的 PE 文件格式,因此,无论什么基础操作系统,.NET Core 都可执行应用。
②、部署包很小。 只需部署应用及其依赖项,而无需部署 .NET Core 本身。
③、许多应用都可使用相同的 .NET Core 安装,从而降低了主机系统上磁盘空间和内存使用量。

缺点:
①、仅当主机系统上已安装你设为目标的 .NET Core 版本或更高版本时,应用才能运行。
②、如果不了解将来版本,.NET Core 运行时和库可能发生更改。 在极少数情况下,这可能会更改应用的行为。

独立部署:

独立部署 (SCD) 不依赖目标系统上存在的共享组件。 所有组件(包括 .NET Core 库和 .NET Core 运行时)都包含在应用程序中,并且独立于其他 .NET Core 应用程序。 SCD 包括一个可执行文件(如 Windows 平台上名为 app 的应用程序的 app.exe),它是特定于平台的 .NET Core 主机的重命名版本,还包括一个 .dll 文件(如 app.dll),而它是实际的应用程序。
对于独立部署,可以部署应用和所需的第三方依赖项以及生成应用所使用的 .NET Core 版本。 创建 SCD 不包括各种平台上的 .NET Core 本机依赖项,因此运行应用前这些依赖项必须已存在

优点:
①、可以对与应用一起部署的 .NET Core 版本具有单独的控制权
②、目标系统可以运行你的 .NET Core 应用,因为你提供的是应用将在其上运行的 .NET Core 版本

缺点:
①、由于 .NET Core 包含在部署包中,因此必须提前选择为其生成部署包的目标平台
②、部署包相对较大,因为需要将 .NET Core 和应用及其第三方依赖项包括在内。
③、向系统部署大量独立的 .NET Core 应用可能会使用大量磁盘空间,因为每个应用都会复制 .NET Core 文件

image-20210116111525878

在上图可以看到,发布之后的文件的路径为:bin/Release/net5.0/publish/

image-20210113162422379

打开Xftp,将publish文件夹拖到Xftp右侧窗口,即可完成上传。

image-20210113162958593

切换到发布的目录,启动运行,如下图所示,成功运行。

image-20210113165147617

也可以指定端口

  1. #启动站点,自定义端口号,运行环境
  2. dotnet Core50Test.dll --urls="http://*:8081;http://*:8082" --environment=Development

这里urls配置,如果需要局域网或者外网访问,不能填成urls=”http://localhost:8081;http://localhost:8082

首先,将代码推送到git仓库中,复制SSH地址。如下图所示:

image-20210113163255139

然后在服务器中,执行克隆命令:

  1. mkdir core50test
  2. cd core50test
  3. git clone git@gitee.com:******/core50test.git

执行结果如下图所示:

git克隆

此时项目代码已经下载到服务器中,切换工作目录到解决方案所在的目录。

  1. cd core50test

然后执行dotnet publish命令对程序进行编译发布。

  1. dotnet publish -o /yonghu/web/publish

执行完毕后,编译发布后的文件将被保存在/yonghu/web/publish目录中。

image-20210113164049764

将工作目录切换到/yonghu/web/publish,执行如下命令:

  1. dotnet core50test.dll

执行结果如下图:

image-20210113164425166

到这里为止,咱们的程序已经在linux服务器运行起来了。

image-20210113164755688

通过上在的介绍,相信很多小伙伴已经对.netcore项目到linux的发布有了深刻的认识了,但这些操作还是略显繁琐,启动、停止、摘取等都是单独的去处理,下次文章我们将介绍通过配置使用Supervisor+Nginx,以及shell脚本来实现.net core的高效部署。

 

作者|国思软件

原文链接:https://www.cnblogs.com/88223100/archive/2023/04/28/The-most-comprehensive-solution-for-deploying-NET-Core-to-Linux-CentOS-general-section.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:.NET Core部署到linux(CentOS)最全解决方案,常规篇 - Python技术站

(0)
上一篇 2023年4月28日
下一篇 2023年4月28日

相关文章

  • Asp.Mvc 2.0用户客户端验证实例讲解(3)

    Asp.Mvc 2.0用户客户端验证实例讲解是一篇教程文章,介绍了如何使用Asp.Mvc 2.0实现用户客户端验证。下面是Asp.Mvc 2.0用户客户端验证实例讲解的完整攻略。 1. 概述 本文将介绍如何使用Asp.Mvc 2.0实现用户客户端验证,在前后端分离开发中,用户客户端验证是非常重要的,可以在一定程度上减少请求次数,提高用户体验,同时还可以避免一…

    C# 2023年5月31日
    00
  • ASP.NET Core使用Swagger/OpenAPI规范

    ASP.NET Core使用Swagger/OpenAPI规范 Swagger/OpenAPI是一种用于描述RESTful API的规范,它可以帮助开发人员更好地理解和使用API。在本攻略中,我们将讨论如何在ASP.NET Core应用程序中使用Swagger/OpenAPI规范,并提供两个示例说明。 步骤一:安装Swashbuckle.AspNetCore…

    C# 2023年5月17日
    00
  • ASP.NET Core MVC中的标签助手(TagHelper)用法

    ASP.NET Core MVC 中的标签助手(TagHelper)用法 在 ASP.NET Core MVC 中,标签助手(TagHelper)是一种非常有用的工具,可以帮助开发人员更轻松地创建 HTML 标记。本攻略将详细介绍 ASP.NET Core MVC 中的标签助手用法,并提供多个示例说明。 步骤一:创建标签助手 在 ASP.NET Core M…

    C# 2023年5月17日
    00
  • c#根据网址抓取网页截屏生成图片的示例

    当我们需要对网页进行截屏处理时,一种常见的做法就是使用C#语言中的WebBrowser类来实现。下面是使用C#根据网址抓取网页截屏生成图片的示例攻略: 步骤一:创建Winform应用程序 首先我们需要创建一个Winform应用程序,用于显示网络页面截图。具体步骤如下: 打开Visual Studio,并创建一个新的Winform应用程序。 在主窗口下,添加一…

    C# 2023年6月7日
    00
  • 解析C#网络编程中的Http请求

    解析C#网络编程中的Http请求可以分为以下几个步骤: 1. 构造HttpWebRequest对象 在C#网络编程中,我们使用HttpWebRequest对象来发起一次HTTP请求。构造HttpWebRequest对象需要指定请求的URL、请求方法等参数。下面是一个构造HttpWebRequest对象的示例代码: HttpWebRequest request…

    C# 2023年5月31日
    00
  • C#中的Task.Delay()和Thread.Sleep()区别(代码案例)

    下面是详细讲解“C#中的Task.Delay()和Thread.Sleep()区别(代码案例)”的完整攻略。 简介 在C#中,Task.Delay()和Thread.Sleep()都是让当前线程进行暂停的方法,但它们的底层实现不同,使用时需要注意它们的区别。 Task.Delay() Task.Delay()是一个异步的方法,用于在特定的时间间隔后才恢复线程…

    C# 2023年6月6日
    00
  • C#实现的MD5加密功能与用法示例

    C#实现的MD5加密功能与用法示例 MD5简介 MD5是一种常用的密码散列函数,常用于数据加密、检验消息完整性和数字签名等。该算法由美国密码学家罗纳德·李维斯特(Ronald Linn Rivest)设计,MD5的全称是“Message-Digest Algorithm 5”,即消息摘要算法第5版。 MD5的实现 在C#中实现MD5加密功能,可以通过引用Sy…

    C# 2023年6月7日
    00
  • C# Equals(Object):确定指定的对象是否等于当前对象

    C# 的 Equals(Object) 方法用于比较两个对象是否相等。它的返回值类型是 bool,如果两个对象相等则返回 true,否则返回 false。 比较对象相等的方式需要根据对象类型的不同而有所调整。在比较值类型时,Equals方法会比较值本身;而在比较引用类型时,Equals方法会比较引用所指向的对象的地址是否相同。如果想比较引用型变量是否相等,需…

    C# 2023年4月19日
    00
合作推广
合作推广
分享本页
返回顶部