Linux守護進程管理利器——Supervisor

来源:https://www.cnblogs.com/qtxy/archive/2019/03/27/10607952.html
-Advertisement-
Play Games

Supervisor是採用 Python(2.4+) 開發的,它是一個允許用戶管理 基於 Unix 系統進程的 Client/Server 系統,提供了大量功能來實現對進程的管理。安裝: 安裝完成之後,在 /ect/supervisor/conf.d/ 目錄下新建一個配置文件( touch Hell ...


Supervisor是採用 Python(2.4+) 開發的,它是一個允許用戶管理 基於 Unix 系統進程的 Client/Server 系統,提供了大量功能來實現對進程的管理。
安裝:

yum install supervisor

安裝完成之後,在 /ect/supervisor/conf.d/ 目錄下新建一個配置文件( touch HelloWebApp.conf ),取名為 HelloWebApp.conf

打開HelloWebApp.conf ( vim HelloWebApp.conf ),寫入如下命令:

[program:HelloWebApp]
command=dotnet HelloWebApp.dll #要執行的命令
directory=/home/yxd/Workspace/publish #命令執行的目錄
environment=ASPNETCORE__ENVIRONMENT=Production #環境變數
user=www-data #進程執行的用戶身份
stopsignal=INT
autostart=true #是否自動啟動
autorestart=true #是否自動重啟
startsecs=1 #自動重啟間隔
stderr_logfile=/var/log/HelloWebApp.err.log #標準錯誤日誌
stdout_logfile=/var/log/HelloWebApp.out.log #標準輸出日誌

配置好以後 ( :wq 保存退出),需要重新載入一下配置

sudo supervisorctl shutdown && sudo supervisord -c /etc/supervisor/supervisord.conf

或者你可以直接重啟 Supervisor:

sudo service supervisor stop
sudo service supervisor start

如果啟動的時候報錯,可以打開位於/etc/log/supervisor/supervisord.log文件來查看具體的日誌。

其中dotnet 命令輸出的日誌文件分別為位於

/var/log/HelloWebApp.err.log
/var/log/HelloWebApp.out.log

常用命令

sudo service supervisor stop 停止supervisor服務

sudo service supervisor start 啟動supervisor服務

supervisorctl shutdown #關閉所有任務

supervisorctl stop|start program_name #啟動或停止服務

supervisorctl status #查看所有任務狀態

 

supervisord.conf配置文件說明:

[unix_http_server]
file=/tmp/supervisor.sock   ;UNIX socket 文件,supervisorctl 會使用
;chmod=0700                 ;socket文件的mode,預設是0700
;chown=nobody:nogroup       ;socket文件的owner,格式:uid:gid

;[inet_http_server]         ;HTTP伺服器,提供web管理界面
;port=127.0.0.1:9001        ;Web管理後臺運行的IP和埠,如果開放到公網,需要註意安全性
;username=user              ;登錄管理後臺的用戶名
;password=123               ;登錄管理後臺的密碼

[supervisord]
logfile=/tmp/supervisord.log ;日誌文件,預設是 $CWD/supervisord.log
logfile_maxbytes=50MB        ;日誌文件大小,超出會rotate,預設 50MB,如果設成0,表示不限制大小
logfile_backups=10           ;日誌文件保留備份數量預設10,設為0表示不備份
loglevel=info                ;日誌級別,預設info,其它: debug,warn,trace
pidfile=/tmp/supervisord.pid ;pid 文件
nodaemon=false               ;是否在前臺啟動,預設是false,即以 daemon 的方式啟動
minfds=1024                  ;可以打開的文件描述符的最小值,預設 1024
minprocs=200                 ;可以打開的進程數的最小值,預設 200

[supervisorctl]
serverurl=unix:///tmp/supervisor.sock ;通過UNIX socket連接supervisord,路徑與unix_http_server部分的file一致
;serverurl=http://127.0.0.1:9001 ; 通過HTTP的方式連接supervisord

; [program:xx]是被管理的進程配置參數,xx是進程的名稱
[program:xx]
command=/opt/apache-tomcat-8.0.35/bin/catalina.sh run  ; 程式啟動命令
autostart=true       ; 在supervisord啟動的時候也自動啟動
startsecs=10         ; 啟動10秒後沒有異常退出,就表示進程正常啟動了,預設為1秒
autorestart=true     ; 程式退出後自動重啟,可選值:[unexpected,true,false],預設為unexpected,表示進程意外殺死後才重啟
startretries=3       ; 啟動失敗自動重試次數,預設是3
user=tomcat          ; 用哪個用戶啟動進程,預設是root
priority=999         ; 進程啟動優先順序,預設999,值小的優先啟動
redirect_stderr=true ; 把stderr重定向到stdout,預設false
stdout_logfile_maxbytes=20MB  ; stdout 日誌文件大小,預設50MB
stdout_logfile_backups = 20   ; stdout 日誌文件備份數,預設是10
; stdout 日誌文件,需要註意當指定目錄不存在時無法正常啟動,所以需要手動創建目錄(supervisord 會自動創建日誌文件)
stdout_logfile=/opt/apache-tomcat-8.0.35/logs/catalina.out
stopasgroup=false     ;預設為false,進程被殺死時,是否向這個進程組發送stop信號,包括子進程
killasgroup=false     ;預設為false,向進程組發送kill信號,包括子進程

;包含其它配置文件
[include]
files = relative/directory/*.ini    ;可以指定一個或多個以.ini結束的配置文件

 


 參考文章:

ASP.NET Core Linux下為 dotnet 創建守護進程(必備知識)

Linux配置Supervisor 配置遇到的坑


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 之前花了很長的一段時間研究之後,以便把(第三方或)系統的和應用的dll分開,最後還寫了一篇文章介紹,木有想到,今天又入坑了,發現了一個bug。 ...
  • 本文將會根據情況持續更新。 作為一個 `Framework`,`ASP.NET Core` 提供了諸多的擴展點。使用內置的組件和預設的配置通常就能夠滿足部分需求,當需要擴展的時就需要先去找出這些擴展點。除了基於實際應用對 `ASP.NET Core` 進行擴展,也會故意搞一些不切實際的偽需求,解決一... ...
  • 是這樣的,大概10天前,我忽然就想造個輪子,這個輪子的主要作用是收集客戶端的日誌,通過服務端存儲到指定的持久化介質中。客戶端和服務端都可以通過簡單的配置實現快速接入 ...
  • C#訪問修飾符,無時無刻都在使用,這裡記錄一下,如果寫錯的地方,歡迎指正。 總結:類只能被定義為public或internal,嵌套類除外,因為嵌套類也具有成員的形態,同時嵌套類可以訪問所屬類的所有成員,包括私有成員!類預設的訪問修飾符是internal,也可以被修飾為public。 參考: htt ...
  • 原文地址:http://www.entityframeworktutorial.net/basics/what-is-entity-in-entityframework.aspx EF中的實體就是繼承自DbContext類的上下文類中的,DbSet類型的實體類。EF API 將這樣的每個實體映射成數 ...
  • 問題 執行若幹個任務,只需要對其中任意一個的完成進行響應。這主要用於:對一個操作進行多種獨立的嘗試,只要一個嘗試完成,任務就算完成。例如,同時向多個 Web 服務詢問股票價格,但是只關心第一個響應的。 文中舉的是向多個Web服務詢問股票價格的例子。 我曾在過往的工作中遇到另一個不太相似的例子。一個問 ...
  • private void button1_Click(object sender, EventArgs e) { string txt = this.richTextBox1.Text; txt = txt.Replace("\n", ",").Replace(" ", "!"). Replac..... ...
  • KoobooJson - 更小更快的C# JSON序列化工具(基於表達式樹構建) 在C#領域,有很多成熟的開源JSON框架,其中最著名且使用最多的是 Newtonsoft.Json ,然而因為版本迭代,其代碼要相容從net2.0到現在的最新的net框架,並且要支持.net平臺下的其它語言,所以最新發 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...