前言
SSH是一种安全通道协议,主要用来实现字符界面远程登陆、远程复制功能。
一、SSH远程管理
1.SSH定义
- SSH(Secure Shell)是一种安全通道协议,主要用来实现字符界面的远程登录、远程复制等功能
- SSH协议对通信双方的数据传输进行了加密处理,其中包括用户登录时输入的用户口令。因此SSH协议具有很好的安全性
2.SSH优点
- 数据传输是加密的,可以防止信息泄漏
- 数据传输是压缩的,可以提高传输速度
3.SSH配置文件
- sshd 服务的默认配置文件是/etc/ssh/sshd_config
- ssh_config和sshd_config都是ssh服务器的配置文件
二者区别在于ssh_config是针对客户端的配置文件,sshd_config则是针对服务端的配置文件
4.SSH客户端与与服务端
- SSH客户端:Putty、Xshell、CRT
- SSH服务端:OpenSSH
- OpenSSH 是实现 SSH 协议的开源软件项目,适用于各种 UNIX、Linux 操作系统
- CentOS 7系统默认已安装openssh相关软件包,并已将 sshd 服务添加为开机自启动
二、配置OpenSSH服务端
vim /etc/ssh/sshd_config
Port 22 //监听端口为22
ListenAddress 0.0.0.0 //监听地址为任意网段,也可以指定OpenSSH服务器的具体IP
LoginGraceTime 2m //登录验证时间为2分钟
PermitRootLogin no //禁止root用户登录
MaxAuthTries 6 //最大重试次数为 6
PermitEmptyPasswords no //禁止空密码用户登录
UseDNS no //禁用 DNS 反向解析,以提高服务器的响应速度
//只允许zhangsan、lisi、wangwu用户登录,且其中wangwu用户仅能够从IP地址为61.23.24.25 的主机远程登录
AllowUsers zhangsan lisi wangwu@61.23.24.25 //多个用户以空格分隔
//禁止某些用户登录,用法于AllowUsers 类似(注意不要同时使用)
DenyUsers zhangsan
三、scp远程复制
1.下行复制:将远程主机的/etc/passwd文件复制到本机
scp root@192.168.71.20:/etc/passwd /root/passwd1
2.上行复制:将本机的/etc/ssh目录复制到远程主机
scp -r /etc/ssh/ root@192.168.71.20:/opt
四、sftp安全FTP
由于使用了加密/解密技术,所以传输效率比普通的FTP要低,但安全性更高,操作语法sftp与ftp差不多
sftp root@192.168.71.20
sftp> ls
sftp> get 文件名 //下载件到ftp目录(下载和上传目录 -r)
sftp> put 文件名 //复制(上传)文件到ftp目录
sftp> quit //退出
五、在客户机设置ssh代理功能,实现免交互登录
ssh-agent bash //开启ssh代理服务
ssh-add //密钥添加到高速缓存中
Enter passphrase for /home/admin/.ssh/id_ecdsa: //输入私钥的密码
ssh zhangsan@192.168.71.10 //验证无需输入密码登入用户
目录