FantasticMao 个人博客

OpenSSH 常用命令

发表于 2020-02-21,预计阅读时间 2 分钟

前言

这篇文章记录自己在系统性地学习 OpenSSH 相关命令过程中的一些零碎笔记,SSH 协议不在本篇文章记录的范围之内。

ssh

官方文档:https://www.ssh.com/ssh/command

大部分 Unix / Linux 系统都内置了 ssh 命令,用于在本机启动 SSH 客户端程序,建立与远程主机安全的连接。ssh 命令可以用于登录远程主机,在两台主机之间传输文件,以及在远程主机上执行命令。

使用 ssh 登录远程主机非常简单,常用形式如下:

ssh [-p port] [user@]host

使用 ssh 第一次连接到某台远程主机时,用户需要遵循提示,将这台远程主机的 host key 保存到本机的 ~/.ssh/known_hosts 文件中。

使用 ssh 与远程主机建立连之后,用户需要输入密码进行身份认证。在身份认证成功之后,用户便会进入远程主机的 shell prompt(即等待用户输入 shell 命令的交互界面)。

ssh 也经常被用于这样的场景:无需登录至远程主机的 shell prompt 进行交互,可以直接执行远程主机上的命令,并返回执行结果至当前主机。在这种场景中,可以使用如下形式的 ssh 命令:

ssh [-p port] [user@]host [command]

ssh 默认会从用户级别的 ~/.ssh/config 文件和系统级别的 /etc/ssh/ssh_config 文件读取 ssh 配置数据。ssh 命令行中的配置选项优先级最高,其次是用户级别的配置文件,再其次是系统级别的配置文件。ssh 配置文件的语法如下:

ssh 配置文件中包含多台主机的配置以 Host 或者 Match 关键字分隔,并且每个部分的配置都会只应用于匹配模式成功的主机。ssh 配置文件中的关键字不区分大小写,但参数值区分大小写。一个简单的 ssh 配置文件如下:

~$ cat ~/.ssh/config
# 阿里云
Host aliyun
HostName 11.22.33.44
User root

# 腾讯云
Host tencent
HostName 55.66.77.88
User app
Port 22222

更多关于 ssh 配置文件的信息请查看 man ssh_config

ssh-keygen

官方文档:https://www.ssh.com/ssh/keygen

SSH 协议使用公共密钥加密(public key cryptography)技术对主机和用户进行身份认证,其中的认证密钥被叫做 SSH 密钥(包含公钥和私钥),需要使用 ssh-keygen 命令创建。SSH 密钥可以用于自动登录、单点登录和主机认证。

创建 SSH 密钥最简单的方式是不带任何参数地直接运行 ssh-keygen 命令,在这种情况下,ssh-keygen 命令会提示用户 SSH 密钥文件的存储位置,如下图所示:

image

ssh-keygen 首先会主动询问用户密钥文件的存储位置,默认地址是 ~/.ssh/ 目录。其次会要求用户输入用于加密生成 SSH 密钥的密码短语,这个密码应该具备足够的加密强度。SSH.COM 站点上提供了一个用于生成足够强度的密码短语的在线服务,地址是:https://www.ssh.com/iam/password/generator

SSH 支持多种用于认证密钥的公共密钥算法,包括 rsadsaecdsaed25519。在 ssh-keygen 中,提供了 -t 选项用于择选择这些算法(默认值为 rsa),还有 -b 选项用于指定密钥的字节长度。

ssh-copy-id

官方文档:https://www.ssh.com/ssh/copy-id

在 SSH 中为了使用公共密钥认证(public key authentication)技术来对用户进行身份认证,公钥必须被拷贝至服务端,并需要被添加到 ./ssh/authorized_keys 文件中。可以使用 ssh-copy-id 命令很方便地完成此操作,如下所示:

ssh-copy-id -i ~/.ssh/id_rsa user@host

在服务端配置了公钥之后,服务端将会允许携带密钥的所有正在连接中的用户登录。在登录过程中,客户端通过对 密钥交换(Key Exchange) 进行 数字签名(Digitally Signing) 来证明客户端是拥有密钥的。

ssh-agent

官方文档:https://www.ssh.com/ssh/agent

ssh-agent 是一个帮助程序,用于跟踪用户的身份密钥(私钥)和密码短语。ssh-agent 可以使用密钥直接登录远程主机,而无需用户再次输入密码短语。ssh-agent 通过这种形式实现了单点登录(single sign-on)。

ssh-agent 被用于 SSH 公共密钥认证,它需要使用 SSH 密钥。用户可以使用 ssh-kengen 命令创建 SSH 密钥,然后使用 ssh-copy-id 命令在远程主机上安装 SSH 密钥。

在大部分 Linux 系统中,ssh-agent 会被自动配置,并且会在用户登录时自动运行,用户不需要其它操作既可直接使用 ssh-agent。如果 ssh-agent 没有被配置为在登录时运行,它也可以通过以下命令手动运行:

eval `ssh-agent`

ssh-add

官方文档:https://www.ssh.com/ssh/add

ssh-agent 默认会使用 ~/.ssh/ 目录下的 SSH 密钥,但用户可以使用 ssh-add 命令主动添加密钥至 ssh-agent 中。

运行 ssh-add 命令时如果不带任何参数的话,ssh-add 会默认添加 ~/.ssh/id_rsa~/.ssh/id_dsa~/.ssh/id_ecdsa~/.ssh/id_ed25519~/.ssh/identity 文件,也可以通过参数指定私钥的文件。

ssh-addd -l 命令可以列出当前 ssh-agent 允许访问的私钥。

scp

官方文档:https://www.ssh.com/ssh/scp

scp 是一个使用 SSH 协议在多台主机之间复制文件的程序。大部分 Unix / Linux 系统都内置了 scp 命令。

使用 scp 复制文件至远程主机的命令如下:

scp file ... [user@]host:[path]

使用 scp 从远程主机复制文件的命令如下:

scp [user@]host:[file] ... path

使用 scp 复制整个目录时,需要添加 -r 选项:

scp -r [user@]host:[path/directory] path

sftp

略,详细内容请查看 官方文档

sshd

略,详细内容请查看 官方文档