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%]
相关推荐
聆风吟º1 小时前
CANN开源项目实战指南:使用oam-tools构建自动化故障诊断与运维可观测性体系
运维·开源·自动化·cann
NPE~2 小时前
自动化工具Drissonpage 保姆级教程(含xpath语法)
运维·后端·爬虫·自动化·网络爬虫·xpath·浏览器自动化
神梦流2 小时前
GE 引擎的内存优化终局:静态生命周期分析指导下的内存分配与复用策略
linux·运维·服务器
Lsir10110_2 小时前
【Linux】进程信号(下半)
linux·运维·服务器
田井中律.2 小时前
【无标题】
ssh
skywalk81633 小时前
unbound dns解析出现问题,寻求解决之道
运维·服务器·dns·unbound
酉鬼女又兒3 小时前
零基础入门Linux指南:每天一个Linux命令_pwd
linux·运维·服务器
云飞云共享云桌面3 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
skywalk81633 小时前
走近科学:unbound dns域名服务器自己本地解析出现问题,寻求解决之道
运维·服务器·dns·unbound
袁煦丞 cpolar内网穿透实验室3 小时前
远程调试内网 Kafka 不再求运维!cpolar 内网穿透实验室第 791 个成功挑战
运维·分布式·kafka·远程工作·内网穿透·cpolar