【服务器】服务器进程运行不受本地终端影响的方法总结

服务器进程运行不受本地终端影响的方法总结

  • [1. 使用 nohup](#1. 使用 nohup)
  • [2. 使用 setsid](#2. 使用 setsid)
  • [3. 将命令放入后台 (&)](#3. 将命令放入后台 (&))
  • 总结
  • 参考

为了确保在集群或服务器上运行的长时间作业不受本地计算机网络中断或用户注销的影响,可以使用以下三种方法:nohup、setsid 和将命令放入后台 (&)。

下面是对这三种方法的详细说明:

1. 使用 nohup

nohup(no hang up)命令可以阻止进程接收到 HUP(hangup)信号。这意味着即使用户注销,使用 nohup 启动的进程仍然会继续运行。使用方法如下:

bash 复制代码
nohup your_command &

示例:如果你想在服务器上运行一个 Python 脚本 script.py,可以这样做:

bash 复制代码
nohup python script.py &

输出处理:默认情况下,nohup 会将命令的输出写入到 nohup.out 文件中。如果想指定输出文件,可以使用重定向:

bash 复制代码
nohup python script.py > output.log 2>&1 &
nohup python3 UDI_Beijing.py > UDI_Beijing.log 2>&1 &
nohup python3 UDI_CDMet.py > UDI_CDMet.log 2>&1 &

这里 > output.log 将标准输出重定向到 output.log,而 2>&1 将错误输出也重定向到同一文件。

2. 使用 setsid

setsid 命令用于创建一个新的会话,并将进程的父进程设置为 init 进程,从而使得该进程不再受当前终端的控制。同样,这样的进程也不会接收到 HUP 信号。使用方法如下:

bash 复制代码
setsid your_command &

示例:运行同样的 Python 脚本,可以这样做:

bash 复制代码
setsid python script.py &
setsid python3 UDI_CDMet.py &

注意:与 nohup 相似,你可能需要处理输出:

bash 复制代码
setsid python script.py > output.log 2>&1 &

3. 将命令放入后台 (&)

将命令放入后台并不直接防止 HUP 信号,但它可以在某些情况下实现类似效果。通过在命令后添加 &,程序将在后台运行,用户可以关闭终端窗口而不影响后台进程。但是,仍然建议结合其他方法来确保作业的持久性。例如:

bash 复制代码
(your_command) &

示例:运行后台任务:

bash 复制代码
(python script.py) &
python3 UDI_CDMet.py &
python3 UDI_Beijing.py &

注意:虽然这种方法可以让进程在后台执行,但如果用户注销,进程仍可能受到 HUP 信号的影响。因此,最好与 nohup 或 setsid 配合使用。

总结

  • 推荐方案:通常推荐使用 nohup 或 setsid 来确保长时间运行的作业不受网络或用户注销的影响。
  • 输出管理:确保正确处理输出,以便后续查看日志和结果。

参考

相关推荐
橙色小博10 分钟前
长短期记忆神经网络(LSTM)基础学习与实例:预测序列的未来
人工智能·python·深度学习·神经网络·lstm
SsummerC13 分钟前
【leetcode100】每日温度
数据结构·python·leetcode
仙人掌_lz24 分钟前
机器学习ML极简指南
人工智能·python·算法·机器学习·面试·强化学习
船长@Quant26 分钟前
PyTorch量化进阶教程:第六章 模型部署与生产化
pytorch·python·深度学习·transformer·量化交易·sklearn·ta-lib
叫我王富贵i40 分钟前
0基础入门scrapy 框架,获取豆瓣top250存入mysql
爬虫·python·scrapy
爱写代码的小朋友40 分钟前
华三交换机配置常用命令
运维·服务器·网络
wangjun51591 小时前
jenkins 参数化发布到服务器 publish over ssh、label、Parameterized publishing
服务器·ssh·jenkins
巷北夜未央1 小时前
Python每日一题(13)
开发语言·python·算法
愚润求学1 小时前
【Linux】Linux权限
linux·服务器·语法
低头不见1 小时前
一个服务器算分布式吗,分布式需要几个服务器
运维·服务器·分布式