0


Linux(Centos7)OpenSSH漏洞修复,升级最新openssh-9.7p1

OpenSSH更新

一、OpenSSH漏洞

服务器被扫描出了漏洞需要修复,准备升级为最新openssh服务
在这里插入图片描述
在这里插入图片描述

1. 使用ssh -v查看本机ssh服务版本号

  1. ssh-V

虚拟机为OpenSSH7.4p1,现在准备升级为OpenSSH9.7p1
在这里插入图片描述
2. 准备好需要用到的安装包

  1. 链接:https://pan.baidu.com/s/1fN624AdqSp7aG2QXs8nAKw?pwd=8888
  2. 提取码:8888

在这里插入图片描述
3. 将安装包全部上传至服务器/opt目录(可以是任意目录,解压时注意路径)
在这里插入图片描述
**4. 安装

  1. telnet服务

。为了保险起见,假如ssh更新失败断开又连不上我们可以使用telnet服务连接。

  1. 此步骤可跳过

大家根据自己实际情况来。升级OpenSSH之前多打开一个连接窗口,假如升级失败了卸载了SSH也还是能连上的,只是不能断开,断开就连不上了。**

4.1 telnet服务是由xinetd管理的,需要安装xinetd服务才能启动telnet-server

  1. yum -yinstall telnet-server xinetd

在这里插入图片描述在这里插入图片描述
4.2 添加telnet配置文件

  1. echo"service telnet
  2. {
  3. flags = REUSE
  4. socket_type = stream
  5. wait = no
  6. user = root
  7. server = /usr/sbin/in.telnetd
  8. log_on_failure += USERID
  9. disable = no
  10. }"> /etc/xinetd.d/telnet

在这里插入图片描述
4.3 启动xinetd

  1. systemctl start xinetd && systemctl status xinetd

在这里插入图片描述
4.4 开机自启xinetd

  1. systemctl enable xinetd

4.5 创建连接账号密码

  1. #创建连接账号useradd admins
  2. #设置连接密码passwd admins
  3. #设置密码
  4. Asd123!!!

在这里插入图片描述
4.6 测试连接
**使用win+r输入cmd打开指令板,输入

  1. telnet 服务器IP

**在这里插入图片描述
输入刚刚创建的账号密码连接,和SSH连接一样

  1. #步骤4.5创建的
  2. 账号: admins
  3. 密码: Asd123!!!

在这里插入图片描述
4.7 现在不需要ssh连接工具也能连接了,这样即便ssh连接失败也能用指令板操作。
在这里插入图片描述
5. 备份之前的SSH配置文件

  1. cp-p /etc/ssh/sshd_config /etc/ssh/sshd_config.bak
  2. cp-p /usr/sbin/sshd /usr/sbin/sshd.bak
  3. cp-p /usr/bin/ssh /usr/bin/ssh.bak
  4. cp-rf /usr/bin/openssl /usr/bin/openssl.bak
  5. cp-p /usr/bin/ssh-keygen /usr/bin/ssh-keygen.bak
  6. cp-p /etc/ssh/ssh_host_ecdsa_key.pub /etc/ssh/ssh_host_ecdsa_key.pub.bak
  7. cp-rf /usr/lib/systemd/system /system.bak
  8. cp /etc/pam.d/sshd /etc/pam.d/sshd.bak

在这里插入图片描述
6. 依赖安装-绝大部分应该都已经装过,可以只装没装过的

  1. yum install-y gcc gcc-c++ glibc make autoconf openssl openssl-devel pcre-devel pam-devel zlib-devel perl-IPC-Cmd

在这里插入图片描述

二、安装zlib

1. 解压

  1. tar-zxvf zlib-1.3.1.tar.gz -C /usr/local/
  2. cd /usr/local/zlib-1.3.1/

在这里插入图片描述
在这里插入图片描述
2. 编译 && 安装

  1. ./configure --prefix=/usr/local/zlib

在这里插入图片描述

  1. make&&makeinstall

在这里插入图片描述
在这里插入图片描述

三、安装OpenSSL

1. 解压

  1. cd /opt
  2. tar-zxvf openssl-3.3.0.tar.gz -C /usr/local/
  3. cd /usr/local/openssl-3.3.0

在这里插入图片描述
2. 安装依赖

  1. yum install-y perl-CPAN perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker

在这里插入图片描述

  1. perl-IPC-CmdData-Dumper-2不装直接安装openssl会报错,可能是虚拟机比较老,正常服务器应该有安装,可先跳过,如果报错在回来装

**3. 安装

  1. perl-IPC-Cmd

**

  1. cp /opt
  2. unzip perl-IPC-Cmd.zip -d /usr/local/
  3. cd /usr/local

在这里插入图片描述

  1. cd perl
  2. rpm-ivhU * --nodeps--force

在这里插入图片描述
**4. 安装

  1. Data-Dumper-2.183

**

  1. cp /opt
  2. tar-zxvf Data-Dumper-2.183.tar.gz -C /usr/local
  3. cd Data-Dumper-2.183

在这里插入图片描述

  1. cd Data-Dumper-2.183
  2. perl Makefile.PL
  3. makemakeinstall

在这里插入图片描述
**5. 安装

  1. openssl

**

  1. cd /opt
  2. tar-zxvf openssl-3.3.0.tar.gz -C /usr/local/
  3. cd /usr/local/openssl-3.3.0/
  4. ./config --prefix=/usr/local/ssl --shared

在这里插入图片描述
6. 编译安装,过程比较久,大概十来分钟

  1. make&&makeinstall

在这里插入图片描述
编译安装完成
在这里插入图片描述
7. 配置

  1. #依次执行mv /usr/bin/openssl /usr/bin/oldopenssl
  2. ln-s /usr/local/ssl/bin/openssl /usr/bin/openssl
  3. ln-s /usr/local/ssl/lib64/libssl.so.3 /usr/lib64/libssl.so.3
  4. ln-s /usr/local/ssl/lib64/libcrypto.so.3 /usr/lib64/libcrypto.so.3
  5. echo"/usr/local/ssl/lib64">> /etc/ld.so.conf
  6. ldconfig

在这里插入图片描述
8. 查看更新后的版本

  1. openssl version -v

在这里插入图片描述

四、安装OpenSSH

1. 卸载旧版本openssh7.4p1

  1. 注意:卸载完千万不能断开,断开就连不上了
  1. yum remove -y openssh

在这里插入图片描述

2. 清理残余文件

  1. rm-rf /etc/ssh/*

在这里插入图片描述
3. 解压

  1. cd /opt
  2. tar-zxvf openssh-9.7p1.tar.gz -C /usr/local/
  3. cd /usr/local/openssh-9.7p1

在这里插入图片描述
4. 编译安装

  1. ./configure --prefix=/usr/local/openssh --with-zlib=/usr/local/zlib --with-ssl-dir=/usr/local/ssl

在这里插入图片描述

在这里插入图片描述

  1. make&&makeinstall

在这里插入图片描述

5. 配置ssh

  1. #ssh允许root登录、需要密码进行验证echo'PermitRootLogin yes'>>/usr/local/openssh/etc/sshd_config
  2. echo'PubkeyAuthentication yes'>>/usr/local/openssh/etc/sshd_config
  3. echo'PasswordAuthentication yes'>>/usr/local/openssh/etc/sshd_config
  4. #将编译安装的新配置文件 拷贝到原路径下cp /usr/local/openssh/etc/sshd_config /etc/ssh/sshd_config
  5. cp /usr/local/openssh/sbin/sshd /usr/sbin/sshd
  6. cp /usr/local/openssh/bin/ssh /usr/bin/ssh
  7. cp /usr/local/openssh/bin/ssh-keygen /usr/bin/ssh-keygen
  8. cp /usr/local/openssh/etc/ssh_host_ecdsa_key.pub /etc/ssh/ssh_host_ecdsa_key.pub
  9. #拷贝启动脚本cp-p contrib/redhat/sshd.init /etc/init.d/sshd
  10. #给sshd添加可执行权限chmod +x /etc/init.d/sshd
  11. #设置开机自启
  12. systemctl enable sshd
  13. #重新启动sshd服务
  14. systemctl restart sshd
  15. #查看sshd服务状态
  16. systemctl status sshd

在这里插入图片描述
6. 查看OpenSSH版本,显示新版本就是升级成功了,如果显示还是旧的话断开重连一下再查看版本,可能没刷新

  1. ssh-V

在这里插入图片描述

标签: linux 服务器 ssh

本文转载自: https://blog.csdn.net/dontYouWorry/article/details/139629793
版权归原作者 一只大萌新! 所有, 如有侵权,请联系我们删除。

“Linux(Centos7)OpenSSH漏洞修复,升级最新openssh-9.7p1”的评论:

还没有评论