8000 GitHub - mokyle/sshgo: script for managing ssh hosts list
[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Skip to content

mokyle/sshgo

 
 

Repository files navigation

sshgo

​ 用于管理ssh主机列表的脚本,并且支持自动输入,可用于:

  • 自动输入密码
  • 登录后自动执行命令
  • 登录后自动ssh跳转到其他机器。(即所谓跳板机登录)
  • 支持终端自动设置Title(仅支持部分终端的bash)

预览图

screenshot

依赖

ssh或zssh python3 pexpect

配置文件ssh_hosts.json 示例

[
    {
        "title": "me",
        "expanded": false,
        "sub_node": [
            {
                "title": "local",
                "ssh": "k@127.0.0.1 -p 22",
                "expect": [
                    {"passwd": "123456"}
                ]
            },
            {
                "title": "localToTemp",
                "pre_host": "local",
                "expect": [
                    {"$": "cd /tmp/"},
                    {"ps1": "inTempPath"},
                    {"setTitle": ""}
                ]
            }
        ]
    },
    {
        "title": "prod",
        "expanded": true,
        "sub_node": [
            {
                "title": "manualLocal",
                "ssh": "k@127.0.0.1 -p 22",
                "expect": [
                    {"k@127.0.0.1's password:": "123456"},
                    {"$": "cd /tmp/"}
                ]
            },
            {
                "title": "ping",
                "pre_host": "localToTemp",
                "expect": [
                    {"$": "ping -c 3 127.0.0.1 && sleep 5 && exit"}
                ]
            }
        ]
    }
]

配置文件详解:

首先效果见上图。

配置文件中有两个组,共包含4个主机的配置。

参数含义:

  • title 表示在主界面显示的名称。

  • expanded 表示组是否默认展开。 (上图示例中"me"组就是默认没展开的)

  • sub_node 表示组里包含的具体的host

  • ssh 表示要登录指定主机时候需要的ssh命令具体参数

  • expect 表示ssh登录指定主机时候或登录到指定主机之后要自动执行的命令。例如 示例配置文件中主机manualLocal 示例:"expect":[{"k@127.0.0.1's password:":"123456"},{"$":"cd /tmp/"}],意思是:登录主机时收到请输入密码的提示: "k@127.0.0.1's password:",此脚本自动输入密码123456并回车,然后再等待出现"$",又刚回车后ssh命令继续执行登录成功进入bash,并显示了一个$符号表示是普通用户登录成功。这时此脚本捕获到出现的"$"后自动执行"cd /tmp/"并回车。 (这整个流程中有个麻烦的地方是每个主机的密码提示语可能都不太一样,运行示例时候请将"k@127.0.0.1's password:"改为自己目标主机实际的提示语。另外为了解决这个麻烦,脚本支持关键字"passwd",可以自动识别各种密码提示语,详见下文)

注意: expect 参数的类型是数组,数组里面放{},可以有多个{},但每个{}中应该有且仅有一个键值对。为什么这么设计而不是设计成 expect:{"key1":"value1","key2":"value2"}呢? 原因是python数组才可以保证顺序,而python元祖没有顺序。

对于expect数组中每个{}的键值对:

​ 键表示等待出现的字符串, 值表示自动发送的内容。 另外,键有预设的几个关键字,目前有"passwd", "setTitle","ps1"。

  • passwd 对应请输入密码的提示,可以同时匹配中文和英文密码提示,也支持第一次连接某个新主机时自动确认是否信任新秘钥的询问。

  • setTitle 设置终端显示的标题。其实就是登录成功后自动执行一条命令:PROMPT_COMMAND='echo -ne "\033]0;sshToLocal\007"' 。已知深度终端是默认支持的,如果是konsole,需要设置konsole的 配置方案->标签页->标签标题格式为%w

  • ps1 或 ps1-bench 或 ps1-prod 表示登陆后自动设置终端的提示符(即bash的PS1变量)。其实就是登录成功后自动执行一条命令:export PS1='\[\e[30;46m\]lo:\w\[\e[36;42m\]▶\[\e[30;42m\]\t \$\[\e[0m\]\[\e[32m\]▶\[\e[0m\]' 。值留空时,表示使用title的值。值支持\w和\h变量,变量具体用法可以自行搜索bash的PS1变量,注意在这里变量需要使用双反斜杠。此脚本里面预设了PS1的格式和“ps1” “ps1-bench” “ps1-prod”三种不同配色风格。ps1的效果见下图:(如果你实际运行后▶符号显示效果不如下图完美,可以使用此项目中提供的这款字体Hack-Regular-kai.ttf)

screenshot

  • pre_host 值为其他主机中的title值。表示此主机配置是基于某个主机配置,有了pre_host参数就不再需要ssh参数。 比如示例文件中localToTemp主机,执行登录时先执行local主机的ssh命令,然后执行local主机的expect,然后再执行localToTemp主机的expect。

执行图例:

screenshot

快捷键

  • 上一组:PgUp 或 -
  • 下一组:PgDn 或 =
  • 进入主机: space 或 Enter 或 Right
  • 搜索: /
  • 退出或退出搜索: q
  • 上一屏: k
  • 下一屏: j
  • 上翻页: u
  • 下翻页: d
  • 展开组: o 或 Right
  • 折叠组: c 或 Left
  • 展开所有组: O
  • 折叠所有组: C

About

script for managing ssh hosts list

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%
0