linux-远程访问管理(sshd,scp,sftp)

1、ssh的概述

SSH(Secure Shell)是一种安全通道协议,通过加密 和认证机制实现安全的远程访问和文件传输等业务,主要 用来实现字符界面的远程登录、远程复制等功能。 SSH 协议对通信双方的数据传输进行了加密处理,其中包括用户登录时输入的用户口令。

与早期的 Telent(远程登录)、RSH(Remote Shell, 远程执行命令)、RCP(Remote File Copy,远程文件复制)等应用相比,SSH 协议提供了更好的安全性。

ssh传输层协议,提供了服务器认证,保密性及完整性。此外它有时还提供压缩功能。通常运行在TCP/IP连接上,也可能用于其它可靠数据流上。

SSH依赖端口进行通信,默认端口号为22。SSH服务器在 指定端口侦听连接请求,客户端发起连接请求后,双方建立TCP连接。

常用工具:

  • OpenSSH:开源的SSH实现,广泛应用于各种操作系统。yum install openssh-clients openssh-server 或者 apt install openssh-clients openssh-server
  • PuTTY:Windows平台上的SSH和Telnet客户端,支持多种认证方式和端口转发等功能。

ssh的文件:

  • 服务端主程序:/usr/sbin/sshd
  • 服务端配置文件:/etc/ssh/sshd_config
  • 默认配置文件:/etc/ssh/sshd_config

ssh配置文件的常见限制:

ssh 配置文件的验证文件:

密码验证:PermitRootLogin yes允许root用户登录

公钥私钥验证:PubkeyAuthentication yes启用公钥认证功能,允许用户通过私钥与服务器公钥配对完成登录,替代传统密码认证。

2、ssh的远程登录

注:准备两台服务器,在同一个局域网下,可以相互ping通(内网)

2.1 普通密码连接

  • ssh username@hostname_or_ip # 连接远程主机(默认端口22)
  • ssh -p 2222 username@hostname # 指定端口,连接非默认端口

2.2 免密码连接(公私钥连接)

  • 生成SSH密钥对,命令生成密钥:在本地客户端终端:ssh-keygen -t rsa -b 4096 -C "注释"
  • 将公钥复制到目标服务器,使用 ssh-copy-id命令:ssh-copy-id username@server_ip
  • 编辑SSH配置文件,启用公钥认证:PubkeyAuthentication yes
  • 其他安全建议:PermitRootLogin no # 禁止root登录,Port 2222 # 修改默认端口(非必选)
  • 重启sshd服务,配置生效

3、scp 远程文件传输

通过 scp 命令可以利用 SSH 安全连接与远程主机相互复制文件。使用 scp 命令时,除了必须指定复制源、目标之外,还应指定目标主机地址、登录用户,执行后根据提示输入验证口令即可。

用法:

  • scp [选项] 源文件或目录 目标路径

  • -r递归复制目录(必须使用): scp -r /local/dir user@remote:/remote/dir

  • -P 指定SSH端口(大写,非默认端口):scp -P 2222 file.txt user@remote:/path

  • -i指定密钥文件路径(如非默认位置):scp -i ~/.ssh/mykey.pem file.txt user@remote:/path

  • -C 启用压缩传输(减少带宽,提升速度)

  • -p 保留文件属性 (修改时间、权限等)

  • -v 显示详细传输信息(调试用)

  • -l限制带宽(单位:Kbit/s)

4、sftp文件传输协****议

SFTP(SSH File Transfer Protocol,SSH 文件传输协议)是一种基于 SSH(Secure Shell)的文件传输协议,用于在客户端和服务器之间安全地传输文件。与传统的 FTP 不同,SFTP 通过加密通信保护数据传输,适合传输敏感信息。

sftp用法:

  • 连接到SFTP服务器:在命令行中输入sftp user@hostname,也可使用 -P 指定端口号
  • 下载文件:get命令下载文件,如get /remote/path/file /local/path
  • 上传文件:put命令上传文件,如get /local/path/file /remote/path
  • mput上传多个文件
  • mget下载多文件
相关推荐
Yama1173 分钟前
服务器端安全检测与防御技术概述
服务器·网络·安全
失因15 分钟前
PPP 链路及 MP 捆绑与 CHAP 验证实验
运维·网络·网络安全·智能路由器
那个指针是空的?22 分钟前
Samba配置使用
linux·samba
H3C-Navigator31 分钟前
【AI高性能网络解析】第一期:面向GPU算力纵向扩展的Scale-up网络技术研究
网络·人工智能·gpu算力·ai-native
wxy8888881 小时前
CIU32L051系列 DMA串口无阻塞性收发的实现
linux·运维·服务器
:-)1 小时前
mac上通过homebrew安装nvm管理多版本nodejs
linux·macos·编辑器·vim
真智AI1 小时前
全面安装指南:在Linux、Windows和macOS上部署Apache Cassandra
linux·windows·macos
_可乐无糖2 小时前
用鼠标点击终端窗口的时候出现:0;61;50M0;61;50M0;62;50M0
linux·ssh
特种加菲猫3 小时前
硬件与软件的桥梁:冯诺依曼体系、操作系统和初始进程的深度解析
linux·笔记
创小匠4 小时前
创客匠人:创始人 IP 变现,从 “单点尝试” 到 “生态赋能” 的跨越
网络·网络协议·tcp/ip