Linux運用保守ツールSupervisor(プロセス管理ツール)のインストールと使用

Linux運用保守ツールSupervisor(プロセス管理ツール)のインストールと使用

1. はじめに

Supervisor は Python で開発された汎用プロセス管理プログラムです。通常のコマンドライン プロセスをバックグラウンド デーモンに変換し、プロセスの状態を監視し、異常終了したときに自動的に再起動することができます。現在、Supervisor はほとんどの Unix システムで実行できますが、Windows システムでの実行はサポートされていません。 Supervisor には Python 2.4 以降が必要ですが、Python 3 バージョンはサポートされていません。

2. 組み込みのWeb管理プログラム

スーパーバイザーには 4 つのコンポーネントがあります。

1. 監督者
Supervisor バックグラウンド サービスを実行します。このサービスは、Supervisor で管理する必要があるサブプロセスの開始と管理、クライアントからの要求への応答、予期せず終了したサブプロセスの再起動、サブプロセスの stdout と stderr のログへの書き込み、イベントへの応答などに使用されます。これはSupervisorの中核部分です。

2. スーパーバイザー
これは supervisord のクライアントと同等であり、サブプロセスのステータスの確認やサブプロセスの開始またはシャットダウンなどの指示をユーザーが supervisord サービスに送信できるコマンドライン ツールです。リモート マシン上のサービスを含むさまざまな監視サービスに接続できます。

3. Web サーバー これは supervisord の Web クライアントです。ユーザーは Web ページ上で supervisorctl と同様の機能を実行できます。

4. XML-RPC インターフェース これは、サードパーティ統合用に予約されたインターフェースです。サービスはこれらの XML-RPC インターフェースをリモートで呼び出して、supervisord によって管理されるサブプロセスを制御できます。上記の Web サーバーは、実際にはこの XML-RPC インターフェイスを通じて実装されています。

3. インストール

以下の3つの方法からお選びいただけます

1. インストール

echo "supervisor-3.3.4 のインストール (はいの場合は 1 を入力してください。いいえの場合はその他を入力してください):" 
SVを読む
[ "$SV" = "1" ]の場合; 
	cd $ベースパス
	$basepath/supervisor-3.3.4.zip を解凍します。 
	cd スーパーバイザー-3.3.4
	python setup.py インストール
	echo "supervisor-3.3.4 のインストールが完了しました"
それ以外
	echo "supervisor-3.3.4 をインストールしないことを選択しました"
フィ

2. ソースコードのインストール

 https://pypi.python.org/packages/7b/17/88adf8cb25f80e2bc0d18e094fcd7ab300632ea00b601cbbbb84c2419eae/supervisor-3.3.4.tar.gz を実行します。
 tar -zxvf スーパーバイザー-3.3.4.tar.gz
 cd スーパーバイザー-3.3.4
 python setup.py install #ローカルの python バージョンは python2.7 です

3. Yumのインストール

yum インストール スーパーバイザー

4. 設定ファイル

インストール後に /etc/supervisord.conf 構成ファイルが存在しない場合は、次のコマンドで生成します。

echo_supervisord_conf > /etc/supervisord.conf

5. スタートアップ

スーパーバイザード -c /etc/supervisord/supervisord.conf 
	echo "supervisor-3.3.4 が正常に起動しました"

6. スタートアップを設定する

systemctl は supervisord.service を有効にします

7. supervisordが実行中かどうかを確認する

ps aux | grep supervisord

8. supervisorctl 管理コマンド

supervisorctl status #ステータス supervisorctl stop nginx #nginx をシャットダウン
 supervisorctl start nginx #nginxを起動する
 supervisorctl restart nginx #nginxを再起動します
 supervisorctl reload #すべてを再起動 supervisorctl update #設定を更新

このコマンドは、個別に使用することも、組み合わせて使用​​することもできます。

9. 設定ファイルの説明

[unix_http_サーバー]
file=/tmp/supervisor.sock ;UNIX ソケット ファイル、supervisorctl が使用します。chmod=0700 ;ソケット ファイル モード、デフォルトは 0700 です。
;chown=nobody:nogroup ;ソケットファイルの所有者、形式: uid:gid

;[inet_http_server] ;Web 管理インターフェースを提供する HTTP サーバー;port=127.0.0.1:9001 ;Web 管理バックエンドの IP とポート。パブリック ネットワークに公開されている場合は、セキュリティに注意する必要があります;username=user ;管理バックエンドにログインするためのユーザー名;password=123 ;管理バックエンドにログインするためのパスワード [supervisord]
logfile=/tmp/supervisord.log; ログファイル、デフォルトは $CWD/supervisord.log
logfile_maxbytes=50MB; ログ ファイルのサイズ。これを超えるとローテーションされます。デフォルトは 50MB です。0 に設定すると、サイズ制限がないことを意味します。logfile_backups=10; ログ ファイルのバックアップのデフォルト数は 10 です。0 に設定すると、バックアップがないことを意味します。loglevel=info; ログ レベル。デフォルトは info、その他: debug、warn、trace
pidfile=/tmp/supervisord.pid ;pid ファイル nodaemon=false ;フォアグラウンドで起動するかどうか。デフォルトは false、つまりデーモン モードで起動します。 minfds=1024 ;開くことができるファイル記述子の最小値。デフォルトは 1024 です。
minprocs=200; 開くことができるプロセスの最小数。デフォルトは200です。

[スーパーバイザーctl]
serverurl=unix:///tmp/supervisor.sock ; UNIX ソケット経由で supervisord に接続します。パスは unix_http_server 部分のファイルと一致します。 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 で、プロセスが強制終了されたときに、子プロセスを含むプロセス グループに停止信号を送信するかどうかを指定します。killasgroup=false; デフォルトは false で、子プロセスを含むプロセス グループに強制終了信号を送信します。その他の設定ファイルが含まれます [include]
files =/etc/supervisord.d/*.ini ; .iniで終わる1つ以上の設定ファイルを指定できます。

10. ini設定ファイルの例

[プログラム:MysqlToRedis]
ディレクトリ = /data/py/SmartServerModel/SmartServerModel/ModelManagerServer/
コマンド = python3 -u mysql2redis_robot_config.py cs
自動起動 = true
自動再起動=true
開始秒数 = 5
ユーザー =root
リダイレクトstderr = true
stdout_logfile = /data/logs/supervisord/mysqltoredis.log

[プログラム:SmartBinLog]
コマンド = /data/go/src/SmartBinLog/SmartBinLog
自動起動 = true
自動再起動=true
開始秒数 = 5
ユーザー =root
リダイレクトstderr = true
stdout_logfile = /data/logs/supervisord/smartbinlog.log

[グループ:nlp]
programs=MysqlToRedis、SmartBinLog ;server、progname2 はそれぞれ [program:x] 定義の 'x' を参照します
priority=999 ; 相対的な開始優先度(デフォルト 999)

11.ウェブページ管理プログラムを開く

conf設定ファイル内のコメント行をすべてコメント解除し、ポート、ユーザー名、パスワードを変更します。

[inet_http_server] ;Web 管理インターフェイスを提供する HTTP サーバーport=127.0.0.1:9001 ;Web 管理バックエンドの IP とポート。パブリック ネットワークに公開されている場合は、セキュリティに注意してくださいusername=user ;管理バックエンドにログインするためのユーザー名password=123 ;管理バックエンドにログインするためのパスワード

12. 「unix:///tmp/supervisor.sock そのようなファイルはありません」という問題を解決する

時々、次のような問題に遭遇します:


解決策は簡単です:

①. 既存のsupervisorctlプロセスを停止する


②. 設定ファイル「/etc/supervisord.conf」を修正し、tmpをetcに変更します。 /tmpディレクトリ内のファイルはオペレーティングシステムによって定期的にリサイクルされるため、変更する必要があります。

③. 変更した設定ファイルを使用して supervisord を起動すると、すべてが正常に戻ります。

以下もご興味があるかもしれません:
  • Linux プロセス管理ツール スーパーバイザーのインストールと設定のチュートリアル
  • Linux でのプロセスデーモン スーパーバイザーのインストール、構成、および使用
  • Supervisor のインストールと構成の詳細な説明 (Linux/Unix プロセス管理ツール)
  • PHPプログラマーはスーパーバイザーを使用してデーモンプロセスを実装するLinuxシリーズをプレイします
  • スーパーバイザーウォッチドッグの使い方を3分で学ぶ

<<:  Vueメソッドに基づくシンプルなタイマーの実装

>>:  MySQLデュアルマシンホットスタンバイと負荷分散の実装手順の詳細説明

推薦する

スケーラブルな列の完全な例を実現するための Ant 設計 Vue テーブル

ant-design-vue テーブルのスケーラブルな列の問題に対する完璧なソリューション。固定列と...

JavaScriptにおけるこのポインティング問題の詳細な説明

序文信じてください。この記事の 7️⃣ ステップを覚えておけば、JS の this リファレンスを完...

Mysqlは実行中のトランザクションを照会し、ロックを待機する方法

navicatを使用してテストと学習を行います。まず、 set autocommit = 0;を使用...

SSHトンネルを使用してMySQLサーバーに接続する方法

序文場合によっては、データベースのイントラネット アドレスしか知らず、イントラネット経由で接続できな...

Vueフレームワークで習得しなければならない重要な知識を学びます

1. Vueとは何かVue は、ユーザー ページを構築するためのプログレッシブ フレームワークです。...

Ubuntu 上の Apache で SSL (https 証明書) を設定する正しい方法の詳細な説明

まず、Alibaba Cloud の公式チュートリアルをご覧ください。ファイルの説明: 1. 証明書...

Docker データ ストレージ ボリュームの詳細な説明

デフォルトでは、コンテナ データの読み取りと書き込みはコンテナのストレージ レイヤーで行われます。コ...

Centos7 での mysql 8.0.15 のインストールと設定

この記事では、参考までにMySQL 8.0.15のインストールと設定のグラフィックチュートリアルを紹...

Nginx+Tomcat 負荷分散クラスタのインストールと構成のケースの詳細な説明

目次序文1. Nginx+Tomcat 2. Nginxサーバーを構成する3. Tomcatアプリケ...

mysql5.5.28 のインストール チュートリアルは非常に詳細です。

参考までにmysql5.5.28のインストールチュートリアルです。具体的な内容は次のとおりです。イン...

docker-swarm をベースにした継続的インテグレーション クラスタ サービスの構築の詳細な説明

序文この記事は私自身の製作過程の簡単な記録です。練習中に質問があれば、一緒に話し合うことができます。...

MySQLはフィールドからカンマ区切りの値を取り出して新しいフィールドを形成します

1例: 図1のフィールドを図2に分割するには アカウントIDを選択、 サブストリングインデックス(サ...

Dockerでspringcloudプロジェクトをデプロイする方法

目次Dockerイメージのダウンロードmysqlとnacosを起動する独自のJavaプロジェクトを変...

Docker+K8S クラスタ環境構築と分散アプリケーション展開

1. Dockerをインストールする yumでdockerをインストール #サービスを開始する sy...

React+Amapは緯度と経度をリアルタイムで取得し、住所を特定します

目次1. マップを初期化する2. マップポイント3. 位置決めを有効にする4. マップの変更を監視す...