1、基礎(chǔ)知識(shí)
站在用戶的角度思考問題,與客戶深入溝通,找到鶴峰網(wǎng)站設(shè)計(jì)與鶴峰網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站制作、成都做網(wǎng)站、外貿(mào)營銷網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊(cè)、網(wǎng)絡(luò)空間、企業(yè)郵箱。業(yè)務(wù)覆蓋鶴峰地區(qū)。在mysql5.0以前版本支持文本格式和二進(jìn)制格式的日志,但是在mysql5.0后版本就只支持二進(jìn)制格式的日志。因?yàn)槎M(jìn)制日志在性能、信息處理等方面有更多的優(yōu)點(diǎn)。
2、啟用mysql二進(jìn)制日志
mysql二進(jìn)制日志由配置文件my.cnf的log-bin選項(xiàng)負(fù)責(zé)啟用的。
mysql服務(wù)器默認(rèn)會(huì)在數(shù)據(jù)根目錄創(chuàng)建兩個(gè)新文件:XXX-bin.000001和XXX-bin.index。若配置選項(xiàng)沒有給出文件名,mysql將使用mysql-bin來命名這兩個(gè)文件,其中.index文件包含一份完整的日志文件清單。如下:
[root@xin-c ~]# vim /etc/my.cnf
默認(rèn)沒有打開,我們將注釋打開:
重啟服務(wù)
[root@xin-c ~]# /etc/init.d/mysqld restart
[root@xin-c ~]# cd /data/mysql/
mysql會(huì)把用戶對(duì)所有數(shù)據(jù)庫的內(nèi)容和結(jié)構(gòu)的修改情況記入XXX-bin.n文件,但是不會(huì)記錄SELECT和沒有實(shí)際更新的UPDATE語句。
當(dāng)然我們也可以通過相關(guān)命令查詢,mysql是否已經(jīng)開啟binlog日志。如下:
mysql> show variables like 'log_%';
3、binlog日志文件的生成
當(dāng)mysql停止或重啟時(shí),服務(wù)器會(huì)把日志文件記入下一個(gè)日志文件,mysql會(huì)在重啟時(shí)生成一個(gè)新的日志文件,文件序號(hào)依次遞增。
如果日志文件超過max_binlog_size(在my.cnf文件中配置)系統(tǒng)變量配置的上限時(shí),也會(huì)生成新的日志文件。
注: /etc/my.cnf 默認(rèn)情況下是沒有這個(gè)選項(xiàng)的,需要自定義添加:
[root@xin-m mysql]# vim /etc/my.cnf
除此之外,如果在mysql命令中執(zhí)行flush logs命令也會(huì)生成新的日志文件。
mysql> flush logs;
4、查看系統(tǒng)中的binlog日志
查看系統(tǒng)中的binlog日志,使用show master logs命令。如下:
mysql> show master logs;
5、查看binlog日志文件
mysql提供了mysqlbinlog命令來查看日志文件,在記錄每條變更日志的時(shí)候,日志文件都會(huì)把當(dāng)前時(shí)間給記錄下來,以便進(jìn)行數(shù)據(jù)庫恢復(fù)。如下:
[root@xin-m mysql]# mysqlbinlog mysql-bin.000004| more
6、使用binlog日志進(jìn)行數(shù)據(jù)庫恢復(fù)
如果遇到災(zāi)難事件,應(yīng)該用最近一次制作的完整備份恢復(fù)數(shù)據(jù)庫,然后使用備份之后的binlog日志件把數(shù)據(jù)庫恢復(fù)到最接近現(xiàn)在的可用狀態(tài)。
使用binlog日志進(jìn)行恢復(fù)時(shí)需要依次進(jìn)行,即最早生成的日志文件要最先恢復(fù)?;謴?fù)數(shù)據(jù)的命令格式如下:
mysqlbinlog xxx-bin.000001|mysql -uroot –p'password' dataname
-u 指定數(shù)據(jù)庫用戶名–p 用戶名對(duì)應(yīng)的密碼dataname 數(shù)據(jù)庫的名字
7、binlog命令行參數(shù)詳解
my.cnf配置文件有關(guān)binlog配置如下:
[root@xin-m mysql]# cat /etc/my.cnf |grep -v ^#|grep -v ^$
8、刪除binlog日志
8.1刪除部分binlog日志
刪除binlog部分日志,我們可以日志名稱和日志生成的時(shí)間來進(jìn)行刪除。刪除命令如下:
mysql> purge master logs to 'mysql-bin.000009';
根據(jù)日志名稱刪除,只刪除log_name之前的日志,log_name本身不會(huì)被刪除。
通過上圖我們可以看到,mysql-bin.000009之前的日志已經(jīng)被全部刪除。
[root@xin-c mysql]# ll --full-time
mysql> purge master logs before '2016-05-17 15:27:53';
根據(jù)日志生成的時(shí)間刪除,只刪除date之前的日志,date本身不會(huì)被刪除。
8.2刪除全部binlog日志
刪除之前所有的binlog日志,并重新生成新的binlog,后綴從000001開始。使用命令:
mysql> reset master;
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。