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
    • 最新
    • 标签
主页 / server / 问题 / 1172565
Accepted
Tom Bennett
Tom Bennett
Asked: 2025-02-11 12:46:33 +0800 CST2025-02-11 12:46:33 +0800 CST 2025-02-11 12:46:33 +0800 CST

对伪 tty 分配感到困惑:ssh -t

  • 772

ssh -t我对这个选项的作用和原因感到困惑-t。我的理解是,如果我运行ssh -t program,ssh 将被强制分配一个伪 tty,它将键盘输入传递给program,并将program的输出传递给 stdout。

但看来我错了。例如,以下两个命令似乎功能相同,因为我可以使用其中任何一个与 rclone 进行交互操作,即使第一个命令强制它分配伪 tty,而第二个命令强制它不分配伪 tty:

  1. ssh -t [email protected] rclone config
  2. ssh -T [email protected] rclone config

那么它ssh -t实际上做什么呢?

更新:

为了进一步阐明这个问题,我编写了下面名为的 Python 脚本hello.py。

import sys, signal

def signal_handler(sig, frame):
    print('You pressed Ctrl+C!')
    sys.exit(0)

signal.signal(signal.SIGINT, signal_handler)

print(f"stdin is tty:{sys.stdin.isatty()}")
print(f"stdout is tty:{sys.stdout.isatty()}")

s = input("Enter what you want:")
print("Hello ", s)

在远程机器上,如果我以 方式调用它,我会得到以下输出:ssh -t [email protected] "python hello.py"

stdin is tty: true
stdout is tty: true
Enter what you want: cat
Hello cat

如果我将其作为 调用,则会得到以下内容:ssh -T [email protected] "python hello.py"

stdin is tty: false
stdout is tty: false
Enter what you want: cat
Hello cat

无论哪种情况,我都可以通过在键盘上输入“cat”来与程序进行交互。

我观察到的一个区别是,当我按下 CTRL-C 时,-t版本捕获 SIGINT,但-T版本没有。

我很好奇为什么即使 stdin/stdout 不是 tty,我仍然可以与它交互。此外,isatty()它实际上是一个标准 C 库函数。这里的 (伪) TTY 到底是什么意思?

ssh
  • 1 1 个回答
  • 36 Views

1 个回答

  • Voted
  1. Best Answer
    grawity
    2025-02-11T15:17:27+08:002025-02-11T15:17:27+08:00

    ssh 被强制分配一个伪 tty,通过它将键盘输入传递给程序,并将程序的输出传递给 stdout。

    它可以做到这一点,但伪 tty 不是 stdin/stdout 工作所必需的。这也可以使用普通管道来实现。当您运行 时ssh -T,远程程序的输入和输出将使用匿名管道连接到 sshd。

    但是,tty 还有其他功能Ctrl-C- 它提供输入和输出转换(例如,LF 到 CRLF,或到 SIGINT 信号),它有“尺寸”的概念(宽度 × 高度存储为 tty 参数)。内核还会跟踪连接到特定 tty 的进程,以便可以实现作业控制(如 shell 中的 Ctrl-Z),以及当 sshd 退出且 tty“挂断”时发出 SIGHUP 信号,或当尺寸发生变化时发出 SIGWINCH 信号。

    (由于交互式终端意味着拥有一个 tty,许多程序还会检查stdin 上是否存在tty,以确定是否以交互模式运行。例如,您可以在没有 tty 的情况下运行 Bash,但 – 除了无法执行作业控制之外 – 它还将决定禁用其行编辑功能并默认使用空的“提示符”。Glibc fwrite() 等运行时的缓冲 I/O 将检查 tty,以了解是否逐行缓冲交互式输出,或大批量缓冲文件/管道输出。)

    -t当您想要运行面向终端的程序(例如)时htop,以及当您想要一个“干净的” 8 位通道来传输二进制数据时,请使用-T。(通常,唯一需要显式命令的情况-T是当远程端有强制命令时。)

    • 1

相关问题

  • 如何最好地设置 ssh 隧道以访问远程网络 (Linux)

  • SSH 和重定向

  • 通过 SSH 会话使用 NET USER 命令拒绝访问

  • SSH 服务器零日漏洞利用 - 保护自己的建议

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

Sidebar

Stats

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

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve