你是否曾经历过这样的惊魂一幕:在远程服务器上执行一项关键任务时,网络突然波动,SSH连接意外中断。你心中一紧,任务会不会因此中断?别担心,今天,我们将一起探索如何在SSH注销后确保任务持续运行的秘籍。
01、为什么SSH注销后任务会终止?
在Linux系统中,当用户注销或者网络断开时,终端会收到HUP(hangup)信号,从而关闭其所有子进程。这是因为系统默认认为,当用户注销或终端关闭时,与其相关的所有进程都应该终止,以释放系统资源并确保没有孤立进程在运行。
HUP (Hangup) 信号是一种 UNIX/Linux 系统中的信号,通常用于通知进程其控制终端已经关闭,或者需要重新加载配置文件。
在传统的 UNIX 系统中,当一个终端会话被挂起或关闭时,所有连接到该终端的进程都会接收到一个 HUP 信号。后来,这个信号被用来作为“重新加载”或“重启”信号,用于通知后台进程(如服务器程序)重新加载其配置文件或执行其他清理任务,而不需要完全终止进程。
常见的应用场景有:
-
**配置重载:**很多守护进程(如 nginx, apache)会监听 HUP 信号,以便在收到信号时重新加载配置文件。例如,执行 nginx -s reload 实际上是向 nginx 进程发送一个 HUP 信号。
-
**终端挂断:**如果一个进程是通过某个终端启动的,当终端关闭时,它会收到 HUP 信号。这时进程可以选择退出,或者继续运行。
-
**信号处理:**开发者可以通过捕捉并处理 HUP 信号来执行某些特定操作,例如在接收到信号时刷新日志、清理缓存或更新状态。
02、工具命令
但是,有些任务需要长时间运行,我们不希望它们因为SSH会话的断开而终止。这时,我们可以利用一些工具和技巧来忽略HUP信号,确保任务继续运行。
nohup
nohup 是一个常用的工具,它可以忽略HUP信号,让进程在用户注销或终端关闭后继续运行。使用nohup命令非常简单,只需在命令前加上nohup,然后将命令放入后台执行即可。
nohup command [arguments] &
例如,我们可以使用nohup命令来启动一个长时间运行的ping操作,即使我们关闭了SSH会话,ping操作也会继续运行。默认会在当前路径下生成nohup.out文件存放执行日志。
nohup ping www.bing.com &
setsid
setsid 同样可以实现这一目的。它创建一个新的会话,并将指定的程序在这个新的会话中运行,从而使程序脱离当前终端的控制。这样,即使SSH会话断开,程序也不会受到影响。
setsid command [arguments]
disown
disown命令是另一个有用的工具,它可以从Shell终端中移除作业,正在运行的作业也可以被移除,亦可以对作业进行标记,确保任务在SSH注销后继续运行。使用disown命令后,即使我们关闭了SSH会话,任务也不会终止。使用过diisown命令的作业,可以用 ps -aux查找。
disown [options] [job_spec]
# options
## -h:标记作业使其结束 Shell 终端窗口时不退出;
## -a:移除所有的作业;
## -r:移除运行的作业;
## -ah:所有的作业都忽略 HUP 信号;
## -rh:正在运行的作业忽略 HUP 信号;
screen
screen是一个终端多路复用工具,它们可以在SSH连接断开或终端关闭时,保持会话和进程的运行状态。保持会话活跃(即使 ssh 连接断开或终端关闭,正在运行的任务依旧继续)、恢复会话(断开后可以重新连接到同一个会话,查看任务执行情况)、多任务管理(在一个 screen 会话中可以运行多个终端任务,类似于多标签的终端操作)、会话分离与恢复(可以随时将会话分离detach,稍后再恢复reattach)。
screen [options] [command]
在实际应用中,我们可以根据具体的场景选择合适的方法。例如,如果我们需要临时运行一个长时间任务,可以使用nohup命令。如果我们需要在SSH会话断开后继续运行已经在执行的任务,可以使用disown命令。而对于需要同时运行多个任务的场景,screen则是更好的选择。
通过这些方法,我们可以确保即使SSH会话断开,我们的任务也能继续运行。这样,无论我们身处何地,都可以放心地让任务在远程服务器上运行,而不用担心因为网络波动或其他原因导致任务中断。
题外话
黑客&网络安全如何学习
今天只要你给我的文章点赞,我私藏的网安学习资料一样免费共享给你们,来看看有哪些东西。
1.学习路线图
攻击和防守要学的东西也不少,具体要学的东西我都写在了上面的路线图,如果你能学完它们,你去就业和接私活完全没有问题。
2.视频教程
网上虽然也有很多的学习资源,但基本上都残缺不全的,这是我自己录的网安视频教程,上面路线图的每一个知识点,我都有配套的视频讲解。
内容涵盖了网络安全法学习、网络安全运营等保测评、渗透测试基础、漏洞详解、计算机基础知识等,都是网络安全入门必知必会的学习内容。
(都打包成一块的了,不能一一展开,总共300多集)
因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取
🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源
3.技术文档和电子书
技术文档也是我自己整理的,包括我参加大型网安行动、CTF和挖SRC漏洞的经验和技术要点,电子书也有200多本,由于内容的敏感性,我就不一一展示了。
因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取
🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源
4.工具包、面试题和源码
“工欲善其事必先利其器”我为大家总结出了最受欢迎的几十款款黑客工具。涉及范围主要集中在 信息收集、Android黑客工具、自动化工具、网络钓鱼等,感兴趣的同学不容错过。
还有我视频里讲的案例源码和对应的工具包,需要的话也可以拿走。
🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源
最后就是我这几年整理的网安方面的面试题,如果你是要找网安方面的工作,它们绝对能帮你大忙。
这些题目都是大家在面试深信服、奇安信、腾讯或者其它大厂面试时经常遇到的,如果大家有好的题目或者好的见解欢迎分享。
参考解析:深信服官网、奇安信官网、Freebuf、csdn等
内容特点:条理清晰,含图像化表示更加易懂。
内容概要:包括 内网、操作系统、协议、渗透测试、安服、漏洞、注入、XSS、CSRF、SSRF、文件上传、文件下载、文件包含、XXE、逻辑漏洞、工具、SQLmap、NMAP、BP、MSF…
因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取
🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源
————————————————
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。