PM2 部署任务脚本

2024-04-12 15:20
文章标签 部署 脚本 任务 pm2

本文主要是介绍PM2 部署任务脚本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

进程脚本多了之后,在服务器上运行的时候,如果纯手工启动就很麻烦,就想着使用pm2来作为进程管理工具,
优点就是:
1、可以定时执行脚本;
2、指定日志输出,小脚本就不需要额外再写日志输出模块;
2、进程启动,关闭,添加都比较方便,命令也很简单
缺点:
1、如果脚本过多,PM2也不方便进行管理了,这种只适合常驻脚本、服务,或者是几十个固定脚本
2、直接查看日志信息的时候,pm2 log id, 打印出来的中文日志,直接查看,发现会有乱码,目前还没有解决

记录下部署的步骤,我这边使用的是windows, 不过跟liunx应该是一样的

1、安装nodejs: https://blog.csdn.net/finghting321/article/details/105563346, 到step4
2、安装PM2:https://blog.csdn.net/kevlin_V/article/details/119551742?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-0-119551742-blog-105563346.235^v43^pc_blog_bottom_relevance_base5&spm=1001.2101.3001.4242.1&utm_relevant_index=3。npm install pm2 -gnpm install pm2-windows-startup -g			这是windows时可以使用web页面查看进程,liunx则不需要pm2 -v     查看pm2有没有安装正常,如果没有正常安装则有可能是环境变量没有自动配好,需要手动配置:https://blog.csdn.net/Ai_Zbh/article/details/121135459pm2-startup install 
3、cmd.exe   cd 到项目目录下,../tiktok_project/
4、pm2 start ecosystem.config.js	使用文件批量启动进程
5、pm2 list 查看进程
6、pm2 logs 进程id 查看日志

ecosystem.config.js 文件示例范围, 当然也可以直接使用命令直接启动,这个文件只不过将它记录下来,启动的时候方便批量启动

//使用PM2启动不同的脚本进程
//直接进行定时脚本部署的话,需要将autorestart设置为false, 然后加上cron_restart参数
//如果进程是异步处理的话,则需要修改min_uptime值,修改小一些为100,避免重复启动
module.exports = {apps: [{name: '订单信息发送给用户',script: 'ziniao_chrome/order_exception.py', // 你的 Python 脚本路径interpreter: 'venv/Scripts/python.exe', // 如果你使用虚拟环境,指定虚拟环境中的 Python 解释器路径instances: 1, // 应用实例数量autorestart: true, // 应用程序崩溃时自动重启watch: false, // 是否监听文件变化max_memory_restart: '1G', // 内存达到上限时自动重},// {//     name: 'TTshipping面单上传易达云',//     script: 'ziniao_chrome/order_print_document.py', // 你的 Python 脚本路径//     interpreter: 'venv/Scripts/python.exe', // 如果你使用虚拟环境,指定虚拟环境中的 Python 解释器路径//     instances: 1, // 应用实例数量//     autorestart: true, // 应用程序崩溃时自动重启//     watch: false, // 是否监听文件变化//     max_memory_restart: '1G', // 内存达到上限时自动重// },{name: '定时应收订单-补偿金脚本(16:10)',script: 'ziniao_chrome/order_payable_spider.py', // 你的 Python 脚本路径interpreter: 'venv/Scripts/python.exe', // 如果你使用虚拟环境,指定虚拟环境中的 Python 解释器路径instances: 1, // 应用实例数量autorestart: false, // ****应用程序崩溃时自动重启,但是定时的时候需要把这个关掉cron_restart: '10 16 * * *', // ***每天16:10重启应用watch: false, // 是否监听文件变化max_memory_restart: '1G', // 内存达到上限时自动重}]
};

这篇关于PM2 部署任务脚本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/897504

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

Linux系统管理与进程任务管理方式

《Linux系统管理与进程任务管理方式》本文系统讲解Linux管理核心技能,涵盖引导流程、服务控制(Systemd与GRUB2)、进程管理(前台/后台运行、工具使用)、计划任务(at/cron)及常用... 目录引言一、linux系统引导过程与服务控制1.1 系统引导的五个关键阶段1.2 GRUB2的进化优

Java调用Python脚本实现HelloWorld的示例详解

《Java调用Python脚本实现HelloWorld的示例详解》作为程序员,我们经常会遇到需要在Java项目中调用Python脚本的场景,下面我们来看看如何从基础到进阶,一步步实现Java与Pyth... 目录一、环境准备二、基础调用:使用 Runtime.exec()2.1 实现步骤2.2 代码解析三、

Python脚本轻松实现检测麦克风功能

《Python脚本轻松实现检测麦克风功能》在进行音频处理或开发需要使用麦克风的应用程序时,确保麦克风功能正常是非常重要的,本文将介绍一个简单的Python脚本,能够帮助我们检测本地麦克风的功能,需要的... 目录轻松检测麦克风功能脚本介绍一、python环境准备二、代码解析三、使用方法四、知识扩展轻松检测麦

Python Flask实现定时任务的不同方法详解

《PythonFlask实现定时任务的不同方法详解》在Flask中实现定时任务,最常用的方法是使用APScheduler库,本文将提供一个完整的解决方案,有需要的小伙伴可以跟随小编一起学习一下... 目录完js整实现方案代码解释1. 依赖安装2. 核心组件3. 任务类型4. 任务管理5. 持久化存储生产环境

Linux部署中的文件大小写问题的解决方案

《Linux部署中的文件大小写问题的解决方案》在本地开发环境(Windows/macOS)一切正常,但部署到Linux服务器后出现模块加载错误,核心原因是Linux文件系统严格区分大小写,所以本文给大... 目录问题背景解决方案配置要求问题背景在本地开发环境(Windows/MACOS)一切正常,但部署到

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总