云原生容器内的一次pg_repack排错和解决过程

postgresql的pg_repack 这个cronjob一直执行不了。

排错过程:

  1. 用命令 kubectl describe job pg-repack-scheduler-manual-wv82r -n xxx没有查看用有用信息
  2. 想办法进它启动的pod查看,于是在执行pg_repack.sh命令前,先加一个睡眠时间,如下:
yaml 复制代码
- command:
  - sh
  - -c
  - sleep 60000 && ./pg_repack.sh
  1. run cronjob, 进入其起来后的pod, 手动执行./pg_repack.sh,可以看到报错信息是pg_repack 和postgresal数据库里面的版本不匹配
html 复制代码
pg_repack failed with error: program 'pg_repack 1.4.7' does not match database library 'pg_repack 1.4.8'

解决过程

  1. 将Dockerfile中的pg_repack下载地址改掉

  2. 用podman 重新构建image,并上传到远程仓库.(如果是docker,命令中直接把podman换成docker就行了)

powershell 复制代码
podman build -t gxxx.io/xxx/pg-repack:1.4.8-13.5 .
podman images
podman push gxxx.io/xxx/pg-repack:1.4.8-13.5

注意,如果在执行pg_repack命令时,如:pg_repack --dry-run --table category_aspects,遇到如下错误

ERROR: pg_repack failed with error: You must be a superuser to use pg_repack

此时,可以在命令后面加-k 参数掠过superuser检查pg_repack --dry-run --table category_aspects -k

相关推荐
Empty_77733 分钟前
K8S-Ingress资源对象
云原生·容器·kubernetes
猴哥聊项目管理37 分钟前
2025年项目管理软件10款云原生部署方案的稳定性对比
安全·云原生·金融·软件工程·项目管理工具·项目管理软件·企业管理
weixin_466844 分钟前
ks8核心组件、Pod分类、网络模型
云原生·容器·kubernetes
白帽子黑客杰哥1 小时前
WAF在云原生环境下的部署方案与性能优化策略
云原生·性能优化
不会kao代码的小王1 小时前
openEuler上Docker部署Kafka消息队列实战
前端·云原生·stable diffusion·eureka
橙色云-智橙协同研发1 小时前
【PLM实施专家宝典】离散制造企业产品成本管理(PCM)与面向成本的设计实施方案:构建研发利润中心
阿里云·云原生·解决方案·数字化转型·plm·国产plm·数字工艺
谷粒.2 小时前
云原生测试:在分布式系统中的质量保障策略
运维·python·测试工具·云原生·架构·自动化·测试覆盖率
哦你看看2 小时前
K8S-Configmap资源
云原生·容器·kubernetes
苏 凉2 小时前
openEuler云原生AI性能测试:Qwen3模型KServe部署实战
人工智能·云原生