supervisor常见报错[通俗易懂]

supervisor常见报错[通俗易懂]supervisor常见报错

大家好,又见面了,我是你们的朋友全栈君。

基本思路:

1.首先我们要明确问题出在supervisor上还是启动的程序上,可以用ps -ef | grep supervisord查看是否启动,在用ps查看自己的进程有没有启动;
2.确认下启动的supervisor配置文件是哪个,有的是/etc/supervisor/supervisord.conf,有的是/etc/supervisord.conf,以自己的为准,不要弄混;
3.推荐使用apt-get安装,其次是pip ,最后才是yum。不要问为什么,踩坑踩得。另外,尽量用supervisord 3.x以上的版本,2.x版本出问题概率大;
4.supervisord的日志在 /var/log/supervisor/supervisord.log,启动失败一般能再这里找到有用的信息

常用命令
  • 启动守护进程:supervisord -c /etc/supervisor/supervisord.conf
  • 重载配置:supervisorctl reload
具体报错分析

下面是三种常见的通用报错:

第一类:

报错信息:

error: <class 'socket.error'>, [Errno 2] No such file or directory: file: <string> line: 1

解决办法:
这个可能有多种原因,可能是已经启动过了也可能是没权限,解决步骤如下:

  1. 先要确认是否已经启动过了:’ps -ef | grep supervisord’

  2. 如果有的话先kill掉

  3. 运行下面命令:
    sudo touch /var/run/supervisor.sock
    sudo chmod 777 /var/run/supervisor.sock

  4. 再尝试重新启动:supervisord -c /etc/supervisord.conf(如果没有文件找个别人的配置拷贝过来或者运行echo_supervisord_conf > /etc/supervisord.conf)

第二类:

报错信息:

Error: .ini file does not include supervisorctl section

解决办法:
又是一个权限问题的,步骤:

  1. 先确保supervisord.conf中有[supervisord],[supervisorctl]有这两个基本模块,还有[program:XXX]自己程序的配置(可以在supervisord.conf也可以在/etc/supervisor/*.ini中)
  2. 最关键的两个命令:chmod +x /usr/bin/supervisord
    chmod +x /usr/bin/supervisorctl
    chmod +x /etc/supervisord.conf主要是把把相关文件都授权了
  3. 把supervisord杀掉后再次启动supervisord
第三类:

报错信息:

Exited too quickly (process log may have details)

如果前面的问题都解决了,但还是会遇到这个问题,恭喜你已经离胜利很近了,起码supervisord本身已经没什么问题了_

解决办法:

  1. 先确认[program:XXX]中自己的程序的command=<启动命令>和 directory=<运行命令的路径>没有问题,python是不是用的自己要的环境的python(比如虚拟环境的),log文件的文件夹是不是已经创建(没创建的话supervisor没权限生成log文件),以及改log文件是不是授权给所有用户了(可参考前面的解决办法chmod +x aaaaa.log)
  2. 确保用上面的配置中的command在指定路径可以直接运行不会报错,这时候一般就不会有什么问题了。这时候tail你自己的log文件一般就能看到log信息,启动失败报错的信息也会在你的log文件中,照着解决后supervisorctl reload就好了。
  3. 如果上面的命令确保可以跑,但还是没法正常运行,也看不到自己程序的报错(不然你就能根据报错解决问题了),那么恭喜,你遇到了跟我一样的情况。我的解决办法很诡异,尝试把[program:XXX]中的名字换成了一个跟启动命令不一样的另一个名字(不要太短),reload之后居然就可以跑了。。。。嗯,很不合常理,但是对我来说确实管用了。

可参考文章:
详解supervisor进程管理
supervisor 进程管理

原文:https://blog.csdn.net/kkevinyang/article/details/80539940

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/105885.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 安卓java游戏模拟器_Java手机游戏模拟器

    安卓java游戏模拟器_Java手机游戏模拟器Java手机游戏模拟器主要针对诺基亚S60系列(屏幕176*220)手机以及其他大屏手机(小屏游戏也可运行,但不能全屏显示),是一款非常简单而且实用的JAVA游戏模拟器,可以正常运行绝大部分JAVA手机游戏!软件特色众所周知DM2的JAVA模拟器相当好用。但是,虽然模拟器本身可以放在卡上运行,但是用模拟器安装的JAVA文件仍然被放在手机的ProgramFilesCoreTekDeltaMIDP…

    2022年7月7日
    49
  • MySQL数据库分区分表配置以及原理、特点、概念、区别详解「建议收藏」

    MySQL数据库分区分表配置以及原理、特点、概念、区别详解「建议收藏」一、为什么要分表和分区?我们的数据库数据越来越大,随之而来的是单个表中数据太多。以至于查询速度变慢,而且由于表的锁机制导致应用操作也受到严重影响,出现了数据库性能瓶颈。mysql中有一种机制是表锁定和行锁定,是为了保证数据的完整性。表锁定表示你们都不能对这张表进行操作,必须等我对表操作完才行。行锁定也一样,别的sql必须等我对这条数据操作完了,才能对这条数据进行操作。当出现这种情况时,我们可以考虑…

    2022年5月22日
    40
  • webstorm激活码2021年-激活码分享

    (webstorm激活码2021年)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlMLZPB5EL5Q-eyJsaWN…

    2022年3月20日
    139
  • 安装并使用EVE模拟器

    安装并使用EVE模拟器本文提供的软件及相关镜像有:VMWareEVECommunityVMversion2.0.3-95Wireshark-win64-2.6.4CiscoIOL镜像(路由器、交换机)CRTWindowsXP镜像安装步骤如下:1.进行VMWare的安装a.在安装包文件夹内选择“VMware-workstation-full-15.0.0-10134415”的应用程…

    2022年6月12日
    48
  • ~按位取反_按位取反什么意思

    ~按位取反_按位取反什么意思inta=0;intb=~a;System.out.println(b);  // -1计算方法:因为整形是32位有符号补码整数表示的。因此将整形转换为二进制后为:a 十进制0二进制00000000000000000000000000000000~a的二进制1111111111111111111111111

    2022年8月15日
    11
  • phpstom 2022.01 激活码【最新永久激活】2022.02.03

    (phpstom 2022.01 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年4月1日
    50

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号