当在 ~/.bashrc 中设置 force_color_prompt=yes 时,为什么 SSH 会终止我的 /etc/update-motd.d/ 脚本中的颜色?

Rou*_*tor 2 ssh ubuntu motd

我在 /etc/update-motd.d 中安装了一个可以正常工作的 MOTD 脚本,但是似乎 SSH 会渗出颜色。

固态硬盘外观:

在此处输入图片说明

登录后运行脚本时的输出:

在此处输入图片说明

实际脚本:

cat /etc/update-motd.d/20-logo 
#! /usr/bin/env bash
echo "";
echo "$(tput setaf 2)    .::::::::::::::::::::::::::::::::::::::::...
   :::::::::::::::::::::::::::::::::::::::::::::::::::.
   .::::::::::::::::::::::::::::::::::::::::::::::::::::::.
                                      .....::::::::::::::::::
                  $(tput setaf 7):@@@@@O                          $(tput setaf 2).:::::::::::
                  $(tput setaf 7)@@@@@@@o                             $(tput setaf 2).::::::::
                  $(tput setaf 7)@@@@@@@o                                $(tput setaf 2):::::::
                  $(tput setaf 7)@@@@@@@o                                $(tput setaf 2).::::::
        $(tput setaf 7):@@@@@O   @@@@@@@o   O@@@@O                       $(tput setaf 2):::::::
      $(tput setaf 7):@@@@@@@@o  @@@@@@@o  o@@@@@@@O                    $(tput setaf 2):::::::.
     $(tput setaf 7)o@@@@@@@@O   @@@@@@@o  :@@@@@@@@@                $(tput setaf 2).::::::::.
    $(tput setaf 7)o@@@@@@@O     @@@@@@@o    o@@@@@@@O        $(tput setaf 2)..:::::::::::::
    $(tput setaf 7)@@@@@@@O      @@@@@@@o     :@@@@@@@o  $(tput setaf 2)::::::::::::::::::
   $(tput setaf 7)o@@@@@@@       @@@@@@@:      o@@@@@@@ $(tput setaf 2)::::::::::::::::.
   $(tput setaf 7)o@@@@@@o        o@@@O:        @@@@@@@ $(tput setaf 2).:::::::::..
   $(tput setaf 7)o@@@@@@@                     o@@@@@@@   $(tput setaf 2).:::::::::
   $(tput setaf 7)o@@@@@@@                     O@@@@@@O     $(tput setaf 2).:::::::::.
    $(tput setaf 7)@@@@@@@@                   O@@@@@@@:       $(tput setaf 2).::::::::::.
     $(tput setaf 7)@@@@@@@@O               :@@@@@@@@o           $(tput setaf 2).:::::::::::.
      $(tput setaf 7)@@@@@@@@@O:          o@@@@@@@@@o               $(tput setaf 2)::::::::::::::.
       $(tput setaf 7)O@@@@@@@@@@@@@@@@@@@@@@@@@@@@:                   $(tput setaf 2).:::::::::::::::..
         $(tput setaf 7)O@@@@@@@@@@@@@@@@@@@@@@@@:                         $(tput setaf 2).:::::::::::::::.
           $(tput setaf 7):@@@@@@@@@@@@@@@@@@@O                                $(tput setaf 2).::::::::::::
               $(tput setaf 7)oO@@@@@@@@@@o:                                        $(tput setaf 2)..::::.$(tput sgr0)
";
echo "================================================================================";
Run Code Online (Sandbox Code Playgroud)

我确保force_color_prompt=yes已启用~/.bashrc并且我的$TERM变量在两侧看起来都正确。终端模拟器和服务器都显示xterm-256color

什么可能导致颜色在 SSH 登录时失败?

zep*_*lin 5

动态 MOTD 由pam_motd模块 (/etc/pam.d/login)生成,它使用这样的一段代码来完成:

if (!system("/usr/bin/env -i PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin run-parts --lsbsysinit /etc/update-motd.d > /run/motd.dynamic.new"))
rename("/run/motd.dynamic.new", "/run/motd.dynamic");
Run Code Online (Sandbox Code Playgroud)

Asenv被调用-i

-i, --ignore-environment 从一个空的环境开始

运行时没有 TERM 变量可用tput,因此输出中不包含颜色代码:

%env -i /etc/update-motd.d/20-logoenv -i /etc/update-motd.d/20-logo
tput: No value for $TERM and no -T specified
tput: No value for $TERM and no -T specified
tput: No value for $TERM and no -T specified
...
Run Code Online (Sandbox Code Playgroud)

作为一种解决方法,您可以预先生成带有嵌入其中的转义码的徽标,如下所示:

%/etc/update-motd.d/20-logo > /tmp/color.logo
%(echo "#! /usr/bin/env bash"; 
  echo "cat <<EOF"; cat /tmp/color.logo; 
  echo "EOF") > /etc/update-motd.d/20-logo
Run Code Online (Sandbox Code Playgroud)

或者只是在脚本的顶部设置一个显式的 TERM 变量:

 export TERM=xterm-256color
Run Code Online (Sandbox Code Playgroud)

这两个选项都不完美(因为 TERM 类型将在生成 MOTD 时设置固定),但是 AFAIK 是您能做的最好的(除非您想修补pam_motd自身)。