赞
踩
OpenSSH 是 SSH (Secure SHell) 协议的免费开源实现。SSH协议族可以用来进行远程控制,
或在计算机之间传送文件。而实现此功能的传统方式,如telnet(终端仿真协议)、 rcp ftp、 rlogin、
rsh都是极为不安全的,并且会使用明文传送密码。OpenSSH提供了服务端后台程序和客户端工
具,用来加密远程控件和文件传输过程中的数据,并由此来代替原来的类似服务。
是用于 安全 远程登录和其他安全 网络 服务的软件包,对于大多数Linux发行版来说,它都是默认
安装的。 随着时间的推移,OpenSSH的新版本可能会引入安全性更新和改进,因此升级到最新版
本是很有必要的。 特别是对于CentOS 7,由于它已经停止了官方支持,因此及时升级系统组件变
得更加重要。
v1:基于CRC-32 做MAC,不安全; (一般用于实现主机认证)
v2:基于协议协商选择双方都支持的最安全的MAC机制
基于DH做密钥交换,基于RSA或DSA实现身份认证,从而实现无需输入账号密码
客户端通过检查服务器端的主机秘钥来判断是否能够继续通信;
1 基于口令的认证
2 基于密钥的认证
为什么要使用OpenSSH:
由于传统的telnet、rcp ftp等工具是明文传输数据的,对数据安全性存在很大的安全隐患,
OpenSSH可以对传输的数据进行加密从而大大提高了数据的安全性
升级版本原因:OpenSSH有严重漏洞,因此要升级到最新版本
首先查看ssh版本
ssh -V ##查看当前版本
关闭防火墙及核心防护
- systemctl stop firewalld
- setenforce 0
为了防止升级安装失败,无法使用ssh做远程连接,因此先安装telnet预防
- rpm -q telnet-server ##telnet服务端
-
- rpm -q telnet ##telnet客户端
- yum install telnet-server -y
-
- yum install telnet -y
-
- 或者
-
- yum install telnet* -y
- systemctl start telnet.socket
-
- systemctl enable telnet.socket
-
- systemctl status telnet.socket
-
- ss -natp |grep 23
默认情况下,系统是不允许root用户telnet远程登陆的,如果要使用root用户直接登录,需设置以下内容。或者可以添加一个可以登录的用户,登录并su到root用户
- mv /etc/securetty /etc/securetty.bak
-
- 或者
- echo 'pts/0' >>/etc/securetty
- echo 'pts/1' >>/etc/securetty
- yum -y install zlib*
-
- yum -y install pam-*
-
- yum -y install gcc
-
- yum -y install openssl-devel
- mv /etc/ssh /etc/ssh.bak
- mv /usr/bin/ssh /usr/bin/ssh.bak
- mv /usr/sbin/sshd /usr/sbin/sshd.bak
官方下载地址:Index of /pub/OpenBSD/OpenSSH/portable/
./configure --sysconfdir=/etc/ssh
which sshd
12 复制源码解压路径的开机启动脚本
- cp /opt/openssh-8.9p1/contrib/redhat/sshd.init /etc/init.d/sshd
-
- ls /etc/init.d/
- sed -i '25cSSHD=/usr/local/sbin/sshd' /etc/init.d/sshd
-
- sed -i '41c/usr/local/bin/ssh-keygen -A' /etc/init.d/sshd
sed -i "/#PermitRootLogin prohibit-password/c\PermitRootLogin yes" /etc/ssh/sshd_config
- cp /opt/openssh-8.9p1/contrib/ssh-copy-id /usr/local/bin/
-
- chmod +x /opt/openssh-8.9p1/contrib/ssh-copy-id
- #启动
- service sshd start
-
- #查看版本号
- ssh -V
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。