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

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

MySQL 發(fā)生同步延遲時Seconds_Behind_Master還為0的原因

瀏覽:34日期:2023-10-01 14:59:56
目錄問題描述原理簡析問題分析拓展一下總結(jié)一下問題描述

用戶在主庫上執(zhí)行了一個 alter 操作,持續(xù)約一小時。操作完成之后,從庫發(fā)現(xiàn)存在同步延遲,但是監(jiān)控圖表中的 Seconds_Behind_Master 指標(biāo)顯示為 0,且 binlog 的延遲距離在不斷上升。

原理簡析

既然是分析延遲時間,那么自然先從延遲的計算方式開始入手。為了方便起見,此處引用官方版本 5.7.31 的源代碼進行閱讀。找到計算延遲時間的代碼:

./sql/rpl_slave.ccbool show_slave_status_send_data(THD *thd, Master_info *mi, char* io_gtid_set_buffer, char* sql_gtid_set_buffer)......if ((mi->get_master_log_pos() == mi->rli->get_group_master_log_pos()) &&(!strcmp(mi->get_master_log_name(), mi->rli->get_group_master_log_name()))) { if (mi->slave_running == MYSQL_SLAVE_RUN_CONNECT)protocol->store(0LL); elseprotocol->store_null(); } else { long time_diff= ((long)(time(0) - mi->rli->last_master_timestamp) - mi->clock_diff_with_master); protocol->store((longlong)(mi->rli->last_master_timestamp ? max(0L, time_diff) : 0)); }......

從 time_diff 的計算方式來看,可以發(fā)現(xiàn)這個延遲基本上就是一個時間差值,然后再算上主從之間的時間差。不過 if 挺多的,所以借用源代碼文件中的注釋:

/* The pseudo code to compute Seconds_Behind_Master: if (SQL thread is running) { if (SQL thread processed all the available relay log) { if (IO thread is running) print 0; else print NULL; }else compute Seconds_Behind_Master; } else print NULL; */

可以知道,Seconds_Behind_Master的計算分為兩個部分:

SQL 線程正常,且回放完所有的 relaylog 時,如果 IO 線程正常,那么直接置 0。 SQL 線程正常,且回放完所有的 relaylog 時,如果 IO 線程不正常,那么直接置 NULL。 SQL 線程正常,且沒有回放完所有的 relaylog 時,計算延遲時間。

那么在最后計算延遲時間的時候,看看那幾個變量代表的意義:

time(0):當(dāng)前的時間戳,timestamp 格式的。 last_master_timestamp:這個 event 在主庫上執(zhí)行的時刻,timestamp 格式。 clock_diff_with_master:slave 和 master 的時間差,在 IO 線程啟動時獲取的。

由此可見,延遲計算的時候,實際上是以 slave 本地的時間來減掉回放的這個 event 在 master 執(zhí)行的時刻,再補償兩者之間的時間差,最后得到的一個數(shù)值。從邏輯上看是沒什么問題的,由于 time(0) 和 clock_diff_with_master 在大多數(shù)時候是沒有什么出問題的機會的,所以這次的問題,應(yīng)該是出在 last_master_timestamp 上了。

PS:雖說大部分時候沒問題,但是 time(0) 取的是本地時間,因此 slave 的本地時間有問題的話,這個最終的值也會出錯,不過不在本案例的問題討論范圍之內(nèi)了。

那么找一下執(zhí)行 event 的時候,計算last_master_timestamp的邏輯,結(jié)合注釋可以發(fā)現(xiàn)普通復(fù)制和并行復(fù)制用了不同的計算方式,第一個是普通的復(fù)制,計算時間點在執(zhí)行 event 之前:

./sql/rpl_slave.cc...... if (ev) { enum enum_slave_apply_event_and_update_pos_retval exec_res; ptr_ev= &ev; /* Even if we don’t execute this event, we keep the master timestamp, so that seconds behind master shows correct delta (there are events that are not replayed, so we keep falling behind). If it is an artificial event, or a relay log event (IO thread generated event) or ev->when is set to 0, or a FD from master, or a heartbeat event with server_id ’0’ then we don’t update the last_master_timestamp. In case of parallel execution last_master_timestamp is only updated when a job is taken out of GAQ. Thus when last_master_timestamp is 0 (which indicates that GAQ is empty, all slave workers are waiting for events from the Coordinator), we need to initialize it with a timestamp from the first event to be executed in parallel. */ if ((!rli->is_parallel_exec() || rli->last_master_timestamp == 0) && !(ev->is_artificial_event() || ev->is_relay_log_event() || (ev->common_header->when.tv_sec == 0) || ev->get_type_code() == binary_log::FORMAT_DESCRIPTION_EVENT || ev->server_id == 0)) { rli->last_master_timestamp= ev->common_header->when.tv_sec + (time_t) ev->exec_time; DBUG_ASSERT(rli->last_master_timestamp >= 0); }......

last_master_timestamp的值是取了 event 的開始時間并加上執(zhí)行時間,在 5.7 中有不少 event 是沒有執(zhí)行時間這個數(shù)值的,8.0 給很多 event 添加了這個數(shù)值,因此也算是升級 8.0 之后帶來的好處。

而并行復(fù)制的計算方式,參考如下這一段代碼:

./sql/rpl_slave.cc...... /* We need to ensure that this is never called at this point when cnt is zero. This value means that the checkpoint information will be completely reset. */ /* Update the rli->last_master_timestamp for reporting correct Seconds_behind_master. If GAQ is empty, set it to zero. Else, update it with the timestamp of the first job of the Slave_job_queue which was assigned in the Log_event::get_slave_worker() function. */ ts= rli->gaq->empty() ? 0 : reinterpret_cast<Slave_job_group*>(rli->gaq->head_queue())->ts; rli->reset_notified_checkpoint(cnt, ts, need_data_lock, true); /* end-of 'Coordinator::'commit_positions' */......

在 Coordinator 的 commit_positions 這個邏輯中,如果 gaq 隊列為空,那么last_master_timestamp直接置 0,否則會選擇 gaq 隊列的第一個 job 的時間戳。需要補充一點的是,這個計算并不是實時的,而是間歇性的,在計算邏輯前面,有如下的邏輯:

/* Currently, the checkpoint routine is being called by the SQL Thread. For that reason, this function is called call from appropriate points in the SQL Thread’s execution path and the elapsed time is calculated here to check if it is time to execute it. */ set_timespec_nsec(&curr_clock, 0); ulonglong diff= diff_timespec(&curr_clock, &rli->last_clock); if (!force && diff < period) { /* We do not need to execute the checkpoint now because the time elapsed is not enough. */ DBUG_RETURN(FALSE); }

即在這個 period 的時間間隔之內(nèi),會直接 return,并不會更新這個last_master_timestamp,所以有時候也會發(fā)現(xiàn)并行復(fù)制會時不時出現(xiàn) Seconds_Behind_Master 在數(shù)值上從 0 到 1 的變化。

而 gaq 隊列的操作,估計是類似于入棧退棧的操作,所以留在 gaq 的總是沒有執(zhí)行完的事務(wù),因此時間計算從一般場景的角度來看是沒問題。

問題分析

原理簡析中簡要闡述了整個計算的邏輯,那么回到這個問題本身,騰訊云數(shù)據(jù)庫 MySQL 默認(rèn)是開啟了并行復(fù)制的,因此會存在 gaq 隊列,而 alter 操作耗時非常的長,不論 alter 操作是否會被放在一組并行事務(wù)中執(zhí)行(大概率,DDL 永遠(yuǎn)是一個單獨的事務(wù)組),最終都會出現(xiàn) gaq 隊列持續(xù)為空,那么就會把last_master_timestamp置 0,而參考 Seconds_Behind_Master 的計算邏輯,最終的 time_diff 也會被置 0,因此 alter 操作結(jié)束前的延遲時間一直會是 0。而當(dāng) alter 操作執(zhí)行完之后,gaq 隊列會填充新的 event 和事務(wù),所以會出現(xiàn)延遲之前一直是 0,但是突然跳到非常高的現(xiàn)象。

拓展一下

對比普通復(fù)制和并行復(fù)制計算方式上的差異,可以知道以下幾個特點:

開啟并行復(fù)制之后,延遲時間會經(jīng)常性的在 0 和 1 之間跳變。 alter 操作,單個大事務(wù)等在并行復(fù)制的場景下容易導(dǎo)致延遲時間不準(zhǔn),而普通的復(fù)制方式不會。 由于主從時間差是在 IO 線程啟動時就計算好的,所以期間 slave 的時間出現(xiàn)偏差之后,延遲時間也會出現(xiàn)偏差。總結(jié)一下

嚴(yán)謹(jǐn)?shù)难舆t判斷,還是依靠 GTID 的差距和 binlog 的 position 差距會比較好,從 8.0 的 event 執(zhí)行時間變化來看,至少 Oracle 官方還是在認(rèn)真干活的,希望這些小毛病能盡快的修復(fù)吧。

以上就是MySQL 發(fā)生同步延遲時Seconds_Behind_Master還為0的原因的詳細(xì)內(nèi)容,更多關(guān)于MySQL 同步延遲Seconds_Behind_Master為0的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久免费影院| 精品久久国产一区| 亚洲高清激情| 成人va天堂| 日韩精品1区| 日韩欧美另类一区二区| 国产极品一区| 免费一区二区三区在线视频| 国产免费av一区二区三区| 日韩av中文在线观看| 91成人在线网站| 亚洲欧美网站在线观看| 久久蜜桃av| 在线视频精品| 亚洲精品福利| 91精品久久久久久久久久不卡| 日韩中文欧美在线| 国产videos久久| 捆绑调教日本一区二区三区| 在线天堂资源www在线污| 人在线成免费视频| 欧美日韩国产高清电影| 老司机精品视频在线播放| 国产免费av国片精品草莓男男| 国产99在线| 久久中文字幕导航| 国产美女高潮在线| 69堂精品视频在线播放| 久久久久久久久丰满| 精品72久久久久中文字幕| 麻豆精品新av中文字幕| 中文av在线全新| 五月天综合网站| 亚洲精品成人一区| 久久一区欧美| 久久人人97超碰国产公开结果| 国产精品激情电影| 国内精品麻豆美女在线播放视频| 亚洲18在线| 国产乱码精品一区二区亚洲| 国产精品一卡| 精品国模一区二区三区| 首页亚洲欧美制服丝腿| 国产精品nxnn| 婷婷亚洲五月| 国产日产高清欧美一区二区三区 | 美国三级日本三级久久99 | 超级白嫩亚洲国产第一| 91精品在线观看国产| 视频一区二区三区中文字幕| 激情综合亚洲| 亚洲精品日本| 日韩欧美二区| 鲁鲁在线中文| 国产视频一区在线观看一区免费| 99视频精品全国免费| 蜜臀av国产精品久久久久| 久久国产精品99国产| 国产精品三p一区二区| 久久久精品久久久久久96| 综合欧美亚洲| 日韩欧美中文| 日韩av中文字幕一区二区三区| 日本不卡一二三区黄网| 国产成人精品一区二区免费看京 | caoporn视频在线| 久久亚洲欧洲| 日韩久久视频| 欧美伊人影院| 欧美日韩中文字幕一区二区三区| 日韩精品影视| 国产亚洲欧美日韩精品一区二区三区 | 精精国产xxxx视频在线播放| 在线国产精品一区| 高潮一区二区| 国产日韩中文在线中文字幕 | 日韩成人在线看| 色爱av综合网| 日韩成人午夜精品| 91精品一区二区三区综合在线爱 | 国产精品2区| 久久电影一区| 免费污视频在线一区| 亚洲精品高潮| 国精品一区二区| 国产aⅴ精品一区二区三区久久| 国产自产自拍视频在线观看| 最新国产精品| 午夜国产一区二区| av在线资源| 国产精品天堂蜜av在线播放| 亚洲色图综合| 亚洲精品午夜av福利久久蜜桃| 亚洲免费婷婷| 中文字幕在线视频网站| 激情视频一区二区三区| 精品资源在线| 国产日产高清欧美一区二区三区| 97精品视频在线看| 欧美亚洲色图校园春色| 蜜臀久久99精品久久久久久9| **爰片久久毛片| 亚洲激情欧美| 久久在线免费| 亚洲欧美网站在线观看| 欧美成人高清| 久久久噜噜噜| 日韩精品dvd| 蜜桃免费网站一区二区三区| 九九精品调教| 97精品在线| 精品视频在线观看网站| 国产精品一国产精品| 国产欧美日韩精品一区二区免费 | 久久精品二区亚洲w码| 日韩av不卡一区二区| 亚洲精品少妇| 亚洲午夜天堂| 成人污污视频| 成人国产综合| 欧美xxxx中国| 国产一区二区三区探花| 精品一区二区男人吃奶 | 欧美日韩视频| 国产在线不卡| 亚洲先锋成人| 2023国产精品久久久精品双| 尤物tv在线精品| 国模 一区 二区 三区| 日韩在线观看不卡| 久久精品青草| 91久久亚洲| 免费国产亚洲视频| 日韩av一二三| 久久av综合| 久久精品国产久精国产爱| 成年男女免费视频网站不卡| 日韩久久精品| 亚洲精品a级片| 性色一区二区| 日欧美一区二区| 亚洲一级二级| 亚洲成人日韩| 伊人久久亚洲| 欧美有码在线| 激情久久99| 综合日韩av| 影音国产精品| 四虎8848精品成人免费网站| sm久久捆绑调教精品一区| 久久久久免费av| 久久不射网站| 欧美日韩亚洲一区在线观看| 麻豆91精品视频| 亚洲精品在线a| 久久精品99久久久| 精品美女视频 | 视频一区在线播放| 婷婷成人在线| 国产精品日本| 日本欧美不卡| 久久精品一区二区国产| 国产精品不卡| 午夜久久tv| 日本久久二区| 粉嫩av一区二区三区四区五区 | 婷婷激情综合| 日韩在线麻豆| 国产专区精品| 国产免费成人| 久久精品xxxxx| 黄色在线网站噜噜噜| 国产亚洲精品久久久久婷婷瑜伽| 国产精品伦理久久久久久| 欧美日韩一二| 日本免费在线视频不卡一不卡二| 久久大逼视频| 国产精品亚洲产品| 欧美久久天堂| 蜜桃久久久久久| 久久亚洲精品伦理| 久久av影院| 午夜亚洲福利在线老司机| 国产精品宾馆| 欧美激情 亚洲a∨综合| 欧美天堂视频| 亚洲精品裸体| 韩国久久久久久| 日韩欧美久久| 日本久久成人网| 久久中文视频| 日本午夜精品一区二区三区电影| 亚洲精品无吗| 福利一区二区三区视频在线观看| 成人日韩av| 国产一区二区三区四区| 99国产精品视频免费观看一公开| 亚洲作爱视频| 麻豆国产欧美日韩综合精品二区| 国产成人精品一区二区免费看京|