Springboot系列 --- 利用Binlog和Kafka實(shí)時(shí)同步mysql數(shù)據(jù)到Elasticsearch(一) - 開啟Binlog日志

目錄

1欢揖、利用Binlog和Kafka實(shí)時(shí)同步mysql數(shù)據(jù)到Elasticsearch(一) - 開啟Binlog日志
2怒详、利用Binlog和Kafka實(shí)時(shí)同步mysql數(shù)據(jù)到Elasticsearch(二) - 安裝并運(yùn)行Kafka
3、利用Binlog和Kafka實(shí)時(shí)同步mysql數(shù)據(jù)到Elasticsearch(三) - Binlog日志生產(chǎn)消息到Kafka
4废赞、利用Binlog和Kafka實(shí)時(shí)同步mysql數(shù)據(jù)到Elasticsearch(四) - 消費(fèi)Kafka消息同步數(shù)據(jù)到ES


前言

- 項(xiàng)目模塊

BinlogMiddleware

1复颈、binlog中間件傅瞻,負(fù)責(zé)解析binlog脉执,把變動(dòng)的數(shù)據(jù)以json形式發(fā)送到kafka隊(duì)列。

KafkaMiddleware

2戒劫、kafka中間件半夷,負(fù)責(zé)消費(fèi)kafka隊(duì)列中的Message,把數(shù)據(jù)寫入Elasticsearch中迅细。

- 基礎(chǔ)服務(wù)

(1)Mysql
(2)Kafka(用于存放mysql變動(dòng)消息巫橄,存放于Kafka隊(duì)列)
(3)Elasticsearch

- 項(xiàng)目源碼

碼云:https://gitee.com/OrgXxxx/SyncMysqlToElasticsearch

1、開啟mysql的binlog

(1)binlog簡介

binlog,即二進(jìn)制日志,它記錄了數(shù)據(jù)庫上的所有改變茵典,并以二進(jìn)制的形式保存在磁盤中湘换;
它可以用來查看數(shù)據(jù)庫的變更歷史、數(shù)據(jù)庫增量備份和恢復(fù)统阿、Mysql的復(fù)制(主從數(shù)據(jù)庫的復(fù)制)。

(2)Binary Log記錄方式

Row Level

Binary Log會(huì)記錄成每一行數(shù)據(jù)被修改的形式,然后在Slave端再對(duì)相同的數(shù)據(jù)進(jìn)行修改赂苗。
如果修改了表的結(jié)構(gòu)独榴,那么binlog日志記錄的是重新創(chuàng)建表,在插入字段结澄、update等操作語句哥谷,而不是的alter的動(dòng)作。
優(yōu)點(diǎn):在Row Level模式下麻献,Binnary Log可以不記錄執(zhí)行的Query語句的上下文相關(guān)信息们妥,只要記錄哪一行修改了,修改成什么樣子勉吻。Row Level會(huì)詳細(xì)的記錄下每一行數(shù)據(jù)的修改細(xì)節(jié)监婶,而且不會(huì)出現(xiàn)某個(gè)特定情況下的存儲(chǔ)過程,或Function餐曼,以及Trigger的調(diào)用和觸發(fā)無法被正確復(fù)制問題压储。
缺點(diǎn):產(chǎn)生大量的日志內(nèi)容。

Statment Level

每一條會(huì)修改的SQL語句都會(huì)記錄到Master的Binnary中源譬。Slave端在復(fù)制的時(shí)候集惋,SQL線程會(huì)解析成和原來Master端執(zhí)行過相同的SQL語句,并再次執(zhí)行踩娘。
優(yōu)點(diǎn):首先刮刑,解決了Row Level下的缺點(diǎn)喉祭,不須要記錄每一行的數(shù)據(jù)變化,減少了Binnary Log日志量雷绢,節(jié)約了IO成本泛烙,提高了性能。
缺點(diǎn):由于它是記錄的執(zhí)行語句翘紊,為了讓這些語句在Slave端也能正確執(zhí)行蔽氨。那么它還必須記錄每條語句在執(zhí)行時(shí)的一些相關(guān)信息,即上下文信息帆疟,以保證所有語句在Slave端被執(zhí)行的時(shí)候能夠得到和在Master端執(zhí)行時(shí)相同的結(jié)果鹉究。另外,由于MySQL發(fā)展比較快踪宠,很多新功能不斷加入自赔,使得MySQL復(fù)制遇到了不小的挑戰(zhàn),復(fù)制時(shí)設(shè)計(jì)的內(nèi)容岳父在柳琢,越容易出bug绍妨。在Statement Level下,目前已發(fā)現(xiàn)不少的情況下會(huì)造成MySQL的復(fù)制問題柬脸。主要是在修改數(shù)據(jù)使用了某些特定的函數(shù)貨功能后他去,出現(xiàn),比如:Sleep()函數(shù)在有些版本中就不能正確的復(fù)制肖粮,在存儲(chǔ)過程中使用了last_insert_id()函數(shù)孤页,可能會(huì)使Slave和Master的到不一致的ID,等等涩馆。

Mixed Level

在Mixed模式下行施,MySQL會(huì)根據(jù)執(zhí)行的每一條具體的SQL語句來區(qū)分對(duì)待記錄的日志形式,也就是在Statement和Row之間選擇一種魂那。除了MySQL認(rèn)為通過Statement方式可能造成復(fù)制過程中Master和Slave之間產(chǎn)生不一致數(shù)據(jù)蛾号。(如特殊Procedure和Funtion的使用,UUID()函數(shù)的使用等特殊情況)時(shí)涯雅,它會(huì)選擇ROW的模式來記錄變更之外鲜结,都會(huì)使用Statement方式。
ps:在后續(xù)開發(fā)中將使用Row格式

(3)開啟mysql的binlog

a.修改my.cnf配置
[mysqld]
log-bin=mysql-bin  # 開啟binlog
binlog-format=ROW  # 設(shè)置Binary Log記錄方式為Row
server_id=1 # 記住id 后續(xù)開發(fā)會(huì)使用
b.重啟mysql
mysql.server restart
c.查看開啟狀態(tài)

輸入 show variables like 'log_bin'; 查看binlog開啟狀態(tài)活逆。如下圖所示精刷。


查看開啟狀態(tài)

輸入 show variables like 'binlog_format'; 查看Binary Log記錄方式。如下圖所示蔗候。


查看Binary Log記錄方式
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末怒允,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子锈遥,更是在濱河造成了極大的恐慌纫事,老刑警劉巖勘畔,帶你破解...
    沈念sama閱讀 206,378評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異丽惶,居然都是意外死亡炫七,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門钾唬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來万哪,“玉大人,你說我怎么就攤上這事抡秆∪榔裕” “怎么了?”我有些...
    開封第一講書人閱讀 152,702評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵琅轧,是天一觀的道長。 經(jīng)常有香客問我踊挠,道長乍桂,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,259評(píng)論 1 279
  • 正文 為了忘掉前任效床,我火速辦了婚禮睹酌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘剩檀。我一直安慰自己憋沿,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評(píng)論 5 371
  • 文/花漫 我一把揭開白布沪猴。 她就那樣靜靜地躺著辐啄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪运嗜。 梳的紋絲不亂的頭發(fā)上壶辜,一...
    開封第一講書人閱讀 49,036評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音担租,去河邊找鬼砸民。 笑死,一個(gè)胖子當(dāng)著我的面吹牛奋救,可吹牛的內(nèi)容都是我干的岭参。 我是一名探鬼主播,決...
    沈念sama閱讀 38,349評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼尝艘,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼演侯!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起利耍,我...
    開封第一講書人閱讀 36,979評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤蚌本,失蹤者是張志新(化名)和其女友劉穎盔粹,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體程癌,經(jīng)...
    沈念sama閱讀 43,469評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡舷嗡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了嵌莉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片进萄。...
    茶點(diǎn)故事閱讀 38,059評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖锐峭,靈堂內(nèi)的尸體忽然破棺而出中鼠,到底是詐尸還是另有隱情,我是刑警寧澤沿癞,帶...
    沈念sama閱讀 33,703評(píng)論 4 323
  • 正文 年R本政府宣布援雇,位于F島的核電站,受9級(jí)特大地震影響椎扬,放射性物質(zhì)發(fā)生泄漏惫搏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評(píng)論 3 307
  • 文/蒙蒙 一蚕涤、第九天 我趴在偏房一處隱蔽的房頂上張望筐赔。 院中可真熱鬧,春花似錦揖铜、人聲如沸茴丰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贿肩。三九已至,卻和暖如春失仁,著一層夾襖步出監(jiān)牢的瞬間尸曼,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國打工萄焦, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留控轿,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,501評(píng)論 2 354
  • 正文 我出身青樓拂封,卻偏偏與公主長得像茬射,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子冒签,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容