软件更新-openssh和openssl-centos

说明

centos7存在关于openssh的安全漏洞,需打补丁。

环境描述:联网,centos7.9公版云主机,有云端控制台,可在无ssh时访问系统。

访问环境

root用户ssh到云主机

查询信息

查询ssh版本

bash 复制代码
ssh -V

查询openssl

bash 复制代码
openssl version


注意:低于1.1.1的必须升级至1.1.1及以上版本

查询opeensl的位置及安装的软件

bash 复制代码
which openssl
rpm -qa | grep openssl

查询命令位置

bash 复制代码
which -a ssh
which -a sshd

查询操作系统版本

bash 复制代码
cat /etc/os-release

查询服务状态

此处用于规避纠纷扯皮。

bash 复制代码
systemctl status sshd

备份数据

bash 复制代码
mkdir -p /opt/backup/{ssh,pam,sshd}
cp -r /etc/ssh/* /opt/backup/ssh
cp -r /etc/pam.d/* /opt/backup/pam
cp -r /etc/sysconfig/sshd/* /opt/backup/sshd

下载软件

下载openssl

浏览器访问https://openssl-library.org/source/

推荐选择LTS标记的版本

上传至云主机的/opt目录

下载openssh

浏览器访问https://www.openssh.org/portable.html

任意选择下载通道,例如

INSTALL是安装说明

README是整体说明

tar.gz是本次使用的软件包。推荐下载最新版本。

上传至云主机的/opt目录

更新openssl

注意,高危操作,操作失误会导致系统多个重要内置工具故障。

安装基础环境

bash 复制代码
yum -y groupinstall "Development Tools"
yum -y install wget zlib-devel perl-core pcre-devel

解压文件

bash 复制代码
tar -zxf openssl-3.5.6.tar.gz
cd openssl-3.5.6

配置代码

bash 复制代码
./config --prefix=/usr/local/openssl --openssldir=/usr/local/openssl shared zlib

编译代码

bash 复制代码
make -j$(nproc)

测试代码

可选。时间充裕且流程严谨的环境需操作。摸鱼必备。

bash 复制代码
make test

安装

bash 复制代码
make install

备份旧版openssl

bash 复制代码
mv /usr/bin/openssl /usr/bin/openssl.old

配置软链接

bash 复制代码
ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl

更新动态库

bash 复制代码
echo "/usr/local/openssl/lib64" > /etc/ld.so.conf.d/openssl3.conf
ldconfig

查询配置

bash 复制代码
ldconfig -p | grep ssl
ldconfig -p | grep crypto

查询版本

bash 复制代码
openssl version

更新完成且成功。

卸载openssh

注意:卸载后,将无法新建会话进行ssh访问,原有ssh会话不关闭时,可继续使用,建议后续操作保持ssh会话。应确保自己可以通过服务器的BMC界面或云平台的VNC界面访问操作系统,在ssh会话断开时,随时可访问。

查询已安装的ssh软件包

bash 复制代码
rpm -qa | grep openssh
yum list installed | grep openssh
rpm -ql openssh-server

完整卸载旧版ssh

bash 复制代码
systemctl stop sshd
systemctl disable sshd
yum remove -y openssh-server openssh-clients openssh
rm -rf /etc/ssh/*
rm -rf /etc/pam.d/sshd
rm -rf /etc/sysconfig/sshd
rm -rf /var/empty/sshd

安装新版openssh

解压

bash 复制代码
tar -zxf openssh-10.3p1.tar.gz
cd openssh-10.3p1

配置软件

bash 复制代码
yum makecache

查询基础软件是否存在

bash 复制代码
gcc --version
make --version
autoconf --version
automake --version
libtool --version
pkg-config --version

安装依赖库

bash 复制代码
yum install -y pam-devel

验证必备内容

bash 复制代码
rpm -qa | grep devel | grep -E "zlib|openssl|pam"

安装扩展功能库

可选。推荐。

bash 复制代码
yum install -y libedit-devel libselinux-devel krb5-devel openldap-devel

安装FIDO2支持

可选,忘记操作了,没记录。

安装安装 LDNS(DNSSEC 支持)

可选,忘记操作了,没记录。

配置专用账户

bash 复制代码
groupadd -f -r sshd
useradd -c "Privilege-separated SSH" -g sshd -s /bin/false -M sshd

配置代码

bash 复制代码
./configure \
  --prefix=/usr \
  --sysconfdir=/etc/ssh \
  --with-ssl-dir=/usr/local/openssl \
  --with-pam \
  --with-zlib \
  --with-md5-passwords \
  --with-privsep-user=sshd \
  --with-privsep-path=/var/lib/sshd

编译代码

bash 复制代码
  make -j$(nproc)

安装

bash 复制代码
make install

验证

bash 复制代码
ssh -V
sshd -V

配置服务持久化

执行以下命令

服务1

bash 复制代码
cat > /usr/lib/systemd/system/sshd.service <<EOF
[Unit]
Description=OpenSSH server daemon
Documentation=man:sshd(8) man:sshd_config(5)
After=network.target sshd-keygen.service
Wants=sshd-keygen.service

[Service]
Type=notify
EnvironmentFile=-/etc/sysconfig/sshd
ExecStart=/usr/sbin/sshd -D \$OPTIONS
ExecReload=/bin/kill -HUP \$MAINPID
KillMode=process
Restart=on-failure
RestartSec=42s

[Install]
WantedBy=multi-user.target
EOF

服务2

bash 复制代码
cat > /usr/lib/systemd/system/sshd-keygen.service <<EOF
[Unit]
Description=OpenSSH server key generation
Before=sshd.service

[Service]
ExecStart=/usr/sbin/sshd-keygen
Type=oneshot
RemainAfterExit=yes

[Install]
WantedBy=multi-user.target
EOF

重新加载服务,查询验证

bash 复制代码
systemctl daemon-reload
systemctl enable sshd
systemctl restart sshd
systemctl status sshd
netstat -lntp | grep sshd

访问验证

ssh 账户名@localhost

输入密码登录成功即可。root用户登录需要在配置文件修改Permi开头的参数。

重启操作系统,确认配置持久生效。

说明更新成功。

相关推荐
码农小白AI6 小时前
AI报告审核加速融入自动化实验室:IACheck破解智能设备时代报告管理新挑战
运维·人工智能·自动化
utf8mb4安全女神6 小时前
克隆的虚拟机怎么更改ip地址
运维
赵民勇6 小时前
fuse-overlayfs命令详解
linux·容器
sulikey6 小时前
个人Linux操作系统学习笔记6 - 操作系统与进程初识
linux·笔记·学习·操作系统·进程
万能的知了7 小时前
服务器托管 vs 云主机 vs 裸金属:一个决策故事
运维·服务器·云计算
杨云龙UP8 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
Shingmc38 小时前
【Linux】多路转接之select
linux·网络
luweis8 小时前
企智孪生 ETA(3.3 认知算法层:ETA 的思维内核 3.4 基础架构:算力与弹性)【浙江联保网络 卢伟舜】
大数据·运维·线性代数·ai·矩阵·学习方法
极客老王说Agent8 小时前
屏幕理解能力是下一代自动化的关键吗?2026年自动化范式演进深度解析
运维·人工智能·ai·chatgpt·自动化
LT10157974449 小时前
2026年电商RPA选型指南:电商运营全流程自动化测评
运维·自动化·rpa