當前位置:首頁 » 操作系統 » dump資料庫

dump資料庫

發布時間: 2022-04-23 06:41:05

① 怎麼分析打開後綴為 .mp 的資料庫文件

應該是Postgresql資料庫的備份文件。
資料庫的導入導出是最常用的功能之一,每種資料庫都提供有這方面的工具,PostgreSQL提供的對應工具為pg_mp和pg_restore。
pg_mp是用於備份PostgreSQL資料庫的工具。它可以在資料庫正在使用的時候進行完整一致的備份,並不阻塞其它用戶對資料庫的訪問。轉儲格式可以是一個腳本或者歸檔文件。
歸檔文件格式必須和pg_restore一起使用重建資料庫。
X:>pg_mp -U postgres -Fc TestDb1 >TestDb1.mp
X:>pg_restore -U postgres -d TestDb2 TestDb1.mp

② mp是啥意思

backup只是說備份,可以是備份到本地,形成一個副本/復本。
mp更多的是指備份到另一個設備上。比如以前是備份到磁帶機等其他設備上。

③ mysql中的mp命令用法

用到MySQL的mysqlmp工具,基本用法是:

shell> mysqlmp [OPTIONS] database [tables]

如果你不給定任何錶,整個資料庫將被導出。
通過執行mysqlmp --help,你能得到你mysqlmp的版本支持的選項表。
注意,如果你運行mysqlmp沒有--quick或--opt選項,mysqlmp將在導出結果前裝載整個結果集到內存中,如果你正在導出一個大的資料庫,這將可能是一個問題。
1.1、mysqlmp支持下列選項:
--add-locks
在每個表導出之前增加LOCK TABLES並且之後UNLOCK TABLE。(為了使得更快地插入到MySQL)。
--add-drop-table
在每個create語句之前增加一個drop table。
--allow-keywords
允許創建是關鍵詞的列名字。這由表名前綴於每個列名做到。
-c, --complete-insert
使用完整的insert語句(用列名字)。
-C, --compress
如果客戶和伺服器均支持壓縮,壓縮兩者間所有的信息。
--delayed
用INSERT DELAYED命令插入行。
-e, --extended-insert
使用全新多行INSERT語法。(給出更緊縮並且更快的插入語句)
-#, --debug[=option_string]
跟蹤程序的使用(為了調試)。
--help
顯示一條幫助消息並且退出。

LOAD DATA INFILE
--fields-terminated-by=...
--fields-enclosed-by=...
--fields-optionally-enclosed-by=...
--fields-escaped-by=...
--fields-terminated-by=...
這些選擇與-T選擇一起使用,並且有相應的LOAD DATA INFILE子句相同的含義。
LOAD DATA INFILE語法。
-F, --flush-logs
在開始導出前,洗掉在MySQL伺服器中的日誌文件。
-f, --force,
即使我們在一個表導出期間得到一個SQL錯誤,繼續。
-h, --host=..
從命名的主機上的MySQL伺服器導出數據。預設主機是localhost。
-l, --lock-tables.
為開始導出鎖定所有表。
-t, --no-create-info
不寫入表創建信息(CREATE TABLE語句)
-d, --no-data
不寫入表的任何行信息。如果你只想得到一個表的結構的導出,這是很有用的!
--opt
同--quick --add-drop-table --add-locks --extended-insert --lock-tables。
應該給你為讀入一個MySQL伺服器的盡可能最快的導出。
-pyour_pass, --password[=your_pass]
與伺服器連接時使用的口令。如果你不指定「=your_pass」部分,mysqlmp需要來自終端的口令。
-P port_num, --port=port_num
與一台主機連接時使用的TCP/IP埠號。(這用於連接到localhost以外的主機,因為它使用 Unix套接字。)
-q, --quick
不緩沖查詢,直接導出至stdout;使用mysql_use_result()做它。
-S /path/to/socket, --socket=/path/to/socket
與localhost連接時(它是預設主機)使用的套接字文件。
-T, --tab=path-to-some-directory
對於每個給定的表,創建一個 table_name.sql文件,它包含SQL CREATE 命令,和一個table_name.txt文件,它包含數據。 注意:這只有在mysqlmp運行在mysqld守護進程運行的同一台機器上的時候才工作。.txt文件的格式根據--fields-xxx和 --lines--xxx選項來定。
-u user_name, --user=user_name
與伺服器連接時,MySQL使用的用戶名。預設值是你的Unix登錄名。
-O var=option, --set-variable var=option設置一個變數的值。可能的變數被列在下面。
-v, --verbose
冗長模式。列印出程序所做的更多的信息。
-V, --version
列印版本信息並且退出。
-w, --where=''''where-condition''''
只導出被選擇了的記錄;注意引號是強制的!
"--where=user=''''jimf''''" "-wuserid>1" "-wuserid<1"

1.2、最常見的mysqlmp的一個備份:
雖然mysqlmp支持的命令有很多,對於大多數人而言,我們只需要使用-opt這個命令就已經足夠了,為你的資料庫做一個完整的備份:

mysqlmp --opt database > backup-file.sql

但是它對用來自於一個資料庫的信息充實另外一個MySQL資料庫也是有用的:

mysqlmp --opt database | mysql --host=remote-host -C database

1.3、使用mysqlmp導出的文件恢復資料庫
由於mysqlmp導出的是完整的SQL語句,所以用mysql客戶程序很容易就能把數據導入了:

shell> mysqladmin create target_db_name
shell> mysql target_db_name < backup-file.sql

就是
shell> mysql 庫名 < 文件名
二、使用mysqlmp定時備份資料庫的腳本
2.1、備份腳本
使用腳本每天定期執行資料庫備份操作,對每個使用mysql資料庫的人來說都很有必要,這樣的腳本網上有很多,這里摘抄一個朋友的腳本 dbbackup:

這個腳本每天最多隻執行一次,而且只保留最近五天的備份在伺服器上。

dbbackup代碼:

#!/bin/bash
#This is a ShellScript For Auto DB Backup
#Powered by aspbiz
#2004-09

#Setting
#設置資料庫名,資料庫登錄名,密碼,備份路徑,日誌路徑,數據文件位置,以及備份方式
#默認情況下備份方式是tar,還可以是mysqlmp,mysqldot
#默認情況下,用root(空)登錄mysql資料庫,備份至/root/dbxxxxx.tgz
DBName=mysql
DBUser=root
DBPasswd=
BackupPath=/root/
LogFile=/root/db.log
DBPath=/var/lib/mysql/
#BackupMethod=mysqlmp
#BackupMethod=mysqlhot
#BackupMethod=tar
#Setting End

NewFile="$BackupPath"db$(date +%y%m%d).tgz
DumpFile="$BackupPath"db$(date +%y%m%d)
OldFile="$BackupPath"db$(date +%y%m%d --date=''''5 days ago'''').tgz

echo "-------------------------------------------" >> $LogFile
echo $(date +"%y-%m-%d %H:%M:%S") >> $LogFile
echo "--------------------------" >> $LogFile
#Delete Old File
if [ -f $OldFile ]
then
rm -f $OldFile >> $LogFile 2>&1
echo "[$OldFile]Delete Old File Success!" >> $LogFile
else
echo "[$OldFile]No Old Backup File!" >> $LogFile
fi

if [ -f $NewFile ]
then
echo "[$NewFile]The Backup File is exists,Can''''t Backup!" >> $LogFile
else
case $BackupMethod in
mysqlmp)
if [ -z $DBPasswd ]
then
mysqlmp -u $DBUser --opt $DBName > $DumpFile
else
mysqlmp -u $DBUser -p$DBPasswd --opt $DBName > $DumpFile
fi
tar czvf $NewFile $DumpFile >> $LogFile 2>&1
echo "[$NewFile]Backup Success!" >> $LogFile
rm -rf $DumpFile
;;
mysqlhot)
rm -rf $DumpFile
mkdir $DumpFile
if [ -z $DBPasswd ]
then
mysqlhot -u $DBUser $DBName $DumpFile >> $LogFile 2>&1
else
mysqlhot -u $DBUser -p $DBPasswd $DBName $DumpFile >>$LogFile 2>&1
fi
tar czvf $NewFile $DumpFile >> $LogFile 2>&1
echo "[$NewFile]Backup Success!" >> $LogFile
rm -rf $DumpFile
;;
*)
/etc/init.d/mysqld stop >/dev/null 2>&1
tar czvf $NewFile $DBPath$DBName >> $LogFile 2>&1
/etc/init.d/mysqld start >/dev/null 2>&1
echo "[$NewFile]Backup Success!" >> $LogFile
;;
esac
fi

echo "-------------------------------------------" >> $LogFile

2.2、放入crontab定期執行dbbackup
假定dbbackup在/root目錄下。我們通過使用crontab命令,設置每天0點10分執行/root/dbbakup腳本。
1、 使用 crontab –e編輯crontab
2、 在crontab中加入:

#back for jabber database
10 0 * * * /root/dbbackup

④ DUMP文件有用嗎

Dump文件是進程的內存鏡像。可以把程序的執行狀態通過調試器保存到mp文件中。 Dump文件是用來給驅動程序編寫人員調試驅動程序用的,這種文件必須用專用工具軟體打開,比如使用WinDbg打開。
在Windbg中可以通過.mp命令保存進程的mp文件。比如下面的命令把當前進程的鏡像
保存為c:\testmp.dmp文件: .mp /ma C:\testmp.dmp
其中的/ma參數表示mp文件應該包含進程的完整信息,包括整個用戶態的內存,這樣mp文件尺寸會比較大,信息非常全面。如果不使用/ma參數,保存下來的mp文件只包含了部分重要資料,比如寄存器和線程棧空間,文件尺寸會比較小,無法分析所有的數據。 在Windbg中,通過File→Open Crash Dump菜單可以打開mp文件進行分析。打開mp文件後,運行調試命令看到的信息和狀態,就是mp文件保存時進程的狀態。通過mp文件能夠方便地保存發生問題時進程的狀態,方便事後分析。 mp還是oracle及SQL資料庫中導出的數據文件。可以備份數據,並可以實現後期的導入。

⑤ mp備份是什麼意思

DUMP備份
DUMP的意思就是:
『電腦』將內儲資料直接傳送的結果

而DUMP備份通常是除了數據本身外,還會把相關的底層程序也同時備份,是一種比較全面的備份方式。

⑥ 怎麼把mysqlnbsp;mp的資料庫文件導入到一個表

通常我運行mysqlnbsp;-unbsp;-pnbsp;databaseamp;lt;mp.sqlnbsp;nbsp;這樣的意思就是導入到一個庫中nbsp;只要nbsp;database不變nbsp;表名不重復就可以導入。
查看原帖>>
採納哦

⑦ mp mysql導出資料庫時,怎麼執行

比方說你要把一個名為luciatest2的庫導出到文件:
mysqlmp -uroot -p123456 luciatest2 > luciatest2.sql

⑧ mysql資料庫如何導入.mp文件

如果是,可以用 mysqlmp _u用戶名 _P 密碼 資料庫名 [表名1 表名2..]存放路徑(d:/bk.mp) 比如: 把temp資料庫備份到 d:\temp.mp 就可以使用下面的命令:mysqlmp –u root –proot temp d:\temp.mp

⑨ 備份或導出資料庫命令mysqlmp怎麼使用

、各種用法說明
A. 最簡單的用法:
mysqlmp -uroot -pPassword [database name]
> [mp file]

上述命令將指定資料庫備份到某mp文件(轉儲文件)中,比如:
mysqlmp -uroot -p123 test > test.mp

生成的test.mp文件中包含建表語句(生成資料庫結構哦)和插入數據的insert語句。

B. --opt
如果加上--opt參數則生成的mp文件中稍有不同:
. 建表語句包含drop table if exists tableName
. insert之前包含一個鎖表語句lock tables tableName write,insert之後包含unlock tables

C. 跨主機備份
使用下面的命令可以將host1上的sourceDb復制到host2的targetDb,前提是host2主機上已經創建targetDb資料庫:
mysqlmp --host=host1 --opt sourceDb| mysql --host=host2 -C targetDb

-C指示主機間的數據傳輸使用數據壓縮

D. 只備份表結構
mysqlmp --no-data --databases mydatabase1 mydatabase2 mydatabase3 > test.mp

將只備份表結構。--databases指示主機上要備份的資料庫。如果要備份某個MySQL主機上的所有資料庫可以使用--all-databases選項,如下:
mysqlmp --all-databases
> test.mp

E. 從備份文件恢復資料庫
mysql [database name] < [backup file name]

2、結合Linux的cron命令實現定時備份
比如需要在每天凌晨1:30備份某個主機上的所有資料庫並壓縮mp文件為gz格式,那麼可在/etc/crontab配置文件中加入下面代碼行:
30 1 * * * root mysqlmp -u root -pPASSWORD --all-databases | gzip > /mnt/disk2/database_`date '+%m-%d-%Y'`.sql.gz

前面5個參數分別表示分鍾、小時、日、月、年,星號表示任意。date '+%m-%d-%Y'得到當前日期的MM-DD-YYYY格式。

3、一個完整的Shell腳本備份MySQL資料庫示例

#vi /backup/backup.sh

#!bin/bash
cd /backup
echo "You are in backup dir"
mv backup* /oldbackup
echo "Old dbs are moved to oldbackup folder"
File = backup-$Now.sql
mysqlmp -u user -p password database-name > $File
echo "Your database backup successfully completed"

⑩ 後綴mp的文件是哪個資料庫的文件,如何導入

應該是PostgreSQL資料庫的備份文件。
資料庫的導入導出是最常用的功能之一,每種資料庫都提供有這方面的工具,PostgreSQL提供的對應工具為pg_mp和pg_restore。
pg_mp是用於備份PostgreSQL資料庫的工具。它可以在資料庫正在使用的時候進行完整一致的備份,並不阻塞其它用戶對資料庫的訪問。轉儲格式可以是一個腳本或者歸檔文件。
歸檔文件格式必須和pg_restore一起使用重建資料庫。
X:\>pg_mp -U postgres -Fc TestDb1 >TestDb1.mp
X:\>pg_restore -U postgres -d TestDb2 TestDb1.mp

熱點內容
mac訪問windows共享 發布:2024-10-01 23:31:58 瀏覽:643
java培訓要學什麼 發布:2024-10-01 23:15:54 瀏覽:539
c語言編程學習寶典 發布:2024-10-01 22:35:08 瀏覽:346
無法打開腳本文件 發布:2024-10-01 22:14:51 瀏覽:110
javaxml格式字元串格式 發布:2024-10-01 21:54:03 瀏覽:657
為什麼安卓玩游戲都選驍龍 發布:2024-10-01 21:48:07 瀏覽:377
如何避免伺服器暴露ip 發布:2024-10-01 21:38:24 瀏覽:221
pythonrequestjson 發布:2024-10-01 21:37:37 瀏覽:858
珠海java 發布:2024-10-01 21:07:29 瀏覽:825
伺服器剩餘維護是什麼 發布:2024-10-01 21:03:46 瀏覽:547