postgresql – 无需停机即可在Production Server上更新Postgres

我有一台运行Postgres 9.4的生产服务器.该数据库是> 10 GB.是否可以在没有停机且不丢失数据的情况下升级到Postgres 9.5?

升级教程建议在执行sudo pg_upgradecluster 9.4 main时停止Postgres,但这可能需要很长时间.更新10 GB群集可能需要几个小时!

我也试过pg_dump mydb> db.sql.删除数据库并在PG 9.4(psql -d mydb -f db.sql)中再次插入转储大约需要50分钟.

但是在PG 9.5中插入转储仅在7个小时之后完成.特别是创建索引真的很慢……

2016-07-18 00:13:55 CEST [60358-5] ERROR:  canceling autovacuum task
2016-07-18 00:13:55 CEST [60358-6] CONTEXT:  automatic analyze of table ...
2016-07-18 00:36:20 CEST [60366-1] ERROR:  canceling autovacuum task
2016-07-18 00:36:20 CEST [60366-2] CONTEXT:  automatic analyze of table ...
2016-07-18 04:21:40 CEST [60361-1] ERROR:  canceling autovacuum task
2016-07-18 04:21:40 CEST [60361-2] CONTEXT:  automatic analyze of table ...
2016-07-18 07:55:19 CEST [61316-1] ERROR:  canceling autovacuum task
2016-07-18 07:55:19 CEST [61316-2] CONTEXT:  automatic analyze of table ...

因此,pg_upgradecluster和pg_dump都不是可接受的解决方案.即使使用PG 4,您也可以获得至少50分钟的停机时间.因此:如何在没有停机和数据输出的情况下在生产服务器或大型主从集群上升级数据库

没有一些聚类魔法,就不可能没有停机时间.

其他一些可能性:

>将pg_upgrade与–link选项一起使用.使用此选项,不会复制原始数据库文件,而是将它们硬链接到新目录,从而大大加快了进程.请注意,这将永久更改源数据库文件.>使用pg_dump并在新数据库上恢复.您可以通过在新数据库中禁用同步写入来大大缩短所需的时间(新PG实例的配置文件中为fsync = false)>侧安装新的PG实例,让它在不同的端口上运行.然后,使用pg_dump通过网络将转储加载到新实例.完成后,交换端口并使用新实例.

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...