日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

如何基于LSM-tree架构实现一写多读

發(fā)布時間:2024/8/23 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何基于LSM-tree架构实现一写多读 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

簡介:傳統(tǒng)MySQL基于binlog復(fù)制的主備架構(gòu)有它的局限性,包括存儲空間有限,備份恢復(fù)慢,主備復(fù)制延遲等問題,為了解決用戶對于云上RDS(X-Engine)大容量存儲,以及彈性伸縮的訴求,PolarDB推出了歷史庫(基于X-Engine引擎的一寫多讀)產(chǎn)品,支持物理復(fù)制,提供一寫多讀的能力,目前已經(jīng)在阿里云官網(wǎng)售賣。本文主要闡述如何基于LSM-tree結(jié)構(gòu)的存儲引擎實(shí)現(xiàn)數(shù)據(jù)庫的一寫多讀能力。

作者 | 雁閑
來源 | 阿里技術(shù)公眾號

一 前言

PolarDB是阿里巴巴自研的新一代云原生關(guān)系型數(shù)據(jù)庫,在存儲計(jì)算分離架構(gòu)下,利用了軟硬件結(jié)合的優(yōu)勢,為用戶提供具備極致彈性、海量存儲、高性能、低成本的數(shù)據(jù)庫服務(wù)。X-Engine是阿里巴巴自研的新一代存儲引擎,作為AliSQL的核心引擎之一已廣泛用于阿里巴巴集團(tuán)核心業(yè)務(wù),包括交易歷史庫,釘釘歷史庫,圖片空間等。X-Engine基于LSM-tree架構(gòu),其核心特征是數(shù)據(jù)以追加寫方式寫入,高壓縮低成本,適用于寫多讀少,有低成本訴求的業(yè)務(wù)場景。傳統(tǒng)MySQL基于binlog復(fù)制的主備架構(gòu)有它的局限性,包括存儲空間有限,備份恢復(fù)慢,主備復(fù)制延遲等問題,為了解決用戶對于云上RDS(X-Engine)大容量存儲,以及彈性伸縮的訴求,PolarDB推出了歷史庫(基于X-Engine引擎的一寫多讀)產(chǎn)品,支持物理復(fù)制,提供一寫多讀的能力,目前已經(jīng)在阿里云官網(wǎng)售賣。本文主要闡述如何基于LSM-tree結(jié)構(gòu)的存儲引擎實(shí)現(xiàn)數(shù)據(jù)庫的一寫多讀能力。

二 LSM-tree數(shù)據(jù)庫引擎

LSM-Tree全稱是Log Structured Merge Tree,是一種分層,有序,面向磁盤設(shè)計(jì)的數(shù)據(jù)結(jié)構(gòu),其核心思想是利用磁盤批量的順序?qū)懸入S機(jī)寫性能高的特點(diǎn),將所有更新操作都轉(zhuǎn)化為追加寫方式,提升寫入吞吐。LSM-tree類的存儲引擎最早源于Google三駕馬車之一的BigTable的存儲引擎以及它的開源實(shí)現(xiàn)LevelDB。LSM-tree存儲引擎有幾個特點(diǎn),首先增量數(shù)據(jù)像日志一樣,通過追加方式寫入,順序落盤;其次,數(shù)據(jù)按照key來進(jìn)行有序組織,這樣在內(nèi)存和磁盤中會形成一顆顆小的“有序樹”;最后,各個“有序樹”可以進(jìn)行歸并,將內(nèi)存中的增量數(shù)據(jù)遷移到磁盤上,磁盤上的多個“有序樹”可以進(jìn)行歸并,優(yōu)化樹的形狀,整個LSM-tree是一個有序的索引組織結(jié)構(gòu)。

在云原生數(shù)據(jù)庫時代,一寫多讀技術(shù)已被廣泛應(yīng)用于生產(chǎn)環(huán)境中,主要云產(chǎn)商都有其標(biāo)桿產(chǎn)品,典型代表包括亞馬遜的Aurora,阿里云的PolarDB以及微軟云的Socrates。它的核心思想是計(jì)算存儲分離,將有狀態(tài)的數(shù)據(jù)和日志下推到分布式存儲,計(jì)算節(jié)點(diǎn)無狀態(tài),多個計(jì)算節(jié)點(diǎn)共享一份數(shù)據(jù),數(shù)據(jù)庫可以低成本快速擴(kuò)展讀性能。Aurora是這個領(lǐng)域的開山鼻祖,實(shí)現(xiàn)了業(yè)內(nèi)第一個一寫多讀的數(shù)據(jù)庫,計(jì)算節(jié)點(diǎn)Scale up,存儲節(jié)點(diǎn)Scale out,并將日志模塊下推到存儲層,計(jì)算節(jié)點(diǎn)之間,計(jì)算與存儲節(jié)點(diǎn)之間傳輸redo日志,計(jì)算節(jié)點(diǎn)基于Quorum協(xié)議寫多副本保證可靠性,存儲層提供多版本頁服務(wù)。PolarDB與Aurora類似,也采用了存儲計(jì)算分離架構(gòu),與Aurora相比,PolarDB它自己的特色,存儲基座是一個通用的分布式文件系統(tǒng),大量采用OS-bypass和zero-copy技術(shù),存儲的多副本一致性由ParallelRaft協(xié)議保證。PolarDB計(jì)算節(jié)點(diǎn)與存儲節(jié)點(diǎn)同時傳輸數(shù)據(jù)頁和redo日志,計(jì)算節(jié)點(diǎn)與計(jì)算節(jié)點(diǎn)之間只傳遞位點(diǎn)信息。與Aurora的“日志即數(shù)據(jù)庫”理念一樣,Socrates的節(jié)點(diǎn)之間只傳輸redo日志,也實(shí)現(xiàn)了多版本頁服務(wù),它的特點(diǎn)是將數(shù)據(jù)庫存儲層的持久性與可用性分開,抽象出一套日志服務(wù)。整個數(shù)據(jù)庫分為3層,一層計(jì)算服務(wù),一層page server服務(wù)和一層日志服務(wù),這樣設(shè)計(jì)的好處是可以分層進(jìn)行優(yōu)化,提供更靈活和細(xì)粒度的控制。

雖然Aurora,PolarDB和Socrates在設(shè)計(jì)上各有特點(diǎn),但它們都共同踐行了存儲計(jì)算分離思想,數(shù)據(jù)庫層面提供一寫多讀的能力。深入到存儲引擎這一層來說,這幾個產(chǎn)品都是基于B+tree的存儲引擎,如果基于LSM-tree存儲引擎來做呢?LSM-tree有它自己的特點(diǎn),追加順序?qū)?#xff0c;數(shù)據(jù)分層存儲,磁盤上數(shù)據(jù)塊只讀更有利于壓縮。X-Engine引擎云上產(chǎn)品RDS(X-Engine)已經(jīng)充分發(fā)揮了LSM-tree高壓縮低成本特點(diǎn),同樣的數(shù)據(jù)量,存儲空間只占到RDS(InnoDB)的1/3甚至更少,RDS(X-Engine)傳統(tǒng)的主備架構(gòu),依然面臨著主備復(fù)制延遲大,備份恢復(fù)慢等問題。基于LSM-tree引擎實(shí)現(xiàn)一寫多讀,不僅計(jì)算資源和存儲資源解耦,多個節(jié)點(diǎn)共享一份數(shù)據(jù)還能進(jìn)一步壓縮存儲成本。

基于LSM-tree引擎實(shí)現(xiàn)一寫多讀面臨著與B+tree引擎不一樣的技術(shù)挑戰(zhàn),首先是存儲引擎日志不一樣,LSM-tree引擎是雙日志流,需要解決雙日志流的物理復(fù)制問題;其次是數(shù)據(jù)組織方式不一樣,LSM-tree引擎采用分層存儲,追加寫入新數(shù)據(jù),需要解決多個計(jì)算節(jié)點(diǎn)一致性物理快照以及Compation問題。最后,作為數(shù)據(jù)庫引擎,還需要解決一寫多讀模式下DDL的物理復(fù)制問題。同時,為了產(chǎn)品化,充分發(fā)揮B+tree引擎和LSM-tree引擎的各自優(yōu)勢,還面臨著新的挑戰(zhàn),即如何在一個數(shù)據(jù)庫產(chǎn)品中同時實(shí)現(xiàn)兩個存儲引擎(InnoDB,X-Engine)的一寫多讀。

三 LSM-tree引擎一寫多讀的關(guān)鍵技術(shù)

1 PolarDB整體架構(gòu)

PolarDB支持X-Engine引擎后,X-Engine引擎與InnoDB引擎仍然獨(dú)立存在。兩個引擎各自接收寫入請求,數(shù)據(jù)和日志均存儲在底層的分布式存儲上,其中idb文件表示的是InnoDB的數(shù)據(jù)文件,sst文件表示的是X-Engine的數(shù)據(jù)文件。這里最主要的點(diǎn)在于InnoDB與XEngine共享一份redo日志,X-Engine寫入時,將wal日志嵌入到InnoDB的redo中,Replica節(jié)點(diǎn)和Standby節(jié)點(diǎn)在解析redo日志后,分發(fā)給InnoDB引擎和XEngine引擎分別回放進(jìn)行同步。

PolarDB(X-Engine)架構(gòu)圖

X-Engine引擎架構(gòu)

X-Engine引擎采用LSM-tree結(jié)構(gòu),數(shù)據(jù)以追加寫的方式寫入內(nèi)存,并周期性物化到磁盤上,內(nèi)存中數(shù)據(jù)以memtable形式存在,包括一個活躍的active memtable和多個靜態(tài)的immutable。磁盤上數(shù)據(jù)分層存儲,總共包括3層,L0,L1和L2,每一層數(shù)據(jù)按塊有序組織。X-Engine最小空間分配單位是一個extent,默認(rèn)是2M,每個extent包含若干個block,默認(rèn)是16k。數(shù)據(jù)記錄緊湊存儲在block中,由于追加寫特點(diǎn),磁盤上的數(shù)據(jù)塊都是只讀的,因此X-Engine引擎可以默認(rèn)對block進(jìn)行壓縮,另外block中的記錄還會進(jìn)行前綴編碼,綜合這些使得X-Engine的存儲空間相對于InnoDB引擎只有1/3,部分場景(比如圖片空間)甚至能壓縮到1/7。有利就有弊,追加寫帶來了寫入優(yōu)勢,對于歷史版本數(shù)據(jù)需要通過Compaction任務(wù)來進(jìn)行回收。有關(guān)X-Engine的核心技術(shù)可以參考發(fā)表在Sigmod19的論文,《X-Engine: An Optimized Storage Engine for Large-scale E-commerce Transaction Processing》

X-Engine整體架構(gòu)

2 物理復(fù)制架構(gòu)

物理復(fù)制的核心是通過引擎自身的日志來完成復(fù)制,避免寫額外的日志帶來的成本和性能損失。MySQL原生的復(fù)制架構(gòu)是通過binlog日志進(jìn)行復(fù)制,寫事務(wù)需要同時寫引擎日志和binlog日志,這帶來的問題是一方面單個事務(wù)在關(guān)鍵寫路徑上需要寫兩份日志,寫性能受制于二階段提交和binlog的串行寫入,另一方面binlog復(fù)制是邏輯復(fù)制,復(fù)制延遲問題也使得復(fù)制架構(gòu)的高可用,以及只讀庫的讀服務(wù)能力大打折扣,尤其是在做DDL操作時,這個延遲會進(jìn)一步放大。

在InnoDB中有redo和undo兩種日志,undo日志可以理解為一種特殊的“data”,所以實(shí)際上InnoDB的所有操作都能通過redo日志來保證持久性。因此,在進(jìn)行復(fù)制時,只需要在主從節(jié)點(diǎn)復(fù)制redo日志即可。X-Engine引擎包含兩種日志,一種是wal日志(WriteAheadLog),用于記錄前臺的事務(wù)的操作;另一種是Slog(StorageLog),用于記錄LSM-tree形狀變化的操作,主要指Compaction/Flush等。wal日志保證了前臺事務(wù)的原子性和持久性,Slog則保證了X-Engine內(nèi)部LSM-tree形狀變化的原子性和持久性,這兩個日志缺一不可,都需要復(fù)制同步。

共享存儲下的物理復(fù)制

Primary-Replica物理復(fù)制架構(gòu)

LSM-tree引擎一寫多讀的能力是對PolarDB進(jìn)行功能增強(qiáng),體現(xiàn)在架構(gòu)層面就是充分利用已有的復(fù)制鏈路,包括Primary->Replica傳遞日志信息鏈路和Replica->Primary傳遞協(xié)同控制信息鏈路。InnoDB事務(wù)由若干個mtr(Mini-Transaction)組成,寫入redo日志的最小單位是mtr。我們在Innodb的redo日志新增一種日志類型用于表示X-Engine日志,將X-Engine的事務(wù)內(nèi)容作為一個mtr事務(wù)寫入到redo日志中,這樣Innodb的redo和X-Engine的wal日志能共享一條復(fù)制鏈路。由于Primary和Replica共享一份日志和數(shù)據(jù),Dump_thread只需要傳遞位點(diǎn)信息,由Replica根據(jù)位點(diǎn)信息去讀redo日志。Replica解析日志,根據(jù)日志類型來分發(fā)日志給不同的回放引擎,這種架構(gòu)使得所有復(fù)制框架與之前的復(fù)制保持一致,只需要新增解析、分發(fā)X-Engine日志邏輯,新增X-Engine的回放引擎,充分與InnoDB引擎解耦。

由于LSM-tree追加寫特點(diǎn),內(nèi)存memtable中數(shù)據(jù)會周期性的Flush到磁盤,為了保證Primary和Replica讀到一致性物理視圖,Primary和Replica需要同步SwitchMemtable,需要新增一條SwitchMemtable控制日志來協(xié)調(diào)。redo日志持久化后,Primary通過日志方式將位點(diǎn)信息主動推送給Replica,以便Replica及時回放最新的日志,減少同步延遲。對于Slog日志,既可以采用類似于redo的日志方式來主動“push”方式來同步位點(diǎn),也可以采用Replica主動“pull”的方式來同步。SLog是后臺日志,相對于前臺事務(wù)回放實(shí)時性要求不高,不必要將redo位點(diǎn)和SLog位點(diǎn)都放在一條復(fù)制鏈路增加復(fù)雜性,所以采用了Replica的“pull”的方式來同步SLog。

災(zāi)備集群間的物理復(fù)制

Primary-Standby物理復(fù)制架構(gòu)

與共享集群復(fù)制不同,災(zāi)備集群有獨(dú)立一份存儲,Primary—>Standby需要傳遞完整的redo日志。Stanby與Replica區(qū)別在于日志來源不同,Replica從共享存儲上獲取日志,Standy從復(fù)制鏈路獲取日志,其它解析和回放路徑是一樣的。是否將Slog日志作為redo日志一部分傳遞給Standby是一個問題,Slog日志由Flush/Compaction動作產(chǎn)生,記錄的是LSM-tree形狀的物理變化。如果也通過redo日志鏈路同步給Standby,會帶來一些復(fù)雜性,一方面是X-Engine內(nèi)部寫日志的方式需要改動,需要新增新增文件操作相關(guān)的物理日志來確保主從物理結(jié)構(gòu)一致,故障恢復(fù)的邏輯也需要適配;另一方面,Slog作為后臺任務(wù)的操作日志,意味著復(fù)制鏈路上的所有角色都需要同構(gòu);如果放棄同構(gòu),那么Standy節(jié)點(diǎn)可能會觸發(fā)Flush/Compaction任務(wù)寫日志,這與物理復(fù)制中,只允許Primary寫日志是相違背的。實(shí)際上,Slog同步寫入到redo log中不是必須的,因?yàn)镾log是后臺日志,這個動作不及時回放并不影響數(shù)據(jù)視圖的正確性,因此,復(fù)制鏈路上只包含redo日志(X-Engine wal日志和InnoDB redo日志),Standby自己控制Flush/Compaction產(chǎn)生Slog日志,這樣Standby也不必與Primary節(jié)點(diǎn)物理同構(gòu),整個架構(gòu)與現(xiàn)有體系相匹配,同時也更加靈活。

3 并行物理復(fù)制加速

X-Engine的事務(wù)包括兩個階段,第一個階段是讀寫階段,這個階段事務(wù)操作數(shù)據(jù)會緩存在事務(wù)上下文中,第二階段是提交階段,將操作數(shù)據(jù)寫入到redo日志持久化,隨后寫到memtable中供讀操作訪問。對于Standby/Replica節(jié)點(diǎn)而言,回放過程與Primary節(jié)點(diǎn)類似,從redo中解析到事務(wù)日志,然后將事務(wù)回放到memtable中。事務(wù)之間不存在沖突,通過Sequence版本號來確定可見性。并行回放的粒度是事務(wù),需要處理的一個關(guān)鍵問題就是可見性問題。事務(wù)串行回放時,Sequence版本號都是連續(xù)遞增的,事務(wù)可見性不存在問題。在并行回放場景下,我們?nèi)匀恍枰P?#xff0c;通過引入“滑動窗口”機(jī)制,只有連續(xù)一段沒有空洞的Sequence才能推進(jìn)全局的Sequence版本號,這個全局Sequence用于讀操作獲取快照。

并行復(fù)制框架

一寫多讀架構(gòu)下,為了保證同一數(shù)據(jù)庫實(shí)例的Primary、Replica、Standby三個角色的內(nèi)存鏡像完全一致,新增了一種SwitchMemtableLog,該Log Record在RW的switch_memtable過程中產(chǎn)生,因此RO、Standby不再主動觸發(fā)switch_memtable操作,而是通過從RW上同步SwitchMemtableLog進(jìn)行switch_memtable。SwitchMemtable操作是一個全局的屏障點(diǎn),以防止當(dāng)前可寫memtable在插入過程中switch從而導(dǎo)致數(shù)據(jù)錯亂。另外,對于2PC事務(wù),并發(fā)控制也需要做適配。一個2PC事務(wù)除了數(shù)據(jù)本身的日志,還包括BeginPrepare、EndPrepare、Commit、Rollback四類日志,寫入過程中保證BeginPrepare和EndPrepare寫入到一個WriteBatch中并順序落盤,因此可以保證同一個事務(wù)的Prepare日志都會被解析到一個ReplayTask中。在并行回放過程中,由于無法保證Commit或Rollback日志一定后于Prepare日志被回放,因此如果Commit、Rollback日志先于Prepare日志被回放,那么在全局的recovered_transaction_map中插入一個key對xid的空事務(wù),對應(yīng)的事務(wù)狀態(tài)為Commit或Rollback;隨后Prepare日志完成回放時,如果發(fā)現(xiàn)recovered_transaction_map中已經(jīng)存在對應(yīng)的事務(wù),那么可以根據(jù)事務(wù)的狀態(tài)來決定直接提交事務(wù)還是丟棄事務(wù)。

對于B+Tree的物理復(fù)制,LSM-tree的物理復(fù)制并不是真正的“物理”復(fù)制。因?yàn)锽+Tree傳遞的redo的內(nèi)容是數(shù)據(jù)頁面的修改,而LSM-tree傳遞的redo內(nèi)容是KeyValue值。這帶來的結(jié)果是,B+tree物理復(fù)制可以基于數(shù)據(jù)頁粒度做并發(fā)回放,而LSM-tree的物理復(fù)制是基于事務(wù)粒度的并發(fā)回放。B+tree并發(fā)回放有它自身的復(fù)雜性,比如需要解決系統(tǒng)頁回放與普通數(shù)據(jù)頁回放先后順序問題,并且還需要解決同一個mtr中多個數(shù)據(jù)頁并發(fā)回放可能導(dǎo)致的物理視圖不一致問題。LSM-tree需要解決多個節(jié)點(diǎn)在同樣位置SwitchMemtable,以及2PC事務(wù)回放等問題。

4 MVCC(多版本并發(fā)控制)

物理復(fù)制技術(shù)解決了數(shù)據(jù)同步的問題,為存儲計(jì)算分離打下了基礎(chǔ)。為了實(shí)現(xiàn)彈性,動態(tài)升降配,增刪只讀節(jié)點(diǎn)的能力,需要只讀節(jié)點(diǎn)具備一致性讀的能力,另外RW節(jié)點(diǎn)和RO節(jié)點(diǎn)共享一份數(shù)據(jù),歷史版本回收也是必需要考慮的問題。

一致性讀

X-Engine提供快照讀的能力,通過多版本機(jī)制來實(shí)現(xiàn)讀寫不互斥效果。從上述的X-Engine架構(gòu)圖可以看到,X-Engine的數(shù)據(jù)實(shí)際上包括了內(nèi)存和磁盤兩部分,不同于InnoDB引擎內(nèi)存中page是磁盤上page的緩存,X-Engine中內(nèi)存數(shù)據(jù)與磁盤數(shù)據(jù)完全異構(gòu),一份“快照”需要對應(yīng)的是內(nèi)存+磁盤數(shù)據(jù)。X-Engine采用追加寫方式,新數(shù)據(jù)進(jìn)來會產(chǎn)生新的memtable,后臺任務(wù)做flush/compaction任務(wù)也會產(chǎn)生新的extent。那么如何獲取一致性視圖呢?X-Engine內(nèi)部實(shí)際上是通過MetaSnapshot+Snapshot來管理,首先每個MetaSnapshot對應(yīng)一組memtable和L0,L1, L2的extents,這樣在物理上確定了數(shù)據(jù)范圍,然后通過Snapshot來處理行級版本的可見性,這里的Snapshot實(shí)際上就是一個事務(wù)提交序列號Sequence。不同于InnoDB事務(wù)編號采用開始序,需要通過活躍事務(wù)視圖來判斷記錄的可見性;X-Engine事務(wù)采用提交序,每條記錄有一個唯一遞增序列號Sequence,判斷行級版本的可見性只需要比較Sequence即可。在一寫多讀的模式下,Replica節(jié)點(diǎn)與Primary節(jié)點(diǎn)共享一份磁盤數(shù)據(jù),而磁盤數(shù)據(jù)是有內(nèi)存中數(shù)據(jù)定期dump出來的,因此需要保證Primary和Replica節(jié)點(diǎn)有相同的切memtable位點(diǎn),從而保證數(shù)據(jù)視圖的一致性。

一寫多讀下的Compaction

在一寫多讀場景下,Replica可以通過類似于Primary的快照機(jī)制來實(shí)現(xiàn)快照讀,需要處理的問題是歷史版本回收問題。歷史版本的回收,依賴于Compaction任務(wù)來完成,這里的回收包括兩部分,一部分MetaSnapshot的回收,主要確認(rèn)哪些memtable和extents可以被物理回收掉,另一部分是行級多版本回收,這里主要是確認(rèn)哪些歷史版本行可以被回收掉。對于MetaSnapshot的回收,Primary會收集所有Replica節(jié)點(diǎn)上的最小不再使用的MetaSnapshot版本號,X-Engine引擎的每個索引都是一個LSM-tree,因此匯報MetaSnaphot版本號是索引粒度的。Primary收集完MetaSnapshot版本號,計(jì)算最小可以回收的MetaSnapshot進(jìn)行資源回收操作,回收操作以Slog日志的方式同步給Replica節(jié)點(diǎn)。Replica節(jié)點(diǎn)在回放日志進(jìn)行資源回收時,需要將內(nèi)存和磁盤資源分開,內(nèi)存資源在各個節(jié)點(diǎn)是獨(dú)立的,磁盤資源是共享的,因此Replica節(jié)點(diǎn)的內(nèi)存資源可以獨(dú)立釋放,而磁盤資源則統(tǒng)一由Primary節(jié)點(diǎn)來釋放。對于行級多版本的回收,同樣需要由Primary節(jié)點(diǎn)收集所有Replica節(jié)點(diǎn)最小序列號Sequence,由Primary節(jié)點(diǎn)通過Compaction任務(wù)來消除。這塊匯報鏈路復(fù)用PolarDB的ACK鏈路,只是新增了X-Engine的匯報信息。

5 DDL的物理復(fù)制如何實(shí)現(xiàn)

物理復(fù)制相對于邏輯復(fù)制一個關(guān)鍵優(yōu)勢在于DDL,對于DDL而言,邏輯復(fù)制可以簡單理解為復(fù)制SQL語句,DDL在從庫上會重新再執(zhí)行一遍。邏輯復(fù)制對于比較重的DDL操作,比如Alter table影響非常大,一個Alter變更操作在主庫執(zhí)行需要半小時,那么復(fù)制到從庫也需要再執(zhí)行半小時,那么主從延遲最大可能就會是1個小時,這個延遲對只讀庫提供讀服務(wù)產(chǎn)生嚴(yán)重影響。

Server層復(fù)制

DDL操作同時涉及到Server層和引擎層,包括字典,緩存以及數(shù)據(jù)。最基礎(chǔ)的DDL操作,比如

Create/Drop操作,在一寫多讀架構(gòu)下,要考慮數(shù)據(jù)與數(shù)據(jù)字典,數(shù)據(jù)與字典緩存一致性等問題。一寫多讀的基礎(chǔ)是物理復(fù)制,物理復(fù)制日志只在引擎層流動,不涉及到Server層,因此需要新增日志來解決DDL操作導(dǎo)致的不一致問題。我們新增了meta信息變更的日志,并作為redo日志的一部分同步給從節(jié)點(diǎn),這個meta信息變更日志主要包括兩部分內(nèi)容,一個是字典同步,主要是同步MDL鎖,確保Primary/Replica節(jié)點(diǎn)字典一致;另一個是字典緩存同步,Replica上的內(nèi)存是獨(dú)立的,Server層緩存的字典信息也需要更新,因此要新增日志來處理,比如Drop Table/Drop db/Upate function/Upate precedure等操作。另外,還需要同步失效Replica的QueryCache,避免使用錯誤的查詢緩存。

引擎層復(fù)制

X-Engine引擎與InnoDB引擎一樣是索引組織表,在X-Engine內(nèi)部,每個索引都是一個LSM-tree結(jié)構(gòu),內(nèi)部稱為Subtable,所有寫入都是在Subtable中進(jìn)行,Subtable的生命周期與DDL操作緊密相關(guān)。用戶發(fā)起建表動作會產(chǎn)生Subtable,這個是物理LSM-tree結(jié)構(gòu)的載體,然后才能有后續(xù)的DML操作;同樣的,用戶發(fā)起刪表動作后,所有這個Subtable的DML操作都應(yīng)該執(zhí)行完畢。Create/Drop Table操作涉及到索引結(jié)構(gòu)的產(chǎn)生和消亡,會同時產(chǎn)生redo控制日志和SLog日志,在回放時,需要解決redo控制日志和SLog日志回放的時序問題。這里我們將對應(yīng)Subtable的redo日志的LSN位點(diǎn)持久化到SLog中,作為一個同步位點(diǎn),Replica回放時,兩個回放鏈路做協(xié)調(diào)即可,redo日志記錄的是前臺操作,Slog記錄的是后臺操作,因此兩個鏈路做協(xié)同時,需要盡量避免redo復(fù)制鏈路等待Slog復(fù)制鏈路。比如,對于Create操作,回放Slog時,需要等待對應(yīng)的redo日志的LSN位點(diǎn)回放完畢才推進(jìn);對于DROP操作,回放SLog也需要協(xié)同等待,避免回放前臺事務(wù)找不到Subtable。

OnlineDDL復(fù)制技術(shù)

對于Alter Table操作,X-Engine實(shí)現(xiàn)了一套OnlineDDL機(jī)制,詳細(xì)實(shí)現(xiàn)原理可以參考內(nèi)核月報。在一寫多讀架構(gòu)下,X-Engine引擎在處理這類Alter操作時采用了物理復(fù)制,實(shí)際上對于Replica而言,由于是同一份數(shù)據(jù),并不需要重新生成物理extent,只需要同步元信息即可。對于Standby節(jié)點(diǎn),需要通過物理extent復(fù)制來重新構(gòu)建索引。DDL復(fù)制時,實(shí)際上包含了基線和增量部分。DDL復(fù)制充分利用了X-Engine的分層存儲以及LSM-tree結(jié)構(gòu)追加寫特點(diǎn),在獲取快照后,利用快照直接構(gòu)建L2作為基線數(shù)據(jù),這部分?jǐn)?shù)據(jù)以extent塊復(fù)制形式,通過redo通道傳遞給Standby,而增量數(shù)據(jù)則與普通的DML事務(wù)一樣,所以整個操作都是通過物理復(fù)制進(jìn)行,大大提高了復(fù)制效率。這里需要限制的僅僅是在Alter操作過程中,禁止做到L2的compaction即可。整個OnlineDDL過程與InnoDB的OnlineDDL流程類似,也是包括3個階段,prepare階段,build階段和commit階段,其中prepare階段需要獲取快照,commit階段元數(shù)據(jù)生效,需要通過MDL鎖來確保字典一致。與基于B+tree的OnlineDDL復(fù)制相比,基線部分,B+tree索引復(fù)制的是物理頁,而LSM-tree復(fù)制的是物理extent;增量部分B+tree索引是通過記增量日志,回放增量日志到數(shù)據(jù)頁寫redo日志進(jìn)行同步,LSM-tree則是通過DML前臺操作寫redo的方式同步。

OnlineDDL復(fù)制

6 雙引擎技術(shù)

Checkpoint位點(diǎn)推進(jìn)

通過wal-in-redo技術(shù),我們將X-Engine的wal日志嵌入到了InnoDB的redo中,首先要處理的一個問題就是redo日志的回收問題。日志回收首先涉及到一個位點(diǎn)問題,融合進(jìn)redo日志后,X-Engine內(nèi)部將RecoveryPoint定義為<lsn, Sequence>,lsn表示redo日志的位點(diǎn),Sequence為對應(yīng)的X-Engine的事務(wù)的版本號。Redo日志回收與Checkpoint(檢查點(diǎn))強(qiáng)相關(guān),確保Checkpoint位點(diǎn)及時推進(jìn)是需要考慮的問題,否則redo日志的堆積一方面影響磁盤空間,另一方面也影響恢復(fù)速度。這里有一個基本的原則是,Checkpoint=min(innodb-ckpt-lsn, xengine-ckpt-lsn),xengine-ckpt-lsn就是來源于X-Engine的RecoveryPoint,確保任何引擎有內(nèi)存數(shù)據(jù)沒有落盤時,對應(yīng)的redo日志不能被清理。為了避免X-Engine的checkpoint推進(jìn)影響整體位點(diǎn)推進(jìn),內(nèi)部會確保xengine-ckpt-lsn與全局的redo-lsn保持一定的閥值,超過閥值則會強(qiáng)制將memtable落盤,推進(jìn)檢查點(diǎn)。

數(shù)據(jù)字典與DDL

X-Engine作為一個數(shù)據(jù)庫引擎有自己獨(dú)立的字典,InnoDB也有自己的字典,兩份字典在一個系統(tǒng)里面肯定會存在問題。為了解決問題,這里有兩種思路,一是X-Engine仍然保留自己的數(shù)據(jù)字典,在做DDL時,通過2PC事務(wù)來保證一致性,這帶來的問題是需要有協(xié)調(diào)者。一般情況下,MySQL的協(xié)調(diào)者是binlog日志,在binlog關(guān)閉時是tclog日志。顯然,從功能和性能角度,我們都不會強(qiáng)依賴binlog日志。我們采用了另外一種思路,X-Engine不再用自身引擎存儲元數(shù)據(jù),所有元數(shù)據(jù)均通過InnoDB引擎持久化,X-Engine元數(shù)據(jù)實(shí)際上是InnoDB字典的一份緩存,那么在做DDL變更時,元數(shù)據(jù)部分實(shí)際上只涉及InnoDB引擎,通過事務(wù)能保證DDL的原子性。

通過元數(shù)據(jù)歸一化我們解決了元數(shù)據(jù)的原子性問題,但X-Engine數(shù)據(jù)和InnoDB元數(shù)據(jù)如何保證一致也是個問題。比如一個DDL操作,alter table xxx engine = xengine,這個DDL是將innodb表轉(zhuǎn)為xengine表,由于表結(jié)構(gòu)變更是Innodb字典修改,數(shù)據(jù)是在修改X-Engine,是一個跨引擎事務(wù),跨引擎事務(wù)需要通過協(xié)調(diào)者保證一致性。為了避免引入binlog作為協(xié)調(diào)者依賴,tclog作為協(xié)調(diào)者沒有經(jīng)過大規(guī)模生產(chǎn)環(huán)境驗(yàn)證,我們選擇了另外一種處理方式,具體來說,在涉及跨引擎事務(wù)時,優(yōu)先提交X-Engine事務(wù),然后再提交InnoDB事務(wù)。對于DDL來說,就是“先數(shù)據(jù),后元數(shù)據(jù)”,元數(shù)據(jù)提交了,才真正表示這個DDL完成。如果中途失敗,則結(jié)合“延遲刪除”的機(jī)制,來保證垃圾數(shù)據(jù)能被最終清理掉,通過一個后臺任務(wù)來周期性的對比X-Engine數(shù)據(jù)與InnoDB的字典,以InnoDB字典為準(zhǔn),結(jié)合X-Engine內(nèi)存元信息,確認(rèn)這部分?jǐn)?shù)據(jù)是否有用。

CrashRecovery

X-Engine與InnoDB引擎一樣是MySQL的一個插件,X-Enigne作為一個可選的插件,啟動順序在Innodb之后。每個引擎在恢復(fù)階段都需要通過redo日志來將數(shù)據(jù)庫恢復(fù)到宕機(jī)前狀態(tài)。在雙引擎形態(tài)下,所有redo都在InnoDB中,那意味著無論是InnoDB引擎還是X-Engine引擎在讀取日志恢復(fù)時,都需要掃描整個redo日志,相當(dāng)于整個恢復(fù)階段掃描了兩遍redo,這可能使得整個宕機(jī)恢復(fù)過程非常長,降低了系統(tǒng)的可用性。為了解決這個問題,我們將X-Engine的恢復(fù)階段細(xì)分,并且調(diào)整引擎的啟動順序,在InnoDB啟動前,先完成X-Engine的初始化以及Slog等恢復(fù)過程,處于恢復(fù)redo的狀態(tài)。在InnoDB啟動時,根據(jù)類型將日志分發(fā)X-Engine引擎,整個流程與正常同步redo日志的過程一致。當(dāng)redo日志分發(fā)完畢,相當(dāng)于InnoDB引擎和X-Engine引擎自身的宕機(jī)恢復(fù)過程已經(jīng)完成,然后走正常XA-Recovery和Post-Recovery階段即可,這個流程與之前保持一致。

HA

PolarDB支持雙引擎后,整個升降級流程中都會嵌套有X-Engine引擎的邏輯,比如在Standby升級為RW前,需要確保X-Engine的回放流水線完成,并將未決的事務(wù)保存起來,以便后續(xù)通過XA_Recovery繼續(xù)推進(jìn)。RW降級為Standby的時候需要等待X-Engine寫流水線回放,同時如果還殘留有未決事務(wù),需要在切換過程中將這部分未決事務(wù)遍歷出來存入Recovered_transactions_集合供后續(xù)并發(fā)回放使用。

四 LSM-tree VS B+tree

上節(jié)我們詳細(xì)描述了基于LSM-tree架構(gòu)的存儲引擎,實(shí)現(xiàn)一寫多讀所需要的關(guān)鍵技術(shù),并結(jié)合PolarDB雙引擎介紹了一些工程實(shí)現(xiàn)。現(xiàn)在我們跳出來看看基于B+tree和基于LSM-tree兩種數(shù)據(jù)組織結(jié)構(gòu)在實(shí)現(xiàn)技術(shù)上的對比。首先要回到一個基本點(diǎn),B+tree是原地更新,而LSM-tree是追加寫,這帶來的區(qū)別就是B+tree的數(shù)據(jù)視圖在內(nèi)存和外存一個緩存映射關(guān)系,而LSM-tree是一個疊加的關(guān)系。因而需要面對的技術(shù)問題也不同,B+tree需要刷臟,需要有double-write(在PolarFS支持16k原子寫后,消除了這個限制);LSM-tree需要Compaction來回收歷史版本。在一寫多讀的模式下面臨的問題也不一樣,比如,B+tree引擎復(fù)制是單redo日志流,LSM-tree引擎是雙日志流;B+tree在處理并行回放時,可以做到更細(xì)粒度的頁級并發(fā),但是需要處理SMO(SplitMergeOperation)問題,避免讀節(jié)點(diǎn)讀到“過去頁”或是“未來頁”。而LSM-tree是事務(wù)級別的并發(fā),為了保證RW和RO節(jié)點(diǎn)“內(nèi)存+磁盤”的一致性視圖,需要RW和RO在相同的位點(diǎn)做Switch Memtable。下表以InnoDB引擎和X-Engine引擎為例,列出了一些關(guān)鍵的區(qū)別點(diǎn)。

五 LSM-tree引擎業(yè)內(nèi)發(fā)展?fàn)顩r

目前業(yè)內(nèi)LSM-tree類型引擎比較熱的是Rocksdb,它的主要應(yīng)用場景是作為一個KeyValue引擎使用。Facebook將Rocksdb引擎引入到了他們的MySQL8.0分支,類似于X-Engine之于AliSQL,主要服務(wù)于他們的用戶數(shù)據(jù)庫UDB業(yè)務(wù),存儲用戶數(shù)據(jù)和消息數(shù)據(jù),采用的仍然是基于binlog的主備復(fù)制結(jié)構(gòu),目前沒有看到有做存儲計(jì)算分離,以及一寫多讀的事情。另外,github上有一個rocksdb-cloud項(xiàng)目,將rocksdb作為底座,架在AWS等云服務(wù)上提供NoSQL接口服務(wù),相當(dāng)于做了存儲計(jì)算分離,但并不支持物理復(fù)制和一寫多讀。在數(shù)據(jù)庫領(lǐng)域,阿里巴巴的Oceanbase和谷歌的Spanner的底層存儲引擎都是基于LSM-tree結(jié)構(gòu),這顯示了LSM-tree作為數(shù)據(jù)庫引擎的可行性,這兩個數(shù)據(jù)庫都是基于Share-Nothing的架構(gòu)。基于Share-Storage的數(shù)據(jù)庫,到目前為止還沒有成熟的產(chǎn)品,PolarDB(X-Engine)是業(yè)內(nèi)第一個基于LSM-tree結(jié)構(gòu)的實(shí)現(xiàn)的一寫多讀方案,對于后來者有很好的借鑒意義,LSM-tree這種結(jié)構(gòu)天然將內(nèi)存和磁盤存儲分離,我們充分利用了磁盤存儲只讀的特點(diǎn),通過壓縮將其成本優(yōu)勢發(fā)揮出來,結(jié)合一寫多讀的能力,將成本優(yōu)勢發(fā)揮到極致。

六 性能測試

基于X-Engine引擎實(shí)現(xiàn)一寫多讀能力后,我們采用基準(zhǔn)測試工具sysbench對性能做了摸底,主要對比了RDS(X-Engine),PolarDB(X-Engine)以及PolarDB(InnoDB)的性能。

1 測試環(huán)境

測試的client和數(shù)據(jù)庫server均從阿里云官網(wǎng)購買。client采用ecs,規(guī)格是ecs.c7.8xlarge(32core,64G),測試sysbench版本是sysbench-1.0.20,測試的數(shù)據(jù)庫server包括RDS(X-Engine),PolarDB(X-Engine),PolarDB(InnoDB)均采用8core32G規(guī)格,配置文件采用線上默認(rèn)的配置。測試場景覆蓋了全內(nèi)存態(tài)和IO-bound的幾種典型的workload。測試表數(shù)目是250張表,全內(nèi)存態(tài)單表行數(shù)為25000行,IO-bound的表行數(shù)為300萬行。

2 測試結(jié)果

RDS VS PolarDB

上面左圖是小表全內(nèi)存場景,右圖是大表io-bound場景。PolarDB(X-Engine)相比RDS(X-Engine)主要是寫入路徑發(fā)生了變化,最核心的區(qū)別是RDS主備架構(gòu)依賴binlog做復(fù)制,而PolarDB形態(tài)只需要redo日志即可。PolarDB形態(tài)的寫相關(guān)workload的性能相比RDS形態(tài),無論在全內(nèi)存態(tài),還是IO-bound場景,都有很大的性能提升。

B+tree VS LSM-tree

上圖是小表全內(nèi)存場景,下圖是大表io-bound場景。PolarDB形態(tài)下,X-Engine引擎相對于InnoDB引擎還有差距,這個差距主要來源于range查詢,另外更新場景導(dǎo)致的多版本,也會導(dǎo)致更新時需要做range查詢,這些因素導(dǎo)致了讀寫相關(guān)的workload,InnoDB引擎比X-Engine表現(xiàn)更優(yōu)秀。同時我們可以看到,在IO-bound場景,X-Engine引擎寫入更有優(yōu)勢。

七 未來展望

PolarDB(X-Engine)解決方案很好解決了用戶的歸檔存儲問題,但目前來看還不夠徹底。第一,技術(shù)上雖然PolarDB支持了雙引擎,但我們還沒有充分將兩個引擎結(jié)合起來。一個可行的思路是在線歸檔一體化,用戶的在線數(shù)據(jù)采用默認(rèn)的引擎InnoDB,通過設(shè)定一定的規(guī)則,PolarDB內(nèi)部自動將部分歷史數(shù)據(jù)進(jìn)行歸檔并轉(zhuǎn)換為X-Engine引擎存儲,整個過程對用戶透明。第二,目前的存儲都落在PolarDB的高性能存儲PolarStore上,為了進(jìn)一步降低成本,X-Engine引擎可以將部分冷數(shù)據(jù)存儲在OSS上,這個對于分層存儲是非常友好和自然的。實(shí)際上,基于LSM-tree的存儲引擎有很強(qiáng)的可塑性,我們目前的工作只是充分發(fā)揮了存儲優(yōu)勢,未來還可以對內(nèi)存中數(shù)據(jù)結(jié)構(gòu)進(jìn)行進(jìn)一步探索,比如做內(nèi)存數(shù)據(jù)庫等都是可以探索的方向。

原文鏈接
本文為阿里云原創(chuàng)內(nèi)容,未經(jīng)允許不得轉(zhuǎn)載。?

總結(jié)

以上是生活随笔為你收集整理的如何基于LSM-tree架构实现一写多读的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

久久综合干| 欧美一二三视频 | 午夜在线免费视频 | 国产999久久久 | 99re8这里有精品热视频免费 | 中文在线字幕免费观看 | 久久ww| 国产亚洲情侣一区二区无 | 在线日韩一区 | 免费黄色av | 国产亚洲精品久 | 手机在线看永久av片免费 | 国产成人99av超碰超爽 | 精品国产一区二区三区久久 | 婷婷 综合 色 | 在线观看午夜 | 国产品久精国精产拍 | 色综合久久精品 | 精品久久网 | 天天操天天射天天添 | 免费观看视频黄 | 一区二区视频在线播放 | 中文字幕av免费 | 欧美激情精品久久久久久 | 啪啪精品| 日韩欧美在线不卡 | 成人在线视频免费观看 | 九九热av| 国产亚洲精品美女 | 久久色在线观看 | 欧美十八| 国产视频亚洲 | .国产精品成人自产拍在线观看6 | 国产永久免费高清在线观看视频 | 色噜噜在线观看视频 | www.色综合.com | 国产日韩欧美在线一区 | 亚洲伦理精品 | 成人小电影在线看 | 国产人成在线观看 | www免费黄色| 日韩精品影视 | 麻豆免费观看视频 | 麻豆免费视频观看 | 99色国产 | 久久手机看片 | 岛国一区在线 | 成人羞羞免费 | 99精品偷拍视频一区二区三区 | 日韩免费观看一区二区三区 | 久久国产精品精品国产色婷婷 | 成人黄大片 | 国产一区成人 | 精品国产一区二区三区久久久蜜月 | 亚洲黄色片在线 | 99热精品久久 | 少妇性aaaaaaaaa视频 | 成人免费观看网站 | 成人在线小视频 | 婷婷综合| 人人插人人草 | 日韩久久影院 | 波多野结衣一区二区三区中文字幕 | av免费高清观看 | 中文字幕在线视频一区二区三区 | 国产一级不卡视频 | 久久精品在线免费观看 | 日韩美女久久 | 伊人婷婷在线 | 久久精品欧美一区二区三区麻豆 | 911久久香蕉国产线看观看 | av日韩在线网站 | 欧美日韩不卡在线观看 | 欧洲成人av | 精品一区二区三区四区在线 | 国产精品一区二区三区免费看 | 91成年人在线观看 | 国产免费久久精品 | 九九天堂 | 日韩精品免费一线在线观看 | 欧美激情视频一区二区三区免费 | 天天激情站 | 免费观看av网站 | 色吧久久| 极品中文字幕 | 国产精品成人久久久 | 久久精视频 | av在线播放中文字幕 | 国产精品1区2区3区 久久免费视频7 | 999视频精品 | 久久99免费视频 | 久久在线免费观看 | 韩国av三级 | 特级黄色片免费看 | 99热国产在线中文 | 麻豆视频在线观看免费 | 成人一级影视 | 久久这里精品视频 | 欧美少妇影院 | 在线天堂8√ | 干干日日 | 色91av| 中文字幕久久亚洲 | 国产精品一区二区美女视频免费看 | 国产成人高清在线 | 国产精品久久久久久久免费 | 中文字幕在线观看你懂的 | 国产中年夫妇高潮精品视频 | 国产精品一区久久久久 | 日韩综合一区二区 | 亚洲一区天堂 | 不卡av在线免费观看 | 特级黄色片免费看 | 亚洲激情综合 | 国产精品扒开做爽爽的视频 | 青青草在久久免费久久免费 | 国产黄色电影 | 亚洲精品乱码久久久久久久久久 | 狠狠插狠狠操 | 九九免费精品视频在线观看 | 亚洲午夜精品电影 | 精品久久久久久综合 | 久久综合九色 | 久久撸在线视频 | 天天色天天射天天干 | 在线不卡的av | 国产在线国产 | 免费在线成人 | 国产字幕在线播放 | 久久久久欠精品国产毛片国产毛生 | 九九激情视频 | 国产黄影院色大全免费 | 日韩夜夜爽| www.夜夜操.com | 欧美精品网站 | 欧美三级在线播放 | 91精品久久久久 | 国产精品毛片一区二区 | 亚洲人人爱 | 国产丝袜美腿在线 | 综合在线色| 亚洲五月婷婷 | 中文字幕日本在线观看 | 日韩中文在线电影 | 婷婷免费视频 | 中文字幕在线视频国产 | 婷婷在线免费视频 | 97视频成人| av在线永久免费观看 | 中文网丁香综合网 | 天天插视频 | 天天操夜夜拍 | 日本中文字幕观看 | 深爱婷婷网 | 免费观看国产精品视频 | 国产精品永久免费在线 | 91免费高清在线观看 | 国内外成人在线视频 | 91亚洲精品国产 | 午夜少妇av| 伊人婷婷综合 | 丁香影院在线 | 成人在线视频免费看 | 亚洲精品在线视频网站 | 久久久久成人精品免费播放动漫 | 伊人资源视频在线 | 婷婷色九月 | 久草精品资源 | av3级在线 | 午夜国产一区二区三区四区 | 成人久久18免费 | av中文在线播放 | 91精品日韩 | 8x成人在线| 国产成人久久精品一区二区三区 | 国产成人久 | 91精彩在线视频 | 精品乱码一区二区三四区 | 成人在线观看资源 | 在线之家免费在线观看电影 | 一级片免费在线 | 午夜视频播放 | 日韩夜夜爽 | 欧美精品第一 | 国产成年免费视频 | 精品视频在线免费 | 久久精品视频在线 | 国产在线一卡 | 波多野结衣最新 | 亚州精品天堂中文字幕 | 欧美成人日韩 | 日韩午夜剧场 | 久久嗨 | 最新高清无码专区 | 日韩欧美国产视频 | 国产精品国产三级在线专区 | 日韩三级视频在线看 | 日韩av在线网站 | 免费看黄在线观看 | 国产精品成人在线观看 | 国产乱对白刺激视频在线观看女王 | www.激情五月.com | 最近更新好看的中文字幕 | 91精品老司机久久一区啪 | 97国产超碰在线 | 日日摸日日添夜夜爽97 | 天堂在线一区二区 | 在线精品观看国产 | 亚洲天堂网视频在线观看 | 国产黄网站在线观看 | 亚洲97在线| 91色偷偷| 亚洲资源在线观看 | 久久国产免 | 免费福利在线视频 | 国产中文字幕在线观看 | 免费成人黄色av | 国产福利在线不卡 | 免费看三级网站 | 97日日碰人人模人人澡分享吧 | 色婷婷激婷婷情综天天 | 99精品国产高清在线观看 | 久久久国产99久久国产一 | 正在播放亚洲精品 | 午夜在线看片 | 91精品视频观看 | 精品久久久久久久久久久院品网 | 中文字幕五区 | 日日爽夜夜操 | 99精品国产一区二区 | 国产精品一区免费看8c0m | 欧美性网站 | 国产小视频在线免费观看 | 激情深爱.com | 午夜精品电影一区二区在线 | 免费又黄又爽 | 在线一二三区 | 久久草草影视免费网 | 美女精品久久久 | 国产精品网红直播 | 亚洲视频电影在线 | 欧美精品xxx | 91精品久久久久久综合乱菊 | 涩涩网站在线观看 | 欧美一级日韩三级 | 九色91在线视频 | 手机av看片 | 午夜视频久久久 | 久久亚洲成人网 | 97超碰免费 | 91字幕 | 国产精品嫩草影院99网站 | 久久综合九色综合97婷婷女人 | 精品国产一区二区三区四区在线观看 | 国产成人综合精品 | 精品国产一二三四区 | 成人超碰97 | 国产一区二区三区网站 | 国产精品一区在线观看你懂的 | 夜夜婷婷 | 伊人五月天婷婷 | 精品一区二区免费 | 天天色天天综合网 | 国产一区二区三区免费在线观看 | 久久躁日日躁aaaaxxxx | 97在线免费视频观看 | 最新亚洲视频 | 国产又黄又爽又猛视频日本 | 欧美性受极品xxxx喷水 | 人人爽人人爱 | 一区二区三区精品在线 | 亚洲免费在线视频 | 欧美一级免费在线 | 国产成人在线观看免费 | 手机在线小视频 | 一本一本久久aa综合精品 | 黄色小说免费在线观看 | 丁香花在线视频观看免费 | 成人久久久精品国产乱码一区二区 | 久久成人精品电影 | 超级碰碰碰视频 | 亚洲精品国产第一综合99久久 | 欧美日韩免费观看一区=区三区 | 精品国产伦一区二区三区观看说明 | 天天操天天爱天天爽 | 91高清一区 | www91在线 | 九草视频在线 | 狠狠色噜噜狠狠狠狠2021天天 | 中文字幕最新精品 | 成人h动漫在线看 | 国产精品一区二区在线播放 | 久久久久久久久久久久影院 | 日韩久久精品一区二区三区 | 中文字幕免费高清在线 | 伊人婷婷激情 | 国产精品第10页 | 精品国产_亚洲人成在线 | 久久久久在线视频 | 激情丁香久久 | 日韩免费视频观看 | 久久国产乱 | 国产 中文 日韩 欧美 | 国产精品爽爽久久久久久蜜臀 | 99热在线这里只有精品 | 国产一级三级 | 中文字幕av最新 | 日韩精品一区不卡 | 国产精品久久久久一区二区三区共 | 久草在线视频免费资源观看 | 久久婷婷国产色一区二区三区 | 色婷婷免费视频 | 国产高清精品在线观看 | www.狠狠操.com | 98精品国产自产在线观看 | 国产精品99精品久久免费 | 在线观看久| 日韩美女av在线 | 精品一区久久 | 国产精品资源在线观看 | av成人动漫在线观看 | 五月色婷| 97精品在线视频 | 韩国精品在线 | 激情久久伊人 | 成年人视频在线观看免费 | 黄污视频网站 | 人人干在线观看 | 日日操日日 | 最近中文字幕在线 | 黄色a大片| 精品播放 | 亚洲电影网站 | 在线视频 区 | 精品视频在线免费观看 | 国产精品 国内视频 | 在线播放第一页 | 久草精品网 | 免费国产一区二区视频 | 中文字幕av网站 | 中文成人字幕 | 国产99久久久精品视频 | av成人在线网站 | 日韩电影黄色 | 成人在线免费视频 | 日韩大片在线播放 | 毛片3| 91九色蝌蚪视频 | 婷婷深爱网 | 亚洲涩涩涩 | 福利一区视频 | 91最新地址永久入口 | 午夜精品久久久久久久99 | 91精品国自产拍天天拍 | 婷婷色中文字幕 | 婷婷丁香在线 | 91av欧美| 国产中文字幕视频在线 | 国产免费嫩草影院 | 国产一级在线观看 | 国产精品久久三 | 激情视频免费在线 | 午夜精品av | 久久无码av一区二区三区电影网 | 天堂在线视频中文网 | 在线免费黄色av | 成人小视频在线免费观看 | 国产精品成人自产拍在线观看 | 国产精品男女啪啪 | 久久这里只精品 | 色网址99 | 国产一级片不卡 | 国产精品永久久久久久久www | 国产一级不卡视频 | 国产91成人在在线播放 | 狠狠色伊人亚洲综合网站野外 | 天天搞天天干 | 91成年人视频 | 中文字幕精品三级久久久 | 高清久久久 | www.亚洲精品视频 | 日韩簧片在线观看 | 免费h在线观看 | 亚洲成人二区 | 婷婷激情av| 亚洲午夜av久久乱码 | 丝袜av一区 | 久久99久国产精品黄毛片入口 | 特级毛片aaa| 国产99视频在线观看 | 人人dvd| av在线看片 | 日韩在线免费视频观看 | 亚洲国产精品视频在线观看 | 天天艹天天 | 成人黄色av网站 | 中国黄色一级大片 | 国产99久久九九精品免费 | 午夜影视av | 天天操天天艹 | 亚洲第一成网站 | 91资源在线免费观看 | 狠狠色丁香婷婷综合久小说久 | 69视频网站 | 国产香蕉视频在线观看 | 日韩在线视频不卡 | 久久国产精品免费一区二区三区 | 免费观看版 | 夜夜操综合网 | 免费看一级片 | 欧美性精品 | 91cn国产在线 | 午夜视频在线观看网站 | 国产精品久久久久免费 | 亚洲综合视频在线播放 | 国产小视频精品 | 免费观看91视频 | 97av超碰| 国产午夜精品理论片在线 | 丁香导航 | av综合站| 亚洲视频 视频在线 | 久久久夜色 | 国产在线观看你懂得 | 可以免费观看的av片 | 国产成人资源 | 婷婷视频在线播放 | 亚洲国产综合在线 | 国产打女人屁股调教97 | 日韩国产精品毛片 | av大全在线免费观看 | 久久精品站 | 成人在线电影观看 | 一区二区网 | 96久久欧美麻豆网站 | 国产中文字幕在线 | 天天人人综合 | 日韩精品91偷拍在线观看 | 日韩欧美视频免费在线观看 | 日韩.com| 亚洲精品毛片一级91精品 | 手机看片午夜 | www免费黄色 | 热久久免费视频 | 午夜91在线| 免费av片在线 | 久国产在线播放 | 日韩毛片久久久 | 成人中文字幕在线观看 | 久久精品这里都是精品 | 色播五月激情五月 | 国产91精品一区二区麻豆亚洲 | 国产男女爽爽爽免费视频 | 国产午夜精品av一区二区 | 日韩av黄| 国产91精品欧美 | 日日夜夜精品 | 天天鲁天天干天天射 | 国产亚洲片 | 亚洲经典视频 | 日韩视频1区 | 国语黄色片 | 中文字幕在线日亚洲9 | 91在线观看黄 | 国产精品久久久久久久久久久久午夜片 | 91av资源在线 | 高清精品久久 | 91在线国内视频 | 国产专区视频在线 | 国内视频一区二区 | 免费观看性生活大片 | 97超碰在线久草超碰在线观看 | 在线观看国产永久免费视频 | 99视频在线免费播放 | 日韩在线视频观看免费 | 日韩黄色在线观看 | 国产大片免费久久 | 99热在线观看 | 九九综合九九综合 | 99re8这里有精品热视频免费 | 91在线视频一区 | 天无日天天操天天干 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | www.狠狠插.com | 日本最新一区二区三区 | 国产中文字幕久久 | 97超碰在线免费 | 亚洲欧美视频网站 | 亚洲欧美精品一区 | 国产免费黄视频在线观看 | 99精品一区 | 欧美aa在线| 四虎永久视频 | 日韩动漫免费观看高清完整版在线观看 | 欧美午夜剧场 | 狠狠狠色 | 五月宗合网 | 91女人18片女毛片60分钟 | 中文字幕网站视频在线 | 精品国偷自产国产一区 | 日韩免费成人av | 日韩精品一卡 | 免费观看性生交 | 看v片 | 美女视频黄频 | 亚洲国产欧美一区二区三区丁香婷 | 91精品国产一区二区三区 | 狠狠色综合网站久久久久久久 | 在线观看免费av片 | 日韩久久久久久久久久久久 | 亚洲成av人片 | 911国产在线观看 | 91在线麻豆| 亚洲日本三级 | 亚洲国产精品500在线观看 | 特级西西人体444是什么意思 | 国产免费av一区二区三区 | 黄色a一级片 | 免费精品视频在线 | 91精品秘密在线观看 | 精品国产一区二区三区久久久 | 国产精品不卡一区 | 亚洲蜜桃av | 免费一区在线 | 黄色免费在线看 | 黄网站色视频免费观看 | 99热亚洲精品 | 亚洲黄色免费在线看 | 欧美一区二视频在线免费观看 | 在线观看黄网站 | 综合伊人av| 麻豆精品国产传媒 | 91中文字幕视频 | 国产精品九九九九九九 | 99热在线观看 | 亚洲视频免费在线观看 | 96在线 | 欧美综合色在线图区 | 久久久久久精 | 久久精品九色 | 日韩美女av在线 | 色婷婷综合五月 | 亚洲h在线播放在线观看h | 在线 精品 国产 | 日韩久久久久久久久久 | 丰满少妇久久久 | 色播五月激情综合网 | 天堂va欧美va亚洲va老司机 | 免费看一级黄色大全 | 看国产黄色片 | 精品美女久久久久 | 久久在线精品视频 | 久久夜色精品国产欧美一区麻豆 | 国产 中文 日韩 欧美 | av+在线播放在线播放 | av免费看在线 | 日韩在线观看你懂得 | 久久国产一二区 | 91欧美在线| 91国内在线视频 | 91看片淫黄大片一级在线观看 | 日韩欧美区 | 精品国产视频在线观看 | 久久久网站 | 亚洲成人av在线播放 | 狠狠干综合 | av综合在线观看 | 不卡的av中文字幕 | 国产99久久久国产精品免费二区 | 成av在线 | 午夜在线资源 | 一区二区三区四区精品视频 | 天天爽天天爽夜夜爽 | 四虎影视成人永久免费观看亚洲欧美 | 九九亚洲精品 | 亚洲成人动漫在线观看 | 日韩欧美aaa | 999免费视频 | 日韩欧美电影在线 | www.夜夜| 欧美日本日韩aⅴ在线视频 插插插色综合 | 国产日韩在线播放 | 超碰九九 | 天天操人人要 | 色综合色综合久久综合频道88 | 精品福利在线视频 | 中文在线8资源库 | 亚洲电影黄色 | 日韩精品一区二区免费视频 | 91av视频网| 91亚洲欧美激情 | 99色网站| 国产专区在线播放 | 久久久久久久久精 | 国产一区二区不卡在线 | 在线色资源| 久久成人一区 | 国产精品嫩草69影院 | 久久手机在线视频 | 99中文视频在线 | 能在线观看的日韩av | 日韩电影中文字幕 | 欧美精品在线视频观看 | 草在线视频 | 国产三级国产精品国产专区50 | 91成版人在线观看入口 | 中文字幕在线视频一区二区 | a视频在线观看 | 高清在线一区二区 | 六月激情久久 | 国产黄色片一级三级 | 少妇资源站 | 中文字幕在线字幕中文 | 韩国av一区二区 | 天天爱天天草 | 欧美另类高潮 | 国产在线免费 | 婷婷六月色 | 久草在线视频看看 | 国产资源站 | 午夜视频免费播放 | 99一区二区三区 | av在线播放国产 | 91手机电影 | 99久久综合精品五月天 | 精品久久网 | 精品国产诱惑 | 五月婷婷丁香色 | 成人中文字幕在线 | 99精品在线直播 | 2023国产精品自产拍在线观看 | 国产成在线观看免费视频 | 99精品视频在线免费观看 | 成人免费网视频 | 欧美激情xxxx性bbbb | 国产男男gay做爰 | 精品在线一区二区 | 国产小视频国产精品 | 日韩激情av在线 | 国产一级二级视频 | 黄色午夜| 国产成人久久久77777 | 在线免费黄色片 | 亚洲精品国偷拍自产在线观看蜜桃 | 精品在线看 | 日韩69av| 国产视频九色蝌蚪 | 国产成人免费网站 | 久久夜色精品国产欧美一区麻豆 | 欧美 亚洲 另类 激情 另类 | 中文字幕视频网 | 在线免费高清一区二区三区 | 天天操天天爱天天爽 | 日韩欧美在线观看一区二区 | 51精品国自产在线 | 中文字幕成人一区 | 久久综合五月婷婷 | 中文字幕一区在线观看视频 | 久久成年人网站 | 精品一区二区6 | 亚洲国产精品小视频 | 中文字幕999 | 日本中文字幕久久 | 亚洲春色成人 | 久久不见久久见免费影院 | 国产精品一区二区三区在线看 | 中国精品少妇 | 天天射色综合 | 在线观看完整版 | 91精品久久久久久久99蜜桃 | 国产色网 | 色诱亚洲精品久久久久久 | 亚洲综合导航 | 亚洲人在线7777777精品 | 美女视频黄频大全免费 | 欧美aa在线 | 日韩av伦理片 | 欧美最猛性xxxxx免费 | 亚洲一区二区三区在线看 | 色小说av | 国产黄色电影 | 日韩欧美国产激情在线播放 | 成人在线视频论坛 | 亚洲综合射 | 在线有码中文 | 久草av在线播放 | 91成人在线视频 | 久草在线看片 | 国产福利专区 | 国产一卡二卡四卡国 | 精品成人a区在线观看 | 免费看一级特黄a大片 | 丁香五月亚洲综合在线 | 99久久精品国产欧美主题曲 | 色婷婷激情 | 久久99最新地址 | 在线播放国产一区二区三区 | 国产免费叼嘿网站免费 | 韩日色视频 | www.天天射 | 国产伦理剧 | 四虎成人精品 | 五月婷婷综合在线观看 | 欧美午夜久久久 | 超碰免费97| 日韩丝袜在线观看 | 黄色免费大片 | 亚洲精品乱码久久久久久 | 中文字幕在线看视频国产中文版 | 久久久这里有精品 | 中文字幕 国产精品 | 久久在线观看视频 | 中文字幕亚洲在线观看 | 中文字幕在线乱 | 99久久婷婷国产一区二区三区 | 九草在线视频 | 欧美亚洲xxx | 国产 一区二区三区 在线 | 蜜臀久久99精品久久久无需会员 | 正在播放一区 | 中文字幕亚洲五码 | 亚洲精品男人天堂 | 欧美日韩一区二区视频在线观看 | 欧美动漫一区二区三区 | 国产精品久久久久久久久久东京 | 成人性生爱a∨ | 国产精品欧美久久久久久 | 久草电影网 | 国产一线二线三线性视频 | 特黄特色特刺激视频免费播放 | 99热这里只有精品在线观看 | 国产精品免费观看网站 | 欧美成人va| 五月婷婷在线观看 | 精品亚洲va在线va天堂资源站 | 国产91aaa| 国产91丝袜在线播放动漫 | 天天色草| 四川妇女搡bbbb搡bbbb搡 | 伊人电影天堂 | 日韩欧美综合 | 久久一区国产 | 亚洲精品看片 | www久久九 | 国产无区一区二区三麻豆 | av不卡免费在线观看 | 国产一区在线免费观看 | 国产一区在线视频观看 | 色在线免费观看 | 成人黄色免费在线观看 | 久草在线网址 | 少妇精品久久久一区二区免费 | 国产亚洲成av片在线观看 | 精品电影一区 | 在线午夜电影神马影院 | 国产又黄又爽又猛视频日本 | 成年人视频在线免费观看 | 99国产视频| 在线视频日韩精品 | 欧美一区二区在线看 | 精品亚洲二区 | 中文字幕色婷婷在线视频 | 免费黄色a网站 | 在线a视频 | 在线观看91视频 | 国产毛片久久 | 四虎在线观看视频 | 久久99精品国产99久久 | 亚洲精品欧美精品 | 国产成人一区二区三区久久精品 | 久久综合五月 | 九九在线视频 | 爱av在线网 | 日韩视频在线观看视频 | 国产精品毛片一区二区在线看 | 在线看的av网站 | av在线播放免费 | 国产一区在线免费观看视频 | 中文字幕在线观看日本 | 98精品国产自产在线观看 | 国产精品ssss在线亚洲 | 欧美日韩不卡一区二区三区 | 久久久福利影院 | 日日干天夜夜 | 中文字幕在线乱 | 亚洲 欧洲av| 久久99国产精品二区护士 | 国产伦精品一区二区三区在线 | 91免费国产在线观看 | 久草资源在线 | 欧美精品小视频 | 免费视频 你懂的 | 国产一级精品视频 | 国产视频一区在线免费观看 | 久久精品小视频 | 欧美另类性 | 欧美精品成人在线 | 日本精品久久久久中文字幕 | 激情婷婷久久 | 中文字幕网站 | 美国三级黄色大片 | av电影免费在线看 | 天天躁天天躁天天躁婷 | 97超碰免费在线观看 | 91麻豆精品国产91久久久更新时间 | 九九热国产视频 | 黄色免费观看 | 91色国产 | 一区二区三区免费在线观看视频 | 天天色天天色天天色 | 高清日韩一区二区 | 免费看成人a | 日本成址在线观看 | 亚洲激情国产精品 | 狠狠色狠狠色综合系列 | 91久久国产精品 | 又黄又刺激视频 | www.99热精品 | 中午字幕在线观看 | 国产精品av在线 | 久久久精品99 | 成年人免费在线观看网站 | 狠狠操夜夜 | 欧美日韩国产在线 | www.伊人色.com| aaa毛片视频| 500部大龄熟乱视频 欧美日本三级 | 看毛片网站| 日韩一区二区三区免费视频 | 免费看毛片在线 | 成年人在线观看 | 五月综合网站 | 日韩在线在线 | 999色视频| 在线你懂的视频 | 欧美日韩国产xxx | 中文字幕丝袜 | 9992tv成人免费看片 | 欧美不卡视频在线 | 九九在线精品视频 | 亚洲 欧美 变态 国产 另类 | 婷婷在线视频观看 | 亚洲精品综合在线 | 欧美一级性生活片 | 天天透天天插 | 九九综合久久 | 中文字幕在线有码 | 91看毛片| 国内精品视频在线 | 成人中文字幕在线 | 亚洲高清91 | 久久伊人免费视频 | 亚洲精品视频 | 久久免费电影网 | avwww在线| 免费毛片aaaaaa | 成人蜜桃视频 | 成人久久免费 | 91福利影院在线观看 | 色综合夜色一区 | 日韩欧美视频一区二区 | 高清av免费看 | 国产成人高清av | a黄色一级| 一本到在线 | 国产精品久久久网站 | 91免费高清视频 | 精品免费久久久久 | 午夜在线免费观看 | 日韩大片在线观看 | 天天操夜夜干 | 人人干人人干人人干 | 成av在线 | 在线黄频 | 国产福利网站 | 国产群p视频| 九九99| 日韩电影一区二区三区在线观看 | 亚洲春色综合另类校园电影 | 久草在线一免费新视频 | 色九九在线 | 国内视频在线 | 国产中文字幕在线视频 | 一区二区三区影院 | 国产精品福利午夜在线观看 | 国产精品久久久久久超碰 | 99精品色 | 日韩免费久久 | 人人爽人人爽av | 日韩av一区在线观看 | 97超碰福利久久精品 | 欧洲亚洲国产视频 | 亚洲综合激情五月 | 在线观看韩日电影免费 | 麻豆一区二区 | 欧美91精品国产自产 | 亚洲日韩欧美视频 | 日韩三级视频在线看 | 日韩在线视频观看免费 | 女人高潮特级毛片 | 亚洲精品乱码久久久一二三 | 最近的中文字幕大全免费版 | 国产精品不卡 | 久久婷婷色综合 | 日韩欧美精品一区二区 | 成人四虎 | 精品久久久成人 | 99久久精品国产亚洲 | 日本精品视频免费观看 | 亚洲国产福利视频 | 激情视频免费观看 | 这里只有精品视频在线观看 | 黄色免费网站大全 | 在线播放你懂 | 婷婷丁香激情综合 | 亚州五月| 国产午夜精品一区二区三区 | 欧美日韩视频在线观看免费 | 中文字幕资源网在线观看 | 麻豆传媒在线免费看 | 欧美精品乱码久久久久久 | 久久论理| 亚洲人成免费网站 | 久久久久 免费视频 | 在线一二区 | 韩国视频一区二区三区 | 高潮久久久久久久久 | 日韩精品视频久久 | 久久久久一区 | 日日夜夜天天久久 | 日韩美一区二区三区 | 国产五月色婷婷六月丁香视频 | 免费成人在线观看 | 天天爱av导航 | 在线欧美国产 | 日韩久久一区二区 | 欧美精品久久久久久久亚洲调教 | av丁香花 | 成人免费观看在线视频 | 岛国精品一区二区 | 天天插日日操 | 久久久黄视频 | 99在线视频网站 | 国产成人亚洲精品自产在线 | 免费看一级黄色 | 国产精品 日韩精品 | 亚洲黄色在线免费观看 | 91精品一区二区三区蜜臀 | 午夜国产影院 | 免费男女羞羞的视频网站中文字幕 | 亚洲精品久久久久久国 | 久草在线手机视频 | 91看片看淫黄大片 | 在线免费观看一区二区三区 | 国产一二三四在线观看视频 | 国产裸体无遮挡 | 久久综合久久久久88 | 美女网站色免费 | 免费在线观看一级片 | 一二三区av | 韩国av三级 | 国产 欧美 日韩 | 亚洲精品美女久久久 | 亚洲精品国偷拍自产在线观看 | 蜜臀av性久久久久av蜜臀三区 | 成人在线你懂得 | 涩涩爱夜夜爱 | 成人av播放| 国产成人a v电影 | 中文字幕色婷婷在线视频 | 911精品视频 | av福利在线 | 久久狠狠一本精品综合网 | 国产午夜一区 | 91片黄在线观看动漫 | 久久久久国产精品免费免费搜索 | 中文字幕av日韩 | 亚洲电影在线看 | 97国产一区二区 | 444av| 在线观看视频免费播放 | 福利视频一区二区 | 亚洲专区中文字幕 | 国产成人福利在线 | 夜夜视频欧洲 | 国产流白浆高潮在线观看 | 狠狠色丁香婷婷 | 色综合天天狠天天透天天伊人 | www黄色软件| 免费大片av | 中文字幕在线观看国产 | www.888.av | 人人爱天天操 | 亚洲精品在线国产 | 久草视频免费在线播放 | 波多野结衣在线观看视频 | 在线免费观看视频一区 | 狠狠干综合 |