supervisor + uwsgi 部署python服务踩过的坑

supervisor + uwsgi 部署python服务踩过的坑

最近由于某个python服务不稳定,有时候是造成服务器down机,有时候是服务本身突然就挂了。查了一下原因,发现是内存资源占用过高导致的,

为了让服务稳定运行,便打算引入supervisor + uwsgi对服务进行分布式部署。整个部署流程的坑不少,下面给大家分享一下。

1.supervisord服务的目录不对,执行启动命令sudo systemctl start supervisord.service

报错:systemd[18477]: Failed at step EXEC spawning /usr/bin/supervisord: No such file or directory

解决办法:

查看supervisord位置 whereis supervisord,将结果替换supervisord.service文件中ExecStart配置的supervisord路径

2.supervisord.service配置文件不对

supervisord.service配置文件的格式严格按照大驼峰式命名法,即所有的首字母必须大写

如果配置文件不对,执行sudo systemctl status supervisord.service可能会报错

例如下面报错

systemd[1]: [/usr/lib/systemd/system/supervisord.service:9] Unknown lvalue 'killMode' in section 'Service'

就是配置文件中killMode属性的首字母没有大写,导致配置文件失效

解决方案:修改killMode为KillMode,再重新启动即可

3.端口占用

报错:Error: Another program is already listening on a port that one of our HTTP servers is configured to use.

Shut this program down first before starting supervisord

解决方案:查看uwsgi.ini配置中的端口的占用情况,可以杀掉该端口进程,或者更换端口

4.用户设置不对

报错:CRIT Supervisor is running as root. Privileges were not dropped because no user is specified in the config file.

If you intend to run as root, you can set user=root in the config file to avoid this message.

解决方案:supervisor.ini配置文件的program中增加一个配置user=test(修改成你需要的用户)

在supervisord.conf的[supervisord]中增加配置user=test(修改成你需要的用户),在supervisord.service的service中增加配置

user=test(修改成你需要的用户)

5.环境变量不对

现象:使用原有python app.py的方式启动该服务,服务能正常运行。但是使用supervisor + uwsgi的方式部署服务,启动之后服务运行异常

报错[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.7.0:compile (default-compile) on project

test_project: Fatal error compiling: java.lang.ExceptionInInitializerError: com.sun.tools.javac.code.TypeTags -> [Help 1]

解决方案:在restart_service.sh脚本中增加两行

source /etc/profile

source /home/test/.bashrc

将用户的环境变量加载生效

相关推荐
百***92652 分钟前
java进阶1——JVM
java·开发语言·jvm
杜子不疼.14 分钟前
【C++】 map/multimap底层原理与逻辑详解
开发语言·c++
司铭鸿14 分钟前
数学图论的艺术:解码最小公倍数图中的连通奥秘
运维·开发语言·算法·游戏·图论
Cocktail_py19 分钟前
JS如何调用wasm
开发语言·javascript·wasm
饮长安千年月26 分钟前
玄机-第八章 内存马分析-java03-fastjson
开发语言·python·安全·web安全·网络安全·应急响应
天天爱吃肉821831 分钟前
新能源汽车动力系统在环(HIL)半实物仿真测试台架深度解析
人工智能·python·嵌入式硬件·汽车
卡次卡次11 小时前
注意点:挂载与插硬盘,容器挂载实现持久化存储
python
2401_841495641 小时前
【LeetCode刷题】找到字符串中所有字母异位词
数据结构·python·算法·leetcode·数组·滑动窗口·找到字符串中所有字母异位词
MediaTea1 小时前
Python 第三方库:OpenPyXL(Excel 文件读写与操作)
开发语言·python·excel
点云SLAM1 小时前
C++ 中dynamic_cast使用详解和实战示例
开发语言·c++·类型转换·dynamic_cast·c++多态·c++继承