postgresql的pg_repack 这个cronjob一直执行不了。
排错过程:
- 用命令 kubectl describe job pg-repack-scheduler-manual-wv82r -n xxx没有查看用有用信息
- 想办法进它启动的pod查看,于是在执行pg_repack.sh命令前,先加一个睡眠时间,如下:
yaml
- command:
- sh
- -c
- sleep 60000 && ./pg_repack.sh
- 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'
解决过程
-
将Dockerfile中的pg_repack下载地址改掉
-
用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