CentOS 7 制作openssh 9.6 rpm包更新修复安全漏洞 —— 筑梦之路
2023-12-21 12:46:17
2023年12月18日 openssh 发布新版9.6p1,详细内容阅读OpenSSH: Release Notes
背景说明
之前也写过多篇制作openssh rpm包的文章,为何要重新来写一篇制作openssh 9.6版本的?
openssh 9.6 rpm包制作和之前存在区别,对于CentOS 7来说制作步骤上有一些变化,更何况CentOS 7 在2024年6月将结束生命周期,官方将不再维护支持,因此在这里单独来写一篇记录一下。
有哪些变化呢?
1. 强制要求openssl? 1.1.1以上版本
2. 强制要求安装openssl-devel 1.1.1以上版本
这两点也足以说明,逐渐失去对CentOS 7 及以下版本的维护支持。
制作步骤
1. 做好准备工作
阅读这篇了解整个制作安装流程
CentOS 7 制作openssl 1.1.1w 版本rpm包 —— 筑梦之路-CSDN博客?
阅读这篇制作openssl? 1.1.1w rpm包 和 openssl-devel rpm包
CentOS7自制openssh rpm包(含ssh-copy-id命令)—— 筑梦之路_centos7 openssh rpm-CSDN博客
阅读这篇根据需要添加ssh-copy-id命令
2. openssh.spec文件重点地方说明
%if ! %{without_openssl}
BuildRequires: openssl-devel >= 1.1.1
%endif
这段代码中的 `%{without_openssl}` 是一个宏(macro),用于表示是否禁用了 OpenSSL。这个宏的值可以通过在构建RPM包时传递相应的参数进行设置。
如果 `%{without_openssl}` 的值为真(即 OpenSSL 被禁用),则不会执行代码块中的内容。否则,如果 `%{without_openssl}` 的值为假(即 OpenSSL 未被禁用),则会执行代码块中的内容。
在这个例子中,如果 `without_openssl` 为假(即 OpenSSL 未被禁用),则会添加一个构建要求(BuildRequires),要求安装的 OpenSSL 版本大于等于 1.1.1。这意味着在构建包时,必须安装这个指定版本的 OpenSSL 开发库(openssl-devel)。
这段代码的目的是确保在构建RPM包时,当 OpenSSL 未被禁用时,正确指定对 OpenSSL 开发库的依赖。
请注意该代码段中的 `%{without_openssl}` 变量是根据构建环境和参数的不同而变化的,因此需要根据具体的上下文和构建过程设置该变量的值。
9.6版本openssh.spec文件中该段代码(摘自9.5版本)如下:
%if %{compat_openssl}
BuildRequires: compat-openssl10-devel
%else
BuildRequires: openssl-devel >= 1.0.1
#BuildRequires: openssl-devel < 1.1
%endif
?3. openssl的安装
# 安装openssl
rpm -ivh openssl-1.1.1w-1.el7.x86_64.rpm --nodeps --force
# 安装openssl-devel
rpm -ivh openssl-devel-1.1.1w-1.el7.x86_64.rpm --nodeps --force
4. openssh 9.6p1版本rpm制作
rpmbuild -ba openssh.spec
安装测试验证
再次提醒,未经验证不要上生产环境!!!
?有需要已经制作好的rpm包,请查看我的资源。
对于操作系统默认安装了openssl 1.1.1及其以上版本的来说,并不存在该问题。
2023年12月21日
?
文章来源:https://blog.csdn.net/qq_34777982/article/details/135125537
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!