Original package is https://github.com/alemures/ssh-manager/
, this is modification on top of that.
Why it's not a fork
I was looking for a good SSH GUI, which can help me manage multiple server access via SSH (Not being a DevOps guy, I am/was handling too many servers; even multiple organizations). It was painful when ssh to a server was giving me error of Too many authentication failures
, just because I've 10+ pem files. Not being able to find a light-weight and good GUI, I decided to write my own tool (CLI). I just searched on Github (site:github.com ssh manager
on Google), and found this one to be simple and good.
- Modify
servers/servers.json
(easy to do; if you've basic understanding of SSH terminology) - Put the SSH Keys (
.pem
files) inservers
folder - Better create alias (
alias sshm=<CLONE_DIR>/lib/node_modules/ssh-manager/lib/cli.js
) - Good to go. Just
sshm
from shell and choose from the list
- I've never used the flags listed under
Usage
section. Not sure if they are broken. - Each SSH connection is a new ssh-agent shell. (check
lib/Connection.js
#L15) - CSV Reader is removed. (Editing a CSV from vi is a cumbersome task)
- Ping check removed - I find it slow and unnecessary. (It's an opinionated change)
- Table output is changed AFAIK (I don't recall the original table format; because I added
git
to npm installation directory at very later stage) - (Important) Multiple SSH keys supported when forwarding.
Start the script with sshm
(or your chosen alias) and you will be prompted to select a server from few sample servers. To add yours,
you have to create a configuration file with (servers/servers.json
) with the following format:
(please remove comments)
[
{
"name": "Test Server1",
"user": "alejandro",
"host": "8.8.8.8"
},
{
"name": "Test Server2",
"user": "paul",
"host": "7.8.8.8",
"port": 23,
"pems": ["file2.pem", "id_rsa.pem"] // You can specify multiple pem files, all will be forwarded
},
// If you need to ssh via a jumphost. Specify the jumphost's address under host field, and next server under `secondhost` field.
{
"name": "Test Server2",
"user": "paul",
"host": "7.8.8.8",
"port": 23,
"pem": "file2.pem", // you can also use `pems` option
"secondhost": "[email protected]"
}
]
Usage: sshm [options]
Options:
-o, --order Order the table by the given column
[string] [choices: "name", "id", "user", "host", "port"]
-s, --server Specify the server name or id to connect [string]
-h, --help Show help [boolean]
https://github.com/alemures (<-- Original Author)