管道断裂后如何重新连接到 ssh 会话?

管道断裂后如何重新连接到 ssh 会话?

当时我正在服务器上运行apt-get upgrade,路由器认为距离上次让我生气已经过去太久了:它断开了所有连接。这个故事的寓意是,screen当你使用一个糟糕的路由器时,要多加利用。

无论如何,我重新登录并在 htop 中发现该进程仍挂在那里,仍在等待我的 Y/n 升级(幸运的是,还没有达到它)。有什么方法可以重新连接到已中断的会话吗?我最终只是将其杀死,因为它不在包管理的中间,但如果能知道以供将来参考,那就太好了。

答案1

虽然你无法重新连接到中断的 SSH 会话,你可以重新设置 SSH 中运行的进程– 功能上等同于您想要的。

指示

在你的情况下,你将接管这个apt-get过程,目标是从新的SSH 会话、screen会话或类似命令。我最喜欢的reptyr命令是:

$ sudo apt-get install reptyr
$ ps ax | grep apt-get
10626 pts/8   R+     0:32 apt-get upgrade

然后,使用您找到的进程的 pid:

$ sudo reptyr -T 10626

如果这不起作用,请尝试:

$ reptyr 10626

在此阶段之后,您的所有键盘输入都将进入您接管的程序。遗憾的是,您将看不到 SSH 会话的旧输出,例如apt-get要求您确认的输出。

解释

还有多种其他工具基本与其相同reptyr(即通过ptrace调试附件)。请参阅以下讨论它们的问题和答案:

在上面的说明中,reptyr 10626使用ptrace调试附件,而sudo reptyr -T 10626命令使用TTY窃取并且是可取的(细节)。

最后,您无法通过这种方式接管 SSH 会话的原因是,进程sshd不受主机终端控制,而是提供终端的从属部分(pts设备)位于客户端计算机上,而控制它的主控部分位于客户端计算机上,两者之间有一个中断的 SSH 会话。当您使用 强制接管此类进程时sshdreptyr -s <pid>您的键盘输入将转到该进程,而不是其活动的子进程。因此,“Ctrl+Z”只会终止该sshd

答案2

对你的问题的正确答案是:你不能。我认为主要问题是身份验证程序不同步。它根本行不通。

正如你自己注意到的,解决方案是在可能的情况下使用屏幕(顺便说一下,tmux是屏幕的替代品)。

答案3

对于运行长时间的进程,我使用屏幕, 或者屏风如果您想要更友好的界面。

对于屏幕,您可以使用:

screen [program] [args]

这将在屏幕会话。程序完成后,会话将自动关闭。如果您希望在程序运行后保留会话,只需运行屏幕不带任何参数,会话中会出现一个新提示。Ctrl+A+D将终端与当前会话分离。

要重新连接到上一个会话:

screen -r

如果只打开一个会话,它会立即重新连接。如果正在进行多个会话,它会询问您要连接到哪一个。如果您知道会话名称,您可以将其作为参数添加到此命令行。

屏风是一个很好的改进。它基于屏幕,但在底部提供了一个栏,以选项卡形式显示所有当前会话,并提供更方便的快捷方式来移动这些会话。您可以:

  • F2 开始新会话
  • F3 移动到左侧的下一个会话选项卡
  • F4 移动到右侧的下一个会话选项卡
  • F8 为当前会话选项卡指定一个友好名称
  • F9 打开选项菜单
  • CTRL+A+D 从终端分离所有会话。

忠告:避免离开与用户打开的会话。如果任何人获得对您的终端的访问权限(本地或远程),他们可以轻松重新连接到正在进行的会话并以 root 身份使用您的系统。如果需要,最好使用普通用户启动会话,然后须藤根据需要指定单独的命令行。

答案4

do-dist-upgrade我通过 ssh 从一台进入挂起状态的笔记本电脑上执行操作,因此Broken pipe。回到机器后,我看到与升级相关的进程仍在运行,其中包括要求whiptail我输入(选择哪个显示管理器)以及相关的 root 拥有的SCREEN。我能够执行sudo su -并附screen -r加到会话,瞧,我面前的鞭尾对话框能够接受输入。我能够无缝恢复升级。

注意:这是从 Ubuntu 14.04 到 16.04 的升级。

相关内容