六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

MySQL中對于主從數據庫同步延遲的問題處理

[摘要]最近在做MySQL主從數據庫同步測試,發現了一些問題,其中主從同步延遲問題是其中之一,下面內容是從網上找到的一些講解,記錄下來以便自己學習;MySQL的主從同步是一個很成熟的架構,優點為:①在從服務...
最近在做MySQL主從數據庫同步測試,發現了一些問題,其中主從同步延遲問題是其中之一,下面內容是從網上找到的一些講解,記錄下來以便自己學習;

MySQL的主從同步是一個很成熟的架構,優點為:①在從服務器可以執行查詢工作(即我們常說的讀功能),降低主服務器壓力;②在從主服務器進行備份,避免備份期間影響主服務器服務;③當主服務器出現問題時,可以切換到從服務器。

相信大家對于這些好處已經非常了解了,在項目的部署中也采用這種方案。但是MySQL的主從同步一直有從庫延遲的問題,那么為什么會有這種問題。這種問題如何解決呢?

1. MySQL數據庫主從同步延遲原理。

2. MySQL數據庫主從同步延遲是怎么產生的。

3. MySQL數據庫主從同步延遲解決方案。

1. MySQL數據庫主從同步延遲原理。

答:談到MySQL數據庫主從同步延遲原理,得從mysql的數據庫主從復制原理說起,mysql的主從復制都是單線程的操作,主庫對所有DDL和DML產生binlog,binlog是順序寫,所以效率很高,slave的Slave_IO_Running線程到主庫取日志,效率很比較高,下一步,問題來了,slave的Slave_SQL_Running線程將主庫的DDL和DML操作在slave實施。DML和DDL的IO操作是隨即的,不是順序的,成本高很多,還可能可slave上的其他查詢產生lock爭用,由于Slave_SQL_Running也是單線程的,所以一個DDL卡主了,需要執行10分鐘,那么所有之后的DDL會等待這個DDL執行完才會繼續執行,這就導致了延時。有朋友會問:“主庫上那個相同的DDL也需要執行10分,為什么slave會延時?”,答案是master可以并發,Slave_SQL_Running線程卻不可以。

2. MySQL數據庫主從同步延遲是怎么產生的。

答:當主庫的TPS并發較高時,產生的DDL數量超過slave一個sql線程所能承受的范圍,那么延時就產生了,當然還有就是可能與slave的大型query語句產生了鎖等待。

3. MySQL數據庫主從同步延遲解決方案

答:最簡單的減少slave同步延時的方案就是在架構上做優化,盡量讓主庫的DDL快速執行。還有就是主庫是寫,對數據安全性較高,比如sync_binlog=1,innodb_flush_log_at_trx_commit = 1 之類的設置,而slave則不需要這么高的數據安全,完全可以講sync_binlog設置為0或者關閉binlog,innodb_flushlog也可以設置為0來提高sql的執行效率。另外就是使用比主庫更好的硬件設備作為slave。

mysql-5.6.3已經支持了多線程的主從復制。原理和丁奇的類似,丁奇的是以表做多線程,Oracle使用的是以數據庫(schema)為單位做多線程,不同的庫可以使用不同的復制線程。

sync_binlog=1

This makes MySQL synchronize the binary log’s contents to disk each time it commits a transaction

默認情況下,并不是每次寫入時都將binlog與硬盤同步。因此如果操作系統或機器(不僅僅是MySQL服務器)崩潰,有可能binlog中最后的語句丟 失了。要想防止這種情況,你可以使用sync_binlog全局變量(1是最安全的值,但也是最慢的),使binlog在每N次binlog寫入后與硬盤 同步。即使sync_binlog設置為1,出現崩潰時,也有可能表內容和binlog內容之間存在不一致性。如果使用InnoDB表,MySQL服務器 處理COMMIT語句,它將整個事務寫入binlog并將事務提交到InnoDB中。如果在兩次操作之間出現崩潰,重啟時,事務被InnoDB回滾,但仍 然存在binlog中。可以用--innodb-safe-binlog選項來增加InnoDB表內容和binlog之間的一致性。(注釋:在MySQL 5.1中不需要--innodb-safe-binlog;由于引入了XA事務支持,該選項作廢了),該選項可以提供更大程度的安全,使每個事務的 binlog(sync_binlog =1)和(默認情況為真)InnoDB日志與硬盤同步,該選項的效果是崩潰后重啟時,在滾回事務后,MySQL服務器從binlog剪切回滾的 InnoDB事務。這樣可以確保binlog反饋InnoDB表的確切數據等,并使從服務器保持與主服務器保持同步(不接收 回滾的語句)。

innodb_flush_log_at_trx_commit (這個很管用)

抱怨Innodb比MyISAM慢 100倍?那么你大概是忘了調整這個值。默認值1的意思是每一次事務提交或事務外的指令都需要把日志寫入(flush)硬盤,這是很費時的。特別是使用電 池供電緩存(Battery backed up cache)時。設成2對于很多運用,特別是從MyISAM表轉過來的是可以的,它的意思是不寫入硬盤而是寫入系統緩存。日志仍然會每秒flush到硬 盤,所以你一般不會丟失超過1-2秒的更新。設成0會更快一點,但安全方面比較差,即使MySQL掛了也可能會丟失事務的數據。而值2只會在整個操作系統 掛了時才可能丟數據。

以上就是MySQL中關于主從數據庫同步延遲的問題解決的詳細內容,更多請關注php中文網其它相關文章!


學習教程快速掌握從入門到精通的SQL知識。




主站蜘蛛池模板: 天天天天添天天拍天天谢 | 亚洲s色| 日日噜噜噜噜人人爽亚洲精品 | 综合九九| 丝袜美腿护士办公室在线观看 | 日本国产在线观看 | 日韩美女在线看免费观看 | 日韩在线 中文字幕 | 日韩精品 欧美 | 日韩高清在线免费观看 | 亚洲男人天堂影院 | 欧美一级啪啪 | 日本尤物精品视频在线看 | 亚洲国产成人精品区 | 青草久久精品亚洲综合专区 | 在线观看亚洲一区二区 | 色综合色狠狠天天久久婷婷基地 | 日本不卡一区二区三区视频 | 五月婷婷操| 色天使亚洲综合在线观看 | 午夜视频在线播放 | 永久网站 | 婷婷六月丁| 桃花视频全免费观看韩国 | 日日弄| 日本特黄特色免费大片 | 一级做a爱片性色毛片武则天五则 | 亚洲成a人片在线观看中文 亚洲成a人片在线观看精品 | 亚洲欧美日本视频 | 欧美线人一区二区三区 | 亚洲人成在线播放网站 | 日本又黄又硬又粗好爽视频免费 | 天天做天天爱天天爽综合区 | 在线视频日韩精品 | 午夜视频在线观看182tv | 五月激情婷婷丁香 | 青青青青青国产免费手机看视频 | 欧美一区二区三区黄色 | 无码精品一区二区三区免费视频 | 日本黄页网站在线观看 | 亚洲h网站 |