亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

利用Supervisor管理Redis進程的方法教程

發布時間:2020-09-30 17:58:03 來源:腳本之家 閱讀:178 作者:haozlee 欄目:數據庫

前言

Supervisor 是一個用 Python 實現的進程管理工具,可以很方便地啟動,關閉,重啟,查看,以及監控進程,當進程由于某種原因崩潰或者被誤殺后,可以自動重啟并發送事件通知。Supervisor 可謂運維利器,使用 Supervisor 來管理進程,可以提高系統的高可用特性。

隨著 Redis 越來越流行,越來越多的公司都使用上了 redis,因此 Redis 的進程管理就成了很多公司都需要面臨的問題,本文介紹如何使用 Supervisor 來管理 Redis 進程。

Supervisor 簡介

Supervisor 包括以下四個組件。

1、supervisord

服務端程序,主要功能是啟動 supervisord 服務及其管理的子進程,記錄日志,重啟崩潰的子進程,等。

2、supervisorctl

命令行客戶端程序,它提供一個類似 shell 的接口,通過 UNIX 域套接字或者 TCP 套接字并使用 XML_RPC 協議與 supervisord 進程進行數據通信。它的主要功能是管理(啟動,關閉,重啟,查看狀態)子進程。

3、Web Server

實現在界面上管理進程,還能查看進程日志和清除日志。

4、XML-RPC 接口

可以通過 XML_RPC 協議對 supervisord 進行遠程管理,達到和 supervisorctl 以及 Web Server 一樣的管理功能。

進程被 Supervisor 管理后,其運行狀態的轉化圖如下圖 1 所示:

利用Supervisor管理Redis進程的方法教程

圖 1 :子進程狀態轉移圖

我們挑幾個重要的進程狀態來說明。

  • running:進程處于運行狀態
  • starting:Supervisor 收到啟動請求后,進程處于正在啟動過程中
  • stopped:進程處于關閉狀態
  • stopping:Supervisor 收到關閉請求后,進程處于正在關閉過程中
  • backoff:進程進入 starting 狀態后,由于馬上就退出導致沒能進入 running 狀態
  • fatal:進程沒有正常啟動
  • exited:進程從 running 狀態退出

沒有接觸過 Supervisor 的朋友可能對上面的描述感到有些抽象,不用擔心,經過下面的實踐后,會快速理解 Supervisor 涉及的這些名詞的。

Supervisor 初體驗

我們以 CentOS 平臺下為例,說明如何使用 Supervisor 這一強大的進程管理工具。

1. 安裝

可以使用easy_intall來安裝 Supervisor:

easy_install supervisor

也可以使用pip來安裝 Supervisor:

pip install supervisor

安裝過程比較簡單,此處我們不再贅述。

安裝完畢后,可以使用以下命令來測試安裝是否成功:

echo_supervisord_conf

echo_supervisord_conf將會在終端輸出 Supervisor 配置的樣例。

2. 創建配置目錄以及主配置文件

為了將 Supervisor 的配置放置到獨立的目錄中,我們先創建目錄:

cd /etc
mkdir supervisor

接著,可以繼續使用echo_supervisord_conf命令,將 Supervisor 樣例配置重定向輸出到文件文件中:

echo_supervisord_conf > /etc/supervisor/supervisord.conf

這樣,我們便生成了 Supervisor 的主配置文件supervisord.conf。

為了將 Supervisor 管理的進程配置與主配置文件區分開來,我們創建獨立的目錄來存放進程配置。

cd /etc/supervisor
mkdir conf.d

然后,修改主配置文件 supervisord.conf,添加以下配置,將 conf.d 目錄下的進程配置引入 Supervisor 管理:

[include]
files = ./conf.d/*.ini

3. 創建管理進程

為方便測試 Supervisor 的功能,我們編寫以下 python 腳本,并保存為 hello.py。

import time
import sys
while True:
  print("hello\n")
  sys.stdout.flush()
  time.sleep(1)

hello.py 的主要功能是往標準輸出中不斷地輸出 “hello” 字符串。

4. 創建進程配置

為將 hello.py 腳本被 Supervisor 接管,我們在 /etc/supervisor/conf.d 目錄創建其配置 hello.ini:

[program:hello]
command=python /home/lihao/codes/python/hello.py    
stdout_logfile=/home/lihao/codes/python/hello.log
stderr_logfile=/home/lihao/codes/python/hello_error.log
  • command:運行進程使用的命令
  • stdout_logfile:指定標準輸出文件
  • stderr_logfile:標準錯誤輸出文件

需要指出的是,被 Supervisor 管理的進程,不能使用 daemon 模式,而必須在前臺運行,否則會報錯。

5. 運行 supervisord

由于我們需要使用指定目錄下的 Supervisor 主配置文件,在運行 Supervisord 時,需要使用-c參數來指定主配置文件的路徑:

supervisord -c /etc/supervisor/supervisord.conf

6. 使用 supervisorctl 管理進程

使用 supervisorctl 可以查看監控的進程狀態:

supervisorctl -c /etc/supervisor/supervisord.conf

輸出:

hello RUNNING pid 8475, uptime 7:59:46
supervisor>

可以看到,腳本 hello.py 已經運行了起來(當然使用 ps aux | grep hello也可以看到其進程信息)。打開文件 /home/lihao/codes/python/hello.log,可以看到文件中不斷有”hello”輸出。

在 supervisorctl 命令行下,也可以使用start,stop,restart,status,等命令來啟動,關閉,重啟,查看狀態監控的進程,也可以輸入help來查看命令幫助。限于篇幅,此處不再展開,詳細的 supervisorctl 命令可以參考:http://www.supervisord.org/running.html#running-supervisorctl。

Supervisor 管理 Redis 進程

在說完 Supervisor 的基本使用后,我們來看下如何使用 Supervisor 來管理 Redis 進程。

Redis 的 Supervisor 配置

有了上面的基礎,我們很容易寫出 Redis 服務進程的 Supervisor 配置:

[program:redis]
command=/usr/local/bin/redis-server
autostart=true
autorestart=true
startsecs=3

使用 supervisorctl reload 載入新的 Redis 配置后,Redis 進程便讓 Supervisor 啟動了起來。如果需要指定 Redis 的輸出日志,可以通過stdout_logfile配置選項指定,具體也可以參考上述的 hello 例子。

由于 Supervisor 管理的進程不能設置為 daemon 模式,故如果 Redis 無法正常啟動,可以查看一下 Redis 的配置,并將daemonize選項設置為 no。

daemonize no

Supervisord 開機啟動

為了處理機器宕機重啟的情況,Redis 服務進程需要實現機器重啟后自動重啟的功能。 為此,需要配置 supervisord 進程隨著機器啟動而啟動。要實現這一目的 ,可以在 /etc/init 目錄下添加 supervisord.conf 文件:

description  "supervisord"
start on runlevel [2345]
stop on runlevel [!2345]

respawn

exec supervisord -n -c /etc/supervisor/supervisord.conf

這樣,每當機器重啟后,supervisord 進程都會自動啟動起來,避免機器每次重啟后都需要手工啟動 supervisord 進程的操作。Supervisord 進程啟動后,接下來會將其管理的進程自動地啟動起來。這樣,便實現了被 Supervisor 管理的進程隨著機器啟動而啟動的效果。讀者可以自行在測試機器上測試一下。

Supervisor Web 管理界面

如果需要開啟 Web 管理界面功能,需要在supervisord.conf配置中添加以下配置:

[inet_http_server]
port=*:9001
username=user
password=123

然后,打開瀏覽器,輸入地址 http://127.0.0.1:9001,這時,會彈出輸入框,要求輸入用戶名和密碼(用戶名:user,密碼:123),便可以進入 Supervisor 提供的進程管理界面。

利用Supervisor管理Redis進程的方法教程

圖 2 :Supervisor Web 管理界面

在此界面下,可以對單個進程進行重啟,關閉,查看日志等操作,也可以對所有的進程進行重啟,關閉等操作。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

參考資料

  • http://www.supervisord.org/
  • Python Web 開發實戰,董偉明著,電子工業出版社
  • http://www.jianshu.com/p/9abffc905645
  • http://www.supervisord.org/running.html#running-supervisorctl
  • http://supervisord.org/configuration.html
  • http://www.supervisord.org/subprocess.html
  • https://lincolnloop.com/blog/automatically-running-supervisord-startup/
  • https://serverfault.com/questions/96499/how-to-automatically-start-supervisord-on-linux-ubuntu
  • https://segmentfault.com/a/1190000003955182
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巫溪县| 竹山县| 大冶市| 涞源县| 太和县| 霸州市| 昂仁县| 宁强县| 黑河市| 西盟| 崇州市| 如东县| 来宾市| 长治市| 海口市| 顺平县| 福鼎市| 荥阳市| 正阳县| 万宁市| 宣汉县| 剑阁县| 陇川县| 策勒县| 南投市| 资中县| 西平县| 海兴县| 沙雅县| 绍兴市| 社会| 仁布县| 新田县| 通山县| 大丰市| 饶阳县| 田东县| 明溪县| 延长县| 郑州市| 彭山县|