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

DDD CQRS架構和傳統架構的優缺點比較

移動開發 開發
關于CQRS架構的介紹其實已經非常多了,大家可以自行百度或google。我今天主要想總結一下這個架構相對于傳統架構(三層架構、DDD經典四層架構)在數據一致性、擴展性、可用性、伸縮性、性能這幾個方面的異同,希望可以總結出一些優點和缺點,為大家在做架構選型時提供參考。

最近幾年,在DDD的領域,我們經常會看到CQRS架構的概念。我個人也寫了一個ENode框架,專門用來實現這個架構。CQRS架構本身的思想其實非常簡單,就是讀寫分離。是一個很好理解的思想。就像我們用MySQL數據庫的主備,數據寫到主,然后查詢從備來查,主備數據的同步由MySQL數據庫自己負責,這是一種數據庫層面的讀寫分離。關于CQRS架構的介紹其實已經非常多了,大家可以自行百度或google。我今天主要想總結一下這個架構相對于傳統架構(三層架構、DDD經典四層架構)在數據一致性、擴展性、可用性、伸縮性、性能這幾個方面的異同,希望可以總結出一些優點和缺點,為大家在做架構選型時提供參考。

分層架構

前言

CQRS架構由于本身只是一個讀寫分離的思想,實現方式多種多樣。比如數據存儲不分離,僅僅只是代碼層面讀寫分離,也是CQRS的體現;然后數據存儲的讀寫分離,C端負責數據存儲,Q端負責數據查詢,Q端的數據通過C端產生的Event來同步,這種也是CQRS架構的一種實現。今天我討論的CQRS架構就是指這種實現。另外很重要的一點,C端我們還會引入Event Sourcing+In Memory這兩種架構思想,我認為這兩種思想和CQRS架構可以***的結合,發揮CQRS這個架構的***價值。

數據一致性

傳統架構,數據一般是強一致性的,我們通常會使用數據庫事務保證一次操作的所有數據修改都在一個數據庫事務里,從而保證了數據的強一致性。在分布式的場景,我們也同樣希望數據的強一致性,就是使用分布式事務。但是眾所周知,分布式事務的難度、成本是非常高的,而且采用分布式事務的系統的吞吐量都會比較低,系統的可用性也會比較低。所以,很多時候,我們也會放棄數據的強一致性,而采用最終一致性;從CAP定理的角度來說,就是放棄一致性,選擇可用性。

CQRS架構,則完全秉持最終一致性的理念。這種架構基于一個很重要的假設,就是用戶看到的數據總是舊的。對于一個多用戶操作的系統,這種現象很普遍。比如秒殺的場景,當你下單前,也許界面上你看到的商品數量是有的,但是當你下單的時候,系統提示商品賣完了。其實我們只要仔細想想,也確實如此。因為我們在界面上看到的數據是從數據庫取出來的,一旦顯示到界面上,就不會變了。但是很可能其他人已經修改了數據庫中的數據。這種現象在大部分系統中,尤其是高并發的WEB系統,尤其常見。

所以,基于這樣的假設,我們知道,即便我們的系統做到了數據的強一致性,用戶還是很可能會看到舊的數據。所以,這就給我們設計架構提供了一個新的思路。我們能否這樣做:我們只需要確保系統的一切添加、刪除、修改操作所基于的數據是***的,而查詢的數據不必是***的。這樣就很自然的引出了CQRS架構了。C端數據保持***、做到數據強一致;Q端數據不必***,通過C端的事件異步更新即可。所以,基于這個思路,我們開始思考,如何具體的去實現CQ兩端。看到這里,也許你還有一個疑問,就是為何C端的數據是必須要***的?這個其實很容易理解,因為你要修改數據,那你可能會有一些修改的業務規則判斷,如果你基于的數據不是***的,那意味著判斷就失去意義或者說不準確,所以基于老的數據所做的修改是沒有意義的。

擴展性

傳統架構,各個組件之間是強依賴,都是對象之間直接方法調用;而CQRS架構,則是事件驅動的思想;從微觀的聚合根層面,傳統架構是應用層通過過程式的代碼協調多個聚合根一次性以事務的方式完成整個業務操作。而CQRS架構,則是以Saga的思想,通過事件驅動的方式,最終實現多個聚合根的交互。另外,CQRS架構的CQ兩端也是通過事件的方式異步進行數據同步,也是事件驅動的一種體現。上升到架構層面,那前者就是SOA的思想,后者是EDA的思想。SOA是一個服務調用另一個服務完成服務之間的交互,服務之間緊耦合;EDA是一個組件訂閱另一個組件的事件消息,根據事件信息更新組件自己的狀態,所以EDA架構,每個組件都不會依賴其他的組件;組件之間僅僅通過topic產生關聯,耦合性非常低。

上面說了兩種架構的耦合性,顯而易見,耦合性低的架構,擴展性必然好。因為SOA的思路,當我要加一個新功能時,需要修改原來的代碼;比如原來A服務調用了B,C兩個服務,后來我們想多調用一個服務D,則需要改A服務的邏輯;而EDA架構,我們不需要動現有的代碼,原來有B,C兩訂閱者訂閱A產生的消息,現在只需要增加一個新的消息訂閱者D即可。

從CQRS的角度來說,也有一個非常明顯的例子,就是Q端的擴展性。假設我們原來Q端只是使用數據庫實現的,但是后來系統的訪問量增大,數據庫的更新太慢或者滿足不了高并發的查詢了,所以我們希望增加緩存來應對高并發的查詢。那對CQRS架構來說很容易,我們只需要增加一個新的事件訂閱者,用來更新緩存即可。應該說,我們可以隨時方便的增加Q端的數據存儲類型。數據庫、緩存、搜索引擎、NoSQL、日志,等等。我們可以根據自己的業務場景,選擇合適的Q端數據存儲,實現快速查詢的目的。這一切都歸功于我們C端記錄了所有模型變化的事件,當我們要增加一種新的View存儲時,可以根據這些事件得到View存儲的***狀態。這種擴展性在傳統架構下是很難做到的。

可用性

可用性,無論是傳統架構還是CQRS架構,都可以做到高可用,只要我們做到讓我們的系統中每個節點都無單點即可。但是,相比之下,我覺得CQRS架構在可用性方面,我們可以有更多的回避余地和選擇空間。

傳統架構,因為讀寫沒有分離,所以可用性要把讀寫合在一起綜合考慮,難度會比較更大。因為傳統架構,如果一個系統的高峰期的并發寫入很大,比如為2W,并發讀取也很大,比如為10W。那該系統必須優化到能同時支持這種高并發的寫入和查詢,否則系統就會在高峰時掛掉。這個就是基于同步調用思路的系統的缺點,沒有一個東西去削峰填谷,保存瞬間多出來的請求,而必須讓系統不管遇到多少請求,都必須能及時處理完,否則就會造成雪崩效應,造成系統癱瘓。但是一個系統,不會一直處在高峰,高峰可能只有半小時或1小時;但為了確保高峰時系統不掛掉,我們必須使用足夠的硬件去支撐這個高峰。而大部分時候,都不需要這么高的硬件資源,所以會造成資源的浪費。所以,我們說基于同步調用、SOA思想的系統的實現成本是非常昂貴的。

而在CQRS架構下,因為CQRS架構把讀和寫分離了,所以可用性相當于被隔離在了兩個部分去考慮。我們只需要考慮C端如何解決寫的可用性,Q端如何解決讀的可用性即可。C端解決可用性,我覺得是更加容易的,因為C端是消息驅動的。我們要做任何數據修改時,都會發送Command到分布式消息隊列,然后后端消費者處理Command->產生領域事件->持久化事件->發布事件到分布式消息隊列->***事件被Q端消費。這個鏈路是消息驅動的。相比傳統架構的直接服務方法調用,可用性要高很多。因為就算我們處理Command的后端消費者暫時掛了,也不會影響前端Controller發送Command,Controller依然可用。從這個角度來說,CQRS架構在數據修改上可用性要更高。不過你可能會說,要是分布式消息隊列掛了呢?呵呵,對,這確實也是有可能的。但是一般分布式消息隊列屬于中間件,一般中間件都具有很高的可用性(支持集群和主備切換),所以相比我們的應用來說,可用性要高很多。另外,因為命令是先發送到分布式消息隊列,這樣就能充分利用分布式消息隊列的優勢:異步化、拉模式、削峰填谷、基于隊列的水平擴展。這些特性可以保證即便前端Controller在高峰時瞬間發送大量的Command過來,也不會導致后端處理Command的應用掛掉,因為我們是根據自己的消費能力拉取Command。這點也是CQRS C端在可用性方面的優勢,其實本質也是分布式消息隊列帶來的優勢。所以,從這里我們可以體會到EDA架構(事件驅動架構)是非常有價值的,這個架構也體現了我們目前比較流行的Reactive Programming(響應式編程)的思想。

然后,對于Q端,應該說和傳統架構沒什么區別,因為都是要處理高并發的查詢。這點以前怎么優化的,現在還是怎么優化。但是就像我上面可擴展性里強調的,CQRS架構可以更方便的提供更多的View存儲,數據庫、緩存、搜索引擎、NoSQL,而且這些存儲的更新完全可以并行進行,互相不會拖累。理想的場景,我覺得應該是,如果你的應用要實現全文索引這種復雜查詢,那可以在Q端使用搜索引擎,比如ElasticSearch;如果你的查詢場景可以通過keyvalue這種數據結構滿足,那我們可以在Q端使用Redis這種NoSql分布式緩存。總之,我認為CQRS架構,我們解決查詢問題會比傳統架構更加容易,因為我們選擇更多了。但是你可能會說,我的場景只能用關系型數據庫解決,且查詢的并發也是非常高。那沒辦法了,唯一的辦法就是分散查詢IO,我們對數據庫做分庫分表,以及對數據庫做一主多備,查詢走備機。這點上,解決思路就是和傳統架構一樣了。

性能、伸縮性

本來想把性能和伸縮性分開寫的,但是想想這兩個其實有一定的關聯,所以決定放在一起寫。

伸縮性的意思是,當一個系統,在100人訪問時,性能(吞吐量、響應時間)很不錯,在100W人訪問時性能也同樣不錯,這就是伸縮性。100人訪問和100W人訪問,對系統的壓力顯然是不同的。如果我們的系統,在架構上,能夠做到通過簡單的增加機器,就能提高系統的服務能力,那我們就可以說這種架構的伸縮性很強。那我們來想想傳統架構和CQRS架構在性能和伸縮性上面的表現。

說到性能,大家一般會先思考一個系統的性能瓶頸在哪里。只要我們解決了性能瓶頸,那系統就意味著具有通過水平擴展來達到可伸縮的目的了(當然這里沒有考慮數據存儲的水平擴展)。所以,我們只要分析一下傳統架構和CQRS架構的瓶頸點在哪里即可。

傳統架構,瓶頸通常在底層數據庫。然后我們一般的做法是,對于讀:通常使用緩存就可以解決大部分查詢問題;對于寫:辦法也有很多,比如分庫分表,或者使用NoSQL,等等。比如阿里大量采用分庫分表的方案,而且未來應該會全部使用高大上的OceanBase來替代分庫分表的方案。通過分庫分表,本來一臺數據庫服務器高峰時可能要承受10W的高并發寫,如果我們把數據放到十臺數據庫服務器上,那每臺機器只需要承擔1W的寫,相對于要承受10W的寫,現在寫1W就顯得輕松很多了。所以,應該說數據存儲對傳統架構來說,也早已不再是瓶頸了。

傳統架構一次數據修改的步驟是:1)從DB取出數據到內存;2)內存修改數據;3)更新數據回DB。總共涉及到2次數據庫IO。

然后CQRS架構,CQ兩端加起來所用的時間肯定比傳統架構要多,因為CQRS架構最多有3次數據庫IO,1)持久化命令;2)持久化事件;3)根據事件更新讀庫。為什么說最多?因為持久化命令這一步不是必須的,有一種場景是不需要持久化命令的。CQRS架構中持久化命令的目的是為了做冪等處理,即我們要防止同一個命令被處理兩次。那哪一種場景下可以不需要持久化命令呢?就是當命令時在創建聚合根時,可以不需要持久化命令,因為創建聚合根所產生的事件的版本號總是為1,所以我們在持久化事件時根據事件版本號就能檢測到這種重復。

所以,我們說,你要用CQRS架構,就必須要接受CQ數據的最終一致性,因為如果你以讀庫的更新完成為操作處理完成的話,那一次業務場景所用的時間很可能比傳統架構要多。但是,如果我們以C端的處理為結束的話,則CQRS架構可能要快,因為C端可能只需要一次數據庫IO。我覺得這里有一點很重要,對于CQRS架構,我們更加關注C端處理完成所用的時間;而Q端的處理稍微慢一點沒關系,因為Q端只是供我們查看數據用的(最終一致性)。我們選擇CQRS架構,就必須要接受Q端數據更新有一點點延遲的缺點,否則就不應該使用這種架構。所以,希望大家在根據你的業務場景做架構選型時一定要充分認識到這一點。

另外,上面再談到數據一致性時提到,傳統架構會使用事務來保證數據的強一致性;如果事務越復雜,那一次事務鎖的表就越多,鎖是系統伸縮性的大敵;而CQRS架構,一個命令只會修改一個聚合根,如果要修改多個聚合根,則通過Saga來實現。從而繞過了復雜事務的問題,通過最終一致性的思路做到了***的并行和最少的并發,從而整體上提高系統的吞吐能力。

所以,總體來說,性能瓶頸方面,兩種架構都能克服。而只要克服了性能瓶頸,那伸縮性就不是問題了(當然,這里我沒有考慮數據丟失而帶來的系統不可用的問題。這個問題是所有架構都無法回避的問題,唯一的解決辦法就是數據冗余,這里不做展開了)。兩者的瓶頸都在數據的持久化上,但是傳統的架構因為大部分系統都是要存儲數據到關系型數據庫,所以只能自己采用分庫分表的方案。而CQRS架構,如果我們只關注C端的瓶頸,由于C端要保存的東西很簡單,就是命令和事件;如果你信的過一些成熟的NoSQL(我覺得使用文檔性數據庫如MongoDB這種比較適合存儲命令和事件),且你也有足夠的能力和經驗去運維它們,那可以考慮使用NoSQL來持久化。如果你覺得NoSQL靠不住或者沒辦法完全掌控,那可以使用關系型數據庫。但這樣你也要付出努力,比如需要自己負責分庫分表來保存命令和事件,因為命令和事件的數據量都是很大的。不過目前一些云服務如阿里云,已經提供了DRDS這種直接支持分庫分表的數據庫存儲方案,極大的簡化了我們存儲命令和事件的成本。就我個人而言,我覺得我還是會采用分庫分表的方案,原因很簡單:確保數據可靠落地、成熟、可控,而且支持這種只讀數據的落地,框架內置要支持分庫分表也不是什么難事。所以,通過這個對比我們知道傳統架構,我們必須使用分庫分表(除非阿里這種高大上可以使用OceanBase);而CQRS架構,可以帶給我們更多選擇空間。因為持久化命令和事件是很簡單的,它們都是不可修改的只讀數據,且對kv存儲友好,也可以選擇文檔型NoSQL,C端永遠是新增數據,而沒有修改或刪除數據。***,就是關于Q端的瓶頸,如果你Q端也是使用關系型數據庫,那和傳統架構一樣,該怎么優化就怎么優化。而CQRS架構允許你使用其他的架構來實現Q,所以優化手段相對更多。

結束語

我覺得不論是傳統架構還是CQRS架構,都是不錯的架構。傳統架構門檻低,懂的人也多,且因為大部分項目都沒有什么大的并發寫入量和數據量。所以應該說大部分項目,采用傳統架構就OK了。但是通過本文的分析,大家也知道了,傳統架構確實也有一些缺點,比如在擴展性、可用性、性能瓶頸的解決方案上,都比CQRS架構要弱一點。大家有其他意見,歡迎拍磚,交流才能進步,呵呵。所以,如果你的應用場景是高并發寫、高并發讀、大數據,且希望在擴展性、可用性、性能、可伸縮性上表現更優秀,我覺得可以嘗試CQRS架構。但是還有一個問題,CQRS架構的門檻很高,我認為如果沒有成熟的框架支持,很難使用。而目前據我了解,業界還沒有很多成熟的CQRS框架,java平臺有axon framework, jdon framework;.NET平臺,ENode框架正在朝這個方向努力。所以,我想這也是為什么目前幾乎沒有使用CQRS架構的成熟案例的原因之一。另一個原因是使用CQRS架構,需要開發者對DDD有一定的了解,否則也很難實踐,而DDD本身要理解沒個幾年也很難運用到實際。還有一個原因,CQRS架構的核心是非常依賴于高性能的分布式消息中間件,所以要選型一個高性能的分布式消息中間件也是一個門檻(java平臺有RocketMQ),.NET平臺我個人專門開發了一個分布式消息隊列EQueue,呵呵。另外,如果沒有成熟的CQRS框架的支持,那編碼復雜度也會很復雜,比如Event Sourcing,消息重試,消息冪等處理,事件的順序處理,并發控制,這些問題都不是那么容易搞定的。而如果有框架支持,由框架來幫我們搞定這些純技術問題,開發人員只需要關注如何建模,實現領域模型,如何更新讀庫,如何實現查詢,那使用CQRS架構才有可能,因為這樣才可能比傳統的架構開發更簡單,且能獲得很多CQRS架構所帶來的好處。

責任編輯:張子龍 來源: 博客園
相關推薦

2020-07-10 11:30:29

組合式架構傳統存儲存儲

2012-07-01 02:10:49

JSP架構開發工具

2009-08-10 15:09:15

JSP架構JSP開發工具

2017-07-05 17:47:17

架構DockerContainer

2021-01-28 17:26:57

LoRa網絡架構網絡技術

2013-05-07 10:09:07

2021-10-21 10:36:39

云計算云計算環境云應用

2016-01-27 09:56:06

Docker云計算容器

2021-03-04 09:00:00

架構Lambda工具

2018-04-24 08:47:43

超融合HCI數據中心

2021-10-13 14:36:08

邊緣計算云架構

2024-09-18 09:04:33

架構模式查詢

2023-08-14 23:23:56

2013-06-26 10:25:39

2009-12-31 16:42:37

LMDS接入技術

2021-09-13 10:27:34

云備份云恢復云計算

2016-09-08 14:50:59

AndroidiPhoneiOS

2011-03-29 13:09:57

2015-07-17 10:02:15

Linux桌面環境

2012-07-13 15:29:49

點贊
收藏

51CTO技術棧公眾號

手机看片福利视频| 看欧美ab黄色大片视频免费| 亚洲人视频在线观看| 欧美一级一区| 色爱av美腿丝袜综合粉嫩av| 精人妻一区二区三区| 成人bbav| 亚洲欧美自拍偷拍| 精品国产乱码久久久久久88av | 成人精品福利| 国产高清久久久| 日韩美女毛茸茸| 欧美色图一区二区| 久久av免费| 欧美va亚洲va国产综合| 三级在线免费看| 2021天堂中文幕一二区在线观| 欧美国产一区二区| 精品国产免费人成电影在线观...| 中文字幕久久久久| 国产日韩高清一区二区三区在线| 少妇高潮久久77777| 国产精品嫩草av| 秋霞影院一区| 欧美中文字幕一区| 国产亚洲欧美在线视频| 成年视频在线观看| 国产精品区一区二区三区| 狠狠色综合一区二区| 国产美女免费看| 美女精品自拍一二三四| 91成人天堂久久成人| 久久久久久久蜜桃| 影视一区二区| 日韩视频中文字幕| 欧美成人国产精品一区二区| 国产一级成人av| 日韩欧美中文一区| 色婷婷.com| 欧美黄页免费| 欧美性色综合网| 天天摸天天碰天天添| 春色校园综合激情亚洲| 亚洲一区二区三区四区不卡| 法国空姐在线观看免费| 在线免费看a| 亚洲国产成人自拍| 日韩欧美在线一区二区| 嫩草研究院在线观看| 26uuu国产日韩综合| 黑人另类av| 神马久久久久| 久久久久久久性| 久久久影院一区二区三区| 黄色av免费观看| 成人性生交大片免费看中文网站| 91在线视频成人| 91亚洲国产成人精品一区| 久久成人免费日本黄色| 成人免费观看a| 国产精品国产三级国产aⅴ| 毛片av中文字幕一区二区| 国产裸体写真av一区二区| 欧美另类高清videos的特点| 麻豆精品蜜桃视频网站| 成人美女av在线直播| 国产绿帽一区二区三区| 国产乱码精品1区2区3区| 91精品久久久久久久久久| 国产三级第一页| 国产福利一区二区三区在线视频| 粉嫩av四季av绯色av第一区| 天堂av一区二区三区| 久久一区二区三区国产精品| 色视频一区二区三区| 在线观看免费黄视频| 亚洲美女视频在线| 久久国产精品视频在线观看| 日韩欧美看国产| 欧美日本视频在线| 韩国av中国字幕| 一区二区美女| 精品精品国产国产自在线| 久久免费播放视频| 香蕉亚洲视频| 91亚洲精品视频| 日韩一级片免费| 中文字幕第一区二区| 欧美性受xxxx黑人猛交88| 国产精品vvv| 欧美三级日韩三级| 人妻 丝袜美腿 中文字幕| 国产一区二区三区四区| 久久久91精品国产| 成年人免费高清视频| 精品一区二区三区香蕉蜜桃| 国产日韩精品一区观看| 福利视频在线看| 一区二区三区免费在线观看| 黑鬼大战白妞高潮喷白浆| 91成人福利社区| 亚洲精品视频在线播放| 日韩成人短视频| 先锋影音国产一区| 成人午夜电影在线播放| 国产youjizz在线| 亚洲一区二区综合| 午夜视频在线网站| 久久不卡国产精品一区二区| 欧美福利视频在线观看| 姑娘第5集在线观看免费好剧| 福利视频网站一区二区三区| 亚洲国产日韩欧美| 日韩精品av| 精品国产一区二区三区久久久蜜月| 欧洲性xxxx| 国产精品腿扒开做爽爽爽挤奶网站| 成人福利网站在线观看11| 日韩亚洲视频在线观看| 亚洲国产日韩av| 欧美视频亚洲图片| 成人在线视频免费观看| 91精品国产一区| 丰满人妻一区二区三区免费| 中文字幕欧美一区| 成人3d动漫一区二区三区| 鲁大师精品99久久久| 欧美成人午夜影院| 国产又粗又猛视频| 国产色一区二区| 国产肥臀一区二区福利视频| 超碰地址久久| 色中色综合影院手机版在线观看| 国产精品九九九九| 中文字幕成人av| 中文字幕第21页| 一区二区美女| 国产成人久久久| 青青草av免费在线观看| 欧美日韩国产精品一区二区不卡中文| 亚洲性图第一页| 欧美.日韩.国产.一区.二区| 国产在线日韩在线| 婷婷成人激情| 欧美三级三级三级| 国产黄色片在线| 毛片一区二区三区| 一区二区三区四区在线视频 | 日韩欧中文字幕| 欧美深性狂猛ⅹxxx深喉| 亚洲青涩在线| 精品在线观看一区二区| 一区二区三区短视频| 日韩经典一区二区三区| 天堂网一区二区三区| 91视视频在线观看入口直接观看www | 国产日韩亚洲欧美| 看黄网站在线| 精品毛片乱码1区2区3区 | 色哦色哦哦色天天综合| 国产肥白大熟妇bbbb视频| 日韩不卡一区二区三区| 亚洲一区精彩视频| 清纯唯美激情亚洲| 97在线观看免费| 福利在线播放| 欧美一区二区视频在线观看2022 | 中文字幕精品视频在线| 99亚洲一区二区| 日韩av不卡在线播放| 99只有精品| 欧美成人精品在线播放| 欧美特级特黄aaaaaa在线看| 欧美性开放视频| 99久久99久久精品免费看小说.| 激情文学综合插| 国产肉体ⅹxxx137大胆| 亚洲欧洲美洲国产香蕉| 国产综合视频在线观看| 波多野结衣精品| 国产午夜精品视频免费不卡69堂| 91麻豆视频在线观看| 亚洲图片欧美色图| 免费视频91蜜桃| 国产成人免费av在线| 久久精品免费一区二区| 久久在线视频| 国产免费一区二区三区| 成人免费一区| 欧美激情影音先锋| 97视频在线观看网站| 精品国产伦一区二区三区观看方式| 在线免费黄色av| 亚洲免费在线视频| 中文字幕一区二区三区人妻| 国产在线一区二区综合免费视频| 自拍日韩亚洲一区在线| 欧美r级电影| 国产在线一区二区三区欧美| 亚洲a成人v| 97超级碰碰人国产在线观看| 免费av不卡| 亚洲欧洲视频在线| 精品人妻av一区二区三区| 在线日韩一区二区| 国产精品a成v人在线播放| 国产精品无人区| 国产黄色三级网站| 国产精品影音先锋| 怡红院亚洲色图| 新狼窝色av性久久久久久| 成人小视频在线观看免费| 精品久久电影| 欧美激情专区| 免费福利视频一区| www久久99| 亚瑟国产精品| 国产精品一久久香蕉国产线看观看| 91在线超碰| 欧美肥婆姓交大片| 国内精品不卡| 日韩在线视频国产| 国产美女性感在线观看懂色av| 亚洲成年人影院在线| 99久久亚洲精品日本无码| 欧美天堂亚洲电影院在线播放| 黄色片免费观看视频| 亚洲高清一区二区三区| 日本天堂中文字幕| 亚洲色图制服诱惑| 91香蕉视频污在线观看| 国产免费成人在线视频| 小早川怜子久久精品中文字幕| 99精品视频在线观看免费| 毛茸茸free性熟hd| 成人免费视频免费观看| 中文字幕制服丝袜| 国产成人一区在线| 国产裸体视频网站| 国产成人一级电影| 国产精品欧美性爱| 国产福利视频一区二区三区| xxxx国产视频| 丁香亚洲综合激情啪啪综合| 亚洲香蕉中文网| 成人av影院在线| 精品视频站长推荐| 99精品国产视频| 亚洲最大的黄色网| 久久综合av免费| 在线免费观看视频| 国产精品久久久久久久岛一牛影视 | 自拍亚洲一区| 欧美一级片免费观看| 国产亚洲欧美日韩在线观看一区二区 | 555www成人网| 暖暖成人免费视频| 国产精品视频久久久久| 成人亚洲精品| 国产精品二区三区| 偷拍一区二区| 日日骚一区二区网站| 日韩精品免费一区二区三区| 在线观看欧美亚洲| 国产精品红桃| 青青草原av在线播放| 日本亚洲一区二区| 亚洲成人激情小说| eeuss鲁片一区二区三区在线观看| 天堂久久久久久| 国产视频亚洲色图| 欧美国产日韩综合| 精品久久久一区二区| 在线播放亚洲精品| 精品乱码亚洲一区二区不卡| 色播色播色播色播色播在线| 中文字幕亚洲综合久久| jizz性欧美| 欧美在线www| 欧美三级电影网址| 国产精品美女诱惑| 不卡日本视频| 欧美国产视频一区| 久久久久久久高潮| 色黄视频免费看| www成人在线观看| 国产精品久久久免费看| 亚洲国产一区二区在线播放| 午夜精品久久久久久久蜜桃| 91精品国产91综合久久蜜臀| 午夜在线视频免费| 日韩中文在线观看| 国产粉嫩在线观看| 国产欧美日韩最新| 极品一区美女高清| 亚洲高清在线观看一区| 狠久久av成人天堂| 日韩中文字幕a| 91亚洲国产成人精品一区二三| av在线播放中文字幕| 亚洲va国产天堂va久久en| 91丨porny丨在线中文 | 日本不卡网站| 亚洲一区二区三区乱码aⅴ| 精品在线播放| 国产欧美日韩网站| 国产一区二区福利| 国产精品高清无码在线观看| 亚洲综合视频在线观看| 亚洲系列在线观看| 亚洲欧美在线看| 6699嫩草久久久精品影院| 成人午夜激情免费视频| 精品免费在线| 欧美深夜福利视频| 高清成人在线观看| 91在线播放观看| 欧美在线999| 国产一级片在线播放| 久久久爽爽爽美女图片| 精品国产一区二区三区性色av| 污视频在线免费观看一区二区三区| 亚洲激情网址| 中文在线字幕观看| 亚洲女性喷水在线观看一区| 91精品国自产| 国产亚洲精品美女久久久| 欧美13videosex性极品| 国产伦精品一区二区三区在线 | 国产欧美一区| 中国丰满人妻videoshd| 99国产精品久久久久久久久久| 欧美精品videos极品| 欧美一级午夜免费电影| 欧美三级理伦电影| 91精品久久久久久久久| 97欧美在线视频| 性刺激的欧美三级视频| 国产日韩欧美不卡在线| 黄色一级视频免费看| 亚洲女人天堂av| 欧美电影免费看| 日韩资源av在线| 欧美aaaaa成人免费观看视频| 中文字幕av久久爽一区| 欧美日韩一区二区三区四区五区 | 国内精品久久久久久| 91成人短视频| 精品无码一区二区三区在线| 26uuu久久天堂性欧美| 日本中文字幕第一页| 亚洲欧美中文字幕| 91欧美精品| 在线不卡日本| 国产一本一道久久香蕉| 久久国产精品二区| 亚洲国产小视频| 视频二区不卡| 亚洲精品成人自拍| 国产一区二区美女诱惑| 亚洲综合在线小说| 国产麻豆精品久久| 中文字幕 日韩 欧美| 亚洲欧美日韩一区二区 | 久久久久黄色片| 欧美精品一区二区不卡| 美女视频在线免费| 天堂社区 天堂综合网 天堂资源最新版 | 狠狠色狠狠色综合婷婷tag| 欧美三级理论片| 最新国产の精品合集bt伙计| 亚洲国产视频一区二区三区| 国内免费久久久久久久久久久| 中文字幕精品影院| 永久免费的av网站| 亚洲成人动漫精品| 国产三级视频在线| 亚洲综合最新在线| 国产日韩一区二区三区在线播放 | 亚洲男人第一天堂| 日本中文字幕成人| 亚洲一级毛片| 国产成人无码一区二区在线观看| 在线免费观看日本一区| 羞羞污视频在线观看| 麻豆一区区三区四区产品精品蜜桃| 美女视频免费一区| 国产成人亚洲精品自产在线| 在线视频日本亚洲性| 成人在线视频中文字幕| 亚洲一区在线不卡| 亚洲午夜电影网| jizz在线观看中文| 久久99精品久久久久久三级| 久久99久久99小草精品免视看| 日韩免费观看一区二区| 日日摸夜夜添一区| 希岛爱理av免费一区二区| 尤物网站在线看| 欧洲人成人精品|