成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

.NET Worker Service 部署到 Linux 作為 Systemd Service 運行

系統(tǒng) Linux
在本文中,我通過一個實例詳細介紹了如何將 .NET Worker Service 部署到 Linux 系統(tǒng)作為 Systemd Service 運行,并說明了如何使用 systemctl 命令來管理服務,如何使用 journalctl 命令查看 Systemd 服務日志。

[[407943]]

本文轉載自微信公眾號「技術譯站」,作者技術譯站。轉載本文請聯(lián)系技術譯站公眾號。

今天我接著介紹一下如何將 Worker Service 部署到 Linux 上,并作為 Systemd Service 運行。

我在本文中要覆蓋的內容包含:

  • 作為 Linux 控制臺程序運行
  • 作為 Systemd Service 運行
  • 開機自動啟動、查看日志信息

創(chuàng)建項目并發(fā)布

§下載 Worker Service 源碼

我將基于上一篇文章中的 Worker Service 源碼來修改,如果您安裝有 git,可以用下面的命令獲取它:

  1. git clone git@github.com:ITTranslate/WorkerServiceAsWindowsService.git 

然后,使用 Visual Studio Code 打開此項目,構建一下,以確保一切正常:

  1. dotnet build 

§刪除用不到的依賴項

刪除上一篇文章中用于 Windows Services 的依賴程序包:

  1. git clone git@github.com:ITTranslate/WorkerServiceAsWindowsService.git 

然后,刪除 Program.cs 中的 .UseWindowsService() 方法調用。

§修改配置文件

打開配置文件 appsettings.json,將日志文件保存路徑中的 \ 改為 /,其他不用做任何更改。

  1.   "Name""RollingFile"
  2.   "Args": { 
  3.     "pathFormat""Logs/{Hour}.log"
  4.     "outputTemplate""{Timestamp:o} [{Level:u3}] ({MachineName}/{ProcessId}/{ProcessName}/{ThreadId}) {Message}{NewLine}{Exception}" 
  5.   } 
  6. }, 
  7.   "Name""SQLite"
  8.   "Args": { 
  9.     "sqliteDbPath""Logs/log.db"
  10.     "tableName""Logs"
  11.     "maxDatabaseSize": 1, 
  12.     "rollOver"true 
  13.   } 

這是因為 Windows 中使用反斜杠 \ 來表示目錄,而 Linux 中使用正斜杠 / 來表示目錄。

假如不修改保存路徑,您將會看到日志被保存成如下的尷尬文件名:

  1. 'Logs\2021061715.log' 
  2. 'Logs\log.db' 

§發(fā)布程序

運行 dotnet publish 命令將應用程序及其依賴項發(fā)布到文件夾。

  1. dotnet publish -c Release -r linux-x64 -o c:\test\workerpub\linux 

這里我使用 -r linux-x64 參數(shù),指定發(fā)布獨立部署于 Linux 系統(tǒng)的應用程序。

命令運行完成后,您會在 C:\test\workerpub\linux 文件夾中看到適用于 Linux 系統(tǒng)的可執(zhí)行程序及其所有依賴項。

作為 Linux 控制臺程序運行

將文件夾 C:\test\workerpub\linux 下的文件壓縮為 linux.zip。

打開 Xshell 工具,連接到一臺 Linux 測試機(我的測試機操作系統(tǒng)為 CentOS 7.3),在測試機上新建 /srv/Worker 目錄:

  1. mkdir /srv/Worker 

使用 rz 命令將 linux.zip 復制到測試機,

然后在測試機上解壓 linux.zip 到 /srv/Worker 目錄:

  1. unzip linux.zip -d /srv/Worker 

為我們的應用程序分配可執(zhí)行權限,并運行:

  1. # 分配可執(zhí)行權限 
  2. chmod +x /srv/Worker/MyService 
  3. # 運行 
  4. /srv/Worker/MyService 

按下 Ctrl+C 關閉應用,等待關閉前必須完成的任務正常結束后,應用退出。輸入 ls /srv/Worker 命令回車,您會看到在該目錄下多了一個 Logs 目錄,日志文件輸出正常。

作為 Systemd Service 運行

§添加 Systemd Service 依賴

為了讓我們的 Worker 監(jiān)聽來自 Systemd 的啟動和停止信號,我們需要添加 Microsoft.Extensions.Hosting.Systemd NuGet 包:

  1. dotnet add package Microsoft.Extensions.Hosting.Systemd 

然后,我們需要修改 Program.cs 中的 CreateHostBuilder 方法,添加 UseSystemd 方法調用,將宿主(Host)生命周期設置為 Microsoft.Extensions.Hosting.Systemd.SystemdLifetime,以便應用程序可以接收啟動和停止信號,并配置控制臺輸出記錄為 systemd 格式。

  1. public static IHostBuilder CreateHostBuilder(string[] args) => 
  2.     Host.CreateDefaultBuilder(args) 
  3.         .UseSystemd() // Sets the host lifetime to Microsoft.Extensions.Hosting.Systemd.SystemdLifetime... 
  4.         .ConfigureServices((hostContext, services) => 
  5.         { 
  6.             services.AddHostedService<Worker>(); 
  7.         }) 
  8.         .UseSerilog(); //將 Serilog 設置為日志提供程序 

重新運行以下命令將程序發(fā)布到文件夾:

  1. dotnet publish -c Release -r linux-x64 -o c:\test\workerpub\linux 

然后重復前面的步驟,在 Xshell 中使用 rz 命令將應用程序復制到測試機,并為 /srv/Worker/MyService 文件分配可執(zhí)行權限。

§配置文件

接下來我們需要創(chuàng)建配置文件,將服務的有關信息告知 systemd,以便它知道如何運行此服務。為此,我們需要創(chuàng)建一個 .service 文件,我們將在注冊和運行此服務的 Linux 機器上使用該文件。

在我們的項目中創(chuàng)建一個名為 MyService.service 的服務單元配置文件,內容如下:

  1. [Unit] 
  2. Description=Long running service/daemon created from .NET worker template 
  3.  
  4. [Service] 
  5. # The systemd service file must be configured with Type=notify to enable notifications. 
  6. Type=notify 
  7. # will set the Current Working Directory (CWD). Worker service will have issues without this setting 
  8. WorkingDirectory=/srv/Worker 
  9. # systemd will run this executable to start the service 
  10. ExecStart=/srv/Worker/MyService 
  11. to query logs using journalctl, set a logical name here   
  12. SyslogIdentifier=MyService 
  13.  
  14. # Use your username to keep things simple. 
  15. # If you pick a different user, make sure dotnet and all permissions are set correctly to run the app 
  16. To update permissions, use 'chown yourusername -R /srv/Worker' to take ownership of the folder and files, 
  17. #       Use 'chmod +x /srv/Worker/MyService' to allow execution of the executable file 
  18. User=yourusername 
  19.  
  20. # This environment variable is necessary when dotnet isn't loaded for the specified user
  21. To figure out this value, run 'env | grep DOTNET_ROOT' when dotnet has been loaded into your shell. 
  22. Environment=DOTNET_ROOT=/usr/share/dotnet/dotnet 
  23.  
  24. # This gives time to MyService to shutdown gracefully. 
  25. TimeoutStopSec=300 
  26.  
  27. [Install] 
  28. WantedBy=multi-user.target 

使用時應將 User=yourusername 項中的 yourusername 改為具體的 linux 系統(tǒng)的登錄名。

Systemd 期望所有的配置文件放置在 /etc/systemd/system/ 目錄下,我們打開此目錄,并使用 rz 命令將服務配置文件復制到 /etc/systemd/system/MyService.service,

  1. cd /etc/systemd/system/ 
  2.  
  3. rz 

然后執(zhí)行以下命令讓 systemd 重新加載配置文件:

  1. systemctl daemon-reload 

§管理服務

之后,可以運行以下命令來檢查 systemd 是否識別了我們的服務:

  1. systemctl status MyService 

結果顯示如下:

這表明我們注冊的新服務被禁用了,可以通過運行以下命令來啟動它:

  1. systemctl start MyService 

重新運行 systemctl status MyService 命令查看服務狀態(tài),顯示如下:

停止服務可以運行以下命令:

  1. systemctl stop MyService 

如果您希望該服務在開機時自動啟動,那么可以運行以下命令:

  1. systemctl enable MyService 

禁用開機自動啟動,可以運行以下命令:

  1. systemctl disable MyService 

查看服務是否開機自動啟動,可以運行以下命令:

  1. systemctl is-enabled MyService 

§Systemd 服務日志

命令 journalctl 可以用來查看 systemd 收集的日志。systemd-journald 服務負責 systemd 的日志收集,它從內核、systemd 服務和其他源檢索信息。日志的集中收集,有利于對其進行檢索查詢。journal 中的日志記錄是結構化和有索引的,因此 journalctl 能夠以各種有用的格式來展現(xiàn)日志信息。

我們可以使用 journalctl 命令來驗證應用程序是否成功運行,因為該命令可以跟蹤顯示應用程序的輸出信息:

  1. journalctl -u MyService -f 

按 Ctrl-C 退出命令。

當我們在程序中調用 UseSystemd 方法時,會將 Extensions.LogLevel 映射到 Syslog 日志級別:

LogLevel Syslog level systemd name
Trace/Debug 7 debug
Information 6 info
Warning 4 warning
Error 3 err
Critical 2 crit

所以,我們可以使用 journalctl 命令的優(yōu)先級標記(priority-flag)-p 來根據(jù)日志級別過濾應用程序的輸出信息:

  1. journalctl -p 4 -u MyService -f 

總結

在本文中,我通過一個實例詳細介紹了如何將 .NET Worker Service 部署到 Linux 系統(tǒng)作為 Systemd Service 運行,并說明了如何使用 systemctl 命令來管理服務,如何使用 journalctl 命令查看 Systemd 服務日志。

當我們向 HostBuilder 添加了 .UseSystemd() 方法調用后,編譯出的程序,既可以作為 Linux 控制臺應用運行,也可以作為 Systemd Service 運行。

您可以從 GitHub 下載本文中的源碼。

參考:

https://swimburger.net/blog/dotnet/how-to-run-a-dotnet-core-console-app-as-a-service-using-systemd-on-linux

https://devblogs.microsoft.com/dotnet/net-core-and-systemd/

https://docs.microsoft.com/zh-cn/dotnet/core/tools/dotnet-publish

https://www.freedesktop.org/wiki/Software/systemd/

https://systemd.io/

https://www.linode.com/docs/guides/how-to-use-journalctl/

https://github.com/ITTranslate/WorkerServiceAsWindowsService 前篇文章源碼

 

https://github.com/ITTranslate/WorkerServiceAsSystemdService 本文源碼

 

責任編輯:武曉燕 來源: 技術譯站
相關推薦

2022-04-26 09:16:07

PWA線程生命周期

2023-10-31 15:08:56

WorkBoxServiceWorker

2009-03-25 09:44:46

IBM云計算智慧地球

2021-03-03 08:18:54

Service組件

2009-11-27 13:45:02

Tomcat for

2010-12-24 09:36:15

部署Silverlig

2009-10-29 09:06:26

VB.NET Web

2009-10-13 11:22:46

VB.NET調用Web

2009-10-13 10:21:58

VB.NET實現(xiàn)Web

2009-10-13 09:33:49

VB.NET Web

2009-07-27 17:32:39

Web ServiceASP.NET

2009-07-27 09:07:04

Profile SerASP.NET AJA

2009-10-29 11:26:28

VB.NET調用Web

2017-10-18 15:28:08

Service WorPWA離線

2010-03-04 10:50:45

windows ser

2009-07-02 16:36:58

Python程序

2021-09-11 15:36:08

AWS云服務Amazon

2009-12-30 15:50:18

ADO.NET Dat

2021-06-02 08:07:59

LinuxService應用

2021-06-04 06:20:47

systemd定位工具系統(tǒng)運維
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 天天影视亚洲综合网 | 色噜噜狠狠色综合中国 | 三级黄片毛片 | 美女国产 | 国产精品久久av | av不卡一区 | 久久视频精品 | 不卡一二三区 | 中文字幕国 | 国产一区二区三区四区五区3d | 中文字幕在线第二页 | 亚洲综合三区 | 一区久久 | 中文字幕第二十页 | 久久免费观看视频 | 国产在线观看不卡一区二区三区 | 亚洲视频不卡 | 成年视频在线观看福利资源 | 精品国产18久久久久久二百 | 午夜免费在线观看 | 久久久久久网站 | 精品国产视频 | 日韩不卡一二区 | 中文字幕免费观看 | 欧美成人a| 成人欧美在线 | 91天堂| 成人影院在线 | 亚洲视频一区在线播放 | 久久久久久黄 | 欧美一级片在线观看 | 日本电影免费完整观看 | 免费网站国产 | 欧美日韩一区在线 | 精品久久久久久亚洲精品 | 国产黄色网址在线观看 | 久久精品视频免费观看 | 日韩在线观看一区二区三区 | 午夜久久久 | 国产一区 | 日韩欧美精品一区 |