Linux下升级OpenSSH8.4p1修复CVE-2020-15778漏洞

2024-02-23 15:18

本文主要是介绍Linux下升级OpenSSH8.4p1修复CVE-2020-15778漏洞,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

后记

升级到8.4p1后并没能修复该bug,临时解法:禁用scp命令
参考文章:禁用scp

实践环境

系统:CentOS 7.9,OpenSSH版本:7.4p1

#查看版本
cat /etc/redhat-release
ssh -V

一、安装Telnet登录

为防止升级OpenSSH8.4p1出现问题,造成无法远程登录,需要准备一个备用方案,这里选择telnet登录,如果有其他备用方案,也可不安装跳过该步骤

  1. 安装
    yum install xinetd telnet-server -y
    
  2. 配置
    vim /etc/xinetd.d/telnet
    内容如下
    service telnet
    {disable = yesflags       = REUSEsocket_type = stream       wait        = nouser        = rootserver      = /usr/sbin/in.telnetdlog_on_failure  += USERID
    }
    
  3. 防火墙添加23端口
    firewall-cmd --add-port=23/tcp --permanent
    firewall-cmd --reload 
    
  4. 启动服务
    systemctl enable xinetd
    systemctl enable telnet.socket
    systemctl start telnet.socket
    systemctl start xinetd
    
  5. 本地登录测试
    telnet 远程电脑ip
    
    输入用户密码即可,这里不能使用root账号;使用root需要进行额外配置,非root账号最好有sodu权限;

二、备份

备份pam.d的sshd,后面要用
cp /etc/pam.d/sshd /etc/pam.d/sshd.bak

三、卸载原有OpenSSH

systemctl stop sshd
yum remove openssh

以上是使用yum install openssh openssh-clients openssh-server安装或默认安装的卸载方式,如果使用源码安装,则在源码包下执行:make uninstall

验证:ssh -V
升级openssh8.4,卸载原来版本
移除残留

rm -rf /etc/ssh

四、安装必要依赖

yum -y install gcc pam pam-devel zlib zlib-devel openssl-devel

五、源码安装

OpenSSH8.4官方源码包下载地址:http://www.openssh.com/portable.html#http
OpenSSH8.4官方安装文档:
http://www.linuxfromscratch.org/blfs/view/svn/postlfs/openssh.html

  1. 下载源码包
wget http://ftp.openbsd.org/pub/OpenBSD/OpenSSH/portable/openssh-8.4p1.tar.gz
tar -xzf openssh-8.4p1.tar.gz
cd openssh-8.4p1
  1. 安装
 ./configure  --prefix=/usr  --sysconfdir=/etc/ssh  --with-pammakemake install

验证安装是否成功

ssh -V
sshd -V
  1. 配置
cp contrib/redhat/sshd.pam /etc/pam.d/sshd -f
install -v -m755 contrib/ssh-copy-id /usr/bin
install -v -m644 contrib/ssh-copy-id.1 /usr/share/man/man1
cp -p contrib/redhat/sshd.init /etc/init.d/sshd -f
#使用原来覆盖
rm /etc/pam.d/sshd -f
cp /etc/pam.d/sshd.bak /etc/pam.d/sshd -f
echo 'PermitRootLogin yes' >> /etc/ssh/sshd_config
echo 'UsePAM yes' >> /etc/ssh/sshd_config
echo 'PasswordAuthentication yes' >> /etc/ssh/sshd_config
echo 'PubkeyAuthentication yes' >> /etc/ssh/sshd_config
  1. 开机启动
chmod +x /etc/init.d/sshd 
systemctl enable sshd
  1. 启动服务
systemctl restart sshd 

成功启动服务后,在本地验证登录,大功告成!

六、错误查找

通过systemctl status sshd可以看到出错信息;
附上错误集锦:升级OpenSSH8.4常见错误

这篇关于Linux下升级OpenSSH8.4p1修复CVE-2020-15778漏洞的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/739043

相关文章

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

修复已被利用的高危漏洞! macOS Sequoia 15.6.1发布

《修复已被利用的高危漏洞!macOSSequoia15.6.1发布》苹果公司于今日发布了macOSSequoia15.6.1更新,这是去年9月推出的macOSSequoia操作... MACOS Sequoia 15.6.1 正式发布!此次更新修复了一个已被黑客利用的严重安全漏洞,并解决了部分中文用户反馈的

Ubuntu如何升级Python版本

《Ubuntu如何升级Python版本》Ubuntu22.04Docker中,安装Python3.11后,使用update-alternatives设置为默认版本,最后用python3-V验证... 目China编程录问题描述前提环境解决方法总结问题描述Ubuntu22.04系统自带python3.10,想升级

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet