プロセス管理ツールの監督[記事のインストールと使用]

Tpのメッセージキューを使用する場合は、誤って実行することはできませんプロジェクトの最後につながったプロセス・キューと思います!;

だから、スーパーバイザを使用します。あなたの隣の経験だけでなく、インストールするために使用される方法を使用して共有します。

公式サイト:HTTP://supervisord.org/introd ...
まず、インストールする多くの方法がある;
01:wgetのは、圧縮されたパッケージをダウンロードするには:

cd /usr/local/lee   #这个lee是我自己建立的一个目录
wget https://pypi.python.org/packages/7b/17/88adf8cb25f80e2bc0d18e094fcd7ab300632ea00b601cbbbb84c2419eae/supervisor-3.3.2.tar.gz
tar -zxvf supervisor-3.3.2.tar.gz cd supervisor-3.3.2 python setup.py install

02:yumをインストールします。

yum install python-setuptools
easy_install supervisor

私たちは、インストールwgetコマンドを使用すると、
5b5888b468e0e.png

5b5888cf26f49.png

5b5888e4a6449.png

コンフィギュレーション・ファイルを生成した後:

mkdir /etc/supervisor
echo_supervisord_conf > /etc/supervisord.conf

何かを変更するには、コンフィギュレーションファイルを開きます。

vim /etc/supervisord.conf

の底に

;[include]
;files = relative/directory/*.ini
修改为:
[include]
files=/etc/supervisor/*.conf 
(注意去掉分号,第一次安装的时候就因为没去掉分号出现了问题!);

あなたは、ランダムなファイル名の接尾辞の.confを作成した後、私はTest.confをファイルを作成するためにここにいる。
/ WWW / wwwrootに/管理/ディレクトリの下に私のプロジェクト:

vim test.conf
#写入一些配置:
[program:test]   # 设置进程的名称,使用 supervisorctl 来管理进程时需要使用该进程名 我这里就叫做test了!
command=php think queue:work --queue saveLoginLog --daemon --tries 10;  #这个就是队列执行的命令
directory= /www/wwwroot/admin;  #命令执行的目录或者说执行 command 之前,先切换到工作目录 可以理解为在执行命令前会切换到这个目录
process_name=%(process_num)02d; #默认为 %(program_name)s,即 [program:x] 中的 x 这个是进程名,如果我们下面的numprocs参数为1的话,就不用管这个参数 了,它默认值%(program_name)s也就是上面的那个program冒号后面的 numprocs=5; #进程数量当不为1时的时候,就是进程池的概念,注意process_name的设置 autostart=true; #是否自动启动 autorestart=true; #程序意外退出是否自动重启 startsecs=1; 自动重启间隔 startretries=20; 当进程启动失败后,最大尝试启动的次数。。当超过3次后,supervisor将把此进程的状态置为FAIL 默认值为3 。。 redirect_stderr=true; 如果为true,则stderr的日志会被写入stdout日志文件中 理解为重定向输出的日志 user=root; 这个参数可以设置一个非root用户,当我们以root用户启动supervisord之后。我这里面设置的这个用户,也可以对supervisord进行管理 stdout_logfile= /www/wwwroot/admin/test.out.log; 子进程的stdout的日志路径 输出日志文件 stderr_logfile=/www/wwwroot/admin/test.err.log ; 错误日志文件 当redirect_stderr=true。这个就不用

注釈は、上記少し混乱に見えますが、私たちはコメントを書いていないがあります。

[program:test] 
command=php think queue:work --queue saveLoginLog --daemon --tries 10
directory= /www/wwwroot/admin
process_name=%(process_num)02d numprocs=5 autostart=true autorestart=true startsecs=1 startretries=20 redirect_stderr=true user=root stdout_logfile= /www/wwwroot/admin/test.out.log stderr_logfile=/www/wwwroot/admin/test.err.log 

スタートを実行した後:

supervisord -c /etc/supervisord.conf
supervisorctl reload

5b588a07dce5a.png

私は次のように間違った問題に対処し、解決策と言うだろう、実施の過程でエラーが発生しました。

今度聞かせてテスト、
最初のピットストップを実行するには、プロセスが停止し、テストの時になり、その後、接続Redisの後、私たちはいつものRedisに存在していますログイン後タスクを実行した後、ログインキューを実行し、端末を開きます。

supervisorctl stop test 或者直接 supervisorctl stop all

5b588ab662a08.png

あなたが実行されていない見ることができます!今、私たちは、テストプロセスのsupervisorctlを開きます
5b5887de1f28b.png

5b588ac471aa8.png

接下来说一下问题:
问题1:
リンク解除古いソケット/tmp/supervisor.sock
或者:
エラー:別のプログラムが既に私たちのHTTPサーバーのいずれかを使用するように設定されたポートで待機しています。supervisordを開始する前に、まずこのプログラムをシャットダウンします。

5b588add37fa1.png

5b588ae748e75.png

ソリューション:

sudo unlink /tmp/supervisor.sock 
or
sudo unlink /var/run/supervisor.sock

问题2:
あきらめた:Redisのはあまりにも速く、あまりにも多くの開始の再試行をFATAL状態になりました

ソリューション:

Redis.confはデーモン化の修正はありません

その他の問題は見つからない。
私はテストの過程にあったときに実際に殺す行って、そのサーバーを再起動することができます!

おすすめ

転載: www.cnblogs.com/xingxia/p/supervisor_install_use.html