centos7.4下升级最新的ssh

一 安装telnet服务器

安装telnet服务器目的,防止我们升级失败的时候,可以通过telnet登录,而不至于上机房。 由于我们是临时启动,所以只要简单的使用,不要通过xinetd来进行守护。

命令如下:

go 复制代码
yum -y install telnet telnet-server
systemctl enable telnet.socket --now
systemctl start telnet.socket

#防火墙设置
firewall-cmd --list-port
firewall-cmd --permanent --add-port=23/tcp
firewall-cmd --reload

注意,默认是不能通过root登录的、root登录比较麻烦。

二 编译centos7下的openssh

2.1 安装必要依赖包

go 复制代码
yum install rpm-build zlib-devel openssl-devel gcc perl-devel pam-devel unzip libXt-devel imake gtk2-devel -y

2.2 编译打包rpm文件

建立文件:

go 复制代码
mkdir -p /root/rpmbuild/SPECS
mkdir -p /root/rpmbuild/SOURCES

上传到文件

go 复制代码
openssh-9.6p1.tar.gz
和openssh-9.6p1.tar.gz

下载地址:

go 复制代码
https://mirrors.aliyun.com/pub/OpenBSD/OpenSSH/portable/openssh-9.3p1.tar.gz

解压打包:

go 复制代码
tar -zxf openssh-9.3p1.tar.gz 
cp openssh-9.6p1/contrib/redhat/openssh.spec ./

#关掉no_gnome_askpass no_x11_askpass这两个参数
  sed -i -e "s/%define no_x11_askpass 0/%define no_x11_askpass 1/g" openssh.spec
  sed -i -e "s/%define no_gnome_askpass 0/%define no_gnome_askpass 1/g" openssh.spec

#rpm 制作
rpmbuild -ba openssh.spec

报错:

go 复制代码
extracting debug info from /root/rpmbuild/BUILDROOT/openssh-9.6p1-1.el7.centos.x86_64/usr/libexec/openssh/x11-ssh-askpass
*** ERROR: No build ID note found in /root/rpmbuild/BUILDROOT/openssh-9.6p1-1.el7.centos.x86_64/usr/libexec/openssh/x11-ssh-askpass
error: Bad exit status from /var/tmp/rpm-tmp.9Mxy8c (%install)


RPM build errors:
    Bad exit status from /var/tmp/rpm-tmp.9Mxy8c (%install)

在spec文件任意位置添加:

go 复制代码
%define __debug_install_post \
%{_rpmconfigdir}/find-debuginfo.sh %{?_find_debuginfo_opts} "%{_builddir}/%{?buildsubdir}"\
%{nil}

最后制作成功:

go 复制代码
...
...
Wrote: /root/rpmbuild/SRPMS/openssh-9.6p1-1.el7.centos.src.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/openssh-9.6p1-1.el7.centos.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/openssh-clients-9.6p1-1.el7.centos.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/openssh-server-9.6p1-1.el7.centos.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/openssh-askpass-9.6p1-1.el7.centos.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/openssh-askpass-gnome-9.6p1-1.el7.centos.x86_64.rpm
Wrote: /root/rpmbuild/RPMS/x86_64/openssh-debuginfo-9.6p1-1.el7.centos.x86_64.rpm
Executing(%clean): /bin/sh -e /var/tmp/rpm-tmp.FgdHrz
+ umask 022
+ cd /root/rpmbuild/BUILD
+ cd openssh-9.6p1
+ rm -rf /root/rpmbuild/BUILDROOT/openssh-9.6p1-1.el7.centos.x86_64
+ exit 0

2.3 删除老的rpm

go 复制代码
yum remove openssh-server-7.4p1-11.el7.x86_64
yum remove openssh-7.4p1-11.el7.x86_64

安装新的sshd

go 复制代码
[root@localhost x86_64]# cd /root/rpmbuild/RPMS/x86_64

[root@localhost x86_64]# rpm -ivh *.rpm 
Preparing...                          ################################# [100%]
Updating / installing...
   1:openssh-9.6p1-1.el7.centos       ################################# [ 17%]
   2:openssh-askpass-9.6p1-1.el7.cento################################# [ 33%]
   3:openssh-askpass-gnome-9.6p1-1.el7################################# [ 50%]
   4:openssh-clients-9.6p1-1.el7.cento################################# [ 67%]
   5:openssh-server-9.6p1-1.el7.centos################################# [ 83%]
   6:openssh-debuginfo-9.6p1-1.el7.cen################################# [100%]
相关推荐
JuiceFS1 小时前
JuiceFS sync 原理解析与性能优化,企业级数据同步利器
运维·后端
Logan Lie2 小时前
Web服务监听地址的取舍:0.0.0.0 vs 127.0.0.1
运维·后端
Y淑滢潇潇2 小时前
RHCE 防火墙实验
linux·运维·rhce
稻谷君W3 小时前
Ubuntu 远程访问 Win11 WSL2 并固定访问教程
linux·运维·ubuntu
泡沫·3 小时前
4.iSCSI 服务器
运维·服务器·数据库
悠悠121384 小时前
告别Zabbix?我用Netdata只花10分钟就搞定了50台服务器的秒级监控(保姆级实战)
运维·服务器·zabbix
天庭鸡腿哥4 小时前
大小只有4K的软件,可让系统瞬间丝滑!
运维·服务器·windows·microsoft·everything
虚伪的空想家4 小时前
华为昇腾Atlas 800 A2物理服务器开启VT-d模式
运维·服务器·ubuntu·kvm·vt-d·直通
学渣676564 小时前
服务器端口映射
运维·服务器
红袜子i4 小时前
【问题】实验室服务器恢复记录,一个主板挂两张显卡,
运维·服务器