zoukankan      html  css  js  c++  java
  • 2017.7.21 linux下进程管理工具supervisord的安装与使用

    参考来自:http://blog.haohtml.com/archives/15145

    0 操作环境

    1 supervisord的介绍

    Supervisord是用Python实现的一款非常实用的进程管理工具。supervisord会帮你把管理的应用程序转成daemon程序,而且可以方便的通过命令开启、关闭、重启等操作,而且它管理的进程一旦崩溃会自动重启,这样就可以保证程序执行中断后的情况下有自我修复的功能。

    2 supervisord的安装

    2.1 执行sudo easy_install supervisor

    注意:不是supervisord!没有d!

    2.2 elkuser is not in the sudoers file. This incident will be reported

    执行上条命令的时候,可能会报错误:elkuser is not in the sudoers file. This incident will be reported。原因是:用户xxx没有被加到sudo的配置文件里。

    (1)visudo

    切换到root用户或者用root用户登录,否则报无权限。执行:visudo。

    (2)xxx ALL=(ALL) ALL

     在打开的配置文件中,找到root ALL=(ALL) ALL,在下面添加一行:elkuser ALL=(ALL) ALL ,其中elkuser是要加入的用户名称。修改后退出保存,再回到elkuser,就能执行sudo easy_install supervisord命令了。

     

    (3)sudo easy_install supervisor

    从root用户切换回elkuser,执行sudo easy_install supervisor。

    2.3 supervisord和supervisorctl

    supervisord一共有两个类型的命令:supervisord和supervisorctl。安装完成后,可以在/user/bin路径下找到。

    3 supervisord的配置

    3.1 执行echo_supervisord_conf > /etc/supervisord.conf

    supervisord默认的配置文件路径为/etc/supervisord.conf。生成/etc/supervisord.conf后,编辑此示例配置文件即可。

     

    3.2 bash:/etc/supervisord.conf : Permission denied

    当报这个错误的时候,可以先将配置文件生成在别处,然后再复制在/etc/supervisord.conf中。

    执行完这两条语句后:

    3.3 supervisord.conf

    其他的详细配置略(都采用的默认配置),这里在后面增加配置了三个program,名字分别为elasticsearch,logstash,kibana。

    4 supervisord的使用

    4.1 /usr/bin/supervisord -c /etc/supervisord.conf

    执行完此命令,就使得配置文件生效,所有配置在conf中的program都启动了。比如:查看elasticsearch,已经成功启动。并且需要通过supervisorctl的stop命令来关闭。而关闭此登录会话,或者ctrl+c,进程也继续在执行,实现了后台执行。

    4.2 supervisord的一些常用命令

    Supervisord安装完成后有两个可用的命令行supervisord 和 supervisorctl,命令使用解释如下:

    1 supervisord,初始启动Supervisord,启动、管理配置中设置的进程。
    2 
    3 supervisorctl stop programxxx,停止某一个进程(programxxx)
    4 supervisorctl start programxxx,启动某个进程
    5 supervisorctl restart programxxx,重启某个进程
    6 supervisorctl stop all,停止全部进程,注:start、restart、stop都不会载入最新的配置文件。
    7 supervisorctl start all,开启全部进程。
    7 supervisorctl reload,载入最新的配置文件,并按新的配置启动、管理所有进程。

    示例:

    5 遇到的问题

    操作过程:

    1 supervisorctl start all
    2 修改logstsh的配置文件
    3 supervisorctl stop logstash
    4 supervisorctl start logstash

    但是却始终没有获取到最新的日志信息。

    后来在bin目录下重启logstash才行。

     

    即使执行supervisorctl reload ,update等,都不行。执行在bin目录下更新配置文件。这是为什么。

  • 相关阅读:
    mvp在flutter中的应用
    Flutter 网络请求库http
    Flutter Dart中的异步
    阿里云 RDS 数据库又发 CPU 近 100% 的“芯脏病”团队
    上周热点回顾(10.14-10.20) 团队
    云上的芯脏病:奇怪的阿里云 RDS 数据库突发 CPU 近 100% 问题团队
    【故障公告】docker swarm 集群问题引发的故障团队
    上周热点回顾(10.7-10.13)团队
    上周热点回顾(9.30-10.6) 团队
    上周热点回顾(9.23-9.29) 团队
  • 原文地址:https://www.cnblogs.com/lyh421/p/7216624.html
Copyright © 2011-2022 走看看