国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
4. Binlog 的查看與管理
首頁 資料庫 mysql教程 MySQL二進(jìn)制日誌(BINLOG)是什麼?

MySQL二進(jìn)制日誌(BINLOG)是什麼?

Jun 11, 2025 pm 03:41 PM
mysql binlog

MySQL 的binary log(binlog)是記錄數(shù)據(jù)庫更改操作的二進(jìn)制日誌,用於數(shù)據(jù)恢復(fù)、主從復(fù)制和審計等場景。 1. Binlog 是邏輯日誌文件,記錄所有修改數(shù)據(jù)的操作事件,如INSERT、UPDATE、DELETE 等,但不包括SELECT 或SHOW 查詢語句;2. 其主要用途包括:通過重放日誌進(jìn)行數(shù)據(jù)恢復(fù)、支持主從復(fù)制實現(xiàn)數(shù)據(jù)同步、以及用於分析操作記錄滿足審計需求;3. 啟用binlog 需在配置文件中設(shè)置log-bin、server-id、binlog_format 和expire_logs_days 參數(shù),並重啟MySQL 生效;4. 可使用SHOW BINARY LOGS 和SHOW MASTER STATUS 查看日誌信息,通過mysqlbinlog 工具解析內(nèi)容,並可按文件名或時間清理舊日誌以釋放磁盤空間。合理配置與管理binlog 對保障數(shù)據(jù)安全至關(guān)重要。

What is the MySQL binary log (binlog) and what is it used for?

MySQL 的binary log(簡稱binlog)是MySQL 服務(wù)器的一個重要功能,它記錄了所有對數(shù)據(jù)庫執(zhí)行更改的操作(如INSERT、UPDATE、DELETE 等),但不包括SELECT 或SHOW 這類查詢語句。它的主要作用是用於數(shù)據(jù)恢復(fù)、主從復(fù)制以及審計等場景。


1. Binary Log 是什麼?

Binary log 是一個二進(jìn)制格式的文件,記錄的是數(shù)據(jù)庫中所有更改數(shù)據(jù)的“事件”(events)。每個事件描述了一次操作的具體內(nèi)容,比如哪個表被修改了、修改了哪些行、使用了什麼語句等。

你可以把它理解為數(shù)據(jù)庫的“操作日誌”,不過它是邏輯層面的日誌,不是像redo log 那樣的物理日誌。

開啟binlog 後,MySQL 會生成一系列以mysql-bin.xxxxxx格式命名的日誌文件,並在每次重啟或手動刷新日誌時創(chuàng)建新的文件。


2. Binary Log 的常見用途

  • 數(shù)據(jù)恢復(fù):如果你不小心刪除了某個表或者誤刪了數(shù)據(jù),只要binlog 沒有被清理掉,就可以通過它來恢復(fù)數(shù)據(jù)。
  • 主從復(fù)制(Replication) :主庫上的binlog 會被從庫讀取並重放,從而實現(xiàn)數(shù)據(jù)同步。
  • 數(shù)據(jù)審計:可以分析binlog 來追蹤某些操作的發(fā)生時間、來源和具體內(nèi)容,幫助排查問題或滿足合規(guī)要求。

例如,在發(fā)生誤刪後,DBA 可以用mysqlbinlog工具解析日誌,找到出錯前的最後一條正確操作,然後跳過錯誤部分進(jìn)行恢復(fù)。


3.如何啟用和配置Binlog

要在MySQL 中啟用binlog,需要在配置文件(通常是my.cnf 或my.ini)中添加如下配置:

 [mysqld]
server-id=1
log-bin=mysql-bin

幾個關(guān)鍵參數(shù)說明:

  • log-bin :指定binlog 文件名的前綴,默認(rèn)是mysql-bin 。
  • server-id :用於主從復(fù)制,每臺服務(wù)器必須唯一。
  • binlog_format :設(shè)置日誌格式,常用值有STATEMENTROWMIXED 。
  • expire_logs_days :控制日誌保留天數(shù),避免磁盤被佔滿。

配置完成後重啟MySQL 即可生效。


4. Binlog 的查看與管理

你可以使用SHOW BINARY LOGS;查看當(dāng)前有哪些binlog 文件,也可以用SHOW MASTER STATUS;查看當(dāng)前正在寫入的binlog 文件。

要查看binlog 內(nèi)容,需要使用mysqlbinlog命令行工具。例如:

 mysqlbinlog mysql-bin.000001

這個命令會輸出該binlog 文件中的所有事件內(nèi)容。你還可以加上--start-datetime--stop-datetime參數(shù)來過濾特定時間段的操作。

此外,定期清理舊的binlog 很重要,可以通過以下命令手動清理:

 PURGE BINARY LOGS TO 'mysql-bin.000010';
-- 或者按時間清理PURGE BINARY LOGS BEFORE '2025-04-01 00:00:00';

基本上就這些。雖然binlog 看起來只是個日誌文件,但它在數(shù)據(jù)安全和高可用架構(gòu)中扮演著非常關(guān)鍵的角色。合理配置和管理binlog,能在關(guān)鍵時刻幫你挽回?fù)p失。

以上是MySQL二進(jìn)制日誌(BINLOG)是什麼?的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

MySQL Master故障轉(zhuǎn)移的典型過程是什麼? MySQL Master故障轉(zhuǎn)移的典型過程是什麼? Jun 19, 2025 am 01:06 AM

MySQL主庫故障切換主要包括四個步驟。 1.故障檢測:通過監(jiān)控系統(tǒng)定期檢查主庫進(jìn)程、連接狀態(tài)及執(zhí)行簡單查詢判斷是否宕機(jī),設(shè)置重試機(jī)制避免誤判,並可藉助MHA、Orchestrator或Keepalived等工具輔助檢測;2.選擇新主庫:根據(jù)數(shù)據(jù)同步進(jìn)度(Seconds_Behind_Master)、binlog數(shù)據(jù)完整性、網(wǎng)絡(luò)延遲與負(fù)載情況選取最合適從庫接替,必要時進(jìn)行數(shù)據(jù)補(bǔ)償或人工干預(yù);3.切換拓?fù)洌簩⑵渌麖膸熘赶蛐轮鲙?,?zhí)行RESETMASTER或啟用GTID,更新VIP、DNS或代理配置以

如何使用命令行連接到MySQL數(shù)據(jù)庫? 如何使用命令行連接到MySQL數(shù)據(jù)庫? Jun 19, 2025 am 01:05 AM

連接MySQL數(shù)據(jù)庫的步驟如下:1.使用基本命令格式mysql-u用戶名-p-h主機(jī)地址進(jìn)行連接,輸入用戶名和密碼後即可登錄;2.若需直接進(jìn)入指定數(shù)據(jù)庫,可在命令後加上數(shù)據(jù)庫名,如mysql-uroot-pmyproject;3.若端口非默認(rèn)3306,需添加-P參數(shù)指定端口號,如mysql-uroot-p-h192.168.1.100-P3307;此外,遇到密碼錯誤可重新輸入,連接失敗需檢查網(wǎng)絡(luò)、防火牆或權(quán)限設(shè)置,若缺少客戶端可在Linux上通過包管理器安裝mysql-client。掌握這些命令

為什麼索引可以提高M(jìn)ySQL查詢速度? 為什麼索引可以提高M(jìn)ySQL查詢速度? Jun 19, 2025 am 01:05 AM

IndexesinMySQLimprovequeryspeedbyenablingfasterdataretrieval.1.Theyreducedatascanned,allowingMySQLtoquicklylocaterelevantrowsinWHEREorORDERBYclauses,especiallyimportantforlargeorfrequentlyqueriedtables.2.Theyspeedupjoinsandsorting,makingJOINoperation

MySQL中的交易隔離級別是多少?默認(rèn)值是哪個? MySQL中的交易隔離級別是多少?默認(rèn)值是哪個? Jun 23, 2025 pm 03:05 PM

MySQL的默認(rèn)事務(wù)隔離級別是可重複讀(RepeatableRead),它通過MVCC和間隙鎖防止臟讀和不可重複讀,並在大多數(shù)情況下避免幻讀;其他主要級別包括讀未提交(ReadUncommitted),允許臟讀但性能最快,1.讀已提交(ReadCommitted)確保讀取已提交數(shù)據(jù)但可能遇到不可重複讀和幻讀,2.可重複讀(RepeatableRead)默認(rèn)級別,保證事務(wù)內(nèi)多次讀取結(jié)果一致,3.串行化(Serializable)最高級別,通過鎖阻止其他事務(wù)修改數(shù)據(jù),確保數(shù)據(jù)完整性但犧牲性能;可通過

如何將MySQL bin目錄添加到系統(tǒng)路徑 如何將MySQL bin目錄添加到系統(tǒng)路徑 Jul 01, 2025 am 01:39 AM

要將MySQL的bin目錄添加到系統(tǒng)PATH,需根據(jù)不同操作系統(tǒng)進(jìn)行配置。 1.Windows系統(tǒng):找到MySQL安裝目錄下的bin文件夾(默認(rèn)路徑通常為C:\ProgramFiles\MySQL\MySQLServerX.X\bin),右鍵“此電腦”→“屬性”→“高級系統(tǒng)設(shè)置”→“環(huán)境變量”,在“系統(tǒng)變量”中選中Path並編輯,新增MySQLbin路徑,保存後重啟命令提示符並輸入mysql--version驗證;2.macOS和Linux系統(tǒng):Bash用戶編輯~/.bashrc或~/.bash_

如何在Windows 11上安裝MySQL 如何在Windows 11上安裝MySQL Jun 29, 2025 am 01:47 AM

安裝MySQL在Windows11上的關(guān)鍵步驟如下:1.下載正確的版本,選擇Windows的MSI安裝包並確保系統(tǒng)為64位;2.安裝時選擇“Custom”模式,添加MySQLServer並設(shè)置合適的安裝路徑;3.運(yùn)行配置嚮導(dǎo),選擇“ServerComputer”配置類型,設(shè)置root密碼,選擇自動啟動方式;4.測試安裝成功後,若提示命令不可用,則將MySQL的bin目錄添加到系統(tǒng)PATH環(huán)境變量中。按照這些步驟操作即可順利完成安裝與配置。

重置MySQL Server的root密碼 重置MySQL Server的root密碼 Jul 03, 2025 am 02:32 AM

要重置MySQL的root密碼,請按以下步驟操作:1.停止MySQL服務(wù)器,使用sudosystemctlstopmysql或sudosystemctlstopmysqld;2.以--skip-grant-tables模式啟動MySQL,執(zhí)行sudomysqld--skip-grant-tables&;3.登錄MySQL並根據(jù)版本執(zhí)行相應(yīng)的SQL命令修改密碼,如FLUSHPRIVILEGES;ALTERUSER'root'@'localhost'IDENTIFIEDBY'your_new

在MySQL列和查詢中處理零值 在MySQL列和查詢中處理零值 Jul 05, 2025 am 02:46 AM

處理MySQL中的NULL值需注意:1.設(shè)計表時關(guān)鍵字段設(shè)為NOTNULL,可選字段允許NULL;2.查詢判斷必須用ISNULL或ISNOTNULL,不能用=或!=;3.可用IFNULL或COALESCE函數(shù)替換顯示默認(rèn)值;4.插入或更新時直接使用NULL值需謹(jǐn)慎,注意數(shù)據(jù)源和ORM框架處理方式。 NULL表示未知值,不等於任何值,包括自身,因此查詢、統(tǒng)計、連接表時要特別小心,避免漏數(shù)據(jù)或邏輯錯誤。合理使用函數(shù)和約束可以有效減少因NULL帶來的干擾。

See all articles