nohup与&:后台运行程序的差异解析

5星 · 超过95%的资源 需积分: 18 2 下载量 57 浏览量 更新于2024-09-10 3 收藏 788KB DOCX 举报
"本文讨论了在Linux环境下,使用`nohup`和`&`命令启动程序的区别以及它们对信号处理的不同响应。" 在Linux操作系统中,我们常常需要在后台运行程序以避免阻塞终端。`nohup`和`&`都是实现这一目标的工具,但它们有着不同的特性和行为。 1. **使用`&`后台运行程序**: - 当在命令后面添加`&`时,程序将被放在后台执行。终端会立即返回命令提示符,允许用户继续其他操作。 - 输出结果会直接发送到终端,这意味着如果关闭终端,程序的输出也会丢失。 - 使用`Ctrl + C`发送的SIGINT信号通常用于停止程序,但在后台运行的程序会忽略此信号,不会被中断。 - 但是,当关闭当前的登录session(例如,通过断开SSH连接或注销),系统会发送SIGHUP信号,这会导致后台运行的程序被终止。 2. **使用`nohup`运行程序**: - `nohup`命令使得程序即使在用户退出终端后也能继续运行,它会忽略SIGHUP信号。 - 默认情况下,`nohup`命令将程序的输出重定向到`nohup.out`文件,而不是终端,这样即使终端关闭,输出也不会丢失。 - 当使用`nohup`启动的程序接收到`Ctrl + C`(SIGINT信号)时,程序不会免疫,而是会像正常情况一样停止运行。 - 即使用户关闭session,使用`nohup`启动的程序将继续运行,因为它免疫SIGHUP信号。 3. **`nohup`和`&`一起使用**: - 这种组合意味着程序既在后台运行,又免疫SIGHUP信号。它将输出重定向到`nohup.out`,并且在接收到SIGINT信号时不会停止,除非使用`kill`命令或其他方法显式结束进程。 测试案例中的`a.out`程序是一个简单的死循环,每秒输出一次"hello"。当使用不同方式启动时,我们可以观察到上述描述的行为: - 前台运行:`./a.out`,`Ctrl + C`可以停止程序。 - 后台运行:`./a.out &`,`Ctrl + C`不能停止程序,但关闭session会终止程序。 - `nohup`运行:`nohup ./a.out`,`Ctrl + C`会停止程序,即使关闭session,程序仍会继续运行。 - `nohup`和`&`结合:`nohup ./a.out &`,程序在后台运行且免疫SIGHUP,`Ctrl + C`无效,仅能通过`kill`命令关闭。 在测试过程中,注意到`nohup.out`文件可能在某些情况下大小为0,这可能是因为程序在接收到SIGHUP信号之前没有产生任何输出。而`nohup`命令确实会捕获并存储程序的输出,除非另有重定向设置。 总结来说,`&`和`nohup`提供了两种不同的后台运行策略,分别适用于不同的场景。`&`适合快速将任务放到后台,而`nohup`则更适合需要在用户退出后仍需保持运行的长时间任务。结合使用两者可以进一步控制程序的生命周期和信号处理。