解放程式員雙手之Supervisor

来源:https://www.cnblogs.com/coding-night/archive/2019/04/12/10694055.html
-Advertisement-
Play Games

前言 對於大部分程式員來說,主要工作都是進行編碼以及一些簡單的中間件安裝,這就導致了很多人對於“運維”相關的工作會比較生疏。例如當我們擁有一臺自己的伺服器以後,可能會在上面跑一跑自己blog程式,mysql,nginx等等。當程式越來越多了沒有一個統一的入口管理啟停,也可能會遇到一些特殊的原因導致程 ...


 

前言

 

對於大部分程式員來說,主要工作都是進行編碼以及一些簡單的中間件安裝,這就導致了很多人對於“運維”相關的工作會比較生疏。例如當我們擁有一臺自己的伺服器以後,可能會在上面跑一跑自己blog程式,mysql,nginx等等。當程式越來越多了沒有一個統一的入口管理啟停,也可能會遇到一些特殊的原因導致程式被kill掉了,這時候又沒裝相關的監控程式或者腳本(太麻煩了懶得裝,機器配置差不想裝),所以只能當我們訪問自己程式發現異常的時候才會登上伺服器查找原因。

 

這些狀況對我們來說是比較麻煩的,那麼這就需要一個“神器”來解放我們的雙手,鐺鐺鐺!!Supervisor 就來了。

 

正文

 

Supervisor 介紹

 

Supervisor是用Python開發的一套通用的進程管理程式,能將一個普通的命令行進程變為後臺daemon,並監控進程狀態,異常退出時能自動重啟。它是通過fork/exec的方式把這些被管理的進程當作supervisor的子進程來啟動,這樣只要在supervisor的配置文件中,把要管理的進程的可執行文件的路徑寫進去即可。也實現當子進程掛掉的時候,父進程可以準確獲取子進程掛掉的信息的,可以選擇是否自己啟動和報警。

 

supervisor 安裝

 

簡單粗暴

 

yum install supervisor -y

 

supervisor 配置說明

 

通過這種形式安裝的supervisor,其配置文件的目錄位於:
/etc/supervisord.conf (主配置文件,下麵會詳細介紹)
/etc/supervisor.d/ (預設子進程配置文件,也就是需要我們根據程式配置的地方)

 


 

supervisord.conf 基本配置項說明,由於其參數比較多,這些只貼出一些常用的配置項,詳細內容可參閱官網。溫馨提示“;” 符號是表示該行配置被註釋。

 

[unix_http_server]
file=/home/supervisor/supervisor.sock   ; supervisorctl使用的 socket文件的路徑
;chmod=0700                 ; 預設的socket文件許可權0700
;chown=nobody:nogroup       ; socket文件的擁有者

[inet_http_server]         ; 提供web管理後臺管理相關配置
port=0.0.0.0:9001          ; web管理後臺運行的ip地址及埠,綁定外網需考慮安全性 
;username=root             ; web管理後臺登錄用戶名密碼
;password=root

[supervisord]
logfile=/var/log/supervisord.log ; 日誌文件,預設在$CWD/supervisord.log
logfile_maxbytes=50MB        ; 日誌限制大小,超過會生成新文件,0表示不限制
logfile_backups=10           ; 日誌備份數量預設10,0表示不備份
loglevel=info                ; 日誌級別
pidfile=/home/supervisor/supervisord.pid ; supervisord pidfile; default supervisord.pid              ; pid文件
nodaemon=false               ; 是否在前臺啟動,預設後臺啟動false
minfds=1024                  ; 可以打開文件描述符最小值
minprocs=200                 ; 可以打開的進程最小值

[supervisorctl]
serverurl=unix:///home/supervisor/supervisor.sock ; 通過socket連接supervisord,路徑與unix_http_server->file配置的一致

 

[include]
files = supervisor.d/*.conf ;指定了在當前目錄supervisor.d文件夾下配置多個配置文件

  

準備測試項目

 

這裡我打包了一個簡單的spring-boot程式,存放與“/opt/project/”下。

在這個程式中我們只是簡單的定義了一個rest介面,主要用於演示作用。

@RestController
public class HelloController {

    @RequestMapping("/hello")
    public String hello(){
        return "hello world";
    }
}

 

如果不用supervisor的話,我們啟動程式一般用一下命令

nohup java -jar springboot-hello-sample.jar &

 

這是以後臺的方式啟動jar包,程式運行相關輸出會在nohup.out中,我們我們就不再贅述了,那麼我們來看一下,切換到supervisor的方式,我們是怎麼配置項目,以及管理的呢?

 
定義supervisor管理進程配置文件

 

從上面的配置文件[include]->files配置項我們可以知道,supervisor會把supervisor.d/下以conf結尾的配置文件都載入進來,那麼我們在這個目錄下麵新建一個sboot.conf,內容如下:

[program:sboot] ;[program:xxx] 這裡的xxx是指的項目名字
directory = /opt/project  ;程式所在目錄
command =  java -jar springboot-hello-sample.jar ;程式啟動命令
autostart=true ;是否跟隨supervisord的啟動而啟動
autorestart=true; 程式退出後自動重啟,可選值:[unexpected,true,false],預設為unexpected,表示進程意外殺死後才重啟
stopasgroup=true;進程被殺死時,是否向這個進程組發送stop信號,包括子進程
killasgroup=true;向進程組發送kill信號,包括子進程
stdout_logfile=/var/log/sboot/supervisor.log;該程式日誌輸出文件,目錄需要手動創建
stdout_logfile_maxbytes = 50MB;日誌大小
stdout_logfile_backups  = 100;備份數

 

可以看到,在配置文件裡面已經有配置該程式名,啟動路徑等,這樣一來,supervisor就可以完全的掌管程式的生死了。接著我們執行

service supervisord restart

重啟supervisord。

 
觀察效果

瀏覽器輸入:伺服器ip:9001 (這裡的web管理頁面埠是在配置文件配置好的。)

 

 

如圖所示,我們可以可以觀察到springboot程式已經是running狀態了,pid是27517,我們可以點擊Tail -f來觀察輸出日誌,它的作用跟我們在伺服器直接“tail -f”是類似的。

 

 

這裡我們為了方便演示就沒有添加驗證了,如果大家是在公網的使用環境,需要配置文件裡面的用戶名密碼驗證註釋打開。不然別人掃出你的後臺管理頁面就可以隨意控製程序了。

除了web管理頁面,還有一些簡單的命令也是需要我們掌握的。

直接在命令行輸入supervisorctl會展示當前已配置好的項目信息。

 

[root@wangzh supervisor.d]# supervisorctl
sboot                            RUNNING   pid 27517, uptime 0:18:04
supervisor>

 

然後可以執行

start/stop/restart sboot 來簡單控制項目的啟停等

  

其他常用命令

supervisorctl update #更新配置文件
supervisorctl reload #重新啟動配置的程式
supervisorctl stop all #停止全部管理進程

  

結語

只需要一點簡單的配置,就可以統一的管理我們的程式了,同時也可以在進程意外死掉的時候自動重啟,這些工作以後就交給supervisor了,我們只要掌握一點簡單的命令就可以“為所欲為”。

supervisor官網:http://www.supervisord.org/

文章首發於微信公眾號《深夜裡的程式猿》,轉載務必註明出處,侵權必究。


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

-Advertisement-
Play Games
更多相關文章
  • 以相同的速度從開始到結束的過渡效果: Internet Explorer 10、Firefox、Opera 和 Chrome 支持 transition-timing-function 屬性。 Safari 支持替代的 -webkit-transition-timing-function 屬性。 註 ...
  • this關鍵字是JavaScript中最複雜的機制之一,是一個特別的關鍵字,被自動定義在所有函數的作用域中,但是相信很多JavaScript開發者並不是非常清楚它究竟指向的是什麼。聽說你很懂this,是真的嗎? 請先回答第一個問題:如何準確判斷this指向的是什麼?【面試的高頻問題】 ——————— ...
  • 一、viewport視口 1.1什麼是屏幕尺寸、屏幕解析度、屏幕像素密度? 屏幕尺寸:指屏幕的對角線的長度,單位是英寸,常見的屏幕尺寸有3.5、3.7、4.2、4.7、5.0、5.5、6.0等。 屏幕解析度:指在橫縱向上的像素點數,單位是px,1px=1個像素點。一般以縱向像素*橫向像素來表示一個手 ...
  • 後端搭起大體的框架後,接著涉及到的就是如何將數據持久化的問題,也就是對資料庫進行 CURD 操作。 關於資料庫方案, mongodb 和 mysql 都使用過,但我選用的是 mysql ,原因: 1. 目前為止 mysql 與 mongodb 性能相差不大,尤其是 mysql 8.0 版本,速度非常 ...
  • 本文簡要介紹UML及類圖的相關知識。用少量例子講述類圖的一些語法規則,常用的符號表示。 ...
  • 定義: 為子系統中的一組介面提供一個一致的界面,此模式定義了一個高層介面,這個介面使得這一子系統更加容易使用。 結構:(書中圖,侵刪) 結構:(書中圖,侵刪) 一個簡潔易用的外觀類 一個複雜的子系統 實例: 書中提到了理財的例子,找理財經理就不用自己研究各種股票債券什麼了;致使我一度腦子裡只想到了房 ...
  • 首先我們知道Java是一門面向對象的語言 面向對象三大特性,封裝、繼承、多態。 封裝、繼承、多態 ↓ 無論是學習路線,還是眾人的口語習慣,都是按照這個這樣進行排序,這是有原因的。因為封裝好了才能繼承,封裝和繼承都是為多態做準備的。 多態的三個前提條件: 1、繼承關係 2、方法的重寫 3、向上轉型(即 ...
  • 定義: 定義: 定義一個操作中的演算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類可以不改變一個演算法的結構即可重定義該演算法的某些特定步驟。 結構:(書中圖,侵刪) 一個定義整體框架的父類 若幹不同具體實現的子類 實例: 我瞬間就想到了很多RPG游戲。 不同職業在新手村完成任務,最多就是打的怪名字 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...