linux 远程主机后台运行任务 挂起脚本

linux 远程主机后台运行任务 挂起脚本,第1张

背景 :工作需要,需要远程控制主机使其断开Xshell后也能一直运行。

关键字 :& ,nohup,脚本挂起。

在应用Unix/Linux时,我们一般想让某个程序后台运行,于是我们将常会用 &在程序结尾来让程序自动运行。

键入Ctrl + C,发出SIGINT信号,程序会继续运行

方法一、输入命令:jobs

方法二:输入命令:ps

fg、bg、jobs、&、nohup、ctrl+z、ctrl+c 命令

加在一个命令的最后,可以把这个命令放到后台执行,如

可以将一个正在前台执行的命令放到后台,并且处于暂停状态。

查看当前有多少在后台运行的命令

jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped, Terminated。但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识。

将后台中的命令调至前台继续运行。如果后台中有多个命令,可以用fg %jobnumber(是命令编号,不是进程号)将选中的命令调出。

将一个在后台暂停的命令,变成在后台继续执行。如果后台中有多个命令,可以用bg %jobnumber将选中的命令调出。

法子1:通过jobs命令查看job号(假设为num),然后执行kill %num

法子2:通过ps命令查看job的进程号(PID,假设为pid),然后执行kill pid

前台进程的终止:Ctrl+c

如果让程序始终在后台执行,即使关闭当前的终端也执行(之前的&做不到),这时候需要nohup。该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。

关闭中断后,在另一个终端jobs已经无法看到后台跑得程序了,此时利用ps(进程查看命令)

如上所示:

nohup 和 & 组合了后台运行程序。

可以输出到 out.log保存程序输出,也可以输出到/dev/null 即空设备,不保存输出。

上面三种方式无论在nohup.out 或test.out都看不到数据结果,这是因为python执行有缓存输出

解决

新的接口接入查看程序

使用&后台运行程序:

结果会输出到终端

使用Ctrl + C发送SIGINT信号, 程序免疫

关闭session发送SIGHUP信号, 程序关闭

使用nohup运行程序:

结果默认会输出到nohup.out

使用Ctrl + C发送SIGINT信号, 程序关闭

关闭session发送SIGHUP信号, 程序免疫

平日线上经常使用nohup和&配合来启动程序:

同时免疫SIGINT和SIGHUP信号

同时,还有一个最佳实践:

不要将信息输出到终端标准输出,标准错误输出,而要用日志组件将信息记录到日志里

nohup和&究竟有啥区别

挂起 就是进入后台 *** 作

前台看不见 我们能看到的 就是前台

我们看不到了 其实程序还在运作 或者说这个程序还在占用一定的内存空间 就是后台运行 就叫挂起 有些挂起还是可以看到的 比如缩到 右下角的任务栏里了

中断说起来复杂了

叫IRQ 就是中断请求啦

简单的说吧 打个比方 我们的计算机都是通过CPU来计算的 包括内存地址啊 数据什么的 但是我们的CPU不能同时运行多个程序 在一个时间段内 只能运行一个程序

可我们需要运行多个程序 比如现在有两个程序 A B

A运行了10% 要运行B 这时B程序会向CPU发出个中断请求CPU就分配在下个时间段 把CPU分给B使用 当B运行了5% A又要运行 也有个中断请求 就这样反复 直到两个或者几个程序运行完毕

这叫 多道程序处理

这里说的不严谨 只是表达这个意思

这里只是想表述 目前的CPU还不能并发程序 都是串行处理的

挂起的意思是说把程序放置在后台,仍然占用一定的内存空间,有可能对CPU也在占用着.

liuhu314回答的显然不正确。。。 break是用来跳出循环的,狂汗。。设置断点程序就直接退出了,还怎么能做到暂停。。。

如果是想程序刮起,可以采用下列语句:

SuspendThread(GetCurrentThread())

注意,一定要包含windows.h这个头文件。

解释:

SuspendThread(HANDLE)是暂停/挂起线程。参数是将要被挂起的进程句柄,而GetCurrentThread()函数正是获得当前线程的句柄,即获得当前的程序所在线程的句柄,所以可以实现程序暂停的功能。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/12146874.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-21
下一篇 2023-05-21

发表评论

登录后才能评论

评论列表(0条)

保存