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

您的位置:首頁技術文章
文章詳情頁

mysql 如何動態修改復制過濾器

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

MySQL動態修改復制過濾器

說說今天遇到的問題吧,今天在處理一個業務方的需求,比較變態,我大概描述一下:

1、線上的阿里云rds上面有個游戲的日志庫,里面的表都是日表的形式,數據量比較大了,每次備份的時候,都會導致線上的rds報警,報警內容是IO資源占用過多。

2、這個rds上有一個本地的ECS只讀從庫,這個只讀從庫會實時同步線上的rds數據庫中的數據,這個只讀從庫供業務方查詢使用

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

場景就是這么個場景,DBA想要解決報警這個問題,業務方想要保證擁有完整的數據。請問,怎么解決?

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

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

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

3、使用replicate-ignore-table參數進行對于指定的表進行過濾。設置了這個參數,可以讓你過濾指定數據表的所有操作。我們看看官方文檔對這個參數的描述,給個鏈接: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,

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

這和我們的需求符合,也就是我們如果設置了要過濾的表,那么當我們進行刪除表操作的時候,從庫中不會對表進行刪除,就實現了我們想要的結果。測試一下這個功能吧:

首先我們創建數據庫test_ignore,然后在其中創建表:

主庫上操作:

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)

發現已經同步過來了。此時是處于主從同步狀態,如果現在我們在主庫上刪除表,那么從庫上的表一定會刪除,這不是我們想要的結果。

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

首先查看當前的復制狀態:

mysql 如何動態修改復制過濾器

雙Yes狀態,說明復制關系沒有問題

主庫進行操作:

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)

從庫上進行查看:

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

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

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

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

`主庫`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)

發現從庫并沒有同步主庫的表aaf,因為aaf也匹配了test_ignore.aa%這條規則。

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

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

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

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

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

mysql 如何動態修改復制過濾器

mysql 如何動態修改復制過濾器

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

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,想想也能理解,不停止復制直接修改復制的規則好像有點不妥,索性停止了整個復制,然后重新修改復制過濾器,妥了,成功執行,開啟復制,一套操作行云流水。

再來看看復制關系中的狀態:

mysql 如何動態修改復制過濾器

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

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

當然,除了這個方案之外,還有一些方案,例如:

如果業務容忍部分數據丟失,我們還可以使用關閉binlog---刪表---打開binlog的方式使得從庫不會同步主庫的drop操作;

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

這一系列的操作,其實不是從本質上解決問題,本質上還是業務設計的問題,日表中的打點日志太多,可以適當減少這些打點日志,對于打點日志,需要確定保留周期,過期的日志,需要及時清理,保證服務器的指標和性能。

以上就是mysql 如何動態修改復制過濾器的詳細內容,更多關于MySQL動態修改復制過濾器的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久影院资源站| 青青青免费在线视频| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美亚洲三级| 国产麻豆一区| 免费欧美一区| 噜噜噜躁狠狠躁狠狠精品视频 | 97精品在线| 国产日韩欧美中文在线| 亚洲乱码久久| 午夜性色一区二区三区免费视频| 蜜臀久久99精品久久一区二区| 国产欧美自拍| 国产探花在线精品一区二区| 深夜日韩欧美| 97精品资源在线观看| 日本不卡中文字幕| 日本强好片久久久久久aaa| 亚洲久久视频| 最新亚洲国产| 欧美日韩伊人| 国产精品一区三区在线观看| 国产精品一区二区精品| 欧美视频精品全部免费观看| 日本不卡一区二区三区| 欧美一区自拍| 岛国av免费在线观看| 久久精品资源| 99久久www免费| 亚洲一区中文| 日韩二区三区在线观看| 久久精品国产999大香线蕉| 91一区二区三区四区| 亚洲午夜黄色| 99视频一区| 日韩精品久久理论片| 美女视频网站久久| 亚洲小说欧美另类婷婷| 亚洲一区二区成人| 蜜臀av性久久久久蜜臀aⅴ流畅| 婷婷久久免费视频| 美女久久久久久| 国产精品成人一区二区不卡| 久久国产欧美| 丝袜脚交一区二区| 精品视频自拍| 色综合视频一区二区三区日韩 | 欧美日韩第一| 日本成人中文字幕| 亚洲不卡系列| 国产精品探花在线观看| 91精品久久久久久久久久不卡| 日韩一二三区在线观看| 日韩av有码| 日韩国产欧美在线视频| 韩日一区二区| 天堂久久av| 欧美日韩激情| 98精品久久久久久久| 一区二区三区网站| 999视频精品| 久久精品123| 国产伦精品一区二区三区千人斩 | 五月婷婷亚洲| 欧美丝袜一区| 国产精品一卡| 精品一区在线| 在线日韩电影| 电影91久久久| 日韩激情中文字幕| 先锋影音久久久| 美女久久久久| 精品国产精品国产偷麻豆| 亚洲精品中文字幕99999| 中文精品在线| 黄色亚洲精品| 黑丝一区二区三区| 日韩久久一区| 亚洲色图网站| 亚洲一区有码| 国产精品15p| 日韩成人精品一区二区| 国产色噜噜噜91在线精品| 亚洲天堂免费| 欧美久久亚洲| 成人在线丰满少妇av| 一级欧洲+日本+国产| 亚洲成人免费| 亚洲精品福利| 欧美亚洲二区| 国产精品www.| 国产精品亚洲二区| 美女久久99| 久久狠狠婷婷| 中文视频一区| 国产高清视频一区二区| xxxxx性欧美特大| 欧美日韩第一| 亚洲视频播放| 日韩一级欧洲| 日韩欧美三区| 久久av中文| 加勒比视频一区| 视频一区二区不卡| 亚洲黄色免费av| 亚洲精品免费观看| 久久99蜜桃| av资源中文在线| 99精品视频在线| 亚洲不卡视频| 日本午夜大片a在线观看| 九九在线精品| 欧美日韩18| 欧洲毛片在线视频免费观看| 成人精品国产亚洲| 亚洲aa在线| 久久人人88| 国产精品美女久久久久久不卡| 精品国产美女a久久9999| 久久精品国产www456c0m| 亚洲三级网站| 国产精品66| 在线亚洲一区| 给我免费播放日韩视频| 三级一区在线视频先锋| 在线精品亚洲欧美日韩国产| 日韩动漫一区| 日韩不卡一二三区| 日韩在线观看一区二区| 激情综合网五月| 午夜影院欧美| 91精品二区| 欧美激情亚洲| 综合欧美精品| 国产综合婷婷| 在线天堂中文资源最新版| 91福利精品在线观看| 日韩影院二区| 国产激情久久| 日韩精品一级| 男人操女人的视频在线观看欧美| 国产一区调教| 国产精品自拍区| 欧美日韩激情| 亚洲免费播放| 人人精品亚洲| 免费久久精品视频| 精品久久在线| 国产精品调教| 欧美激情综合| 日韩精品dvd| 国产一区观看| 美女亚洲一区| 欧美日韩国产免费观看| 三级欧美韩日大片在线看| 婷婷国产精品| 久久网站免费观看| 91精品一区二区三区综合在线爱 | 欧美黄色一区| 一区免费视频| 美女视频一区在线观看| 精品国产aⅴ| 成人久久久久| 日欧美一区二区| 国产在视频一区二区三区吞精| 成人福利视频| 午夜在线视频观看日韩17c| 亚洲日韩中文字幕一区| 日韩av一二三| 国内自拍视频一区二区三区| 亚洲高清二区| 国产亚洲欧美日韩精品一区二区三区| 精品久久久久中文字幕小说| 宅男在线一区| 国产精品成人自拍| 91成人精品| 国产精品网址| 日韩中文字幕麻豆| 久久成人高清| 色网在线免费观看| 日本v片在线高清不卡在线观看| 久久久久久亚洲精品美女| 热久久国产精品| 欧美在线网站| 中文在线免费视频| 日韩av一区二区在线影视| 亚洲第一区色| 最近高清中文在线字幕在线观看1| 综合色一区二区| 欧美日韩第一| 精品国产aⅴ| 亚洲二区免费| 麻豆视频久久| 色婷婷精品视频| 日韩精品国产欧美| 免费一级欧美在线观看视频| 国产一区成人| 国产麻豆久久| 麻豆精品久久| 国产精品腿扒开做爽爽爽挤奶网站|