Centos7.9升级OpenSSH版本

升级前先多开几个ssh窗口或者打开telnet,因为升级ssh可能会导致ssh无法登录

一、查看当前版本

ssh -V

升级后的版本

二、开始升级OpenSSH

1.备份配置文件

bash 复制代码
cd /etc/ssh
cp sshd_config{,.bak}
cd /etc/pam.d
cp sshd{,.bak}

2.下载OpenSSH

bash 复制代码
 https://mirrors.aliyun.com/openssh/portable/openssh-9.3p2.tar.gz?spm=a2c6h.25603864.0.0.36ab3bf96vJxzA

3.安装依赖软件包

bash 复制代码
yum -y install gcc gcc-c++ zlib-devel openssl-devel pam-devel

4.卸载旧版本,编译安装新版本OpenSSH

bash 复制代码
tar -xf openssh-9.3p2.tar.gz -C /usr/src
cd /usr/src/openssh-9.3p2
# 在此之前,确保安装了pam,没安就执行 =》 yum install pam-devel
./configure --prefix=/usr --sysconfdir=/etc/ssh --with-zlib --with-pam

执行结束会看到"PAM is enabled"

bash 复制代码
rpm -qa | grep openssh
bash 复制代码
rpm -e --nodeps `rpm -qa | grep openssh`
make && make install
bash 复制代码
echo $?

此次升级OpenSSH,并没有同时升级OpenSSL。

5.修改文件权限

bash 复制代码
# 修改文件权限
chmod 600 /etc/ssh/ssh_host_rsa_key /etc/ssh/ssh_host_ecdsa_key /etc/ssh/ssh_host_ed25519_key
# 复制配置文件并授权
cp -a contrib/redhat/sshd.init /etc/init.d/sshd
chmod u+x /etc/init.d/sshd
# 还原之前备份的配置文件
cd /etc/ssh
cp -rap sshd_config.bak sshd_config
cd /etc/pam.d
cp -rap sshd.bak sshd
# 允许root用户远程登录
sed -i 's/#PermitRootLogin yes/PermitRootLogin yes/g' /etc/ssh/sshd_config
# 设置开机自启
chkconfig --add sshd
chkconfig sshd on
chkconfig --list

6.重启并验证ssh是否升级成功

bash 复制代码
# 重启SSH
systemctl restart sshd
# 版本验证
ssh -V

三、可能出现的问题

1.ssh无论是root还是普通用户都无法登录,登录1秒后被弹出

一般是selinux策略有问题,可以先查看selinux状态

bash 复制代码
sestatus

如果是严格模式(Enforcing),可以先切换成宽松模式

bash 复制代码
setenforce 0

然后再去试试是否可以登录ssh了,如果可以,那就是selinux策略问题,按最下面的解决方法处理。

按解决方法处理完后还原成严格模式,再试试在严格模式下是否能ssh登录,如果可以,那就解决了

bash 复制代码
setenforce Enforcing

解决方法

bash 复制代码
# 安装工具(如果还未安装)
yum install policycoreutils selinux-policy-devel -y
# 生成策略模块(会在当前目录生成mypol.te和mypol.pp两个文件)
ausearch -m avc -ts recent | audit2allow -M mypol
# 加载策略模块
semodule -i mypol.pp
# 将策略模块设置为持久化(开机自启)
semodule -e mypol 
# 重启后可使用此来查看此策略模块是否加载成功,如果成功,上面的文件叫mypol,就有一个mypol模块
semodule -l

2.sftp无法使用

bash 复制代码
# vim /etc/ssh/sshd_config
Subsystem  sftp  /usr/libexec/openssh/sftp-server
修改为:
Subsystem  sftp  internal-sftp
# systemctl restart sshd
相关推荐
杨靳言先6 小时前
✨【运维实战】内网服务器无法联网?巧用 SSH 隧道实现反向代理访问公网资源 (Docker/PortForwarding)
服务器·docker·ssh
chinesegf7 小时前
ubuntu中虚拟环境的简单创建和管理
linux·运维·ubuntu
java_logo7 小时前
2025 年 11 月最新 Docker 镜像源加速列表与使用指南
linux·运维·docker·容器·运维开发·kylin
一碗面4218 小时前
Linux下的网络模型
linux·网络模型
小镇学者9 小时前
【python】python项目是如何部署到服务器上的
服务器·python·github
HIT_Weston9 小时前
103、【Ubuntu】【Hugo】搭建私人博客:搜索功能(四)
linux·运维·ubuntu
2501_945837439 小时前
事件驱动无服务器,Knative重塑原子化运算
服务器
旖旎夜光9 小时前
Linux(11)(中)
linux·网络
yaoxin5211239 小时前
296. Java Stream API - 二元操作符与“单位元“
java·服务器·windows
txinyu的博客9 小时前
前置声明与 extern
linux·c++