中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

利用Supervisor管理Redis進(jìn)程的方法教程

前言

站在用戶的角度思考問題,與客戶深入溝通,找到倉山網(wǎng)站設(shè)計(jì)與倉山網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都做網(wǎng)站、網(wǎng)站設(shè)計(jì)、外貿(mào)營銷網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、國際域名空間、虛擬主機(jī)、企業(yè)郵箱。業(yè)務(wù)覆蓋倉山地區(qū)。

Supervisor 是一個(gè)用 Python 實(shí)現(xiàn)的進(jìn)程管理工具,可以很方便地啟動,關(guān)閉,重啟,查看,以及監(jiān)控進(jìn)程,當(dāng)進(jìn)程由于某種原因崩潰或者被誤殺后,可以自動重啟并發(fā)送事件通知。Supervisor 可謂運(yùn)維利器,使用 Supervisor 來管理進(jìn)程,可以提高系統(tǒng)的高可用特性。

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

Supervisor 簡介

Supervisor 包括以下四個(gè)組件。

1、supervisord

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

2、supervisorctl

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

3、Web Server

實(shí)現(xiàn)在界面上管理進(jìn)程,還能查看進(jìn)程日志和清除日志。

4、XML-RPC 接口

可以通過 XML_RPC 協(xié)議對 supervisord 進(jìn)行遠(yuǎn)程管理,達(dá)到和 supervisorctl 以及 Web Server 一樣的管理功能。

進(jìn)程被 Supervisor 管理后,其運(yùn)行狀態(tài)的轉(zhuǎn)化圖如下圖 1 所示:

利用Supervisor管理Redis進(jìn)程的方法教程

圖 1 :子進(jìn)程狀態(tài)轉(zhuǎn)移圖

我們挑幾個(gè)重要的進(jìn)程狀態(tài)來說明。

  • running:進(jìn)程處于運(yùn)行狀態(tài)
  • starting:Supervisor 收到啟動請求后,進(jìn)程處于正在啟動過程中
  • stopped:進(jìn)程處于關(guān)閉狀態(tài)
  • stopping:Supervisor 收到關(guān)閉請求后,進(jìn)程處于正在關(guān)閉過程中
  • backoff:進(jìn)程進(jìn)入 starting 狀態(tài)后,由于馬上就退出導(dǎo)致沒能進(jìn)入 running 狀態(tài)
  • fatal:進(jìn)程沒有正常啟動
  • exited:進(jìn)程從 running 狀態(tài)退出

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

Supervisor 初體驗(yàn)

我們以 CentOS 平臺下為例,說明如何使用 Supervisor 這一強(qiáng)大的進(jìn)程管理工具。

1. 安裝

可以使用easy_intall來安裝 Supervisor:

easy_install supervisor

也可以使用pip來安裝 Supervisor:

pip install supervisor

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

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

echo_supervisord_conf

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

2. 創(chuàng)建配置目錄以及主配置文件

為了將 Supervisor 的配置放置到獨(dú)立的目錄中,我們先創(chuàng)建目錄:

cd /etc
mkdir supervisor

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

echo_supervisord_conf > /etc/supervisor/supervisord.conf

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

為了將 Supervisor 管理的進(jìn)程配置與主配置文件區(qū)分開來,我們創(chuàng)建獨(dú)立的目錄來存放進(jìn)程配置。

cd /etc/supervisor
mkdir conf.d

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

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

3. 創(chuàng)建管理進(jìn)程

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

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

hello.py 的主要功能是往標(biāo)準(zhǔn)輸出中不斷地輸出 “hello” 字符串。

4. 創(chuàng)建進(jìn)程配置

為將 hello.py 腳本被 Supervisor 接管,我們在 /etc/supervisor/conf.d 目錄創(chuàng)建其配置 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:運(yùn)行進(jìn)程使用的命令
  • stdout_logfile:指定標(biāo)準(zhǔn)輸出文件
  • stderr_logfile:標(biāo)準(zhǔn)錯(cuò)誤輸出文件

需要指出的是,被 Supervisor 管理的進(jìn)程,不能使用 daemon 模式,而必須在前臺運(yùn)行,否則會報(bào)錯(cuò)。

5. 運(yùn)行 supervisord

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

supervisord -c /etc/supervisor/supervisord.conf

6. 使用 supervisorctl 管理進(jìn)程

使用 supervisorctl 可以查看監(jiān)控的進(jìn)程狀態(tài):

supervisorctl -c /etc/supervisor/supervisord.conf

輸出:

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

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

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

Supervisor 管理 Redis 進(jìn)程

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

Redis 的 Supervisor 配置

有了上面的基礎(chǔ),我們很容易寫出 Redis 服務(wù)進(jìn)程的 Supervisor 配置:

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

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

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

daemonize no

Supervisord 開機(jī)啟動

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

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

respawn

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

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

Supervisor Web 管理界面

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

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

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

利用Supervisor管理Redis進(jìn)程的方法教程

圖 2 :Supervisor Web 管理界面

在此界面下,可以對單個(gè)進(jìn)程進(jìn)行重啟,關(guān)閉,查看日志等操作,也可以對所有的進(jìn)程進(jìn)行重啟,關(guān)閉等操作。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對創(chuàng)新互聯(lián)的支持。

參考資料

  • http://www.supervisord.org/
  • Python Web 開發(fā)實(shí)戰(zhàn),董偉明著,電子工業(yè)出版社
  • 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

文章標(biāo)題:利用Supervisor管理Redis進(jìn)程的方法教程
標(biāo)題URL:http://www.rwnh.cn/article38/jdggpp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、網(wǎng)站排名做網(wǎng)站、移動網(wǎng)站建設(shè)定制網(wǎng)站、網(wǎng)頁設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
吴桥县| 横峰县| 万源市| 城市| 延寿县| 长岭县| 汉阴县| 二手房| 西乌珠穆沁旗| 镇原县| 咸丰县| 镇雄县| 汶川县| 会宁县| 蓬安县| 越西县| 曲松县| 紫阳县| 呼伦贝尔市| 阳信县| 义乌市| 淅川县| 民和| 桦甸市| 临江市| 敖汉旗| 玉龙| 西畴县| 比如县| 安溪县| 乌什县| 神木县| 二连浩特市| 游戏| 通辽市| 民和| 南和县| 巧家县| 札达县| 平武县| 镇巴县|