摘要:小版本更新不受影響,比如到升級不受影響。下面介紹兩種升級方案可供選擇,均是官方文檔提及的方案官方文檔參考。方案命令是直接對舊的數(shù)據(jù)庫目錄文件進行升級的方案,直接將舊版本的數(shù)據(jù)文件格式升級為新版本使用的格式。
PostgreSQL在默認情況下,是不能跨版本升級的(9.4, 9.5, 9.6等等這些版本跨版本升級。小版本更新不受影響,比如9.6.1到9.6.2升級不受影響)。甚至PG為了數(shù)據(jù)的安全性,高版本不能直接使用低版本創(chuàng)建的數(shù)據(jù)目錄,會在日志中打印相關(guān)的錯誤信息。
下面介紹兩種升級方案可供選擇,均是postgresql官方文檔提及的方案(官方文檔參考: https://www.postgresql.org/do...)。
dump + restore方案此方案的原理是使用pg_dumpall命令將舊數(shù)據(jù)庫的全部dump成sql文件,然后使用psql命令還原至高版本的實例中。借助于管道,可以實現(xiàn)在線升級。配合腳本的話,切換至高版本幾乎零宕機。由于dump+restore總體相對耗時較長,因此不適用于大數(shù)據(jù)量的數(shù)據(jù)庫,或是寫入比較頻繁的場景使用。
在線遷移的步驟大致如下:
保持舊的實例與配置運行
新的PG實例配置新的端口或者新的unix socket文件,確保不與舊實例沖突
使用pg_dumpall | psql管道組合命令在線遷移數(shù)據(jù)
停止舊實例,將新實例的配置修改為舊實例使用的端口,重啟服務(wù)即可完成遷移
參考命令如下:
sudo -u postgres pg_dumpall -h /path/to/old/instance.sock | sudo -u postgres psql -h /path/to/new/instance.sock
數(shù)據(jù)倒入完畢之后,停掉舊實例,刪除舊數(shù)據(jù)的數(shù)據(jù)目錄即可。
不需要在線升級的話,也可以先用pg_dumpall把舊實例的數(shù)據(jù)導(dǎo)出,再更新postgresql,清空數(shù)據(jù)目錄,使用psql還原數(shù)據(jù),效果是完全一樣的。
pg_upgrade方案pg_upgrade命令是直接對舊的數(shù)據(jù)庫目錄文件進行升級的方案,直接將舊版本的數(shù)據(jù)文件格式升級為新版本使用的格式。此方案優(yōu)勢是速度非常快,但是必須停機升級。因此不適用于7x24的場景。
命令非常簡單,同時安裝新版本和舊版本的postgresql,停止postgresql實例后執(zhí)行:
sudo -u postgres pg_upgrade -b oldbindir -B newbindir -d olddatadir -D newdatadir復(fù)制集方案
此方案是最平滑的方案,比較適用于7x24小時以及大數(shù)據(jù)量場景,停機時間非常短,只有幾秒鐘。缺點和優(yōu)點同樣突出——配置繁瑣,需要有集群環(huán)境。
大體的步驟是使用Slony這種復(fù)制集方案,先用上述方案升級從庫,再升級主庫。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/38966.html
摘要:這可以通過負載平衡來實現(xiàn)數(shù)據(jù)分片當問題不是并發(fā)查詢的數(shù)量,而是數(shù)據(jù)庫的大小和單個查詢的速度時,可以實現(xiàn)不同的方法。 showImg(https://segmentfault.com/img/remote/1460000018875091); 來源 | 愿碼(ChainDesk.CN)內(nèi)容編輯 愿碼Slogan | 連接每個程序員的故事 網(wǎng)站 | http://chaindesk.cn...
摘要:這可以通過負載平衡來實現(xiàn)數(shù)據(jù)分片當問題不是并發(fā)查詢的數(shù)量,而是數(shù)據(jù)庫的大小和單個查詢的速度時,可以實現(xiàn)不同的方法。 showImg(https://segmentfault.com/img/remote/1460000018875091); 來源 | 愿碼(ChainDesk.CN)內(nèi)容編輯 愿碼Slogan | 連接每個程序員的故事 網(wǎng)站 | http://chaindesk.cn...
摘要:作者譚峰張文升出版日期年月頁數(shù)頁定價元本書特色中國開源軟件推進聯(lián)盟分會特聘專家撰寫,國內(nèi)多位開源數(shù)據(jù)庫專家鼎力推薦。張文升中國開源軟件推進聯(lián)盟分會核心成員之一。 很高興《PostgreSQL實戰(zhàn)》一書終于出版,本書大體上系統(tǒng)總結(jié)了筆者 PostgreSQL DBA 職業(yè)生涯的經(jīng)驗總結(jié),本書的另一位作者張文升擁有豐富的PostgreSQL運維經(jīng)驗,目前就職于探探科技任首席PostgreS...
摘要:本文主要介紹如何連接到數(shù)據(jù)庫。創(chuàng)建并配置數(shù)據(jù)庫創(chuàng)建與連接的數(shù)據(jù)庫用戶登錄角色例如。或通過命令行確保該用戶擁有連接數(shù)據(jù)庫以及創(chuàng)建和編輯表的權(quán)限。測試連接并保存。注意元素必須指定數(shù)據(jù)庫類型。文件示例啟動現(xiàn)在連接到數(shù)據(jù)庫就配置好了。 本文主要介紹如何連接JIRA到PostgreSQL數(shù)據(jù)庫。 首先 檢查是否支持你的PostgreSQL版本。請參見支持的平臺。 如果是轉(zhuǎn)移JIRA到另一臺服務(wù)...
閱讀 826·2021-11-22 11:59
閱讀 3230·2021-11-17 09:33
閱讀 2308·2021-09-29 09:34
閱讀 1941·2021-09-22 15:25
閱讀 1955·2019-08-30 15:55
閱讀 1321·2019-08-30 15:55
閱讀 530·2019-08-30 15:53
閱讀 3346·2019-08-29 13:55