婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > mysql 如何動態修改復制過濾器

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

熱門標簽:南通自動外呼系統軟件 信陽穩定外呼系統運營商 廣東人工電話機器人 日照旅游地圖標注 芒果電話機器人自動化 申請外呼電話線路 百度地圖圖標標注中心 石家莊電商外呼系統 湖南人工外呼系統多少錢

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都是形如這種的,所以針對這幾個表的操作一定不會同步到從庫了,我們測試一下:

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

雙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 :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 first

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

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

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

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

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

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

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

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

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

您可能感興趣的文章:
  • MySql主從復制機制全面解析
  • 磁盤寫滿導致MySQL復制失敗的解決方案
  • Mysql主從復制與讀寫分離圖文詳解
  • MySQL 復制表的方法
  • MySQL 8.0.23中復制架構從節點自動故障轉移的問題
  • MYSQL數據庫GTID實現主從復制實現(超級方便)
  • MySql主從復制實現原理及配置
  • 淺析MySQL的WriteSet并行復制
  • MySQL主從復制原理以及需要注意的地方
  • 淺析MySQL并行復制
  • MySQL復制問題的三個參數分析

標簽:天津 呼和浩特 牡丹江 阿里 沈陽 公主嶺 惠州 合肥

巨人網絡通訊聲明:本文標題《mysql 如何動態修改復制過濾器》,本文關鍵詞  mysql,如何,動態,修改,復制,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mysql 如何動態修改復制過濾器》相關的同類信息!
  • 本頁收集關于mysql 如何動態修改復制過濾器的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    在线电影院国产精品| 成人午夜视频免费看| 激情综合网天天干| 亚洲www啪成人一区二区麻豆| 成人国产精品免费网站| 亚洲电影视频在线| 69av一区二区三区| 91色婷婷久久久久合中文| 精品一区二区三区久久久| 亚洲香肠在线观看| 国产午夜亚洲精品羞羞网站| 欧美日韩国产综合一区二区三区| 成人av在线资源| 国产经典欧美精品| 激情综合五月天| 免费精品视频在线| 午夜欧美2019年伦理| 亚洲曰韩产成在线| 一区二区三区视频在线看| 国产精品青草综合久久久久99| 欧美va亚洲va香蕉在线| 欧美一区二区三区视频免费播放 | 国产精品麻豆视频| 久久久久亚洲蜜桃| 久久看人人爽人人| 国产欧美一区二区三区沐欲| 中文字幕欧美激情| 国产精品久久久久毛片软件| 国产精品无遮挡| 国产精品白丝在线| 亚洲免费伊人电影| 日韩中文字幕亚洲一区二区va在线| 亚洲高清免费一级二级三级| 亚洲电影中文字幕在线观看| 午夜精品免费在线| 久久99日本精品| 高清免费成人av| www.亚洲色图.com| 在线精品亚洲一区二区不卡| 免费成人av在线| 欧美伦理影视网| 91在线码无精品| 国产在线视频一区二区三区| 亚洲综合av网| 国产精品久久久久久户外露出| 国产不卡在线播放| 国内精品在线播放| 91亚洲国产成人精品一区二三| 色天使色偷偷av一区二区| 日本一区二区三区国色天香 | 91社区在线播放| 久久66热re国产| 午夜精品久久久久久久99水蜜桃| 日韩欧美一二区| 在线视频一区二区免费| 久久99深爱久久99精品| 夜夜嗨av一区二区三区网页| 国产精品乱人伦中文| 国产98色在线|日韩| 国产成人综合在线播放| 欧美在线观看一区| 亚洲精品在线观看视频| 中文字幕日韩精品一区| 日韩极品在线观看| 99精品偷自拍| 精品国产乱码久久久久久蜜臀| 亚洲欧美国产77777| 国产一区欧美二区| 欧美色图激情小说| 欧美国产一区视频在线观看| 亚洲精品高清在线| 懂色av一区二区夜夜嗨| 欧美肥妇bbw| 亚洲三级在线观看| 国产成人在线观看| 欧美一级国产精品| 一区二区三区欧美在线观看| 国内欧美视频一区二区 | av一区二区不卡| 久久一区二区视频| 琪琪一区二区三区| 欧美日韩中文精品| 17c精品麻豆一区二区免费| 六月婷婷色综合| 欧美日韩精品高清| 一区二区三区小说| 成人免费看的视频| 久久久蜜桃精品| 久久成人免费网站| 欧美日韩亚洲高清一区二区| 一区二区三区在线观看动漫| 99久久亚洲一区二区三区青草 | 亚洲欧美日韩国产综合| 国产精品一区二区在线观看不卡| 欧美成人a∨高清免费观看| 日本成人在线电影网| 欧美日韩美女一区二区| 亚洲一区二区三区三| 色哟哟一区二区三区| 欧美国产在线观看| 成人午夜激情影院| 中文字幕日本不卡| 波多野结衣精品在线| 国产色产综合产在线视频| 国产在线观看免费一区| 久久久99免费| 成人污污视频在线观看| 国产精品久久久久久久久久久免费看 | 欧美在线观看视频一区二区| 亚洲激情欧美激情| 在线精品视频免费播放| 一区二区三区在线视频观看| 99久久99久久免费精品蜜臀| 亚洲精品日韩综合观看成人91| 成人免费黄色在线| 成人免费在线视频观看| 色欧美日韩亚洲| 国产性色一区二区| 色婷婷av久久久久久久| 亚洲电影在线免费观看| 日韩一区和二区| 日韩精品一区二区三区在线观看 | 国产91精品久久久久久久网曝门| 欧美伊人精品成人久久综合97| 精品少妇一区二区三区在线视频| 亚洲线精品一区二区三区八戒| 99久久er热在这里只有精品15| 国产无人区一区二区三区| 亚洲国产乱码最新视频| 国产91精品精华液一区二区三区 | 欧美国产一区二区在线观看| 麻豆91免费看| 欧美一区二区三区喷汁尤物| 同产精品九九九| 欧美一区二区三区四区在线观看| 亚洲成人免费在线观看| 91福利精品视频| 一区二区成人在线视频| 97精品久久久午夜一区二区三区 | 亚洲一区精品在线| 99久久精品免费看| 亚洲欧美综合另类在线卡通| 成人黄色软件下载| 国产精品久久久久久亚洲伦| 国产成人自拍在线| 欧洲一区二区三区免费视频| 国产精品久久网站| 人禽交欧美网站| 欧美天天综合网| 亚洲成人动漫精品| 制服丝袜亚洲播放| 亚洲永久精品国产| 欧洲一区二区三区在线| 亚洲欧美一区二区三区国产精品 | 亚洲成年人网站在线观看| 欧美日韩一区不卡| 日日夜夜精品视频天天综合网| 欧美影院精品一区| 精品剧情v国产在线观看在线| 91在线看国产| 国产麻豆成人精品| 17c精品麻豆一区二区免费| 不卡的看片网站| 麻豆成人av在线| 日韩精品一二三四| 亚洲女子a中天字幕| 精品成人a区在线观看| 欧美一区二区三区电影| 欧美中文字幕一区二区三区| 99国产精品一区| 99久久婷婷国产综合精品电影| 国产精品白丝av| 狠狠色丁香婷婷综合久久片| 精品影视av免费| 久久99国产精品成人| 九九视频精品免费| 激情亚洲综合在线| 国产综合色视频| 国产真实乱偷精品视频免| 激情综合色综合久久综合| 国模娜娜一区二区三区| 国产美女精品一区二区三区| 国产很黄免费观看久久| 国产精品亚洲成人| 99这里只有精品| 在线视频国内自拍亚洲视频| 欧美色欧美亚洲另类二区| 欧美日韩黄色一区二区| 日韩三级在线观看| 国产亚洲欧美日韩日本| 日韩理论片中文av| 日韩中文欧美在线| 国产精品综合网| 在线观看日产精品| 色哟哟一区二区在线观看| 亚洲视频一区二区在线| 蜜桃久久久久久久| 亚洲6080在线| 精品亚洲porn| 夫妻av一区二区|