導航:首頁 > 編程大全 > mysql資料庫備份的方法

mysql資料庫備份的方法

發布時間:2025-03-29 06:05:34

⑴ 怎麼備份mysql資料庫

1、先用工具連接到資料庫,如Navicat Premium

2、在要備份的資料庫點右鍵,選擇轉儲sql文件-結構和數據

⑵ 如何備份和還原MYSQL資料庫里的數據

找到伺服器上mysql的資料庫存放路徑下面的資料庫名文件,拷貝過去放到新伺服器的對應路徑下就可以了

比如你要備份test的資料庫,就到你的mysql安裝目錄D:MySQLdata下面把test這個文件夾整個復制走就可以了

⑶ 如何定時備份Mysql資料庫

資料庫的自動備份,可以減輕維護者的工作量也便於系統恢復,對於比較重要的資料庫,最好還是設置下自動備份。

工具/原料



navicat for mysql

mysql 5.5

方法/步驟

  1. 打開navicat客戶端,連上mysql後,雙擊左邊你想要備份的資料庫。點擊「計劃」,再點擊「新建批處理作業」。


⑷ mysql資料庫備份命令mysql數據備份的三種方法

在操作數據過程中,可能會導致數據錯誤,甚至資料庫奔潰,而有效的定時備份能很好地保護資料庫。本篇文章主要講述了幾種方法進行 MySQL 定時備份資料庫。
一. mysqlmp命令備份數據
在MySQL中提供了命令行導出資料庫數據以及文件的一種方便的工具mysqlmp,我們可以通過命令行直接實現資料庫內容的導出mp,首先我們簡單了解一下mysqlmp命令用法:
#MySQLmp常用mysqlmp -u root -p --databases 資料庫1 資料庫2 > xxx.sql
二. mysqlmp常用操作示例
1. 備份全部資料庫的數據和結構
mysqlmp -uroot -p123456 -A > /data/mysqlDump/mydb.sql2.備份全部資料庫的結構(加 -d 參數)
mysqlmp -uroot -p123456 -A -d > /data/mysqlDump/mydb.sql3. 備份全部資料庫的數據(加 -t 參數)
mysqlmp -uroot -p123456 -A -t > /data/mysqlDump/mydb.sql4.備份單個資料庫的數據和結構(,資料庫名mydb)
mysqlmp -uroot-p123456 mydb > /data/mysqlDump/mydb.sql5. 備份單個資料庫的結構
mysqlmp -uroot -p123456 mydb -d > /data/mysqlDump/mydb.sql6. 備份單個資料庫的數據
mysqlmp -uroot -p123456 mydb -t > /data/mysqlDump/mydb.sql7. 備份多個表的數據和結構(數據,結構的單獨備份方法與上同)
mysqlmp -uroot -p123456 mydb t1 t2 > /data/mysqlDump/mydb.sql8. 一次備份多個資料庫
mysqlmp -uroot -p123456 --databases db1 db2 > /data/mysqlDump/mydb.sql三. 還原 MySQL 備份內容有兩種方式還原,第一種是在 MySQL 命令行中,第二種是使用 SHELL 行完成還原
1. 在系統命令行中,輸入如下實現還原:
mysql -uroot -p123456 < /data/mysqlDump/mydb.sql2. 在登錄進入mysql系統中,通過source指令找到對應系統中的文件進行還原:
mysql> source /data/mysqlDump/mydb.sql在 Linux中,通常使用BASH腳本對需要執行的內容進行編寫,加上定時執行命令crontab實現日誌自動化生成。
以下代碼功能就是針對mysql進行備份,配合crontab,實現備份的內容為近一個月(31天)內的每天的mysql資料庫記錄。
編寫BASH維護固定數量備份文件
在Linux中,使用vi或者vim編寫腳本內容並命名為:mysql_mp_script.sh
#!/bin/bash#保存備份個數,備份31天數據number=31#備份保存路徑backup_dir=/root/mysqlbackup#日期dd=`date +%Y-%m-%d-%H-%M-%S`#備份工具tool=mysqlmp#用戶名username=root#密碼password=TankB214#將要備份的資料庫database_name=edoctor#如果文件夾不存在則創建if [ ! -d $backup_dir ];thenmkdir -p $backup_dir;fi#簡單寫法 mysqlmp -u root -p123456 users > /root/mysqlbackup/users-$filename.sql$tool -u $username -p$password $database_name > $backup_dir/$database_name-$dd.sql#寫創建備份日誌echo "create $backup_dir/$database_name-$dd.pm" >> $backup_dir/log.txt#找出需要刪除的備份delfile=`ls -l -crt $backup_dir/*.sql | awk '{print $9 }' | head -1`#判斷現在的備份數量是否大於$numbercount=`ls -l -crt $backup_dir/*.sql | awk '{print $9 }' | wc -l`if [ $count -gt $number ]then#刪除最早生成的備份,只保留number數量的備份rm $delfile#寫刪除文件日誌echo "delete $delfile" >> $backup_dir/log.txtfi如上代碼主要含義如下:
1.首先設置各項參數,例如number最多需要備份的數目,備份路徑,用戶名,密碼等。
2.執行mysqlmp命令保存備份文件,並將操作列印至同目錄下的log.txt中標記操作日誌。
3.定義需要刪除的文件:通過ls命令獲取第九列,即文件名列,再通過實現定義操作時間最晚的那個需要刪除的文件。
4.定義備份數量:通過ls命令加上
統計以sql結尾的文件的行數。
5.如果文件超出限制大小,就刪除最早創建的sql文件
使用crontab定期執行備份腳本
在 Linux 中,周期執行的任務一般由cron這個守護進程來處理[ps -ef|grep cron]。cron讀取一個或多個配置文件,這些配置文件中包含了命令行及其調用時間。cron的配置文件稱為「crontab」,是「cron table」的簡寫。
cron服務
cron是一個 Liunx 下 的定時執行工具,可以在無需人工干預的情況下運行作業。
service crond start //啟動服務
service crond stop //關閉服務
service crond restart //重啟服務
service crond reload //重新載入配置
service crond status //查看服務狀態
crontab語法
crontab命令用於安裝、刪除或者列出用於驅動cron後台進程的表格。用戶把需要執行的命令序列放到crontab文件中以獲得執行。每個用戶都可以有自己的crontab文件。/var/spool/cron下的crontab文件不可以直接創建或者直接修改。該crontab文件是通過crontab命令創建的。
在crontab文件中如何輸入需要執行的命令和時間。該文件中每行都包括六個域,其中前五個域是指定命令被執行的時間,最後一個域是要被執行的命令。每個域之間使用空格或者製表符分隔。
格式如下:
minute hour day-of-month month-of-year day-of-week commands
合法值 00-59 00-23 01-31 01-12 0-6 (0 is sunday)
除了數字還有幾個個特殊的符號就是"*"、"/"和"-"、",",*代表所有的取值范圍內的數字,"/"代表每的意思,"/5"表示每5個單位,"-"代表從某個數字到某個數字,","分開幾個離散的數字。
-l 在標准輸出上顯示當前的crontab。
-r 刪除當前的crontab文件。
-e 使用VISUAL或者EDITOR環境變數所指的編輯器編輯當前的crontab文件。當結束編輯離開時,編輯後的文件將自動安裝。
創建cron腳本
第一步:寫cron腳本文件,命名為mysqlRollBack.cron。
15,30,45,59 * * * * echo "xgmtest....." >> xgmtest.txt 表示,每隔15分鍾,執行列印一次命令
第二步:添加定時任務。執行命令 「crontab crontest.cron」。搞定
第三步:"crontab -l" 查看定時任務是否成功或者檢測/var/spool/cron下是否生成對應cron腳本
注意:這操作是直接替換該用戶下的crontab,而不是新增
定期執行編寫的定時任務腳本(記得先給shell腳本執行許可權)
0 2 * * * /root/mysql_backup_script.sh隨後使用crontab命令定期指令編寫的定時腳本
crontabmysqlRollback.cron再通過命令檢查定時任務是否已創建:
附 crontab 的使用示例:
1. 每天早上6點
0 6 * * * echo "Good morning." >> /tmp/test.txt //注意單純echo,從屏幕上看不到任何輸出,因為cron把任何輸出都email到root的信箱了。2. 每兩個小時
0 */2 * * * echo "Have a break now." >> /tmp/test.txt3. 晚上11點到早上8點之間每兩個小時和早上八點
0 23-7/2,8 * * * echo "Have a good dream" >> /tmp/test.txt4. 每個月的4號和每個禮拜的禮拜一到禮拜三的早上11點
0 11 4 * 1-3 command line5.1 月 1 日早上 4 點
0 4 1 1 * command line SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root //如果出現錯誤,或者有數據輸出,數據作為郵件發給這個帳號 HOME=/6. 每小時執行/etc/cron.hourly內的腳本
01 * * * * root run-parts /etc/cron.hourly7. 每天執行/etc/cron.daily內的腳本
02 4 * * * root run-parts /etc/cron.daily8. 每星期執行/etc/cron.weekly內的腳本
22 4 * * 0 root run-parts /etc/cron.weekly9. 每月去執行/etc/cron.monthly內的腳本
42 4 1 * * root run-parts /etc/cron.monthly注意: "run-parts" 這個參數了,如果去掉這個參數的話,後面就可以寫要運行的某個腳本名,而不是文件夾名。
10. 每天的下午4點、5點、6點的5 min、15 min、25 min、35 min、45 min、55 min時執行命令。
5,15,25,35,45,55 16,17,18 * * * command11. 每周一,三,五的下午3:00系統進入維護狀態,重新啟動系統。
00 15 * * 1,3,5 shutdown -r +512. 每小時的10分,40分執行用戶目錄下的innd/bbslin這個指令:
10,40 * * * * innd/bbslink13. 每小時的1分執行用戶目錄下的bin/account這個指令:
以下是我的測試每分鍾的截圖效果,其對應代碼如下:
* * * * * /root/mysql_backup_script.sh效果截圖:
其中的log.txt記錄備份的操作詳細日誌:
本文參考:
1.MySQLmp常用命令www.cnblogs.com/smail-bao/p/6402265.html2.利用Shell腳本實現對mysql資料庫的備份:www.cnblogs.com/mracale/p/7251292.html3.Linux下的Crontab定時執行任務命令詳解:www.cnblogs.com/longjshz/p/5779215.html

⑸ 實現MySQL資料庫的備份與還原的幾種方法

MyISAM 表是保存成文件的形式,因此相對比較容易備份,上面提到的幾種方法都可以使用。Innodb 所有的表都保存在同一個數據文件 ibdata1 中(也可能是多個文件,或者是獨立的表空間文件),相對來說比較不好備份,免費的方案可以是拷貝數據文件、備份 binlog,或者用 mysqlmp。1. 使用直接拷貝資料庫備份 典型的如cp、tar或cpio實用程序當你使用直接備份方法時,必須保證表不在被使用。如果伺服器在你正在拷貝一個表時改變它,拷貝就失去意義。保證你的拷貝完整性的最好方法是關閉伺服器,拷貝文件,然後重啟伺服器。 如果你不想關閉伺服器,要在執行表檢查的同時鎖定伺服器。如果伺服器在運行,相同的制約也適用於拷貝文件,應該使用相同的鎖定協議讓伺服器「安靜下來」。當你完成了MySQL資料庫備份時,需要重啟伺服器(如果關閉了它)或釋放加在表上的鎖定(如果你讓伺服器運行)。 要用直接拷貝文件把一個資料庫從一台機器拷貝到另一台機器上,只是將文件拷貝到另一台伺服器主機的適當數據目錄下即可。要確保文件是MyIASM格式或兩台機器有相同的硬體結構,否則你的資料庫在另一台主機上有奇怪的內容。你也應該保證在另一台機器上的伺服器在你正在安裝資料庫表時不訪問它們。2. 使用mysqlmp資料庫備份mysqlmp 是採用SQL級別的備份機制,它將數據表導成 SQL 腳本文件,在不同的 MySQL 版本之間升級時相對比較合適,這也是最常用的備份方法。mysqlmp程序備份資料庫較慢,但它生成的文本文件便於移植。mysqlmp 的一些主要參數:1)--compatible=name它告訴 mysqlmp,導出的數據將和哪種資料庫或哪個舊版本的 MySQL 伺服器相兼容。值可以為 ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,要使用幾個值,用逗號將它們隔開。當然了,它並不保證能完全兼容,而是盡量兼容。2)--complete-insert,-c導出的數據採用包含欄位名的完整 INSERT 方式,也就是把所有的值都寫在一行。這么做能提高插入效率,但是可能會受到 max_allowed_packet 參數的影響而導致插入失敗。因此,需要謹慎使用該參數,至少我不推薦。3)--default-character-set=charset指定導出數據時採用何種字元集,如果數據表不是採用默認的 latin1 字元集的話,那麼導出時必須指定該選項,否則再次導入數據後將產生亂碼問題。4)--disable-keys告訴mysqlmp 在 INSERT 語句的開頭和結尾增加 ; 和 ; 語句,這能大大提高插入語句的速度,因為它是在插入完所有數據後才重建索引的。該選項只適合 MyISAM 表。5)--extended-insert = true|false默認情況下,mysqlmp 開啟 --complete-insert 模式,因此不想用它的的話,就使用本選項,設定它的值為 false 即可。6)--hex-blob使用十六進制格式導出二進制字元串欄位。如果有二進制數據就必須使用本選項。影響到的欄位類型有 BINARY、VARBINARY、BLOB。7)--lock-all-tables,-x在開始導出之前,提交請求鎖定所有資料庫中的所有表,以保證數據的一致性。這是一個全局讀鎖,並且自動關閉 --single-transaction 和 --lock-tables 選項。8)--lock-tables它和--lock-all-tables 類似,不過是鎖定當前導出的數據表,而不是一下子鎖定全部庫下的表。本選項只適用於 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 選項。9)--no-create-info,-t只導出數據,而不添加 CREATE TABLE 語句。10)--no-data,-d不導出任何數據,只導出資料庫表結構。11)--opt這只是一個快捷選項,等同於同時添加 --add-drop-tables --add-locking --create-option --disable-keys --extended-insert --lock-tables --quick --set-charset 選項。本選項能讓 mysqlmp 很快的導出數據,並且導出的數據能很快導回。該選項默認開啟,但可以用 --skip-opt 禁用。注意,如果運行 mysqlmp 沒有指定 --quick 或 --opt 選項,則會將整個結果集放在內存中。如果導出大數據庫的話可能會出現問題。12)--quick,-q該選項在導出大表時很有用,它強制 mysqlmp 從伺服器查詢取得記錄直接輸出而不是取得所有記錄後將它們緩存到內存中。13)--routines,-R導出存儲過程以及自定義函數。14)--single-transaction該選項在導出數據之前提交一個 BEGIN SQL語句,BEGIN 不會阻塞任何應用程序且能保證導出時資料庫的一致性狀態。它只適用於事務表,例如 InnoDB 和 BDB。 本選項和 --lock-tables 選項是互斥的,因為 LOCK TABLES 會使任何掛起的事務隱含提交。 要想導出大表的話,應結合使用 --quick 選項。--triggers同時導出觸發器。該選項默認啟用,用 --skip-triggers 禁用它。備份:使用mysqlmp備份資料庫其實就是把資料庫轉儲成一系列CREATE TABLE和INSERT語句,通過這些語句我們就可重新生成資料庫。使用mysqlmp的方法如下:% mysqlmp --opt testdb | gzip > /data/backup/testdb.bak#--opt選項會對轉儲過程進行優化,生成的備份文件會小一點,後的管道操作會進行數據壓縮% mysqlmp --opt testdb mytable1,mytable2 | gzip > /data/backup/testdb_mytable.bak#可在資料庫後接數據表名,只導出指定的數據表,多個數據表可用逗號分隔--opt選項還可激活--add-drop-table選項,它將會在備份文件的每條CREATE TABLE前加上一條DROP TABLE IF EXISTS語句。這可方便進行數據表的更新,而不會發生「數據表已存在」的錯誤。用mysqlmp命令還可直接把資料庫轉移到另外一台伺服器上,不用生成備份文件。重復執行可定期更新遠程資料庫。% mysqladmin -h remote_host create testdb% mysqlmp --opt testdb | mysql -h remote_host testdb另外還可通過ssh遠程調用伺服器上的程序,如:% ssh remote_host mysqladmin create testdb% mysqlmp --opt testdb | ssh remote_host mysql testdb 通過直接拷貝系統文件的方式備份資料庫,在備份時,要確保沒有人對資料庫進行修改操作。要做到這點,最好關閉伺服器。如果不能關閉的,要以只讀方試鎖定有關數據表。下面是一些示例:% cp -r db /backup/db #備份db資料庫到/backup/db目錄% cp table_name.* /backup/db #只備份table_name數據表% scp -r db remotehot:/usr/local/mysql/data #用scp把資料庫直接拷貝到遠程伺服器,在把資料庫直接拷貝到遠程主機時,應注意兩台機器必須有同樣的硬體結構,或者將拷貝的數據表全部是可移植數據表類型。或者/usr/local/mysql/bin/mysqlmp -uroot -proot \--default-character-set=utf8 --opt --extended-insert=false \--triggers -R --hex-blob -x testdb > testdb.sql使用以下 SQL 來備份 Innodb 表:/usr/local/mysql/bin/mysqlmp -uroot -proot \--default-character-set=utf8 --opt --extended-insert=false \--triggers -R --hex-blob --single-transaction testdb > testdb.sql另外,如果想要實現在線備份,還可以使用 --master-data 參數來實現,如下:/usr/local/mysql/bin/mysqlmp -uroot -proot \--default-character-set=utf8 --opt --master-data=1 \--single-transaction --flush-logs testdb > testdb.sql它只是在一開始的瞬間請求鎖表,然後就刷新binlog了,而後在導出的文件中加入CHANGE MASTER 語句來指定當前備份的binlog位置,如果要把這個文件恢復到slave里去,就可以採用這種方法來做。 還原:用mysqlmp 備份出來的文件是一個可以直接倒入的 SQL 腳本,有兩種方法可以將數據導入。直接用 mysql 客戶端例如:/usr/local/mysql/bin/mysql -uroot -proot testdb < testdb.sql用SOURCE 語法其實這不是標準的 SQL 語法,而是 mysql 客戶端提供的功能,例如:SOURCE /tmp/testdb.sql;這里需要指定文件的絕對路徑,並且必須是 mysqld 運行用戶(例如 nobody)有許可權讀取的文件。 3. 使用mysqlhot資料庫備份 使用mysqlhot工具,它是一個Perl DBI腳本,可在不關閉伺服器的情況下備份資料庫,mysqlhot 是一個 PERL 程序,最初由Tim Bunce編寫。它使用 LOCK TABLES、FLUSH TABLES 和 cp 或 scp 來快速備份資料庫。它是備份資料庫或單個表的最快的途徑,但它只能運行在資料庫文件(包括數據表定義文件、數據文件、索引文件)所在的機器上。mysqlhot 只能用於備份 MyISAM,並且只能運行在 類Unix 和 NetWare 系統上。它主要的優點是:它直接拷貝文件,所以它比mysqlmp快。可自動完成數據鎖定工作,備份時不用關閉伺服器。能刷新日誌,使備份文件和日誌文件的檢查點能保持同步。備份:mysqlhot 支持一次性拷貝多個資料庫,同時還支持正則表達。以下是幾個例子:/usr/local/mysql/bin/mysqlhot -h=localhost -u=root -p=root \testdb /tmp (把資料庫目錄 testdb 拷貝到 /tmp 下)/usr/local/mysql/bin/mysqlhot -h=localhost -u=root -p=root \testdb_1 testdb_2 testdb_n /tmp/usr/local/mysql/bin/mysqlhot -h=localhost -u=root -p=root \testdb./regex/ /tmp 還原:mysqlhot 備份出來的是整個資料庫目錄,使用時可以直接拷貝到 mysqld 指定的 datadir (在這里是 /usr/local/mysql/data/)目錄下即可,同時要注意許可權的問題,如下例:cp -rf testdb /usr/local/mysql/data/chown -R nobody:nobody /usr/local/mysql/data/ (將 testdb 目錄的屬主改成 mysqld 運行用戶) 4. 使用SQL語句資料庫備份 BACKUP TABLE 語法其實和 mysqlhot 的工作原理差不多,都是鎖表,然後拷貝數據文件。它能實現在線備份,但是效果不理想,因此不推薦使用。它只拷貝表結構文件和數據文件,不同時拷貝索引文件,因此恢復時比較慢。備份:BACK TABLE tbl_test TO '/tmp/testdb/'; #把tbl_test資料庫備份到/tmp/testdb/目錄里,會自動創建一個testdb目錄 為了執行該語句,你必須擁有那些表的FILE許可權和SELECT許可權,備份目錄還必須是伺服器可寫的。該語句執行時,會先把內存中的數據寫入磁碟,再把各個數據表的.frm(表結構定義文件)、.MYD(數據)文件從數據目錄拷貝到備份目錄。它不拷貝.MYI(索引)文件,因為它能用另外兩個文件重建。BACKUP TABLE語句備份時,依次鎖定數據表,當同時備份多個數據表時,數據表可能會被修改,所以備份0完成時,備份文件中的數據和現時數據表中的數據可能會有差異,為了消除該差異,我們可用只讀方式鎖定數據表,在備份完成後再解鎖。如:mysql> LOCK TABLES tb1 READ,tb2 READ;mysql> BACKUP TABLE tb1,tb2 TO 'backup/db';mysql> UNLOCK TABLES;使用BACKUP TABLE語句備份的數據表可用RESTORE TABLE重新載入到伺服器。注意,必須要有 FILE 許可權才能執行本SQL,並且目錄 /tmp/testdb/ 必須能被 mysqld 用戶可寫,導出的文件不能覆蓋已經存在的文件,以避免安全問題。SELECT INTO OUTFILE 則是把數據導出來成為普通的文本文件,可以自定義欄位間隔的方式,方便處理這些數據。 例子:SELECT * INTO OUTFILE '/tmp/testdb/tbl_test.txt' FROM tbl_test;注意,必須要有 FILE 許可權才能執行本SQL,並且文件 /tmp/testdb/tbl_test.txt 必須能被 mysqld 用戶可寫,導出的文件不能覆蓋已經存在的文件,以避免安全問題。還原:用BACKUP TABLE 方法備份出來的文件,可以運行 RESTORE TABLE 語句來恢復數據表。例子:RESTORE TABLE FROM '/tmp/testdb/';許可權要求類似上面所述。用SELECT INTO OUTFILE 方法備份出來的文件,可以運行 LOAD DATA INFILE 語句來恢復數據表。例子:LOAD DATA INFILE '/tmp/testdb/tbl_name.txt' INTO TABLE tbl_name;許可權要求類似上面所述。倒入數據之前,數據表要已經存在才行。

⑹ 如何備份和還原MYSQL資料庫里的數據

推薦工具Navicat 8 Lite for MySQL

連接到相應的資料庫,導出備份。

恢復時也可以用這個工具恢復

⑺ 如何利用mysqlmp備份MySQL資料庫

一、數據備份的重要性 工作中,如果意外刪除了重要的文件或者目錄的話,那結果可就慘了。尤其是當誤刪除的數據涉及重要的客戶或者關鍵項目,並且這些數據無法輕易重新創建的時候,那滋味,不用我說你也能想像得到。不巧的是,像這樣的數據在公司環境中隨處可見,例如銷售記錄、客戶聯系方式,等等。 二、關於mysqlmp MySQL自身提供了許多命令行工具,例如mysql工具可以用來與MySQL的資料庫模式、數據、用戶和配置變數進行交互,而mysqladmin工具則可以進行各種管理任務,還有就是下面將要介紹的mysqlmp。此外還有很多,不過那超出了本文的討論范圍。工具mysqlmp既可以用來備份資料庫模式,還可以用來備份數據;利用它,我們不僅可以對一個伺服器上的所有資料庫進行地毯式的備份,同時我們還可以選擇性地備份某個資料庫,甚至資料庫中指定的某些表。 當在伺服器上安裝MySQL的時候,應修改系統路徑以便使全局命令行可以訪問各個客戶程序。打開終端窗口,並執行下列命令:%mysqlmp Usage: mysqlmp[OPTIONS]database[tables]ORmysqlmp[OPTIONS]--databases [OPTIONS] DB1 [DB2 DB3...] OR mysqlmp [OPTIONS] --all-databases [OPTIONS]Formore options, usemysqlmp--help這里給出了使用mysqlmp程序的方法。舉例來說,若要備份所有資料庫模式和數據至文件backup092210.sql的話,可以執行如下所示的命令:%mysqlmp-u root-p--all-databases backup092210.sql Enter password: 這里,為了能夠訪問所有資料庫,我們需要一個root許可權,所以這里需要在提示符後面輸入相應口令。此外,如果你是在開發用的伺服器上練習這些命令的話,不妨花一些時間看看備份文件的內容。這時您會看到一系列的SQL語句,先是刪除各個表後重新創建的語句,然後是重新創建相關數據的語句。另外,由於上面的例子中我們對所有資料庫進行備份,所以您還會發現,備份文件將創建每個資料庫(如果它還沒有存在的話),然後通過USE命令切換到該資料庫,進而創建與該資料庫相關的表跟數據。 若要備份單個資料庫,例如要備份名為wiki的資料庫到一個名為wiki-backup092210.sql的文件中,我們可以使用如下所示的命令:%mysqlmp-u root-p wikiwiki-backup092210.sql Enter password: 最後,若要備份資料庫中名為users的表的話,例如要把它備份到名為wikiusers-backup092210.sql的文件中,我們可以使用如下所示的命令:%mysqlmp-u root-p wiki userswikiusers-backup092210.sql Enter password:三、調整備份內容 有時候,我們可能只想備份資料庫的模式,或者只想備份資料庫的數據。為了備份資料庫模式,可以向mysqlmp傳遞參數--no-data,如下所示:%mysqlmp-u root-p--no-data wiki wiki-backup092210.sql 對於前面所舉的例子,僅需要少量的擊鍵次數就能執行mysqlmp命令。然而,工作中要乾的活還有很多,並且如果老是執行這些命令的話,那麼生活就會變得太單調了。因此,我們可以設法使這些過程自動化,這時我們可以藉助cron工具來達成我們的目標,這個工具在所有類UNIX操作系統上都能找到。為了自動執行備份任務,我們需要新建一個正確命名的文件。例如nightly-backup.sh,具體命令如下所示:#!/bin/sh mysqlmp-uroot-psecret wiki/home/backup/sql/wiki-backup-`date+%m%d%Y`.sql當我們執行這個腳本的時候,它會將wiki資料庫備份到一個按照備份時間命名的文件中,如wiki-backup-092210.sql。您需要注意一下這里的用戶名root和口令secret是如何傳遞給mysqlmp的,即將它們分別放到選項- u和- p後面。從安全的角度講,我們必須進行正確的許可權設置。 接下來,我們將這個腳本提供交給cron,方法是使用crontab。為此,我們可以執行如下所示的命令:%crontab-e這將打開當前登錄用戶的crontab文件,如果該文件不存在的話就會自動新建一個。在這個文件中,我們可以添加如下內容,來確保每天上午3時運行該備份腳本:03***/home/backup/scripts/nightly-backup .sh如果您對crontab的語法很陌生的話,這里的參數可能讓您摸不著頭腦。這里前五個參數分別對應於執行腳本的時間,依次為分、時、日、月和星期幾。因此,要想在每星期二的4:45am執行腳本的話,可以使用參數45 4 * * 3。 插入上面所示的一行內容後,保存文件,那麼我們的任務就會開始按照給定時間調度執行。 需要注意的是,第二天早上一定要查看相應的目錄,看看事情是否一切正常。 五、其它備份方案 就像本文前面所說的那樣,mysqlmp只是MySQL眾多備份方案中的一個。此外,您還可以使用MySQL的二進制日誌文件進行增量備份,或者使用從MySQL主伺服器中將數據復制到從伺服器中。 六、小結本文中,我們與讀者一道建立了一個簡單的MySQL備份解決方案。如果您之前還未實施任何解決方案的話,不妨立即動手試一下。重要的是,這只需要花費您幾分鍾的時間,我想這是很劃得來的。

閱讀全文

與mysql資料庫備份的方法相關的資料

熱點內容
匯編語言是面向什麼的編程語言 瀏覽:89
安裝win10無法保留你的文件夾 瀏覽:406
天天動聽歌曲在哪個文件夾 瀏覽:627
招標文件裡面談判內容寫什麼 瀏覽:474
中國搜索網站源碼 瀏覽:838
怎麼下載網路連接 瀏覽:215
手機哪些數據線可以當電池用 瀏覽:234
win10ghost鏡像下載 瀏覽:991
現在看美劇用哪個app最好 瀏覽:19
win8怎麼忘記網路 瀏覽:807
雲痕大數據家長怎麼登錄 瀏覽:638
用戶密碼是如何保存在資料庫的 瀏覽:281
聯系博導用壓縮文件嗎 瀏覽:197
怎麼讓word文檔不顯示標記及修改的狀態 瀏覽:980
ug中zg螺紋用什麼編程 瀏覽:306
招標文件裡面的格式 瀏覽:498
shell腳本生成json 瀏覽:121
會編程對數控有什麼幫助 瀏覽:606
ps導出成矢量文件 瀏覽:849
公司緊急文件分有哪些 瀏覽:148

友情鏈接