我想为每台远程机器将 TERM 环境变量设置为不同的值,因此我使用了SetEnv TERM=myTermForRemoteVar
。~/.ssh/config
远程机器仍然可以看到TERM=myLocalTermVar
。
我在远程机器上添加了它。仍然没有成功AcceptEnv TERM
。/etc/ssh/sshd_config
SetEnv FOO=smth
我尝试了本地测试AcceptEnv FOO
。这运行完美,并且远程机器可以看到FOO=smth
。
是否TERM
被 ssh 特殊处理?SetEnv
一般情况下有效,但对 无效TERM
。还有人看到这种行为吗?至少没有记录。这是一个错误吗?
答案1
更新:自 OpenSSH 8.7 (2021-08-20) 起,SetEnv TERM
现已支持:
允许 ssh_config SetEnv 覆盖 $TERM,否则将由协议专门处理。在 ~/.ssh/config 中,对于缺少 terminfo 条目的目标,将 TERM 设置为通用值(例如“xterm”而不是“xterm-256color”)很有用。
openssh-unix-dev 上的这个线程似乎表明这TERM
确实是特殊的,并且您无法通过来设置它SetEnv
。以下是我对事情的解读:
正如该线程中所述,当 SSH 客户端从 sshd 请求新的 PTY 时,该请求包含一个显式TERM
值(请参阅RFC4254,“安全外壳 (SSH) 连接协议”,第 6.2 节)。这与客户端希望发送的任何环境变量都是分开的。
在 OpenSSH 中ssh.c
, 功能ssh_session2_setup
,OpenSSH 无条件地从当前环境中读取 PTY 请求的TERM
值,而不考虑任何SetEnv
指令。(您可以看到环境变量,包括来自 的变量SetEnv
,在clientloop.c
, 功能client_session2_setup
。
然后,在服务器端,session.c
的do_setup_env
功能按照客户端发送的相反顺序设置新 shell 的环境:第一的它设置环境变量s->env
,然后TERM
它从 PTY 请求的TERM
值( )中设置,覆盖作为正常环境变量发送的s->term
任何值。TERM
由于服务器上的这种操作顺序, a总是会被客户端环境中SetEnv TERM
的值覆盖,而不是任何。TERM
ssh
SetEnv
在上述帖子中,似乎有很好的理由改变 OpenSSH 在这方面的行为,但我认为没有采取任何行动。该帖子中至少有一个人强烈认为,如果需要,应该修改远程主机的 init 文件TERM
。(我个人不同意。)