news 2026/6/10 19:21:18

PostgreSQL archive_command 场景下的 postgres 免密 SSH 配置与排查实录

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PostgreSQL archive_command 场景下的 postgres 免密 SSH 配置与排查实录

一、背景说明

生产环境中,PostgreSQL 的归档配置如下:

archive_command = 'rsync -a %p postgres@10.1.1.2:/var/lib/pgsql/archive/%f'

关键特征:

  • 使用postgres 用户

  • 通过rsync + ssh

  • 每个 WAL 段一次独立连接

  • 无交互(必须免密)

为了复现并分析 rsync/ssh 在该模型下的性能上限,我在两台新服务器上搭建了等价环境:

角色

IP

说明

A(发送端)

192.168.1.167

模拟主库,执行 archive_command

B(接收端)

192.168.1.240

模拟归档机

Jumpserver

仅用于人工登录,不参与运行时链路

⚠️注意

archive_command 运行时是A → B 直连不会经过 jumpserver,jumpserver 仅用于“人工运维操作”。


二、目标

实现:

A 上的 postgres 用户 → 通过 SSH 免密 → 直连 B 上的 postgres 用户 → 执行 rsync

三、免密登录配置步骤

1️⃣ A 上生成 postgres 用户的 SSH key

sudo -u postgres -i echo $HOME # /var/lib/pgsql mkdir -p ~/.ssh chmod 700 ~/.ssh ssh-keygen -t ed25519 -N '' -f ~/.ssh/id_ed25519

生成:

  • /var/lib/pgsql/.ssh/id_ed25519

  • /var/lib/pgsql/.ssh/id_ed25519.pub


2️⃣ 通过 jumpserver 登录到 B,注入公钥

由于B 无密码、只能通过 jumpserver 登录,无法使用 ssh-copy-id,只能手工注入。

在 B 上:

sudo -u postgres -i mkdir -p ~/.ssh chmod 700 ~/.ssh cat >> ~/.ssh/authorized_keys <<'EOF' ssh-ed25519 AAAAC3... postgres@ip-192-168-1-167 EOF chmod 600 ~/.ssh/authorized_keys exit

3️⃣ 修复 SELinux 上下文(非常关键)

B 上执行:

restorecon -Rv /var/lib/pgsql/.ssh

输出示例:

Relabeled /var/lib/pgsql/.ssh to ssh_home_t Relabeled /var/lib/pgsql/.ssh/authorized_keys to ssh_home_t

如果跳过这一步,在SELinux Enforcing的系统上,免密会“看起来都对但就是不生效”。


四、问题出现:A 连接 B 卡住

在 A 上验证免密:

sudo -u postgres ssh -o BatchMode=yes postgres@192.168.1.240 "echo OK"

现象:

  • 命令卡住,无输出

  • 不报权限错误

  • 不提示密码


五、排查过程(关键)

1️⃣ 使用 ssh 调试模式定位阶段

sudo -u postgres ssh -vvv postgres@192.168.1.240

输出停留在:

debug1: Connecting to 192.168.1.240 [192.168.1.240] port 22.

👉说明:连接卡在 TCP 层,尚未进入 SSH 协议


2️⃣ 验证端口连通性

nc -vz 192.168.1.240 22

结果:连接失败


3️⃣ 结论定位

  • jumpserver 能连 B

  • A → B22 端口不通

  • SSH 尚未进入认证阶段

👉根因:安全组 / 防火墙未放通 A → B 的 22 端口


4️⃣ 修复

在云平台安全组中:

  • 放通 192.168.1.167 → 192.168.1.240:22


六、修复后验证

再次在 A 上执行:

sudo -u postgres ssh -o BatchMode=yes postgres@192.168.1.240 "echo OK"

输出:

OK

免密登录成功 🎉


八、Checklist(30 秒自检版)

  • A → B 的 22 端口是否放通

  • postgres home 权限是否 700

  • authorized_keys 权限是否 600

  • SELinux context 是否为 ssh_home_t

  • postgres 是否允许 ssh 登录

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 14:45:23

第7章 洞察与定义:市场需求文档的深度剖析与实战应用

第7章 洞察与定义&#xff1a;市场需求文档的深度剖析与实战应用 如果说商业需求文档&#xff08;BRD&#xff09;是一份面向决策层的“战略融资计划书”&#xff0c;那么市场需求文档&#xff08;MRD&#xff09;就是一份面向产品、设计、研发和运营团队的“战术作战地图”。它…

作者头像 李华
网站建设 2026/6/10 13:12:52

腾讯姚顺雨署名首篇论文:让AI成为上下文学习者

目前的大模型&#xff0c;主要还是个记忆机器&#xff0c;已经学过的知识&#xff0c;推理分析解决问题得心应手。 一旦面对真实世界上下文学习&#xff08;Context Learning&#xff09;任务&#xff0c;即便是表现最好的模型&#xff0c;面对新知识时平均解决率不足五分之一…

作者头像 李华
网站建设 2026/6/10 18:03:49

Win狂喜!国产Cowork和Codex App,昆仑万维Skywork桌面版发布

2026 开年的 AI 圈&#xff0c;一场接一场核爆。 办公自动化方面就令人应接不暇。 Claude Code 开始接管 100% 的代码。 革了程序员再革打工人&#xff1a;Anthropic发布 Cowork&#xff0c;Claude Code 走进数字办公自动化。 刚刚&#xff0c;OpenAI 发布 Codex App。大幅…

作者头像 李华
网站建设 2026/5/21 1:54:10

高校站群系统如何通过插件实现LaTeX公式到HTML的转换?

CMS企业官网项目需求分析与解决方案 大家好&#xff0c;我是安徽的一名.NET程序员&#xff0c;最近接了个CMS企业官网的外包项目。客户提出了一个新需求&#xff0c;要在后台新闻管理系统的文章发布模块编辑器中增加导入Word、Excel、PPT、PDF文档和Word一键粘贴功能。这需求听…

作者头像 李华
网站建设 2026/6/9 22:38:11

开题报告 springboot和vue自行车在线租赁系统

目录 系统概述技术架构核心功能模块创新点应用场景开发与部署 项目技术支持可定制开发之功能亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作 系统概述 SpringBoot和Vue的自行车在线租赁系统是一个前后端分离的Web应用&#xff0c;旨在…

作者头像 李华
网站建设 2026/6/10 15:55:27

开题报告 springboot和vue学生考勤签到系统

目录系统概述技术栈核心功能系统特色应用场景项目技术支持可定制开发之功能亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作系统概述 SpringBoot和Vue学生考勤签到系统是一个基于前后端分离架构的现代化管理系统&#xff0c;旨在简化学…

作者头像 李华