nohup(no hang-up)命令在Linux系统中用于在用户退出登录后继续运行指定的程序或脚本。以下是一些使用nohup命令的最佳实践:
nohup command & command:要运行的命令或脚本。&:将命令放入后台运行。默认情况下,nohup会将输出重定向到当前目录下的nohup.out文件。你可以自定义输出文件:
nohup command > output.log 2>&1 & >:将标准输出重定向到指定文件。2>&1:将标准错误输出重定向到标准输出。&:将命令放入后台运行。&符号确保命令在后台运行,否则nohup命令会等待命令完成。
nohup运行交互式程序nohup不适合运行需要用户交互的程序,因为它会忽略挂起信号(SIGHUP)。
setsid在某些情况下,使用setsid可能比nohup更可靠:
setsid command & setsid会创建一个新的会话,并将命令作为该会话的领头进程。
使用ps命令监控后台进程:
ps -ef | grep command 或者使用pgrep:
pgrep -f command 定期检查和管理日志文件,避免日志文件过大。可以使用logrotate工具来自动管理日志文件。
sudo运行需要特权的命令时,确保nohup命令不会被滥用。screen或tmux对于更复杂的会话管理,可以考虑使用screen或tmux工具。这些工具允许你在多个会话之间切换,并且可以在断开连接后重新连接。
假设你想在后台运行一个Python脚本,并将输出重定向到my_script.log:
nohup python my_script.py > my_script.log 2>&1 & 通过遵循这些最佳实践,你可以更有效地使用nohup命令来确保程序在用户退出登录后继续运行。