當前位置:首頁 » 數據倉庫 » postgresql自動備份資料庫
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

postgresql自動備份資料庫

發布時間: 2022-05-12 17:45:59

A. postgresql的64位資料庫怎麼備份才能恢復到32位資料庫中

pg的64位備份到32位,將數據備份為sql格式的備份文件,然後還原到32位的資料庫就可以了,或者通過第三方工具進行數據遷移,不如kettle

B. postgresql 怎麼備份資料庫

PostgreSQL自帶一個客戶端pgAdmin,裡面有個備份,恢復選項,也能對資料庫進行備份 恢復(還原),但最近發現資料庫慢慢龐大的時候,經常出錯,備份的文件過程中出錯的幾率那是相當大,手動調節灰常有限。所以一直尋找完美的備份恢復方案。

夢里尋他千網路,伊人卻在燈火闌珊處...其實PostgreSQL內置不少的工具,尋找的備份恢復方案就在其中:pg_mp,psql。這兩個指令 在資料庫的安裝目錄下,比如我自己本地安裝的,路徑形如:C:\Program Files\PostgreSQL\9.5\;然後進入到bin文件夾,會看到不少的exe文件,這就是PostgreSQL內置的工具了。裡面會找到 pg_mp.exe,psql.exe兩個文件。我們怎麼用他們?
用法:
備份資料庫,指令如下:
pg_mp -h 164.82.233.54 -U postgres databasename > C:\databasename.bak

開始-運行-cmd 彈出dos控制台;然後 在控制台里,進入PostgreSQL安裝目錄bin下:
cd C:\Program Files\PostgreSQL\9.0\bin
最後執行備份指令:
pg_mp -h 164.82.233.54 -U postgres databasename > C:\databasename.bak

指令解釋:如上命令,pg_mp 是備份資料庫指令,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_mp,psql的現象,我們在可以這樣:
備份:
/opt/PostgreSQL/9.5/bin/pg_mp -h 164.82.233.54 -U postgres databasename > databasename.bak

恢復:
/opt/PostgreSQL/9.5/bin/psql -h localhost -U postgres -d databasename < databasename.bak

C. 如何在PostgreSQL中備份和恢復一張表(包含表結構)

pg_mp -U database_username database -t tablename -f /tmp/tablename.sql恢復數據表,包含表結構。登入資料庫後 \i /tmp/tablename.sql即可創建表。注意此方式恢復在恢復已有表時可能會提示錯誤表已經存在,但應該無大礙,備份時可以嘗試只備份數據

D. 請問如何不用輸入密碼自動備份postgresql資料庫

修改pg_hba.conf文件,添加
host all all 127.0.0.1/32 trust

E. 如何在PostgreSQL中備份一張表(包含表結構)和恢復


--以test作為用戶名,導出localhost:5432伺服器上的Test資料庫。
--導出的文件名為test_data

F:PostgreSQL9.2in>pg_mp-ftest_data-hlocalhost-Utest-p5432Test
口令:

F:PostgreSQL9.2in>dirtest_*
驅動器F中的卷是Install
卷的序列號是24AD-61D9

F:PostgreSQL9.2in的目錄

2013-04-1514:46136,270test_data
1個文件136,270位元組
0個目錄10,456,657,920可用位元組--將test_data文件中的數據,導入到localhost:5432伺服器上的Test2資料庫。

F:PostgreSQL9.2in>psql.exe-hlocalhost-Utest-p5432-dTest2<test_data

用戶test的口令:test

SET
SET
SET
SET
SET
CREATESCHEMA
ALTERSCHEMA
CREATEEXTENSION
COMMENT
CREATEEXTENSION
COMMENT
......

上面的例子, 是 備份 / 恢復整個資料庫的.


如果你是要 僅僅 備份 / 恢復 某個表的, 那麼命令行裡面增加下面的參數:


-t, --table=TABLE 只轉儲指定名稱的表

F. 怎麼在javaWeb里實現備份postgresql的功能

用java運行pg_mp命令行程序就行。
pg_m是postgresql自帶的用來備份資料庫的命令行程序,具體用法請參考文檔。

G. PostgreSQL9.2備份與還原

cd C:\Program Files\PostgreSQL\9.0\bin

備份資料庫:
pg_mp -h localhost -U postgres databasename > C:\databasename.bak

恢復資料庫:
psql -h localhost -U postgres -d databasename < C:\databasename.bak

H. postgresql 怎樣自動備份

第一步:

下載批處理文件。

第二步:

你可以通過一個簡單的命令(schtasks /?查看幫助)或者使用圖形界面(開始-控制面板-系統和安全-管理工具-任務計劃程序)運行任務計劃管理工具,還可以在%SYSTEMROOT%\System32目錄下雙擊Taskschd.msc來啟動它。

第三步:

你可以通過向導或通過XML文件導入信息來創建基本任務。向導方式創建方法見任務計劃程序幫助,下面介紹下命令行語法:
schtasks /Create [/S <system> [/U <username> [/P [<password>]]]] [/RU <username> [/RP <password>]] /SC <schele> [/MO <modifier>] [/D <day>] [/M <months>] [/I <idletime>] /TN <taskname> /TR <taskrun> [/ST <starttime>] [/RI <interval>] [ {/ET <endtime> | /DU <ration>} [/K] [/XML <xmlfile>] [/V1]] [/SD <startdate>] [/ED <enddate>] [/IT] [/Z] [/F]

查看此命令幫助:
schtasks /Create /?

如果在Windows防火牆中遠程任務計劃管理被禁用而文件和列印共享被啟用並且遠程注冊表服務正在運行,遠程計算機上將會被創建一個V1任務即使沒有使用參數V1。參數V1表明一個任務對下層系統可見。

使用代碼

腳本
<a href="http://my.oschina.net/echolee1987" target="_blank" rel="nofollow">@ECHO</a> OFF @setlocal enableextensions<a href="http://my.oschina.net/ini" target="_blank" rel="nofollow">@cd</a> /d "%~dp0" SET PGPATH=C:\"Program Files"\PostgreSQL\9.1\bin\ SET SVPATH=f:\ SET PRJDB=demo SET DBUSR=postgres FOR /F "TOKENS=1,2,3 DELIMS=/ " %%i IN ('DATE /T') DO SET d=%%i-%%j-%%k FOR /F "TOKENS=1,2,3 DELIMS=: " %%i IN ('TIME /T') DO SET t=%%i%%j%%k SET DBDUMP=%PRJDB%_%d%_%t%.sql<a href="http://my.oschina.net/echolee1987" target="_blank" rel="nofollow">@ECHO</a> OFF %PGPATH%pg_mp -h localhost -p 5432 -U postgres %PRJDB% > %SVPATH%%DBDUMP% echo Backup Taken Complete %SVPATH%%DBDUMP%

初始值

PGPATH - PostgreSQL路徑
SVPATH - 備份文件路徑
PRJDB - 要備份的資料庫名
DBUSR - 資料庫用戶名