日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

mysql 如何動態(tài)修改復(fù)制過濾器

瀏覽:161日期:2023-10-09 11:55:36

MySQL動態(tài)修改復(fù)制過濾器

說說今天遇到的問題吧,今天在處理一個業(yè)務(wù)方的需求,比較變態(tài),我大概描述一下:

1、線上的阿里云rds上面有個游戲的日志庫,里面的表都是日表的形式,數(shù)據(jù)量比較大了,每次備份的時候,都會導(dǎo)致線上的rds報(bào)警,報(bào)警內(nèi)容是IO資源占用過多。

2、這個rds上有一個本地的ECS只讀從庫,這個只讀從庫會實(shí)時同步線上的rds數(shù)據(jù)庫中的數(shù)據(jù),這個只讀從庫供業(yè)務(wù)方查詢使用

3、業(yè)務(wù)方說這些數(shù)據(jù)都還有用,只讀從庫上的數(shù)據(jù)必須有,線上rds上的數(shù)據(jù)可以刪除,保留兩個星期即可。

場景就是這么個場景,DBA想要解決報(bào)警這個問題,業(yè)務(wù)方想要保證擁有完整的數(shù)據(jù)。請問,怎么解決?

當(dāng)時看到這個問題,我想罵人,這需求一看就不合理,哪兒有刪除一個庫,另外一個庫上還保留的道理,況且都是些日志數(shù)據(jù),不直接搞個冷備份,然后刪除線上,搞這么一出干啥啊。但是啊,怎么說也沒有緩和的余地,于是就開始思考這個問題應(yīng)該怎么解決。我想到的解決辦法有以下幾個:

1、擴(kuò)容,提升性能。數(shù)據(jù)量大,擴(kuò)磁盤唄,IO使用率高,提升性能么,這是最直接的解決辦法,也是最貴的解決辦法,首先被砍掉。

2、先備份再刪除再還原。rds主庫上提前備份日表數(shù)據(jù),然后刪除數(shù)據(jù),此時從庫會同步刪除數(shù)據(jù),然后再將第一步備份的數(shù)據(jù)還原到從庫上。這個辦法從可行性上來講是可以的,因?yàn)楸WC了沒有數(shù)據(jù)丟失。但是操作起來比較麻煩,手續(xù)太多,不夠方便。

3、使用replicate-ignore-table參數(shù)進(jìn)行對于指定的表進(jìn)行過濾。設(shè)置了這個參數(shù),可以讓你過濾指定數(shù)據(jù)表的所有操作。我們看看官方文檔對這個參數(shù)的描述,給個鏈接:https://dev.mysql.com/doc/refman/5.7/en/replication-options-slave.html#option_mysqld_replicate-wild-ignore-table

描述如下:

Creates a replication filter which keeps the slave thread from replicating a statement in which any table matches the given wildcard pattern. To specify more than one table to ignore, use this option multiple times,

上面的意思是你可以使用這個參數(shù)創(chuàng)建一個過濾器,從而過濾掉匹配你制定的規(guī)則的特定表的操作(聽著很繞口),就是說你可以制定過濾規(guī)則,加入規(guī)則中制定了表a,那么表a的操作就不會同步到從庫中了。

這和我們的需求符合,也就是我們?nèi)绻O(shè)置了要過濾的表,那么當(dāng)我們進(jìn)行刪除表操作的時候,從庫中不會對表進(jìn)行刪除,就實(shí)現(xiàn)了我們想要的結(jié)果。測試一下這個功能吧:

首先我們創(chuàng)建數(shù)據(jù)庫test_ignore,然后在其中創(chuàng)建表:

主庫上操作:

mysql :test_ignore >>show tables;Empty set (0.00 sec)mysql :test_ignore >>create table aaa (id int not null);Query OK, 0 rows affected (0.19 sec)mysql :test_ignore >>create table aab (id int not null); Query OK, 0 rows affected (0.01 sec)mysql :test_ignore >>create table aac (id int not null); Query OK, 0 rows affected (0.00 sec)mysql :test_ignore >>create table aad (id int not null); Query OK, 0 rows affected (0.01 sec)mysql :test_ignore >>create table aae (id int not null); Query OK, 0 rows affected (0.01 sec)

從庫上查看:

mysql :test_ignore >>show tables;+-----------------------+| Tables_in_test_ignore |+-----------------------+| aaa || aab || aac || aad || aae |+-----------------------+5 rows in set (0.00 sec)

發(fā)現(xiàn)已經(jīng)同步過來了。此時是處于主從同步狀態(tài),如果現(xiàn)在我們在主庫上刪除表,那么從庫上的表一定會刪除,這不是我們想要的結(jié)果。

很顯然,接下來的一步是配置replicate-wild-ignore-table這個參數(shù)了,一般情況下,我們需要通過停止從庫的服務(wù)進(jìn)行my.cnf文件的配置,如果我們要配置多個表,則需要在my.cnf文件中寫多條通配的記錄。例如,在本例子中,需要配置該參數(shù)的值為test_ignore.aa%,其中%代表通配符,也就是說,test_ignore數(shù)據(jù)庫中形如aa%這種格式的表操作都會被過濾掉。而我們創(chuàng)建的表aaa、aab、aac、aad、aae都是形如這種的,所以針對這幾個表的操作一定不會同步到從庫了,我們測試一下:

首先查看當(dāng)前的復(fù)制狀態(tài):

mysql 如何動態(tài)修改復(fù)制過濾器

雙Yes狀態(tài),說明復(fù)制關(guān)系沒有問題

主庫進(jìn)行操作:

mysql :test_ignore >>drop table aaa;Query OK, 0 rows affected (0.01 sec)mysql :test_ignore >>drop table aab;Query OK, 0 rows affected (0.00 sec)

從庫上進(jìn)行查看:

mysql :test_ignore >>show tables;+-----------------------+| Tables_in_test_ignore |+-----------------------+| aaa || aab || aac || aad || aae |+-----------------------+5 rows in set (0.00 sec)

從庫上的表還在,說明主庫上的操作沒有被同步到從庫,我們配置的參數(shù)

replicate-wild-ignore-table=test_ignore.aa%

起作用了。此時,如果我們在主庫上創(chuàng)建一個表:

`主庫`mysql :test_ignore >>create table aaf(id int);Query OK, 0 rows affected (0.00 sec)`從庫`mysql :test_ignore >>show tables;+-----------------------+| Tables_in_test_ignore |+-----------------------+| aaa || aab || aac || aad || aae |+-----------------------+5 rows in set (0.00 sec)

發(fā)現(xiàn)從庫并沒有同步主庫的表aaf,因?yàn)閍af也匹配了test_ignore.aa%這條規(guī)則。

利用這個特性,我們能夠很好的解決這個業(yè)務(wù)場景,也就是主庫刪除,從庫保留數(shù)據(jù)。但是,這里要說但是了,這個方法有一個比較嚴(yán)重的問題,就是每次都需要重啟從庫,如果我們需要配置第二條規(guī)則,第三條規(guī)則,則需要重啟從庫2次,3次,這個過程中,從庫對于業(yè)務(wù)方是不可見的,如果無法訪問,很可能造成程序報(bào)錯,這是我們不能忍受的。

這個過程肯定是要解決的,怎么解決呢?能不能找到不停機(jī)就能修改復(fù)制過濾器的方法?找找官方文檔。

果然,停機(jī)是不可能停機(jī)的,這輩子都不可能停機(jī)。官方文檔中有這么一句話:

You can also create such a filter by issuing a CHANGE REPLICATION FILTER REPLICATE_WILD_IGNORE_TABLE statement.

我去,這是個啥語句,表示從來沒有用過,可以通過在線變更復(fù)制過濾器的方法來對過濾器進(jìn)行修改,看看官方文檔中的介紹:

mysql 如何動態(tài)修改復(fù)制過濾器

mysql 如何動態(tài)修改復(fù)制過濾器

看到了一個神奇的語句,趕緊來試試:

mysql :test_ignore >>change replication filter replicate_wild_ignore_table=(’test_ig%.aa%’);ERROR 3017 (HY000): This operation cannot be performed with a running slave sql thread; run STOP SLAVE SQL_THREAD firstmysql :test_ignore >>stop slave;Query OK, 0 rows affected (0.00 sec)mysql :test_ignore >>change replication filter replicate_wild_ignore_table=(’test_ig%.aa%’);Query OK, 0 rows affected (0.00 sec)mysql :test_ignore >>start slave;Query OK, 0 rows affected (0.01 sec)

直接使用,提示需要stop slave sql_thread,想想也能理解,不停止復(fù)制直接修改復(fù)制的規(guī)則好像有點(diǎn)不妥,索性停止了整個復(fù)制,然后重新修改復(fù)制過濾器,妥了,成功執(zhí)行,開啟復(fù)制,一套操作行云流水。

再來看看復(fù)制關(guān)系中的狀態(tài):

mysql 如何動態(tài)修改復(fù)制過濾器

忽略的表規(guī)則已經(jīng)變成了test_ig%.aa%,也就是說,以test_ig開頭的數(shù)據(jù)庫中以aa開頭的表的操作,都不會被同步到從庫,包括對表的alter和drop以及create操作。

但這里,方案就出來了,我們知道,日表一般是YYYYMMDD這種形式的,我們只要過濾YYYYMM%這種格式的日表,然后在主庫上對它進(jìn)行刪除,這個操作將不會被同步到從庫,那么這個問題就可以順利解決了。

當(dāng)然,除了這個方案之外,還有一些方案,例如:

如果業(yè)務(wù)容忍部分?jǐn)?shù)據(jù)丟失,我們還可以使用關(guān)閉binlog---刪表---打開binlog的方式使得從庫不會同步主庫的drop操作;

線上所有的日表操作都配置成ignore,然后利用觸發(fā)器將日表中的更新同步到從庫中;

這一系列的操作,其實(shí)不是從本質(zhì)上解決問題,本質(zhì)上還是業(yè)務(wù)設(shè)計(jì)的問題,日表中的打點(diǎn)日志太多,可以適當(dāng)減少這些打點(diǎn)日志,對于打點(diǎn)日志,需要確定保留周期,過期的日志,需要及時清理,保證服務(wù)器的指標(biāo)和性能。

以上就是mysql 如何動態(tài)修改復(fù)制過濾器的詳細(xì)內(nèi)容,更多關(guān)于MySQL動態(tài)修改復(fù)制過濾器的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品精品| 亚洲成人av观看| 国产精品久久久久久久久久10秀| 欧美精品中文字幕亚洲专区| 国产视频亚洲| 久久精品国产99国产精品| 亚洲五月综合| 国产亚洲一级| 一区福利视频| 99成人在线视频| 你懂的国产精品| 欧美日韩国产观看视频| 高清一区二区| 国产不卡一区| 精品视频99| 成人午夜毛片| 麻豆精品视频在线观看免费| 国产日韩一区| 欧美日韩91| 久久97久久97精品免视看秋霞| 奇米777国产一区国产二区| 免费不卡在线视频| 亚洲欧美日韩精品一区二区 | 久久香蕉网站| 国产精品主播在线观看| 欧美日韩视频免费看| 一区在线免费| 久久不见久久见免费视频7| 日本不卡视频在线| 福利片在线一区二区 | 在线一区免费| 91午夜精品| 伊人精品一区| 99久久精品费精品国产| 亚洲激情精品| 国产精品大片| 国产精品一区亚洲| 裤袜国产欧美精品一区| 麻豆理论在线观看| 久久超级碰碰| 日韩激情视频网站| 欧美精品九九| 久久精品国产久精国产| 日韩美女国产精品| 久久不卡日韩美女| 精品欧美一区二区三区在线观看| 国产一区二区三区久久| 欧美羞羞视频| 尤物网精品视频| 五月婷婷六月综合| 日韩av影院| 久久精品国产99国产精品| 成人国产精品一区二区网站| 日韩高清中文字幕一区二区| 蜜臀av性久久久久蜜臀aⅴ流畅| 婷婷综合国产| 免费一区二区三区在线视频| 精品一区二区三区视频在线播放 | 日韩黄色大片| 香蕉精品999视频一区二区| 视频在线观看91| 欧美色综合网| www在线观看黄色| av亚洲一区二区三区| 日韩美女国产精品| 国产黄色一区| 在线亚洲人成| 宅男噜噜噜66国产日韩在线观看| 欧美日韩国产探花| 日韩精品久久久久久久软件91| 国产精品115| 红桃视频欧美| 欧美亚洲日本精品| 欧美一区网站| 99精品在线观看| 99热精品在线观看| 伊人久久亚洲热| 亚洲精品美女91| 激情91久久| 欧美a在线观看| 一本一道久久a久久| 欧美激情另类| 日本成人手机在线| 欧美特黄一区| 色偷偷偷在线视频播放| 国产精品一区二区av交换| 国产精品腿扒开做爽爽爽挤奶网站| 蜜桃一区二区三区在线| 日韩高清欧美| 日韩精品一区二区三区中文字幕| 特黄特色欧美大片| 国产专区精品| 国产欧美日韩一级| 国产伊人精品| 精品久久久久中文字幕小说| 日韩精品免费一区二区夜夜嗨| 日韩午夜av| 色爱综合av| 国产日韩电影| 精品一区二区三区四区五区| 国产三级一区| 97久久精品| 日韩高清一区| 综合亚洲色图| 视频一区二区国产| 一区在线观看| 黄色亚洲在线| 视频一区中文| 日韩精品影视| 欧洲亚洲一区二区三区| 国产一区二区三区国产精品| 国产精品视频一区二区三区| 国产日产高清欧美一区二区三区 | 国产aⅴ精品一区二区四区| 国产亚洲一卡2卡3卡4卡新区| 日韩综合小视频| 亚洲精品一级| 日精品一区二区三区| 免费在线观看不卡| 午夜国产欧美理论在线播放| 少妇精品导航| 欧美一区二区三区高清视频| 久久三级福利| 欧美丝袜一区| 亚洲激情二区| 麻豆亚洲精品| 自拍自偷一区二区三区| 亚洲午夜免费| 天堂久久av| **爰片久久毛片| 国产精品亚洲人成在99www| 国产亚洲精品精品国产亚洲综合| 国产欧美日韩精品一区二区免费 | 日韩精品1区2区3区| 亚洲免费专区| 亚洲精品护士| 亚洲a级精品| 国产乱人伦精品一区| 国产一区二区精品福利地址| 亚洲三级毛片| 亚洲网址在线观看| 日韩中文字幕av电影| 日韩中文字幕一区二区高清99| 日韩在线成人| 精品一区二区三区中文字幕| 精品一区二区三区四区五区| 在线亚洲一区| 中文视频一区| 欧美日韩一区自拍| 久久爱www成人| 97在线精品| 五月精品视频| 亚洲狼人精品一区二区三区| 综合一区av| 国产精品v亚洲精品v日韩精品| 福利在线免费视频| 日本欧美不卡| 国精品一区二区三区| 亚洲精品九九| 亚洲欧美日本国产专区一区| 亚洲一级淫片| 国产欧美日韩免费观看| 福利一区视频| 日韩午夜av| 日韩高清一区二区| 久久精品国内一区二区三区| 999视频精品| 综合亚洲色图| 欧美精品成人| 国产一区二区三区自拍| 日韩欧美在线精品| 久久69成人| 亚洲美洲欧洲综合国产一区| 欧美亚洲综合视频| 91精品一区二区三区综合| 巨乳诱惑日韩免费av| 国产极品嫩模在线观看91精品| 久久精品亚洲欧美日韩精品中文字幕| 蜜桃视频一区二区| 国产精品一站二站| 999久久久91| 国产精品丝袜在线播放| 99视频精品全部免费在线视频| 日本免费一区二区视频| 神马午夜在线视频| 日本一不卡视频| 99久久精品网站| 欧美精品影院| 欧美日韩国产免费观看| 欧美经典一区| 久久国产高清| 亚洲精品**中文毛片| 一二三区精品| 色老板在线视频一区二区| 欧美中文高清| 亚洲欧美日韩高清在线| 免费一区二区三区在线视频| 蜜桃久久av| 偷拍精品精品一区二区三区| 欧美日本三区|