Ubuntu postgres 从 12.x 升级到 13.x

由于业务需求,需要升级 postgres

  1. 安装 psql13
sudo apt-get install postgresql-13 postgresql-server-dev-13

如果提示没有找到包,可以换源

换源步骤:

sudo sh -c 'echo "deb https://mirrors.bfsu.edu.cn/postgresql/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list'
wget --quiet -O - https://mirrors.bfsu.edu.cn/postgresql/repos/apt/ACCC4CF8.asc | sudo apt-key add -
sudo apt-get update

完成之后,再执行安装命令。

  1. 停止 PostgreSQL 服务
sudo systemctl stop postgresql.service
  1. 进入 postgres 用户
sudo su postgres
  1. 开始升级
sudo /usr/lib/postgresql/13/bin/pg_upgrade \
   -d /var/lib/postgresql/12/main \   
   -D /var/lib/postgresql/13/main \
   -b /usr/lib/postgresql/12/bin \
   -B /usr/lib/postgresql/13/bin \
   -o '-c config_file=/etc/postgresql/12/main/postgresql.conf' \
   -O '-c config_file=/etc/postgresql/13/main/postgresql.conf' 
  1. 这里可能会有权限问题,加上权限就好了。
chmod 750 /var/lib/postgresql/12/main
  1. 如果磁盘空间不够数据库的2倍,请加上 --link 参数

如果还有问题,注意看日志,日志位置:/var/lib/postgresql/pg_upgrade_server.log,根据日志的问题来操作。

  1. 把新的PostgreSQL端口改掉。
sudo vim /etc/postgresql/13/main/postgresql.conf
# ...and change "port = 5433" to "port = 5432"
 
sudo vim /etc/postgresql/12/main/postgresql.conf
# ...and change "port = 5432" to "port = 5433"
  1. 启动 PostgreSQL 服务
sudo systemctl start postgresql.service
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值