这里有一个更加优雅的退出ssh客户端的方法:
是的,在一行的开始,输入『~』跟着『.』就可以结束ssh了。
如果不在一行的开始,这个命令是无效的,这个时候可以先按一下回车,再输入上面的命令。
进程组(process group):
一个或多个进程的集合,每一个进程组有唯一一个进程组ID,即进程组长进程的ID。
会话期(session):
一个或多个进程组的集合,有唯一一个会话期首进程(session leader)。会话期ID为首进程的ID。会话期可以有一个单独的控制终端(controlling terminal)。与控制终端连接的会话期首进程叫做控制进程(controlling process)。当前与终端交互的进程称为前台进程组。其余进程组称为后台进程组。
1. 挂断信号(SIGHUP)默认的动作是终止程序。
2. 当终端接口检测到网络连接断开,将挂断信号发送给控制进程(会话期首进程)。
3. 如果会话期首进程终止,则该信号发送到该会话期前台进程组。
4. 一个进程退出导致一个孤儿进程组中产生时,如果任意一个孤儿进程组进程处于STOP状态,发送SIGHUP和SIGCONT信号到该进程组中所有进程。
5. 因此当网络断开或终端窗口关闭后,控制进程收到SIGHUP信号退出,会导致该会话期内其他进程退出。
如果我们可以忽略SIGHUP信号,关掉窗口应该就不会影响程序的运行了。nohup命令可以达到这个目的,如果程序的标准输出/标准错误是终端,nohup默认将其重定向到nohup.out文件。值得注意的是nohup命令只是使得程序忽略SIGHUP信号,还需要使用标记&把它放在后台运行。
这里主要是用pexpect执行ssh,查看远程uptime和df -h看硬盘状况。#ssh_cmd.py
#coding:utf-8
import pexpect
def ssh_cmd(ip, user, passwd, cmd):
ssh = pexpect.spawn('ssh %s@%s "%s"' % (user, ip, cmd))
r = ''
try:
i = ssh.expect(['password: ', 'continue connecting (yes/no)?'])
if i == 0 :
ssh.sendline(passwd)
elif i == 1:
ssh.sendline('yes')
except pexpect.EOF:
ssh.close()
else:
r = ssh.read()
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)