.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日

相关文章

  • C#仿密保卡功能的简单实现代码

    下面是关于“C#仿密保卡功能的简单实现代码”的完整攻略: 1. 什么是仿密保卡功能? 仿密保卡,顾名思义,是指通过某些方法实现和模拟传统的硬件密保卡的功能。传统的硬件密保卡大多采用一些特定的加密算法和密码体系,将用户的身份信息和敏感数据存储在卡片内部,在用户身份验证和数据交换等场景中发挥重要作用。 仿密保卡则是通过软件的方式实现这些功能,不需要依赖于硬件卡片…

    C# 2023年6月6日
    00
  • C#中char和string的入门使用教程

    C#中char和string的入门使用教程 什么是char和string? 在C#中,char和string都是用来表示文本字符的数据类型。其中,char表示一个单一的字符(注意,是单引号扩起来的字符),而string则表示一串字符(双引号扩起来的字符串)。 char的使用 定义和初始化 定义一个char变量的方式是: char myChar; 同样,我们也…

    C# 2023年6月7日
    00
  • C# 匿名类型之 RuntimeBinderException

    匿名类型在某些场景下使用起来还是比较方便,比如某个类型只会使用一次,那这个时候定义一个 Class 就没有多少意义,完全可以使用匿名类型来解决,但是在跨项目使用时,还是需要注意避免出现 RuntimeBinderException 问题 问题描述 比如我们有一个 netstandard2.0 类型的类库项目,里面有一个这样的方法: public static…

    C# 2023年4月17日
    00
  • Unity实现俄罗斯方块(二)

    Unity实现俄罗斯方块(二)攻略 1. 前言 在上一篇文章《Unity实现俄罗斯方块(一)》中,我们实现了俄罗斯方块游戏的基本框架,包括生成指定形状的方块、方块下落、方块旋转、消行等基本功能。接下来,我们在这个基础上,继续实现俄罗斯方块游戏的其他功能,包括左右移动和加速下落。 下面,我们就一步一步来详细讲解如何实现这些功能。 2. 左右移动 在俄罗斯方块游…

    C# 2023年6月1日
    00
  • ASP.Net Core基于ABP架构配置To Json序列化

    ASP.NET Core是一个跨平台的开源框架,它已成为web应用程序开发的主流,而ABP则是一种ASP.NET Core应用程序架构,有助于开发大型的多租户应用程序。在ABP架构中,To Json序列化是一种常用的配置方式,可以将.NET对象转换为JSON格式的字符串。 下面是ASP.Net Core基于ABP架构配置To Json序列化的完整攻略: 首先…

    C# 2023年6月3日
    00
  • C#调用JS的几种方法

    下面我将详细讲解C#调用JS的几种方法,并提供两个示例说明。 目录 通过WebBrowser控件调用 通过接口调用 通过JavaScriptSerializer序列化调用 示例说明 示例一:通过WebBrowser控件调用 示例二:通过接口调用 通过WebBrowser控件调用 WebBrowser控件可以加载本地HTML文件,也可以通过设置Navigate…

    C# 2023年6月3日
    00
  • C#实现的ZPL条码打印类完整实例

    下面我将为你详细讲解“C#实现的ZPL条码打印类完整实例”的实现攻略。 一、什么是ZPL格式条码打印? ZPL是Zebra Printer Language的缩写,是指扎带打印机编程语言。ZPL格式是一种专为Zebra扎带打印机设计的打印格式,它可以指定条形码类型、字体、大小等打印参数。每个字符都是通过指令来打印的,因此程序员只需要填写打印指令,就可以打印出…

    C# 2023年6月7日
    00
  • C#基于WebSocket实现聊天室功能

    下面是C#基于WebSocket实现聊天室功能的完整攻略: 一、准备工作 在进行C#基于WebSocket实现聊天室功能前,我们需要做好以下准备工作: 1. 安装.Net环境 需要在本地安装.Net环境,建议安装.Net Core版本,以确保兼容性和稳定性。 2. 安装WebSocket库 需要在项目中引入WebSocket库,可以使用Nuget包管理器进行…

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