当前位置: 首页 > news >正文

构建并升级openssh至OpenSSH_9.8p1

组件说明
OpenSSH_9.8p1最新版本(2024年8月)
OpenSSL 1.1.1pCentOS7中默认是OpenSSL 1.0.2k-fips 26 Jan 2017版本,OpenSSH_9.8p1不支持
CentOS7主要是因为有大量CentOS老版本需要升级RPM,需要适配,故选择此版本。
AnolisOS如果在CentOS8或Anolis中构建,则无需升级openssl:OpenSSL 1.1.1k FIPS 25 Mar 2021

准备编译环境

 yum -y groupinstall "development tools"yum install rpm-build rpmdevtools zlib-devel gcc perl perl-devel pam pam-devel unzip compat-openssl10-devel krb5-devel krb5-libs pkgconfig gtk2-devel imake libXt-devel glibc-devel 

准备构建环境

su - user1rpmdev-setuptree$ ll /home/user1/rpmbuild总用量 0drwxr-x--x. 3 user1 user1 27 8月   9 16:55 BUILDdrwxr-x--x. 2 user1 user1  6 8月   9 16:58 BUILDROOTdrwxr-x--x. 3 user1 user1 20 8月   9 16:57 RPMSdrwxr-x--x. 2 user1 user1 34 8月   9 16:38 SOURCESdrwxr-x--x. 2 user1 user1 26 8月   9 16:55 SPECSdrwxr-x--x. 2 user1 user1 41 8月   9 16:57 SRPMS

获取并修改spec文件

$ mv ~/openssh-9.8p1.tar.gz SOURCES/
$ cd rpmbuild
$ tar zxvf SOURCES/openssh-9.8p1.tar.gz -C ~/
$ cp ~/openssh-9.8p1/contrib/redhat/openssh.spec SPECS/
# 修改openssh.spec中的如下位置
$ vi SPECS/openssh.spec 
%global no_x11_askpass 1
%global no_gnome_askpass 1
%global kerberos5 0
#Source1: http://www.jmknoble.net/software/x11-ssh-askpass/x11-ssh-askpass-%{aversion}.tar.gz
#%if %{without_openssl}--with-ssl-dir=/usr/local/openssl \
#%endif

注意:--with-ssl-dir=/usr/local/openssl前提需要按照RPM包安装步骤,先把openssl升级到1.1.1以上版本。如果自己系统里的openssl-devel的版本大于等于1.1.1,这里无需改动。

构建RPM包

 rpmbuild -ba SPECS/openssh.spec 

RPM包安装步骤

<====================更新openssl,如果openssl大于等于1.1.1版本,跳过此步骤

0、查看openssl版本
openssl version
OpenSSL 1.0.2k-fips  26 Jan 20171、将openssl.tar.gz解压到/usr/local/
tar zxvf openssl.tar.gz -C /usr/local/
2、添加所缺函数库
echo "/usr/local/openssl/lib" >> /etc/ld.so.conf
3、更新函数库
ldconfig
4、将旧版本openssl备份
mv /usr/bin/openssl /usr/bin/openssl.old 
5、新版本制作软链接
ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl
6、最后查看版本,更新完毕
openssl version  
OpenSSL 1.1.1p  21 Jun 2022

<==========================升级安装openssh

升级之前请先阅读该总结:
https://blog.csdn.net/avatar_2009/article/details/129665320?spm=1001.2014.3001.5501icon-default.png?t=N7T8http://【OpenSSH升级】无论密码输入正确与否总是登录失败(error: Could not get shadow information for root)# 安装前备份配置文件
mv /etc/ssh/sshd_config /etc/ssh/sshd_config_bak

# 不备份也可以,因为旧文件里的一些配置,新版本可能不识别,导致启动失败;安装完成后,需要关注如下几项被正确配置,否则可能导致密码认证失败。
Port 22
PermitRootLogin yes
PasswordAuthentication yes

# 升级安装
rpm -Uvh openssh* --nodeps

# 修改/etc/ssh/sshd_config

# 重启sshd
chmod 600 /etc/ssh/*key 
service sshd restart  或  systemctl restart sshd
service sshd status  或 systemctl status sshd

# 重启sshd
chkconfig sshd on  或 systemctl enable sshd

# 验证(不关闭当前会话,新建会话,看是否登录成功,如有问题可联系我)
ssh -V
OpenSSH_9.8p1, OpenSSL 1.1.1p  21 Jun 2022

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • leetcode54 螺旋矩阵
  • Python | Leetcode Python题解之第372题超级次方
  • 【MySQL】MySQL 表的增删改查(进阶)
  • Scipy||第二章 Scipy核心模块概述
  • redis 开启事务 pipeline.multi(); 需要关闭嘛?
  • 基于SSM+JSP的手机商城系统网站
  • CentOS 7上开放端口(开放链接)
  • Java IO精髓:高效块读写入技术深入解析
  • Beyond Compare忽略特定格式文本
  • 我写的全部R包和函数,持续更新中
  • 微信小游戏授权问题
  • Shader 透明相关
  • RK3568-设备树休眠唤醒
  • 【ACM出版,快录用】2024年智能医疗与可穿戴智能设备国际学术会议(SHWID 2024, 10月18-20)
  • (每日一问)设计模式:设计模式的原则与分类——如何提升代码质量?
  • 实现windows 窗体的自己画,网上摘抄的,学习了
  • [数据结构]链表的实现在PHP中
  • [译] 理解数组在 PHP 内部的实现(给PHP开发者的PHP源码-第四部分)
  • spring boot下thymeleaf全局静态变量配置
  • 大主子表关联的性能优化方法
  • 得到一个数组中任意X个元素的所有组合 即C(n,m)
  • 反思总结然后整装待发
  • 基于Android乐音识别(2)
  • 理解在java “”i=i++;”所发生的事情
  • 聊聊directory traversal attack
  • 前端工程化(Gulp、Webpack)-webpack
  • 通信类
  • 原生js练习题---第五课
  • 怎么把视频里的音乐提取出来
  • k8s使用glusterfs实现动态持久化存储
  • 移动端高清、多屏适配方案
  • #Datawhale X 李宏毅苹果书 AI夏令营#3.13.2局部极小值与鞍点批量和动量
  • #php的pecl工具#
  • #传输# #传输数据判断#
  • (1)(1.8) MSP(MultiWii 串行协议)(4.1 版)
  • (二十五)admin-boot项目之集成消息队列Rabbitmq
  • (分布式缓存)Redis哨兵
  • (附源码)ssm跨平台教学系统 毕业设计 280843
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (转)PlayerPrefs在Windows下存到哪里去了?
  • ***详解账号泄露:全球约1亿用户已泄露
  • *setTimeout实现text输入在用户停顿时才调用事件!*
  • .NET C# 使用GDAL读取FileGDB要素类
  • .NET Core WebAPI中使用Log4net 日志级别分类并记录到数据库
  • .Net Core 笔试1
  • .NET delegate 委托 、 Event 事件
  • .NET WPF 抖动动画
  • .NET 项目中发送电子邮件异步处理和错误机制的解决方案
  • .NET精简框架的“无法找到资源程序集”异常释疑
  • 。Net下Windows服务程序开发疑惑
  • ?
  • @Autowired @Resource @Qualifier的区别
  • @RequestMapping 和 @GetMapping等子注解的区别及其用法
  • [android] 练习PopupWindow实现对话框
  • [BPU部署教程] 教你搞定YOLOV5部署 (版本: 6.2)