欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Mysql中讀寫分離過期后怎么解決-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)Mysql中讀寫分離過期后怎么解決,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

創(chuàng)新互聯(lián)是專業(yè)的阿巴嘎網(wǎng)站建設(shè)公司,阿巴嘎接單;提供成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行阿巴嘎網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊,希望更多企業(yè)前來合作!

mysql讀寫分離的坑

讀寫分離的主要目標(biāo)是分?jǐn)傊鲙斓膲毫?,由客戶端選擇后端數(shù)據(jù)庫進(jìn)行查詢。還有種架構(gòu)就是在MYSQL和客戶端之間有一個中間代理層proxy,客戶端之連接proxy,由proxy根據(jù)請求類型和上下文決定請求的分發(fā)路由。

  • 客戶端直連方案:因為少了一層proxy轉(zhuǎn)發(fā),所以查詢性能稍微好一點兒,并且整體架構(gòu)簡單,排查問題更方便。但是這種方案,由于要了解后端部署細(xì)節(jié),所以在出現(xiàn)主備切換、庫遷移等操作的時候,客戶端都會感知到,并且需要調(diào)整數(shù)據(jù)庫連接信息。
  • 帶proxy架構(gòu):對客戶端比較友好??蛻舳?amp;#63847;需要關(guān)注后端細(xì)節(jié),連接維護(hù)、后端信息維護(hù)等工作,都是由proxy完成的。但這樣的話,對后端維護(hù)團(tuán)隊的要求會更高。
     

無論使用哪種架構(gòu),由于主從可能存在延遲,客戶端執(zhí)行完一個更新事務(wù)后馬上發(fā)起查詢,如果查詢選擇的是從庫的話,就有可能讀到剛剛的事務(wù)更新之前的狀態(tài)。這種“在從庫上會讀到系統(tǒng)的一個過期狀態(tài)”的現(xiàn)象,我們暫且稱之為“過期讀”。

方案一:強制走主庫方案

將查詢請求分為兩類:

  • 對于必須要拿到最新結(jié)果的請求,強制將其發(fā)到主庫上。比如,在一個交易平臺上,賣家發(fā)布商品以后,馬上要返回主頁面,看商品是否發(fā)布成功。那么,這個請求需要拿到最新的結(jié)果,就必須走主庫。
  • 對于可以讀到舊數(shù)據(jù)的請求,才將其發(fā)到從庫上。在這個交易平臺上,買家來逛商鋪頁面,就算晚幾秒看到最新發(fā)布的商品,也是可以接受的。那么,這類請求就可以走從庫。這個方案的大問題在于會碰到所有查詢都不是“過期讀”的需求,比如金融類業(yè)務(wù),這樣就要放棄讀寫分離,所有的壓力都在主庫。采用以下方案。

方案二:Sleep方案

主庫更新后,讀從庫之前先sleep一下,類似執(zhí)行了select sleep(1)命令,這個方案的假設(shè)是,大多數(shù)情況下主備延遲在1秒之內(nèi),做一個sleep可以有很大概率拿到最新的數(shù)據(jù)。

以賣家發(fā)布商品為例,商品發(fā)布后,用Ajax直接把客戶端輸入的內(nèi)容作為“新的商品”顯示在頁面上,而不是真正地去數(shù)據(jù)庫做查詢。這樣,賣家就可以通過這個顯示,來確認(rèn)產(chǎn)品已經(jīng)發(fā)布成功了。等到賣家再刷新頁面,去查看商品的時候,其實已經(jīng)過了一段時間,也就達(dá)到了sleep的目的,進(jìn)而也就解決了過期讀的問題。

方案三:判斷主備無延遲方案:

第一種方法:先用show slave status結(jié)果里的seconds_behind_master參數(shù)的值,可以用來衡量主備延遲時間的長短。先判斷這個參數(shù)值是否為0,如果不為0,必須等到這個參數(shù)變?yōu)?才能執(zhí)行請求。

第二種方法:對比位點確保主備無延遲。

  • Master_Log_File和Read_Master_Log_Pos,表示的是讀到的主庫的最新位點;
  • Relay_Master_Log_File和Exec_Master_Log_Pos,表示的是備庫執(zhí)行的最新位點。

如果Master_Log_File和Relay_Master_Log_File、Read_Master_Log_Pos和Exec_Master_Log_Pos這兩組值完全相同,就表示接收到的日志已經(jīng)同步完成。

第三種方法:對比GTID(全局事物ID)確保主備無延遲

  • Auto_Position=1 ,表示這對主備關(guān)系使用了GTID協(xié)議。
  • Retrieved_Gtid_Set,是備庫收到的所有日志的GTID集合;
  • Executed_Gtid_Set,是備庫所有已經(jīng)執(zhí)行完成的GTID集合。

如果這兩個集合相同,表示備庫接收到的日志都已經(jīng)同步完成。

方案四:等主庫位點方案

select master_pos_wait(file, pos[, timeout]);

這條命令是在從庫執(zhí)行的 ,參數(shù)file和pos指的是主庫上的文件名和位置,timeout表示這個函數(shù)最多等待N秒。

  • 這個命令正常返回的結(jié)果是一個正整數(shù)M,表示從命令開始執(zhí)行,到應(yīng)用完file和pos表示的binlog位置,執(zhí)行了多少事務(wù)。
  • 如果備庫同步線程發(fā)生異常,則返回null
  • 如果等待超過N秒,就返回-1
  • 如果剛開始執(zhí)行就發(fā)現(xiàn)已經(jīng)執(zhí)行過了,則返回0

Mysql中讀寫分離過期后怎么解決

如圖:先執(zhí)行trx1,再執(zhí)行一個查詢請求的邏輯,要保證能夠查到正確的數(shù)據(jù),我們可以使用

這個邏輯

1. trx1事物更新完成后,馬上執(zhí)行show master status得到當(dāng)前主庫執(zhí)行到的File和Position;

2. 選定一個從庫執(zhí)行查詢語句;

3. 在從庫上執(zhí)行select master_pos_wait(File, Position, 1);

4. 如果返回值是>=0的正整數(shù),則在這個從庫執(zhí)行查詢語句;

5. 否則,到主庫執(zhí)行查詢語句。

這里我們假設(shè),這條select查詢最多在從庫上等待1秒。那么,如果1秒內(nèi)master_pos_wait返回
一個大于等于0的整數(shù),就確保了從庫上執(zhí)行的這個查詢結(jié)果一定包含了trx1的數(shù)據(jù)。

5到主庫執(zhí)行查詢語句,是這類方案常用的退化機(jī)制。因為從庫的延遲時間不可控,不能無
限等待,所以如果等待超時,就應(yīng)該放棄,然后到主庫去查。按照我們設(shè)定不允許過期讀的要求,就只有兩種選擇,一種是超時放棄,一種是轉(zhuǎn)到主庫查詢。

并發(fā)連接和并發(fā)查詢

innodb_thread_concurrency參數(shù)是控制innodb的并發(fā)線程上限。一旦超過這個數(shù)值,新請求就會進(jìn)入等待。

  • show processlist看到的幾千個連接,是值并發(fā)連接,而當(dāng)前正在執(zhí)行的語句,才是并發(fā)查詢。并發(fā)連接影響不大,只是會多占內(nèi)存,而并發(fā)查詢才是CPU殺手。
  • 在線程進(jìn)入鎖等待以后,并發(fā)線程的計數(shù)會建議,也就是等行鎖的線程是不算在并發(fā)查詢里的。因為所等待已經(jīng)不吃CPU了

關(guān)于Mysql中讀寫分離過期后怎么解決就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

文章題目:Mysql中讀寫分離過期后怎么解決-創(chuàng)新互聯(lián)
路徑分享:http://aaarwkj.com/article36/ccocsg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT域名注冊、自適應(yīng)網(wǎng)站網(wǎng)站設(shè)計、做網(wǎng)站、標(biāo)簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司
性激烈的欧美三级男同| 免费高清视频一区二区在线观看| 精品av一区二区在线| 91在线视频欧美国产| 视频精品一区二区在线观看| 丁香色婷婷国产精品视频| 97人妻精品一区二区三区六| 99热在线精品国产观看| 黄色国产欧美国产亚洲| 人妻精品久久一区二区三区| 国产农村妇女一区二区三区 | 先锋影音女同中文字幕| 亚洲av色国产精品色午含羞草| 日韩黄色免费在线观看| 亚洲中文字幕高清无二区| 日本加勒比一道本东京热| 国产91高清视频在线观看| 午夜情色视频在线观看| 日本待黄大片一区二区| 91国产精品视频在线| 亚洲综合日韩欧美一区二区三区| 亚洲精品国产中文字幕| 求个手机免费在线观看av网址| 不卡视频一区中文字幕| 国产真实精品对白又爽欧美| 国产亚洲精品女人久久久| 国产成人精品久久久亚洲| 国产女主播高清在线视频| 日韩性视频激情在线一区| 日韩人妻有码中文字幕| 国产日韩欧美亚洲一区二区| 久久精品一偷一偷国产| 亚洲美女高潮久久久久久久久 | 国产网爆热门精品一区二区| av二区不卡国产精品| 99热免费精品在线观看| 精品日韩电影在线观看| 很色很污无遮挡的网色污| 国产亚洲高清一区二区| 蜜桃臀内射一区二区三区| 精品爆白浆一区二区三区|