AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / ubuntu / 问题 / 850590
Accepted
jirislav
jirislav
Asked: 2016-11-18 11:49:51 +0800 CST2016-11-18 11:49:51 +0800 CST 2016-11-18 11:49:51 +0800 CST

如果我“杀死”了 ssh 服务器,为什么 ssh 会话仍然处于活动状态?

  • 772

我现在遇到了,在您通过 ssh 连接到 Ubuntu 14.04 并将 sshd_config 更改为无效状态后,这service ssh reload将导致服务器停止侦听但不会关闭我已建立的活动 ssh 会话。

要重现我所做的步骤:

  1. 连接到 ssh 服务器:

    ssh host
    
  2. 变为/etc/ssh/sshd_config无效状态,例如设置:

    GatewayPorts 0.0.0.0:62222
    
  3. 重新加载服务器配置

    sudo service ssh reload
    
  4. 检查在步骤 1) 中建立的 ssh 连接是否仍然处于活动状态,您可以输入任何您想要的内容。

  5. 不要关闭已建立的连接并尝试从另一个终端再次连接到服务器:

    ssh host
    

就我而言,我收到了这条消息:

ssh: connect to host IP_ADDR port SSH_PORT: Connection refused

这意味着 ssh 服务器不再监听传入的连接,但不知何故仍然神奇地运行并处理我建立的连接。

我认为这有时会非常方便某人将自己锁定在 ssh 会话中,这样其他人就无法确定连接到服务器并且仍然能够执行用户想要的任何内容。

所以问题是:这是期望的行为吗?这种实施的最初目的是什么?

顺便说一句,我注意到 ssh 服务器在这种情况下处于有点不一致的状态:

$ service ssh reload
reload: Job is not running: ssh
$ service ssh start
start: Job is already running: ssh

因此,要恢复服务器,我必须运行:

service ssh reload

可能重要的注意事项:

  1. Ubuntu 服务器由Mail-in-a-Box v0.20 配置,没有进行进一步的更改。
  2. 服务器提供商(DigitalOcean)在 sshd_config 中为我设置了另外两个规则:
    • ClientAliveInterval 120
    • ClientAliveCountMax 2
networking
  • 1 1 个回答
  • 1236 Views

1 个回答

  • Voted
  1. Best Answer
    Jakuje
    2016-11-21T01:43:26+08:002016-11-21T01:43:26+08:00

    因为用户连接在不同的进程中运行。这是一个非常有用的功能。

    • 它可以防止您使用错误的配置将自己锁定在服务器之外
    • 它更加防故障:单个(用户)进程的失败不会杀死所有其他连接
    • 它比处理所有连接的单个进程提供更好的性能
    • 它更加安全:用户真的被分开到不同的进程。

    以这种方式编写 TCP 服务器是常见的做法。例如,它与 Apache 有点不同,后者产生了几个工作人员,这些工作人员被重用于后续连接。

    • 4

相关问题

  • 如何设置 VLAN 转发?

  • 如何将主机 Ubuntu 上的 VPN (tun0) 网络适配器映射到 VirtualBox 来宾 Windows?

  • 如何限制下载/上传带宽?

  • 如何通过 Windows 网络共享文件?

  • 面板小程序以文本形式显示当前网络流量?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve