pm2 进程守护python flask

pm2 进程守护python flask

文章目录

安装Node.js

1.首先,使用以下命令安装curl(如果尚未安装):

sudo apt update
sudo apt install curl

2.确保你的系统上已安装了Node.js的最新版本(可以替换LTS版本为当前最新版本):

curl -fsSL https://deb.nodesource.com/setup_lts.x | sudo -E bash -

3.安装Node.js:

sudo apt install -y nodejs

安装pm2

1、安装

npm install pm2 -g

2、验证

pm2 -v

or

pm2 list

上传文件至服务器

upload...

python 配置

生成requirements.txt

如果你的项目环境中已经安装了所有必要的包,你可以使用

pip freeze

命令来生成一个包含所有已安装包及其版本的列表。这个列表可以直接用作 requirements.txt 文件。

python 虚拟环境

在Python中,虚拟环境是一种将一组Python包与其他Python项目隔离开的方法。这有助于避免依赖冲突和确保项目的可移植性。

创建和管理Python虚拟环境的常见方法有:

  1. 使用venv模块(Python 3.3及以上版本)
  2. 使用virtualenv工具
  3. 使用pyenv工具
使用Python自带的venv模块创建和管理虚拟环境
# 创建虚拟环境
python3 -m venv /path/to/new/virtual/environment
 
# 激活虚拟环境
source /path/to/new/virtual/environment/bin/activate
 
# 退出虚拟环境
deactivate
使用virtualenv工具创建和管理虚拟环境

首先,你需要安装virtualenv工具,如果你还没有安装,可以使用以下命令进行安装:

pip install virtualenv

然后,你可以使用以下命令创建和管理虚拟环境:

# 创建虚拟环境
virtualenv /path/to/new/virtual/environment
 
# 激活虚拟环境
source /path/to/new/virtual/environment/bin/activate
 
# 退出虚拟环境
deactivate
使用pyenv工具创建和管理虚拟环境

首先,你需要安装pyenv工具,如果你还没有安装,可以根据它的官方文档中的安装指南进行安装:++https://github.com/pyenv/pyenv-installer++

然后,你可以使用以下命令创建和管理虚拟环境:

# 创建虚拟环境
pyenv virtualenv 3.7.1 my-virtual-env
 
# 激活虚拟环境
pyenv activate my-virtual-env
 
# 退出虚拟环境
pyenv deactivate

注意:在这些命令中,/path/to/new/virtual/environment 是你想要创建虚拟环境的目录。在这个目录中,将会有一个新的Python环境,包括Python解释器和pip的副本。

安装依赖

cd ...
pip install requirements.txt

编写flask 启动脚本

直接运行python flask
python3  app.py
gunicorn 运行 flask

安装模块

pip install gunicorn

Gunicorn(绿色独角兽,Green Unicorn)是一个Python的WSGI HTTP服务器,来源于Ruby 的Unicorn项目。它采用pre-fork的worker模型;在启动时,会在主进程中预先fork出指定数量的worker进程来处理请求,极大提升了服务器请求负载能力,又可以兼容于多种Python Web框架,实现简单,占用系统资源少,速度也相当快。

以多thread方式启动(flask在wsgi.py中):

pm2 --name=ai start "gunicorn -c gunicorn_config.py wsgi:app"

其中 gunicorn_config.py 参数如下

# gunicorn_config.py

# 并发工作进程数
workers = 4  # 可根据服务器 CPU 核心数调整

# 工作模式
worker_class = 'gevent'  # 可以选择 'sync', 'eventlet', 'gevent', 'tornado', 'gthread'

# 每个worker的最大线程数,仅在 gthread 模式下有效
threads = 2  # 默认是1, 仅适用于 gthread 工作模式

# 每个 worker 处理的最大请求数,超过此值后重启worker
max_requests = 1000  # 默认0, 表示禁用自动重启

# 绑定的IP和端口
bind = '127.0.0.1:8000'  # 可以根据需求修改

# 进程名称
proc_name = 'my_gunicorn_app'  # 自定义进程名

# 工作进程的超时时间
timeout = 30  # 默认是30秒

# 连接的最大数量,仅适用于 eventlet 或 gevent 工作模式
worker_connections = 1000  # 适用于异步工作模式

# Keep-Alive时间,连接存活时间
keepalive = 2  # 默认2秒

# 日志配置
accesslog = '-'  # 访问日志输出到控制台
errorlog = '-'   # 错误日志输出到控制台

# 设置日志级别,可选 "debug", "info", "warning", "error", "critical"
loglevel = 'info'

# 是否以守护进程方式运行
daemon = False  # 如果为 True,则表示以守护进程的方式运行

# PID文件路径
pidfile = '/tmp/gunicorn.pid'

运行run.sh 文件

pm2 命令列表

命令 作用
pm2 ls 列表 PM2 启动的所有的应用程序
pm2 list 列表 PM2 启动的所有的应用程序
pm2 start 《path》 启动应用程序
pm2 start《path》 --watch 当文件变化时自动重启应用
pm2 start 《path》 --name="test" 启动应用程序并命名为 "test"
pm2 start 《path》 -i 4 cluster mode 模式启动4个bin/www的应用实例。4个应用程序会自动进行负载均衡
pm2 scale 'www' 3 把名字叫www的应用扩展到3个实例.注意要加单引号
pm2 show 【app-name或id】 显示应用程序的所有信息
pm2 monit 显示每个应用程序的CPU和内存占用情况.按键盘上下键切换
pm2 logs 显示所有应用程序的日志
pm2 logs【app-name或id】 显示指定应用程序的日志
pm2 flush 清空logs
pm2 save 保存当前应用列表
pm2 resurrect 重新加载保存的应用列表
pm2 update 保存进程,杀死PM2和恢复进程
pm2 serve 【path】【port】 pm2搭建静态文件服务器
pm2 stop 【app-name或id】 停止应用
pm2 delete 【app-name或id】 删除应用
pm2 remove 【app-name或id】 删除应用
相关推荐
Gu Gu Study2 分钟前
枚举与lambda表达式,枚举实现单例模式为什么是安全的,lambda表达式与函数式接口的小九九~
java·开发语言
时光の尘17 分钟前
C语言菜鸟入门·关键字·float以及double的用法
运维·服务器·c语言·开发语言·stm32·单片机·c
以后不吃煲仔饭30 分钟前
Java基础夯实——2.7 线程上下文切换
java·开发语言
进阶的架构师31 分钟前
2024年Java面试题及答案整理(1000+面试题附答案解析)
java·开发语言
前端拾光者35 分钟前
利用D3.js实现数据可视化的简单示例
开发语言·javascript·信息可视化
程序猿阿伟37 分钟前
《C++ 实现区块链:区块时间戳的存储与验证机制解析》
开发语言·c++·区块链
傻啦嘿哟1 小时前
如何使用 Python 开发一个简单的文本数据转换为 Excel 工具
开发语言·python·excel
大数据编程之光1 小时前
Flink Standalone集群模式安装部署全攻略
java·大数据·开发语言·面试·flink
初九之潜龙勿用1 小时前
C#校验画布签名图片是否为空白
开发语言·ui·c#·.net
B站计算机毕业设计超人1 小时前
计算机毕业设计SparkStreaming+Kafka旅游推荐系统 旅游景点客流量预测 旅游可视化 旅游大数据 Hive数据仓库 机器学习 深度学习
大数据·数据仓库·hadoop·python·kafka·课程设计·数据可视化