sshd除了远程shell外还有哪些功能

1. 远程 Shell 访问 (Interactive Shell Login)

这是 SSH 最基础、最常用的功能。

  • 具体作用:登录到远程服务器的命令行界面,获得一个交互式 Shell(如 bash、zsh),就像直接坐在那台机器前操作一样。
  • 用法ssh [选项] [用户]@[主机名或IP]
  • 使用步骤
    1. 打开你的本地终端(Linux/macOS 的 Terminal,Windows 的 PowerShell 或 CMD)。
    2. 输入命令格式 ssh username@server_ip
    3. 如果是首次连接,会提示你确认服务器指纹,输入 yes
    4. 输入对应用户的密码(如果使用密钥认证且已设置密码,则需要输入密钥密码;如果未设置,则直接登录)。
  • 例子
sh 复制代码
    # 登录到 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 [用户]@[主机] "[命令]"
  • 使用步骤
    1. 在本地终端中,将你要执行的命令用引号括起来,放在 ssh 连接语句的后面。
    2. 执行后,会先进行认证,然后远程执行该命令,输出结果会显示在你的本地终端上。
  • 例子
sh 复制代码
    # 查看远程服务器的当前时间和登录用户
    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 [用户]@[主机]
  • 使用步骤
    1. 在本地终端输入 sftp user@host 建立连接。
    2. 进入一个交互式的 sftp 提示符(如 sftp>)。
    3. 使用特定的命令来管理文件:
      • put [本地文件]:上传文件到服务器。
      • get [远程文件]:从服务器下载文件。
      • ls:列出服务器上的文件。
      • lls:列出本地当前目录的文件。
      • cd [远程路径]:切换服务器上的目录。
      • lcd [本地路径]:切换本地的当前目录。
    4. 输入 exitbye 退出。
  • 例子
sh 复制代码
  # 连接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服务器]
  • 使用步骤
    1. 在本地终端执行转发命令。SSH 连接会建立并保持,只要连接存在,转发就有效。
    2. 在本地计算机上,访问 localhost:[本地端口]
    3. 流量路径:本地应用 -> localhost:本地端口 -> SSH加密隧道 -> SSH服务器 -> 目标主机:目标端口
  • 例子
    场景 :你在家,想访问公司内网 db.internal.com 的 MySQL 数据库(端口3306),但该数据库不对外开放。你有一台可以访问的跳板机 gateway.company.com
sh 复制代码
   # 在本地终端执行:
    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 3307

5. 远程端口转发 (Remote Port Forwarding, -R)

  • 具体作用 :将远程 SSH 服务器 的一个端口"反向"映射回本地计算机(或本地网络中的另一台机器)的某个端口。让外部能够通过访问 SSH 服务器来访问你本地的服务。
  • 用法ssh -R [远程IP:][远程端口]:[本地目标主机]:[本地目标端口] [用户]@[SSH服务器]
  • 使用步骤
    1. 在本地计算机上执行转发命令。
    2. 让其他人访问 SSH服务器IP:远程端口
    3. 流量路径:外部用户 -> SSH服务器:远程端口 -> SSH加密隧道 -> 本地计算机:本地目标端口
  • 例子
    场景 :你在本地电脑(localhost)上开发了一个 Web 应用,运行在 3000 端口。你没有公网 IP,但有一台云服务器 public.com。你想让朋友预览你的网站。
sh 复制代码
    # 在你的本地电脑上执行:
    ssh -R 8080:localhost:3000 alice@public.com
复制代码
# 现在,你的朋友(或你自己)在浏览器访问
# http://public.com:8080
# 这个请求就会被转发到你本地电脑的 3000 端口

6. SSH 代理转发 (SSH Agent Forwarding, -A)

  • 具体作用 :让你本地 ssh-agent 管理的密钥,通过一条 SSH 连接(跳板机),去认证下一台服务器。你的私钥永远不会离开你的本地电脑,提高了安全性。
  • 用法ssh -A [用户]@[跳板机]
  • 使用步骤
    1. 确保你的私钥已经添加到本地的 ssh-agentssh-add ~/.ssh/id_rsa)。
    2. 使用 -A 选项登录跳板机。
    3. 从跳板机上,你可以继续 ssh 到其他内部服务器,而无需在跳板机上存储你的私钥。
  • 例子
sh 复制代码
    # 在本地电脑上启动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
相关推荐
我只会发热2 小时前
Ubuntu 20.04.6 根目录扩容(图文详解)
linux·运维·ubuntu
爱潜水的小L2 小时前
自学嵌入式day34,ipc进程间通信
linux·运维·服务器
保持低旋律节奏2 小时前
linux——进程状态
android·linux·php
zhuzewennamoamtf2 小时前
Linux I2C设备驱动
linux·运维·服务器
zhixingheyi_tian2 小时前
Linux 之 memory 碎片
linux
邂逅星河浪漫2 小时前
【域名解析+反向代理】配置与实现(步骤)-SwitchHosts-Nginx
linux·nginx·反向代理·域名解析·switchhosts
梅尔文.古3 小时前
RaspberryPi-如何启用看门狗
linux·运维·服务器
木子欢儿3 小时前
Ubuntu 24 安装 fcitx5 + rime + 雾凇配置
linux·运维·服务器·ubuntu
Alice3 小时前
linux scripts
java·linux·服务器