精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一文搞明白分布式事務(wù)解決方案!真的 So Easy!

開發(fā) 前端
Seata 中涉及到四種不同的模式,接下來(lái)介紹的四種不同模式,其實(shí)都是在說(shuō)當(dāng)有一個(gè)本地事務(wù)失敗的時(shí)候,該如何回滾?這就是我們后面要說(shuō)的四種不同的分布式事務(wù)模式了。

分布式事務(wù),咱們前邊也聊過(guò)很多次了,網(wǎng)上其實(shí)也有不少文章在介紹分布式事務(wù),不過(guò)里邊都會(huì)涉及到不少專業(yè)名詞,看的大家云里霧里,所以還是有一些小伙伴在微信上問(wèn)我。

那么今天,我就再來(lái)一篇文章,和大家捋一捋這個(gè)話題。以下的內(nèi)容主要圍繞阿里的 seata 來(lái)和大家解釋。

1. 什么是反向補(bǔ)償

首先,來(lái)和大家解釋一個(gè)名詞,大家在看分布式事務(wù)相關(guān)資料的時(shí)候,經(jīng)常會(huì)看到一個(gè)名詞:反向補(bǔ)償。啥是反向補(bǔ)償呢?

我舉一個(gè)例子:假設(shè)我們現(xiàn)在有三個(gè)微服務(wù)分別是 A、B、C,現(xiàn)在在 A 服務(wù)中分別調(diào)用 B 和 C 服務(wù),為了確保 B 和 C 同時(shí)成功或者同時(shí)失敗,我們需要使用到分布式事務(wù)。但是按照我們之前對(duì)本地事務(wù)的理解,B 和 C 中的本地事務(wù),當(dāng) B 服務(wù)中的事務(wù)執(zhí)行完畢并且提交之后,現(xiàn)在 C 服務(wù)中的事務(wù)出現(xiàn)異常需要回滾了,但是,B 已經(jīng)提交了還怎么回滾呀?

此時(shí)我們所說(shuō)的回滾其實(shí)并不是傳統(tǒng)意義上的,通過(guò) MySQL redo log 日志來(lái)回滾的那種,而是通過(guò)一條更新 SQL,再把 B 服務(wù)中已經(jīng)更改過(guò)的數(shù)據(jù)復(fù)原。

這就是我們所說(shuō)的反向補(bǔ)償!

2. 基本概念梳理

Seata 中有三個(gè)核心概念:

  • TC (Transaction Coordinator) - 事務(wù)協(xié)調(diào)者:維護(hù)全局和分支事務(wù)的狀態(tài),驅(qū)動(dòng)全局事務(wù)提交或回滾。
  • TM (Transaction Manager) - 事務(wù)管理器:定義全局事務(wù)的范圍,開始全局事務(wù)、提交或回滾全局事務(wù)。
  • RM ( Resource Manager ) - 資源管理器:管理分支事務(wù)處理的資源( Resource ),與 TC 交談以注冊(cè)分支事務(wù)和報(bào)告分支事務(wù)的狀態(tài),并驅(qū)動(dòng)分支事務(wù)提交或回滾。

其中,TC 為單獨(dú)部署的 Server 服務(wù)端,TM 和 RM 為嵌入到應(yīng)用中的 Client 客戶端。我們來(lái)看如下一張圖片:

圖片

這張圖基本上把這個(gè)三個(gè)概念解釋清楚了。

其實(shí)不看這張圖,我們大概也能猜到分布式事務(wù)的實(shí)現(xiàn)原理:首先得有一個(gè)全局的事務(wù)協(xié)調(diào)者(TC),各個(gè)本地事務(wù)(RM)在開始執(zhí)行的時(shí)候,或者在執(zhí)行的過(guò)程中,及時(shí)將自己的狀態(tài)報(bào)告給全局事務(wù)協(xié)調(diào)者,這個(gè)全局事務(wù)協(xié)調(diào)者知道每一個(gè)分支事務(wù)目前的執(zhí)行狀態(tài),當(dāng)他(TC)發(fā)現(xiàn)所有的本地事務(wù)都執(zhí)行成功的時(shí)候,就通知大家一起提交;當(dāng)他發(fā)現(xiàn)在本次事務(wù)中,有人執(zhí)行失敗的時(shí)候,就通知大家一起回滾(當(dāng)然這個(gè)回滾不一定是真的回滾,而是反向補(bǔ)償)。那么一個(gè)事務(wù)什么時(shí)候開始什么時(shí)候結(jié)束呢?也就是事務(wù)的邊界在哪里?seata 中的分布式事務(wù)都是通過(guò) @GlobalTransactional 注解來(lái)實(shí)現(xiàn)的,換句話說(shuō),這個(gè)注解該加在哪里?添加該注解的地方其實(shí)就是事務(wù)管理器 TM 了。

經(jīng)過(guò)上面的介紹,小伙伴們應(yīng)該明白了,其實(shí)用 Seata 實(shí)現(xiàn)分布式事務(wù)沒有想象的那么難,原理還是非常 Easy 的。

Seata 中涉及到四種不同的模式,接下來(lái)介紹的四種不同模式,其實(shí)都是在說(shuō)當(dāng)有一個(gè)本地事務(wù)失敗的時(shí)候,該如何回滾?這就是我們后面要說(shuō)的四種不同的分布式事務(wù)模式了。

3. 什么是兩階段提交

先來(lái)看下面一張圖:

圖片

這張圖里涉及到三個(gè)概念:

  • AP:這個(gè)不用多說(shuō),AP 就是應(yīng)用程序本身。
  • RM:RM 是資源管理器,也就是事務(wù)的參與者,大部分情況下就是指數(shù)據(jù)庫(kù),一個(gè)分布式事務(wù)往往涉及到多個(gè) RM。
  • TM:TM 就是事務(wù)管理器,創(chuàng)建分布式事務(wù)并協(xié)調(diào)分布式事務(wù)中的各個(gè)子事務(wù)的執(zhí)行和狀態(tài),子事務(wù)就是指在 RM 上執(zhí)行的具體操作。

那么什么是兩階段(Two-Phase Commit, 簡(jiǎn)稱 2PC)提交?

兩階段提交說(shuō)白了道理很簡(jiǎn)單,松哥舉個(gè)簡(jiǎn)單例子來(lái)和大家說(shuō)明兩階段提交:

比如下面一張圖:

圖片

我們?cè)?Business 中分別調(diào)用 Storage 與 Order、Account,這三個(gè)中的操作要同時(shí)成功或者同時(shí)失敗,但是由于這三個(gè)分處于不同服務(wù),因此我們只能先讓這三個(gè)服務(wù)中的操作各自執(zhí)行,三個(gè)服務(wù)中的事務(wù)各自執(zhí)行就是兩階段中的第一階段。

第一階段執(zhí)行完畢后,先不要急著提交,因?yàn)槿齻€(gè)服務(wù)中有的可能執(zhí)行失敗了,此時(shí)需要三個(gè)服務(wù)各自把自己一階段的執(zhí)行結(jié)果報(bào)告給一個(gè)事務(wù)協(xié)調(diào)者,事務(wù)協(xié)調(diào)者收到消息后,如果三個(gè)服務(wù)的一階段都執(zhí)行成功了,此時(shí)就通知三個(gè)事務(wù)分別提交,如果三個(gè)服務(wù)中有服務(wù)執(zhí)行失敗了,此時(shí)就通知三個(gè)事務(wù)分別回滾。

這就是所謂的兩階段提交。

總結(jié)一下:兩階段提交中,事務(wù)分為參與者(例如上圖的各個(gè)具體服務(wù))與協(xié)調(diào)者,參與者將操作成敗通知協(xié)調(diào)者,再由協(xié)調(diào)者根據(jù)所有參與者的反饋情報(bào)決定各參與者是要提交操作還是中止操作,這里的參與者可以理解為 RM,協(xié)調(diào)者可以理解為 TM。

不過(guò) Seata 中的各個(gè)分布式事務(wù)模式,基本都是在二階段提交的基礎(chǔ)上演化出來(lái)的,因此并不完全一樣,這點(diǎn)需要小伙伴們注意。

4. AT 模式

AT 模式是一種全自動(dòng)的事務(wù)回滾模式。

整體上來(lái)說(shuō),AT 模式是兩階段提交協(xié)議的演變:

  • 一階段:業(yè)務(wù)數(shù)據(jù)和回滾日志記錄在同一個(gè)本地事務(wù)中提交,釋放本地鎖和連接資源。
  • 二階段則分兩種情況:2.1 提交異步化,非常快速地完成。2.2 回滾通過(guò)一階段的回滾日志進(jìn)行反向補(bǔ)償。

大致上的邏輯就是上面這樣,我們通過(guò)一個(gè)具體的案例來(lái)看看 AT 模式是如何工作的:

假設(shè)有一個(gè)業(yè)務(wù)表 product,如下:

圖片

現(xiàn)在我們想做如下一個(gè)更新操作:

update product set name = 'GTS' where name = 'TXC';

步驟如下:

一階段:

  • 解析 SQL:得到 SQL 的類型(UPDATE),表(product),條件(where name = 'TXC')等相關(guān)的信息。
  • 查詢前鏡像:根據(jù)解析得到的條件信息,生成查詢語(yǔ)句,定位數(shù)據(jù)(查找到更新之前的數(shù)據(jù))。
  • 執(zhí)行上面的更新 SQL。
  • 查詢后鏡像:根據(jù)前鏡像的結(jié)果,通過(guò)主鍵定位數(shù)據(jù)。
  • 插入回滾日志:把前后鏡像數(shù)據(jù)以及業(yè)務(wù) SQL 相關(guān)的信息組成一條回滾日志記錄,插入到 UNDO_LOG 表中。
  • 提交前,向 TC 注冊(cè)分支:申請(qǐng) product 表中,主鍵值等于 1 的記錄的 全局鎖。
  • 本地事務(wù)提交:業(yè)務(wù)數(shù)據(jù)的更新和前面步驟中生成的 UNDO LOG 一并提交。
  • 將本地事務(wù)提交的結(jié)果上報(bào)給 TC。

二階段:

二階段分兩種情況,提交或者回滾。

先來(lái)看回滾步驟:

  • 首先收到 TC 的分支回滾請(qǐng)求,開啟一個(gè)本地事務(wù),執(zhí)行如下操作。
  • 通過(guò) XID 和 Branch ID 查找到相應(yīng)的 UNDO LOG 記錄(這條記錄中保存了數(shù)據(jù)修改前后對(duì)應(yīng)的鏡像)。
  • 數(shù)據(jù)校驗(yàn):拿 UNDO LOG 中的后鏡像與當(dāng)前數(shù)據(jù)進(jìn)行比較,如果有不同,說(shuō)明數(shù)據(jù)被當(dāng)前全局事務(wù)之外的動(dòng)作做了修改。這種情況,需要根據(jù)配置策略來(lái)做處理。
  • 根據(jù) UNDO LOG 中的前鏡像和業(yè)務(wù) SQL 的相關(guān)信息生成并執(zhí)行回滾的語(yǔ)句:update product set name = 'TXC' where id = 1;
  • 提交本地事務(wù)。并把本地事務(wù)的執(zhí)行結(jié)果(即分支事務(wù)回滾的結(jié)果)上報(bào)給 TC。

再來(lái)看提交步驟:

  • 收到 TC 的分支提交請(qǐng)求,把請(qǐng)求放入一個(gè)異步任務(wù)的隊(duì)列中,馬上返回提交成功的結(jié)果給 TC。
  • 異步任務(wù)階段的分支提交請(qǐng)求將異步和批量地刪除相應(yīng) UNDO LOG 記錄。

大致上就是這樣一個(gè)步驟,思路還是比較清晰的,就是當(dāng)你要更新一條記錄的時(shí)候,系統(tǒng)將這條記錄更新之前和更新之后的內(nèi)容生成一段 JSON 并存入 undo log 表中,將來(lái)要回滾的話,就根據(jù) undo log 中的記錄去更新數(shù)據(jù)(反向補(bǔ)償),將來(lái)要是不回滾的話,就刪除 undo log 中的記錄。

在整個(gè)過(guò)程中,開發(fā)者只需要額外創(chuàng)建一張 undo log 表就行了,然后給需要處理全局事務(wù)的地方加上 @GlobalTransactional 注解就行了。

其他的提交呀回滾呀都是全自動(dòng)的,比較省事。所以如果你項(xiàng)目中選擇了用 seata 來(lái)處理分布式事務(wù),那么用 AT 模式的概率還是相當(dāng)高的。

5. TCC 模式

TCC(Try-Confirm-Cancel) 模式就帶一點(diǎn)手動(dòng)的感覺了,它也是兩階段,但是和 AT 又不太一樣,我們來(lái)看下流程。

官網(wǎng)上有一張 TCC 的流程圖,我們來(lái)看下:

圖片

可以看到,TCC 也是分為兩階段:

  • 第一階段是 prepare,在這個(gè)階段主要是做資源的檢測(cè)和預(yù)留工作,例如銀行轉(zhuǎn)賬,這個(gè)階段就先去檢查下用戶的錢夠不夠,不夠就直接拋異常,夠就先給凍結(jié)上。
  • 第二階段是 commit 或 rollback,這個(gè)主要是等各個(gè)分支事務(wù)的一階段都執(zhí)行完畢,都執(zhí)行完畢后各自將自己的情況報(bào)告給 TC,TC 一統(tǒng)計(jì),發(fā)現(xiàn)各個(gè)分支事務(wù)都沒有異常,那么就通知大家一起提交;如果 TC 發(fā)現(xiàn)有分支事務(wù)發(fā)生異常了,那么就通知大家回滾。

那么小伙伴可能也發(fā)現(xiàn)了,上面這個(gè)流程中,一共涉及到了三個(gè)方法,prepare、commit 以及
rollback,這三個(gè)方法都完全是用戶自定義的方法,都是需要我們自己來(lái)實(shí)現(xiàn)的,所以我一開始就說(shuō) TCC 是一種手動(dòng)的模式。

和 AT 相比,大家發(fā)現(xiàn) TCC 這種模式其實(shí)是不依賴于底層數(shù)據(jù)庫(kù)的事務(wù)支持的,也就是說(shuō),哪怕你底層數(shù)據(jù)庫(kù)不支持事務(wù)也沒關(guān)系,反正 prepare、commit 以及 rollback 三個(gè)方法都是開發(fā)者自己寫的,我們自己將這三個(gè)方法對(duì)應(yīng)的流程捋順就行了。

6. XA 模式

如果小伙伴們懂得 MySQL 數(shù)據(jù)庫(kù)的 XA 事務(wù),那么一下子就懂得 seata 中的 XA 模式是咋回事了。

XA 規(guī)范是 X/Open 組織定義的分布式事務(wù)處理(DTP,Distributed Transaction Processing)標(biāo)準(zhǔn)。

XA 規(guī)范描述了全局的事務(wù)管理器與局部的資源管理器之間的接口。XA規(guī)范的目的是允許的多個(gè)資源(如數(shù)據(jù)庫(kù),應(yīng)用服務(wù)器,消息隊(duì)列等)在同一事務(wù)中訪問(wèn),這樣可以使 ACID 屬性跨越應(yīng)用程序而保持有效。

XA 規(guī)范使用兩階段提交來(lái)保證所有資源同時(shí)提交或回滾任何特定的事務(wù)。

XA 規(guī)范在上世紀(jì) 90 年代初就被提出。目前,幾乎所有主流的數(shù)據(jù)庫(kù)都對(duì) XA 規(guī)范提供了支持。

XA 事務(wù)的基礎(chǔ)是兩階段提交協(xié)議。需要有一個(gè)事務(wù)協(xié)調(diào)者來(lái)保證所有的事務(wù)參與者都完成了準(zhǔn)備工作(第一階段)。如果協(xié)調(diào)者收到所有參與者都準(zhǔn)備好的消息,就會(huì)通知所有的事務(wù)都可以提交了(第二階段)。MySQL 在這個(gè) XA 事務(wù)中扮演的是參與者的角色,而不是協(xié)調(diào)者(事務(wù)管理器)。

MySQL 的 XA 事務(wù)分為內(nèi)部 XA 和外部 XA。外部 XA 可以參與到外部的分布式事務(wù)中,需要應(yīng)用層介入作為協(xié)調(diào)者;內(nèi)部 XA 事務(wù)用于同一實(shí)例下跨多引擎事務(wù),由 Binlog 作為協(xié)調(diào)者,比如在一個(gè)存儲(chǔ)引擎提交時(shí),需要將提交信息寫入二進(jìn)制日志,這就是一個(gè)分布式內(nèi)部 XA
事務(wù),只不過(guò)二進(jìn)制日志的參與者是 MySQL 本身。MySQL 在 XA 事務(wù)中扮演的是一個(gè)參與者的角色,而不是協(xié)調(diào)者。

換言之,MySQL 天然的就可以通過(guò) XA 規(guī)范來(lái)實(shí)現(xiàn)分布式事務(wù),只不過(guò)需要借助一些外部應(yīng)用的支持。我們來(lái)看下 Seata 中的 XA 模式使用流程。

先來(lái)看一張來(lái)自官方的圖片:

圖片

可以看到,這也是一個(gè)兩階段提交:

  • 一階段:業(yè)務(wù) SQL 操作放在 XA 分支中進(jìn)行,XA 分支完成后,執(zhí)行 XA prepare,由 RM 對(duì) XA 協(xié)議的支持來(lái)保證持久化(即之后任何意外都不會(huì)造成無(wú)法回滾的情況)。
  • 二階段分兩種情況:提交或者回滾:

分支提交:執(zhí)行 XA 分支的 commit

分支回滾:執(zhí)行 XA 分支的 rollback

和前面兩種模式的區(qū)別在于,XA 模式中的回滾,是正兒八經(jīng)的回滾,是我們傳統(tǒng)意義上所理解的回滾,而不是一種反向補(bǔ)償。

7. Saga 模式

’最后再來(lái)看看 saga 模式,這種模式應(yīng)用很少,大家作為了解即可。

saga 模式是 seata 提供的長(zhǎng)事務(wù)解決方案,然而長(zhǎng)事務(wù)是我們?cè)陂_發(fā)中應(yīng)該避免的,因?yàn)樾实筒⑶胰菀自斐伤梨i。

這個(gè) saga 模式就有點(diǎn)像流程引擎,開發(fā)者先自己畫一個(gè)流程引擎,把整個(gè)事務(wù)中涉及到的方法都囊括進(jìn)來(lái),每一個(gè)方法返回什么的時(shí)候就是正常的,返回什么就是異常的,正常的就繼續(xù)往下走,異常的就執(zhí)行另一套流程,也就是我們需要提前準(zhǔn)備好兩套方法,第一套是各種正常情況的執(zhí)行流程,第二套則是發(fā)生異常之后的執(zhí)行流程,類似下面這樣:

圖片

綠色的都是正常的流程,紅色的則是發(fā)生異常后回滾的流程。回滾中也是一種反向補(bǔ)償。

8. 小結(jié)

好啦,分布式事務(wù) 4 種模式就和大家說(shuō)清楚啦~后面有空整幾個(gè)案例一起實(shí)踐下!

責(zé)任編輯:武曉燕 來(lái)源: 江南一點(diǎn)雨
相關(guān)推薦

2021-06-28 10:03:44

分布式數(shù)據(jù)庫(kù)架構(gòu)

2025-04-29 04:00:00

分布式事務(wù)事務(wù)消息

2023-09-14 15:44:46

分布式事務(wù)數(shù)據(jù)存儲(chǔ)

2020-05-28 09:35:05

分布式事務(wù)方案

2024-06-13 09:25:14

2025-04-28 00:44:04

2024-03-26 12:08:53

分布式事務(wù)存儲(chǔ)

2022-11-24 17:34:04

TCC分布式

2023-04-03 15:04:00

RPCPHP語(yǔ)言

2010-07-21 13:53:41

SQL Server分

2019-01-11 18:22:07

阿里巴巴技術(shù)開源

2025-05-07 00:10:00

分布式事務(wù)TCC模式

2023-11-06 09:06:54

分布式一致性數(shù)據(jù)

2019-08-27 14:46:59

ElasticSearES數(shù)據(jù)庫(kù)

2020-07-10 08:03:35

DNS網(wǎng)絡(luò)ARPAne

2024-05-10 08:43:04

外觀模式接口系統(tǒng)

2024-05-09 09:09:19

組合模式對(duì)象

2024-05-13 10:45:25

中介模式面向?qū)ο?/a>數(shù)量

2016-10-25 14:35:05

分布式系統(tǒng) 存儲(chǔ)

2019-07-25 15:32:35

分布式事務(wù)微服務(wù)系統(tǒng)架構(gòu)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

最新在线中文字幕| 日本少妇激三级做爰在线| 五月婷在线视频| 日韩在线一二三区| 国产午夜一区二区| 一区二区三区国产免费| 亚洲无线看天堂av| aaa亚洲精品| 国产精品视频一区二区三区四| 美女福利视频在线观看| 亚洲裸色大胆大尺寸艺术写真| 欧美丝袜丝交足nylons| 国产精品一线二线三线| yw193.com尤物在线| 岛国一区二区在线观看| 国产精品1区2区在线观看| 视频直播国产精品| 色婷婷成人在线| 国产二区三区在线| 成人av在线网| 国产成人精品免高潮费视频| 中日韩一级黄色片| 白嫩白嫩国产精品| 日韩欧美在线视频免费观看| 色综合电影网| 国产黄色av网站| 亚洲主播在线| 久久亚洲精品网站| 中文成人无字幕乱码精品区| 全球最大av网站久久| 一区二区三区在线观看动漫| 欧美日韩精品免费观看视一区二区| 在线视频 中文字幕| 欧美激情亚洲| 在线观看国产精品淫| 中国特级黄色片| 欧美色片在线观看| 亚洲午夜视频在线| 亚洲一卡二卡三卡| 日韩av成人| 国产高清无密码一区二区三区| 欧美在线一区二区三区四| 老熟妻内射精品一区| 影视先锋久久| 欧美大片拔萝卜| 欧美 日韩精品| av中文字幕在线观看| 久久婷婷久久一区二区三区| 91免费精品国偷自产在线| 亚洲精品国产精品乱码| 91tv精品福利国产在线观看| 亚洲精品视频网上网址在线观看| 天天操天天干天天做| 日韩脚交footjobhd| 中文字幕在线播放不卡一区| 高清一区二区三区视频| 91在线视频在线观看| 欧美一区二区三区另类| 亚洲区中文字幕| 成人做爰69片免费| 日韩一区二区三区四区五区| 日韩欧美一区视频| 日韩精品综合在线| av在线播放观看| 亚洲靠逼com| 中文字幕久久一区| 欧美jizzhd69巨大| 中国av一区二区三区| 欧美人xxxxx| 无码精品黑人一区二区三区| 国产ts人妖一区二区| 亚洲aa中文字幕| 国产av无码专区亚洲a∨毛片| 精品伊人久久久久7777人| 国产精品视频最多的网站| 日韩成人av毛片| 日韩午夜在线| 欧美在线视频一区| 国产精品久久久久久人| 久久精品女人天堂| 国产成人久久久| 色屁屁影院www国产高清麻豆| 久久精品人人做人人爽电影蜜月| 青草热久免费精品视频| 秋霞av一区二区三区| 日本不卡的三区四区五区| 97视频在线观看免费| 在线免费黄色av| 久热精品视频| 国产精品亚发布| 国产美女精品视频国产| 国产精品123| 国产亚洲福利社区| 裸体xxxx视频在线| 中文字幕中文字幕在线一区| 国产精品亚洲天堂| 国产极品人妖在线观看| 精品久久久久久| 午夜视频在线瓜伦| 天天综合91| 日韩精品一区二区三区中文不卡 | 欧美日韩激情网| 亚洲美免无码中文字幕在线| 亚洲欧美小说色综合小说一区| 色呦呦国产精品| 女人高潮一级片| 超碰成人97| 伊人久久久久久久久久久久久| 成人信息集中地| 好看的av在线不卡观看| 人人做人人澡人人爽欧美| 一本色道久久综合亚洲| 成人性生交大片免费看中文| 日本高清不卡一区二区三| 老司机在线看片网av| 亚洲a一区二区| 中文字幕视频在线免费观看| 伊人久久大香线蕉av超碰| 亚洲日本中文字幕免费在线不卡| 亚洲伦理一区二区三区| 亚洲美女视频在线免费观看| 国产精品欧美日韩| 99精品久久久久久中文字幕| av在线不卡观看免费观看| 欧美视频1区| 在线中文字幕视频观看| 欧美日韩国产大片| 真人bbbbbbbbb毛片| 91精品蜜臀一区二区三区在线| 97成人精品区在线播放| 国产三级自拍视频| 日本一区二区免费在线| 国产一区二区三区小说| 婷婷丁香久久| 亚洲人成电影在线观看天堂色| 欧美成人三级视频| 久久99久久久欧美国产| 欧美日韩精品久久久免费观看| 日本小视频在线免费观看| 欧美性色黄大片| 国产白嫩美女无套久久| 欧美激情自拍| 91探花福利精品国产自产在线| 日韩av地址| 午夜不卡av在线| wwwxxx色| 欧美日韩a区| 91免费视频国产| 在线播放毛片| 精品婷婷伊人一区三区三| 黄色正能量网站| 最新国产拍偷乱拍精品| 91精品天堂| 超碰人人在线| 91精品福利视频| 国产ts在线观看| 91精品蜜臀一区二区三区在线| 成人有码在线视频| 久久经典视频| 一本色道久久综合亚洲aⅴ蜜桃 | 精品国产制服丝袜高跟| 精品人体无码一区二区三区| 国产毛片一区| 国产亚洲情侣一区二区无| 日本不卡视频| 日本电影亚洲天堂一区| 国产熟女高潮一区二区三区 | 久久视频国产精品免费视频在线| 国语对白做受69按摩| 久久久久久久久一| 熟妇人妻va精品中文字幕| 四虎影视精品| 日本欧美一级片| 精品推荐蜜桃传媒| 欧美在线你懂的| 97精品在线播放| 九九**精品视频免费播放| 亚洲精品人成| 国产69精品久久| 亚洲欧美精品伊人久久| 国产三级av片| 91免费版在线| 日韩免费毛片视频| 黑丝美女一区二区| 国产情人节一区| 99自拍视频在线观看| 欧美成人女星排名| 亚洲国产成人精品激情在线| 91小视频在线观看| 成人黄色片视频| 97精品97| 国产免费一区二区| 欧美大胆成人| 久久影院资源网| www天堂在线| 黑人巨大精品欧美一区二区| 微拍福利一区二区| 国产在线视频精品一区| 97视频在线免费| 国产伦精品一区二区三区视频| 国产精品视频在线播放| 国产精品—色呦呦| 亚洲图片在区色| 国产成人精品亚洲精品色欲| 精品国产1区2区| 成人午夜免费影院| 丁香婷婷综合激情五月色| 久久精品国产精品亚洲色婷婷| 成人高清av| 国产乱码一区| 成人免费在线观看视频| 欧美激情精品在线| 国产区av在线| 欧美一区二区国产| 中文在线最新版天堂| 亚洲国产日韩av| 女人裸体性做爰全过| 不卡一区二区三区四区| 天天操,天天操| 91久久视频| 免费看啪啪网站| 亚洲动漫精品| 97超碰人人模人人爽人人看| 欧美色网在线| 久久免费视频观看| 欧美被日视频| 亚洲片av在线| 日韩中文字幕观看| 欧美精品欧美精品系列| 免费黄色网址在线| 亚洲已满18点击进入久久| 中文字幕第24页| 成人免费视频caoporn| 91女神在线观看| 羞羞答答国产精品www一本| 国产91porn| 欧美疯狂party性派对| 蜜桃av久久久亚洲精品| 77成人影视| 成人综合国产精品| 伊人久久综合一区二区| 精品中文字幕在线| 色影院视频在线| 在线日韩第一页| 欧美一级特黄aaaaaa| 日韩你懂的电影在线观看| 91成年人视频| 欧美日韩一区二区三区四区五区| 精品人妻无码一区二区性色| 亚洲v日本v欧美v久久精品| 538任你躁在线精品视频网站| 国产精品沙发午睡系列990531| 黄色工厂在线观看| av在线免费不卡| 国产午夜在线一区二区三区| 国产a精品视频| 黄色片子免费看| 极品美女销魂一区二区三区免费| 男女视频在线看| 欧美aa在线视频| 中文字幕国产传媒| 久久天堂精品| 日本中文字幕高清| 麻豆成人久久精品二区三区小说| 黑鬼大战白妞高潮喷白浆| 乱码第一页成人| 欧美日韩亚洲一二三| 久久人人超碰| 天天爽天天爽夜夜爽| 免费黄网站欧美| 亚洲国产日韩欧美在线观看| 日本午夜一本久久久综合| www.夜夜爽| 精品写真视频在线观看| 天天爽天天爽夜夜爽| 日韩—二三区免费观看av| 欧美视频免费播放| 丝袜美腿亚洲综合| 亚洲免费av一区| 日本亚洲免费观看| 天天色天天综合网| 国产a视频精品免费观看| 无码一区二区精品| 国产婷婷色一区二区三区在线| 人妻熟人中文字幕一区二区| 中文字幕中文字幕一区二区| 东方av正在进入| 亚洲高清在线精品| 69成人免费视频| 欧美日韩一区二区在线视频| www.国产麻豆| 日韩av中文字幕在线| 国产毛片在线| 另类色图亚洲色图| 99爱在线观看| 国产精品久久久久99| 午夜久久av| 日韩欧美亚洲日产国产| 亚洲精品国产首次亮相| www..com日韩| 美女www一区二区| 精产国品一区二区三区| 国产午夜精品久久久久久免费视| 日本女人性生活视频| 亚洲h动漫在线| 一级片在线免费观看视频| 日韩一区二区麻豆国产| 国产91绿帽单男绿奴| 这里只有视频精品| 国产白浆在线免费观看| 欧美中文在线字幕| 日本精品在线观看| 欧美一区观看| 国产真实久久| 日本在线观看免费视频| 成人黄色网址在线观看| 女人黄色一级片| 亚洲午夜久久久久久久久电影网 | 午夜精品久久久久久久爽| 精品视频在线播放| 91国内在线| 国产精品视频资源| 亚洲品质自拍| 国产 欧美 日韩 一区| 麻豆一区二区在线| 成人网站免费观看| 亚洲综合在线第一页| 97人妻精品视频一区| 亚洲精品www久久久| 国产福利在线播放麻豆| 国产精品高潮粉嫩av| 国产精品白丝av嫩草影院| 亚洲制服欧美久久| 久久av最新网址| 亚洲欧美日本一区| 亚洲一区二区三区在线| 国产一区二区女内射| 日韩精品福利网站| 黄色的视频在线观看| 91免费版网站入口| 久久视频在线| 中文字幕第80页| 91老司机福利 在线| 国产一级大片在线观看| 欧美一区二区三区视频免费播放| 成年人视频在线免费观看| 欧美一级大胆视频| 欧美理论电影在线精品| 亚洲精品蜜桃久久久久久| 国产成人精品一区二| 全网免费在线播放视频入口| 欧美日韩高清一区二区不卡| 国产精品麻豆一区二区三区| 欧美亚州一区二区三区| 欧洲在线一区| 黄色一级在线视频| 波多野结衣在线一区| 日本一区二区三区免费视频| 精品久久久久久久人人人人传媒| 成人免费在线电影| 日本高清+成人网在线观看| 动漫3d精品一区二区三区乱码| 亚洲免费av网| 精品一区中文字幕| 久草免费在线视频观看| 日韩欧美一级二级| 欧美草逼视频| 精品国产乱码久久久久| 亚洲深爱激情| wwwwxxxx国产| 色播五月激情综合网| 国产精品视频二区三区| 国产主播欧美精品| 午夜久久黄色| 中文字幕在线视频播放| 精品国产精品自拍| 黄色av免费在线观看| 国产精品久在线观看| 欧美丰满日韩| 潘金莲一级淫片aaaaa| 亚洲成人一区二区在线观看| 天天干视频在线观看| 97在线看福利| 一区二区三区日本久久久| 久热精品在线播放| 一区二区免费在线| 涩涩视频在线观看免费| 国产精品男人的天堂| 欧美福利影院| 精品人妻一区二区三区日产乱码卜| 欧洲人成人精品| 好操啊在线观看免费视频| 国产高清自拍一区| 欧美专区18| 人人澡人人澡人人看| 亚洲国产小视频在线观看| 澳门av一区二区三区| 中文字幕乱码免费| 久久亚洲精品国产精品紫薇| 一区二区三区免费观看视频|