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
相关推荐
濊繵4 分钟前
Linux网络--网络层协议 IP
服务器·网络·tcp/ip
java_logo7 分钟前
宝塔 Linux 面板 Docker 容器化部署指南
linux·运维·docker·宝塔·docker部署宝塔·宝塔部署教程·docker部署baota
云和数据.ChenGuang14 分钟前
批量给100台服务器装系统,还要完成后续的配置和软件部署
运维·服务器·开发语言·mysql
南烟斋..23 分钟前
Linux进程管理完全指南:创建、终止、回收与替换
linux·算法
sunon_24 分钟前
解决linux系统PDF中文乱码问题
linux·运维·pdf
BJ_bafangonline28 分钟前
Xmanager怎么显示远程linux程序的图像?
linux·运维·服务器
古德new32 分钟前
openFuyao多样化算力使能:技术实现原理与开发者集成指南
服务器·数据库·安全
云水木石40 分钟前
Rust 语言开发的 Linux 桌面来了
linux·运维·开发语言·后端·rust
代码游侠1 小时前
学习笔记——写时复制(Copy-on-Write)
linux·网络·笔记·学习·写时复制
wanhengidc1 小时前
云手机 开发测试中的便捷工具
运维·服务器·科技·智能手机·云计算