升级教程建议在执行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 task2016-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 task2016-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 task2016-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 task2016-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通过网络将转储加载到新实例.完成后,交换端口并使用新实例.
总结以上是内存溢出为你收集整理的postgresql – 无需停机即可在Production Server上更新Postgres全部内容,希望文章能够帮你解决postgresql – 无需停机即可在Production Server上更新Postgres所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)