1. 远程 Shell 访问 (Interactive Shell Login)
这是 SSH 最基础、最常用的功能。
- 具体作用:登录到远程服务器的命令行界面,获得一个交互式 Shell(如 bash、zsh),就像直接坐在那台机器前操作一样。
- 用法:
ssh [选项] [用户]@[主机名或IP] - 使用步骤:
- 打开你的本地终端(Linux/macOS 的 Terminal,Windows 的 PowerShell 或 CMD)。
- 输入命令格式
ssh username@server_ip。 - 如果是首次连接,会提示你确认服务器指纹,输入
yes。 - 输入对应用户的密码(如果使用密钥认证且已设置密码,则需要输入密钥密码;如果未设置,则直接登录)。
- 例子:
# 登录到 IP 为 192.168.1.100 的服务器,用户名为 alice ssh alice@192.168.1.100 # 使用特定端口(例如 2222)登录 ssh -p 2222 alice@192.168.1.100* **成功后**:你的终端提示符会变化,表示你现在发出的所有命令都在远程服务器上执行。2. 远程命令执行 (Remote Command Execution)
- 具体作用:在远程服务器上执行单条或一组命令,然后立即返回结果并关闭连接。不进入交互式 Shell。
- 用法:
ssh [用户]@[主机] “[命令]” - 使用步骤:
- 在本地终端中,将你要执行的命令用引号括起来,放在
ssh连接语句的后面。 - 执行后,会先进行认证,然后远程执行该命令,输出结果会显示在你的本地终端上。
- 在本地终端中,将你要执行的命令用引号括起来,放在
- 例子:
# 查看远程服务器的当前时间和登录用户 ssh alice@192.168.1.100 "date && who" # 重启远程服务器上的 web 服务 ssh alice@192.168.1.100 "sudo systemctl restart nginx" # 将远程文件的内容输出到本地屏幕 ssh alice@192.168.1.100 "cat /etc/os-release"3. SFTP (SSH File Transfer Protocol)
- 具体作用:提供一个安全的、交互式的文件传输通道,用于上传、下载、删除、重命名、创建目录等文件操作。这是最推荐的文件传输方式。
- 用法:
sftp [用户]@[主机] - 使用步骤:
- 在本地终端输入
sftp user@host建立连接。 - 进入一个交互式的 sftp 提示符(如
sftp>)。 - 使用特定的命令来管理文件:
put [本地文件]:上传文件到服务器。get [远程文件]:从服务器下载文件。ls:列出服务器上的文件。lls:列出本地当前目录的文件。cd [远程路径]:切换服务器上的目录。lcd [本地路径]:切换本地的当前目录。
- 输入
exit或bye退出。
- 在本地终端输入
- 例子:
# 连接SFTP服务 sftp alice@192.168.1.100 # (进入sftp交互界面后) sftp> lcd /home/localuser/Documents # 切换到本地Documents目录 sftp> cd /tmp # 切换到服务器/tmp目录 sftp> put report.pdf # 上传本地report.pdf文件到服务器/tmp sftp> get server_log.txt # 下载服务器的server_log.txt到本地当前目录 sftp> bye # 退出`4. 本地端口转发 (Local Port Forwarding,-L)
- 具体作用:将本地计算机的一个端口“映射”或“隧道”到远程网络中的另一台机器的某个端口。所有发送到本地端口的数据都会被加密并通过 SSH 连接转发到最终的目标。
- 用法:
ssh -L [本地IP:][本地端口]:[目标主机]:[目标端口] [用户]@[SSH服务器] - 使用步骤:
- 在本地终端执行转发命令。SSH 连接会建立并保持,只要连接存在,转发就有效。
- 在本地计算机上,访问
localhost:[本地端口]。 - 流量路径:
本地应用 -> localhost:本地端口 -> SSH加密隧道 -> SSH服务器 -> 目标主机:目标端口
- 例子:
场景:你在家,想访问公司内网db.internal.com的 MySQL 数据库(端口3306),但该数据库不对外开放。你有一台可以访问的跳板机gateway.company.com。
# 在本地终端执行: ssh -L 3307:db.internal.com:3306 alice@gateway.company.com # 现在,在你本地的机器上 # 你可以用MySQL客户端连接 localhost:3307 # 这个连接实际上被安全地转发到了内部的 db.internal.com:3306 mysql -u dbuser -p -h 127.0.0.1 -P 33075. 远程端口转发 (Remote Port Forwarding,-R)
- 具体作用:将远程 SSH 服务器的一个端口“反向”映射回本地计算机(或本地网络中的另一台机器)的某个端口。让外部能够通过访问 SSH 服务器来访问你本地的服务。
- 用法:
ssh -R [远程IP:][远程端口]:[本地目标主机]:[本地目标端口] [用户]@[SSH服务器] - 使用步骤:
- 在本地计算机上执行转发命令。
- 让其他人访问
SSH服务器IP:远程端口。 - 流量路径:
外部用户 -> SSH服务器:远程端口 -> SSH加密隧道 -> 本地计算机:本地目标端口
- 例子:
场景:你在本地电脑(localhost)上开发了一个 Web 应用,运行在 3000 端口。你没有公网 IP,但有一台云服务器public.com。你想让朋友预览你的网站。
# 在你的本地电脑上执行: ssh -R 8080:localhost:3000 alice@public.com# 现在,你的朋友(或你自己)在浏览器访问 # http://public.com:8080 # 这个请求就会被转发到你本地电脑的 3000 端口6. SSH 代理转发 (SSH Agent Forwarding,-A)
- 具体作用:让你本地
ssh-agent管理的密钥,通过一条 SSH 连接(跳板机),去认证下一台服务器。你的私钥永远不会离开你的本地电脑,提高了安全性。 - 用法:
ssh -A [用户]@[跳板机] - 使用步骤:
- 确保你的私钥已经添加到本地的
ssh-agent(ssh-add ~/.ssh/id_rsa)。 - 使用
-A选项登录跳板机。 - 从跳板机上,你可以继续
ssh到其他内部服务器,而无需在跳板机上存储你的私钥。
- 确保你的私钥已经添加到本地的
- 例子:
# 在本地电脑上启动agent并添加密钥 eval "$(ssh-agent -s)" ssh-add ~/.ssh/id_rsa # 输入你的密钥密码 # 使用代理转发连接到跳板机 ssh -A alice@jump-server.company.com # 现在,在 jump-server 的终端里,你可以直接连接内网其他服务器 # 跳板机会向你的本地agent请求签名来完成认证 ssh db-admin@internal-db-server