您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關postgresql恢復數據庫的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
PostgreSQL自帶一個客戶端pgAdmin,里面有個備份,恢復選項,也能對數據庫進行備份 恢復(還原),但最近發現數據庫慢慢龐大的時候,經常出錯,備份的文件過程中出錯的幾率那是相當大,手動調節灰常有限。所以一直尋找完美的備份恢復方案。
夢里尋他千百度,伊人卻在燈火闌珊處...其實PostgreSQL內置不少的工具,尋找的備份恢復方案就在其中:pg_dump,psql。這兩個指令在數據庫的安裝目錄下,比如我自己本地安裝的,路徑形如:C:\Program Files\PostgreSQL\9.5\;然后進入到bin文件夾,會看到不少的exe文件,這就是PostgreSQL內置的工具了。里面會找到 pg_dump.exe,psql.exe兩個文件。我們怎么用他們?
用法:
備份數據庫,指令如下:
pg_dump -h 164.82.233.54 -U postgres databasename > C:\databasename.bak
開始-運行-cmd 彈出dos控制臺;然后 在控制臺里,進入PostgreSQL安裝目錄bin下:
cd C:\Program Files\PostgreSQL\9.0\bin
最后執行備份指令:
pg_dump -h 164.82.233.54 -U postgres databasename > C:\databasename.bak
指令解釋:如上命令,pg_dump 是備份數據庫指令,164.82.233.54是數據庫的ip地址(必須保證數據庫允許外部訪問的權限哦~),當然本地的數據庫ip寫 localhost;postgres 是數據庫的用戶名;databasename 是數據庫名。> 意思是導出到C:\databasename.bak文件里,如果沒有寫路徑,單單寫databasename.bak文件名,那么備份文件會保存在C: \Program Files\PostgreSQL\9.0\bin 文件夾里。
恢復數據庫,指令如下:
psql -h localhost -U postgres -d databasename < C:\databasename.bak(測試沒有成功) pg_restore.exe --host localhost --port 5432 --username "postgres" --dbname "symbolmcnew" --no-password --verbose "databasename.backup"(測試成功)
指令解釋:如上命令,psql是恢復數據庫命令,localhost是要恢復到哪個數據庫的地址,當然你可以寫上ip地址,也就是說能遠程恢復(必須保證 數據庫允許外部訪問的權限哦~);postgres 就是要恢復到哪個數據庫的用戶;databasename 是要恢復到哪個數據庫。< 的意思是把C:\databasename.bak文件導入到指定的數據庫里。
以上所有的是針對windows而言的,如果在linux下,會不會有效?
在linux里依然有效。有一個值得注意的是:如果直接進入PostgreSQL的安裝目錄bin下,執行命令,可能會出現找不到pg_dump,psql的現象,我們在可以這樣:
備份:
/opt/PostgreSQL/9.5/bin/pg_dump -h 164.82.233.54 -U postgres databasename > databasename.bak
恢復:
/opt/PostgreSQL/9.5/bin/psql -h localhost -U postgres -d databasename < databasename.bak
關于postgresql恢復數據庫的方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。