天天干夜夜操91视频网站,天天干夜夜操91视频网站,一本一道精品欧美中文,老熟妇性老熟妇性色,国产午夜亚洲精品羞羞答答八戒网,亚洲乱熟女一区二区三区色,2021国产精品自慰,大鸡吧草我流水视频,波多野结衣中文字幕在线

首頁 我們 服務(wù) 網(wǎng)站建設(shè) 移動(dòng)應(yīng)用 案例 資訊 聯(lián)系
業(yè)務(wù)專線:13711534025

期待聆聽您的聲音

13711534025

不忽悠,不作惡,不欺詐;敬天理,存良知,思利他。
QQ咨詢 QQ咨詢 QQ咨詢
服務(wù)網(wǎng)點(diǎn):廣州 深圳 佛山 粵西

與我們一起分享美好

淺談12306核心模型設(shè)計(jì)思路和架構(gòu)設(shè)計(jì)

發(fā)布時(shí)間:2016-02-23 發(fā)布作者:睿思設(shè)計(jì) 查閱次數(shù):2934次 標(biāo)簽:12306

前言

春節(jié)期間,無意中看到一篇文章,文章中講到12306的業(yè)務(wù)復(fù)雜度遠(yuǎn)遠(yuǎn)比淘寶天貓這種電商網(wǎng)站要復(fù)雜。后來自己想想,也確實(shí)如此。所以,很想挑戰(zhàn)一下12306這個(gè)系統(tǒng)的核心領(lǐng)域模型的設(shè)計(jì)。一般的電商網(wǎng)站,購買都是基于商品的概念,每個(gè)商品有一定量的庫存,用戶的購買行為是針對商品的。當(dāng)用戶發(fā)起購買行為時(shí),系統(tǒng)只需要生成訂單并對用戶要購買的商品減庫存即可。但是,12306就不是那么簡單了,具體復(fù)雜在哪里,我下面會(huì)進(jìn)一步分析。

另外一個(gè)讓我寫這篇文章的原因,是我發(fā)現(xiàn)也許是否是因?yàn)槟壳?2306的核心領(lǐng)域模型設(shè)計(jì)的不夠好,導(dǎo)致用戶購票時(shí)要處理的業(yè)務(wù)邏輯異常復(fù)雜,維護(hù)數(shù)據(jù)一致性的難度也幾百倍的上升,同時(shí)面對高并發(fā)的訂票也難以支持很高的TPS。我覺得,越是復(fù)雜的業(yè)務(wù),就越要重視業(yè)務(wù)分析,重視領(lǐng)域模型的抽象和設(shè)計(jì)。如果不假思索,憑以往經(jīng)驗(yàn)行事,則很可能會(huì)被以往的設(shè)計(jì)經(jīng)驗(yàn)先入為主,陷入死胡同。我發(fā)現(xiàn)技術(shù)人員往往更注重技術(shù)層面的解決方案,比如一上來就分析如何集群、如何負(fù)載均衡、如何排隊(duì)、如何分庫分表、如何用鎖,如何用緩存等技術(shù)問題,而忽略了最根本的業(yè)務(wù)層面的思考,如分析業(yè)務(wù)、領(lǐng)域建模。我認(rèn)為越是復(fù)雜的業(yè)務(wù)系統(tǒng),則越要設(shè)計(jì)一個(gè)健壯的領(lǐng)域模型。如果一個(gè)系統(tǒng)的架構(gòu)我們設(shè)計(jì)錯(cuò)了,還有補(bǔ)救的余地,因?yàn)榧軜?gòu)最終沉淀的只是代碼,調(diào)整架構(gòu)即可(一個(gè)系統(tǒng)的架構(gòu)本身就是不斷演進(jìn)的);而如果領(lǐng)域模型設(shè)計(jì)錯(cuò)了,那要補(bǔ)救的代價(jià)是非常大的,因?yàn)轭I(lǐng)域模型沉淀的是數(shù)據(jù)結(jié)構(gòu)及其對應(yīng)的大量數(shù)據(jù),對任何一個(gè)大型系統(tǒng),要改核心領(lǐng)域模型都是成本非常高的。

本文的重點(diǎn)不是在如何解決高并發(fā)的問題,而是希望從業(yè)務(wù)角度去分析,12306的理想模型應(yīng)該是怎么樣的。網(wǎng)上目前談12306的文章貌似都是千篇一律的只談技術(shù),不談業(yè)務(wù)分析和如何建模的。所以我想寫一下自己的設(shè)計(jì)和大家交流學(xué)習(xí)。

需求概述

12306這個(gè)系統(tǒng),核心要解決的問題是網(wǎng)上售票。涉及到2個(gè)角色使用該系統(tǒng):用戶、鐵道部。用戶的核心訴求是查詢余票、購票;鐵道部的核心訴求是售票。購票和售票其實(shí)是一個(gè)場景,對用戶來說是購票,對鐵道部來說是售票。因此,我們要設(shè)計(jì)一個(gè)在線的網(wǎng)站系統(tǒng),解決用戶的查詢余票、購票,以及鐵道部的售票這3個(gè)核心訴求??雌饋恚@3個(gè)場景都是圍繞火車票展開的。

查詢余票:用戶輸入出發(fā)地、目的地、出發(fā)日三個(gè)條件,查詢可能存在的車次,用戶可以看到每個(gè)車次經(jīng)過的站點(diǎn)名稱,以及每種座位的余票數(shù)量。

購票:購票分為訂票和付款兩個(gè)階段,本文重點(diǎn)分析訂票的模型設(shè)計(jì)和實(shí)現(xiàn)思路。

其實(shí)還有很多其他的需求,比如給不同的車次設(shè)定銷售座位數(shù)配額,以及不同的區(qū)段設(shè)置不同的限額。但相比前面兩個(gè)需求來說,我覺得這個(gè)需求相對次要一些。

需求分析

確實(shí),12306也是一個(gè)電商系統(tǒng),而且看起來商品就是票了。因?yàn)槿绻岩粡埰笨闯墒且粋€(gè)商品,那購票就類似于購買商品,然后每張票都有庫存,商品也有庫存的概念。但是如果我們仔細(xì)想想,會(huì)發(fā)現(xiàn)12306要復(fù)雜很多,因?yàn)槲覀儫o法預(yù)先確定好所有的票,如果非要確定,那只能通過窮舉法了。

我們以北京西到深圳北的G71車次高鐵為例(這里只考慮南下的方向,不考慮深圳北到北京西的,那是另外一個(gè)車次,叫G72),它有17個(gè)站(北京西是01號(hào)站,深圳北是17號(hào)站),3種座位(商務(wù)、一等、二等)。表面看起來,這不就是3個(gè)商品嗎?G71商務(wù)座、G71一等座、G71二等座。大部分輕易噴12306的技術(shù)人員(包括某些中等規(guī)模公司的專家、CTO)就是在這里栽第一個(gè)跟頭的。實(shí)際上,G71有136*3=408種商品(408個(gè)SKU),怎么算來的?如下:

如果賣北京西始發(fā)的,有16種賣法(因?yàn)楹竺嬗?6個(gè)站),北京西到:保定、石家莊、鄭州、武漢、長沙、廣州、虎門、深圳。。。。都是一個(gè)獨(dú)立的商品,同理,石家莊上車的,有15種下車的可能,以此類推,單以上下車的站來計(jì)算,有136種票:16+15+14....+2+1=136。每種票都有3種座位,一共是408個(gè)商品。

為了方便后面的討論,我們先明確一下票是什么?

一張票的核心信息包括:出發(fā)時(shí)間、出發(fā)地、目的地、車次、座位號(hào)。持有票的人就擁有了一個(gè)憑證,該憑證表示持有它的人可以坐某個(gè)車次的某個(gè)座位號(hào),從某地到某地。所以,一張票,對用戶來說是一個(gè)憑證,對鐵道部來說是一個(gè)承諾;那對系統(tǒng)來說是什么呢?不知道。這就是我們要分析業(yè)務(wù),領(lǐng)域建模的原因,我們再繼續(xù)思考吧。

明白了票的核心信息后,我們再看看G71這個(gè)車次的高鐵,可以賣多少張票?

討論前先說明一下,一輛火車的物理座位數(shù)(站票也可以看成是一種座位,因?yàn)檎酒币灿袛?shù)量配額)不等于可用的最大配合。所有的物理座位不可能都通過12306網(wǎng)站來銷售,而是只會(huì)銷售一部分,比如40%。其余的還是會(huì)通過線下的方式銷售。不僅如此,可能有些站點(diǎn)上車的人會(huì)比較多,有些比較少,所以我們還會(huì)給不同的區(qū)間配置不同的限額。比如D31北京南至上海共有765張,北京南有260張,楊柳青有80張,泰安有76張。如果楊柳青的80張票售完就會(huì)顯示無票,就算其他站有票也會(huì)顯示無票的。每個(gè)車次肯定會(huì)有各種座位的配額和限額的配置的,這種配置我目前無法預(yù)料,但我已經(jīng)把這些規(guī)則都封裝近車次聚合根里了,所有的配置策略都是基于座位類型、站點(diǎn)、區(qū)間配置的。關(guān)于票的配置抽象出來,我覺得主要有兩種:1)某個(gè)區(qū)段最多允許出多少張;2)某個(gè)區(qū)段最少允許出多少張。當(dāng)用戶訂票時(shí),把用戶指定的區(qū)段和這兩種配置條件進(jìn)行比較,兩個(gè)條件都滿足,則可以出票。不滿足,則認(rèn)為無票了。下面舉個(gè)例子:

ABCDEFG,這是所有站點(diǎn)。座位總配額是100,假設(shè)B站點(diǎn)上車,E站下車的人比較少,那我們就可以設(shè)定BE這個(gè)區(qū)段最多只能出10張票。所以,只要是用戶的訂票是在這個(gè)區(qū)段內(nèi)的,就最多出10張。再比如,一列車次,總共100個(gè)座位配額,希望全程票最少滿足80張,那我們只要給AG這個(gè)區(qū)段設(shè)定最少80張。那任何訂票請求,如果是子區(qū)間的,就不能超過100-80,即20張。這兩種條件必須同時(shí)滿足,才允許出票。

但是,不管如何做配額和限額,我們總是針對某個(gè)車次進(jìn)行配置,這些配置只是車次內(nèi)部售票時(shí)的一些額外的判斷條件(業(yè)務(wù)規(guī)則),不影響車次模型的核心地位和對外暴露的功能。所以,為了本文討論的清楚起見,我后續(xù)的討論都不涉及配額和限額的問題,而是認(rèn)為任何區(qū)段都可以享受火車最大的物理座位數(shù)。

并且,為了討論問題方便,我們減少一些站點(diǎn)來討論。假設(shè)某個(gè)車次有A,B,C,D四個(gè)站點(diǎn)。那001這個(gè)人購買了A,B這個(gè)區(qū)間,系統(tǒng)會(huì)分配給001一個(gè)座位x;但是因?yàn)?01坐到B站點(diǎn)后會(huì)下車,所以相當(dāng)于x這個(gè)座位又空出來了,也就是說,從B站點(diǎn)開始,系統(tǒng)又可以認(rèn)為x這個(gè)座位是可用的。所以,我們得出結(jié)論:同一個(gè)座位,其實(shí)可以同時(shí)出售AB,BC這兩張票。通過這個(gè)簡單的分析,我們知道,一列火車雖然只有有限的座位數(shù),比如1000個(gè)座位。但可以賣出的票遠(yuǎn)遠(yuǎn)不止1000個(gè)。還是以A,B,C,D四個(gè)站點(diǎn)為例,假如火車總共有1000個(gè)座位,那AB可以賣1000張,BC也可以賣1000張,同樣,CD也可以賣1000張。也就是說,理論上最多可以賣出3000張票。但是如果換一種賣法,所有人都是買ABCD的票,也就是說所有的票都是經(jīng)過所有站點(diǎn)的,那就是最多只能賣出1000張票了。而實(shí)際的場景,一定是介于1000到3000之間。然后實(shí)際的G71這個(gè)車次,有17個(gè)站,那到底可以賣出多少個(gè)票,大家應(yīng)該可以算了吧。理論上這17個(gè)站中的任意兩個(gè)站點(diǎn)之間所形成的線段,都可以出售為一張票。我數(shù)學(xué)不好,算不太清楚,麻煩有數(shù)學(xué)好的人幫我算算,呵呵。

通過上面的分析,我們知道一張票的本質(zhì)是某個(gè)車次的某一段區(qū)間(一條線段),這個(gè)區(qū)間包含了若干個(gè)站點(diǎn)。然后我們還發(fā)現(xiàn),只要區(qū)間不重疊,那座位就不會(huì)發(fā)生競爭,可以被回收利用,也就是說,可以同時(shí)預(yù)先出售。

另外,經(jīng)過更深入的分析,我們還發(fā)現(xiàn)區(qū)間有4種關(guān)系:1)不重疊;2)部分重疊;3)完全重疊;4)覆蓋;不重疊的情況我們已經(jīng)討論過了,而覆蓋也是重疊的一種。所以我們發(fā)現(xiàn)如果重疊,比如有兩個(gè)區(qū)間發(fā)生重疊,那重疊部分的區(qū)間(可能夸一個(gè)或多個(gè)站點(diǎn))是在爭搶座位的。因?yàn)榧僭O(shè)一列火車有100個(gè)座位,那每個(gè)原子區(qū)間(兩個(gè)相鄰站點(diǎn)的連線),最多允許重疊99次。

所以,經(jīng)過上面的分析,我們知道了一個(gè)車次能夠出售一張車票的核心業(yè)務(wù)規(guī)則是什么?就是:這張車票所包含的每個(gè)原子區(qū)間的重疊次數(shù)加1都不能超過車次的總座位數(shù),實(shí)際上重疊次數(shù)+1也可以理解為線段的厚度。

模型設(shè)計(jì)

上面我分析了一下票的本質(zhì)是什么。那接下來我們再來看看怎么設(shè)計(jì)模型,來快速實(shí)現(xiàn)購票的需求,重點(diǎn)是怎么設(shè)計(jì)商品聚合以及減庫存的邏輯。

傳統(tǒng)電商的思路

如果按照普通電商的思路,把票(站點(diǎn)區(qū)間)設(shè)計(jì)為商品(聚合根),然后為票設(shè)計(jì)庫存數(shù)量。我個(gè)人覺得是很糟糕的。因?yàn)橐环矫孢@種聚合根非常多(上面的G71就有408個(gè));另一方面,即便枚舉出來了,一次購票也一定會(huì)影響非常多其他聚合根的庫存數(shù)量(只要被部分或全部重疊的區(qū)間都受影響)。這樣的一次訂單處理的復(fù)雜度是難以評估的。而且這么多聚合根的更新要在一個(gè)事務(wù)里,這不是為難數(shù)據(jù)庫嗎?而且,這種設(shè)計(jì)必然帶來大量的事務(wù)的并發(fā)沖突,很可能導(dǎo)致數(shù)據(jù)庫死鎖??傊艺J(rèn)為這種是典型的由于領(lǐng)域模型的設(shè)計(jì)錯(cuò)誤,導(dǎo)致并發(fā)沖突高、數(shù)據(jù)持久化落地困難?;蛘呷绻鉀Q并發(fā)問題,只能排隊(duì)單線程處理,但是仍然解決不了要在一個(gè)事務(wù)里修改大量聚合根的尷尬局面。聽說12306是采用了Pivotal Gemfire這種高大上的內(nèi)存數(shù)據(jù)庫,我對這個(gè)不太了解。我不可想象要是不使用內(nèi)存數(shù)據(jù)庫,他們要怎么實(shí)現(xiàn)車次內(nèi)的票之間的數(shù)據(jù)強(qiáng)一致性(就是保證所有出售的票都是符合上面討論的業(yè)務(wù)規(guī)則的)?所以,這種設(shè)計(jì),我個(gè)人認(rèn)為是思維定勢了,把火車票看成是普通電商的商品來看待。所以,我們有時(shí)做設(shè)計(jì)又要依賴于經(jīng)驗(yàn),又要不能被以往經(jīng)驗(yàn)所束縛,真的不容易,關(guān)鍵還是要根據(jù)具體的業(yè)務(wù)場景多多深入分析,盡量分析抽象出問題的本質(zhì)出來,這樣才能對癥下藥。那是否有其他的設(shè)計(jì)思路呢?

我的思路

聚合設(shè)計(jì)

通過上面的分析我們知道,其實(shí)任何一次購票都是針對某個(gè)車次的,我認(rèn)為車次是負(fù)責(zé)處理訂票的聚合根。我們看看一個(gè)車次包含了哪些信息?一個(gè)車次包括了:1)車次名稱,如G71;2)座位數(shù),實(shí)際座位數(shù)會(huì)分類型,比如商務(wù)座20個(gè),一等座200個(gè);二等座500個(gè);我們這里為了簡化問題,可以暫時(shí)忽略類型,我認(rèn)為這個(gè)類型不影響核心的模型的設(shè)計(jì)決策。需要格外注意的是:這里的座位數(shù)不要理解為真實(shí)的物理座位數(shù),很有可能比真實(shí)的座位數(shù)要少。因?yàn)槲覀儾豢赡馨岩粋€(gè)車次的所有座位都在網(wǎng)上通過12306來出售,而是只出售一部分,具體出售多少,要由工作人員人工指定。3)經(jīng)過的站點(diǎn)信息(包括站點(diǎn)的ID、站點(diǎn)名稱等),注意:車次還會(huì)記錄這些站點(diǎn)之間的順序關(guān)系;4)出發(fā)時(shí)間;看過GRASP九大模式中的信息專家模式的同學(xué)應(yīng)該知道,將職責(zé)分配給擁有執(zhí)行該職責(zé)所需信息的類。我們這個(gè)場景,車次具有一次出票的所有信息,所以我們應(yīng)該把出票的職責(zé)交給車次。另外學(xué)過DDD的同學(xué)應(yīng)該知道,聚合設(shè)計(jì)有一個(gè)原則,就是:聚合內(nèi)強(qiáng)一致性,聚合之間最終一致性。經(jīng)過上面的分析,我們知道要產(chǎn)生一張票,其實(shí)要影響很多和這個(gè)票對應(yīng)的線段相交的其他票的可用數(shù)量。因?yàn)樗械恼军c(diǎn)信息都在車次聚合內(nèi)部,所以車次聚合內(nèi)部自然可以維護(hù)所有的原子區(qū)間,以及每個(gè)原子區(qū)間的可用票數(shù)(相當(dāng)于是庫存數(shù))。當(dāng)一個(gè)原子區(qū)間的可用票數(shù)為0的時(shí)候,意味著火車針對這個(gè)區(qū)間的票已經(jīng)賣完了。所以,我們完全可以讓車次這個(gè)聚合根來保證出票時(shí)對所有原子區(qū)間的可用票數(shù)的更新的強(qiáng)一致性。對于車次聚合根來說,這很簡單,因?yàn)橹皇菐状魏唵蔚膬?nèi)存操作而已,耗時(shí)可以忽略。一列火車假如有ABCD四個(gè)站點(diǎn),那原子區(qū)間就是3個(gè)。對于G71,則是16個(gè)。

怎么判斷是否能出票

基于上面的聚合設(shè)計(jì),出票時(shí)扣減庫存的邏輯是:

根據(jù)訂單信息,拿到出發(fā)地和目的地,然后獲取這段區(qū)間里的所有的原子區(qū)間。然后嘗試將每個(gè)原子區(qū)間的可用票數(shù)減1,如果所有的原子區(qū)間都?jí)驕p,則購票成功;否則購票失敗,提示用戶該票已經(jīng)賣完了。是不是很簡單呢?知道了出票的邏輯,那退票的邏輯也就很簡單了,就是把這個(gè)票的所有原子區(qū)間的可用票數(shù)加1就OK了。如果我們從線段的厚度的角度去考慮,那出票時(shí),每個(gè)原子區(qū)間的厚度就是+1,退票時(shí)就是減一。就是相反的操作,但本質(zhì)是一樣的。

所以,通過這樣的思路,我們將一次訂票的處理控制在了一個(gè)聚合根里,用聚合根內(nèi)的強(qiáng)一致性的特性保證了訂票處理的強(qiáng)一致性,同時(shí)也保證了性能,免去了并發(fā)沖突的可能性。傳統(tǒng)電商那種把票單做類似商品的核心聚合根的設(shè)計(jì),我當(dāng)時(shí)第一眼看到就覺得不妥。因?yàn)檫@違背了DDD強(qiáng)調(diào)的強(qiáng)一致性應(yīng)該由聚合根來保證、聚合根之間的最終一致性通過Saga來保證的原則。

還有一個(gè)很重要的概念我想說一下我的看法,就是座位和區(qū)間的關(guān)系。因?yàn)橛行┡笥押臀抑v,考慮座位號(hào)的問題,雖然都能減1,座位號(hào)也必須是同一個(gè)。我覺得座位是全局共享的,和區(qū)段無關(guān)(也許我的理解完全有誤,請大家指正)。座位是一個(gè)物理概念,一個(gè)用戶成功購買了一張票后,座位就會(huì)少一個(gè),一張票唯一對應(yīng)一個(gè)座位,但是一個(gè)座位有可能會(huì)對應(yīng)多張票;而區(qū)間是一個(gè)邏輯上的概念,區(qū)間的作用有兩個(gè):1)表示票的出發(fā)地和目的地;2)記錄票的可用數(shù)額。如果區(qū)間能連通(即該區(qū)間內(nèi)的每個(gè)原子區(qū)間的可用數(shù)額都大于0),則表示允許擁有一個(gè)座位。所以,我覺得座位和票(區(qū)間)是兩個(gè)維度的概念。

如何為票分配座位

我覺得車次聚合根內(nèi)部應(yīng)該維護(hù)所有該車次已經(jīng)售出的票,已經(jīng)出售的票的的本質(zhì)是區(qū)間和座位的對應(yīng)關(guān)系。系統(tǒng)處理訂票時(shí),用戶提交過來的是一段區(qū)間。所以,系統(tǒng)應(yīng)該做兩個(gè)事情:

  1. 先根據(jù)區(qū)間去判斷是否有可用的座位;
  2. 如果有可用座位,則再通過算法去選擇一個(gè)可用的座位;

當(dāng)?shù)玫揭粋€(gè)可用座位后,就可以生成一張票了,然后保存這個(gè)票到車次聚合根內(nèi)部即可。下面舉個(gè)例子:

假設(shè)現(xiàn)在的情況是座位有3個(gè),站點(diǎn)有4個(gè)
座位:1,2,3
站點(diǎn):abcd

票的賣法1:
票1:ab,1
票2:bc,2
票3:cd,3
票4:ac,3
票5:bd,1
這種選座位的方式應(yīng)該比較高效,因?yàn)榭偸莾?yōu)先從座位池里去拿座位,只有在萬不得已的時(shí)候才會(huì)去回收可重復(fù)利用的票。
上面的4,5兩個(gè)票,就是考慮回收利用的結(jié)果。

票的賣法2:
票1:ab,1
票2:bc,1
票3:cd,1
票4:ac,2
票5:bd,3
這種選座位的方式應(yīng)該相對低效,因?yàn)榭偸莾?yōu)先會(huì)去掃描是否有可回收的座位,而掃描相對直接從座位池里去拿票總是成本相對要高的。
上面的2,3兩個(gè)票,就是考慮回收利用的結(jié)果。

但是,優(yōu)先從座位池里拿票的算法有缺陷,就是會(huì)出現(xiàn)雖然第一步判斷認(rèn)為有可用的座位,但是這個(gè)座位可能不是全程都是同一個(gè)座位。舉例:
假設(shè)現(xiàn)在的情況是座位有3個(gè),站點(diǎn)有4個(gè)
座位:1,2,3
站點(diǎn):abcd

票的賣法3:
票1:ab,1
票2:bc,2
票3:cd,3

現(xiàn)在如果有人要買ad的票,那可用的座位有2,或者3。但是無論是2還是3,都要這個(gè)乘客中途換車位。比如賣給他座位2,那他ab是坐的座位2,但是bc的時(shí)候要坐座位1的。否則拿票2的那個(gè)人上車時(shí),發(fā)現(xiàn)座位2已經(jīng)有人了。而通過優(yōu)先回收利用的算法,是沒這個(gè)問題的。

所以,從上面的分析我們也知道選座位的算法該怎么寫了,就是采用優(yōu)先回收利用座位的算法。我認(rèn)為不管我們這里怎么設(shè)計(jì)算法,都不影響大局,因?yàn)檫@一切都只發(fā)生在車次聚合根內(nèi)部,這就是預(yù)先設(shè)計(jì)好聚合根,明確出票職責(zé)在哪個(gè)對象上的好處。

模型分析總結(jié)

  1. 我認(rèn)為票不是核心聚合根,票只是一次出票的結(jié)果,一個(gè)憑證而已。
  2. 12306真正的核心聚合根應(yīng)該是車次,車次具有出票的職責(zé),一次出票具體做的事情有:
    • 判斷是否可出票;
    • 選擇可用的座位;
    • 更新一次出票時(shí)所有原子區(qū)間的可用票數(shù),用于判斷下次是否能出票;
    • 維護(hù)所有已售出的票,用于為選擇可用座位提供依據(jù);

通過這樣的模型設(shè)計(jì),我們可以確保一次出票處理只會(huì)在一個(gè)車次聚合根內(nèi)進(jìn)行。這樣的好處是:

  1. 不需要依賴數(shù)據(jù)庫事務(wù)就能實(shí)現(xiàn)數(shù)據(jù)修改的強(qiáng)一致性,因?yàn)樗行薷闹辉谝粋€(gè)聚合根內(nèi)發(fā)生;
  2. 在保證數(shù)據(jù)強(qiáng)一致性的同時(shí)還能提供很高的并發(fā)處理能力,具體設(shè)計(jì)見下面的架構(gòu)設(shè)計(jì);

架構(gòu)設(shè)計(jì)(非本文重點(diǎn),沒興趣的朋友可以略過)

我覺得12306這樣的業(yè)務(wù)場景,非常適合使用CQRS架構(gòu);因?yàn)槭紫人且粋€(gè)查多寫少、但是寫的業(yè)務(wù)邏輯非常復(fù)雜的系統(tǒng)。所以,非常適合做架構(gòu)層面的讀寫分離,即采用CQRS架構(gòu)。而且應(yīng)該使用數(shù)據(jù)存儲(chǔ)也分離的CQRS。這樣CQ兩端才可以完全不需要顧及對方的問題,各自優(yōu)化自己的問題即可。我們可以在C端使用DDD領(lǐng)域模型的思路,用良好設(shè)計(jì)的領(lǐng)域模型實(shí)現(xiàn)復(fù)雜的業(yè)務(wù)規(guī)則和業(yè)務(wù)邏輯。而Q端則使用分布式緩存方案,實(shí)現(xiàn)可伸縮的查詢能力。

訂票的實(shí)現(xiàn)思路

同時(shí)借助像ENode這樣的框架,我們可以實(shí)現(xiàn)in-memory + Event Sourcing的架構(gòu)。Event Sourcing技術(shù),可以讓領(lǐng)域模型的所有狀態(tài)修改的持久化統(tǒng)一起來,本來要用ORM的方式保存聚合根最新狀態(tài)的,現(xiàn)在只需要簡單的通用的方式保存一個(gè)事件即可(一次訂票只涉及一個(gè)車次聚合根的修改,修改只產(chǎn)生一個(gè)事件,只需要持久化一個(gè)事件(一個(gè)JSON串)即可,保證了高性能,無須依賴事務(wù),而且通過ENode可以解決并發(fā)問題)。我們只要保存了聚合根每次變化的事件(事件的結(jié)構(gòu)怎么設(shè)計(jì),本文不做多的介紹了,大家可以思考下),就相當(dāng)于保存了聚合根的最新狀態(tài)。而正是由于Event Sourcing技術(shù)的引入,讓我們的模型可以一直存活在內(nèi)存中,即可以使用in-memory技術(shù)。不要小看in-memory技術(shù),in-memory技術(shù)在某些方面對提高命令的處理性能非常有幫助。比如就以我們車次聚合根處理出票的邏輯,假設(shè)某個(gè)車次有大量的命令發(fā)送到分布式消息隊(duì)列,然后有一臺(tái)機(jī)器訂閱了這個(gè)隊(duì)列的消息,然后這臺(tái)機(jī)器處理這個(gè)車次的訂票命令時(shí),由于這個(gè)車次聚合根一直在內(nèi)存,所以就省去了每次要去數(shù)據(jù)庫取出聚合根的步驟,相當(dāng)于少了一次數(shù)據(jù)庫IO。這樣的好處是,因?yàn)橐粋€(gè)車次能夠真正出售的票是有限的,因?yàn)樽痪湍敲磶讉€(gè),比如就1000個(gè)座位,估計(jì)一般正常情況也就出個(gè)2000個(gè)左右的票吧(具體能出多少張票要取決于區(qū)間的相交程度,上面分析過)。也就是說,這個(gè)聚合根只會(huì)產(chǎn)生2000個(gè)事件,也就是說只會(huì)有2000個(gè)訂票命令的處理是會(huì)產(chǎn)生事件,并持久化事件;而其余的大量命令,因?yàn)檐嚧卧趦?nèi)存計(jì)算后發(fā)現(xiàn)沒有余票了,就不會(huì)做任何修改,也不會(huì)產(chǎn)生領(lǐng)域事件,這樣就可以直接處理下一個(gè)訂票命令了。這樣就可以大大提高處理訂票命令的性能。

另外一個(gè)問題我覺得還需要提一下,因?yàn)橛脩粲喥背晒螅€需要付款。但用戶有可能不去付款或者沒有在規(guī)定的時(shí)間內(nèi)完成付款。那這種情況下,系統(tǒng)會(huì)自動(dòng)釋放該用戶之前訂購的票。所以基于這樣的需求,我們在業(yè)務(wù)上需要支持業(yè)務(wù)級(jí)別的2pc。即先預(yù)扣庫存,也就是先占住這張票一定時(shí)間(比如15分鐘),然后付款成功后再真實(shí)給你這張票,系統(tǒng)做真正的庫存修改。通過這樣的預(yù)扣處理,可以保證不會(huì)出現(xiàn)超賣的情況。這個(gè)思路其實(shí)和傳統(tǒng)電商比如淘寶這樣的系統(tǒng)類似,我就不多展開了,我之前寫的Conference案例也是這樣的思路,大家有興趣的可以去看一下我之前錄制的視頻。

查詢余票的實(shí)現(xiàn)思路

我覺得余票的查詢的實(shí)現(xiàn)相對簡單。雖然對于12306來說,查詢的請求占了80%,提交訂單的請求只占20%。但查詢由于對數(shù)據(jù)沒有修改,所以我們完全可以使用分布式緩存來實(shí)現(xiàn)。我們只需要精心設(shè)計(jì)好緩存的key即可;緩存key的多少要看成本,如果所有可能的查詢都設(shè)計(jì)對應(yīng)的key,那時(shí)間復(fù)雜度為1,查詢性能自然高;但代價(jià)也大,因?yàn)閗ey多了。如果想key少一點(diǎn),那查詢的復(fù)雜度自然要上去一點(diǎn)。所以緩存設(shè)計(jì)無非就是空間換時(shí)間的思路。然后,緩存的更新無非就是:自動(dòng)失效、定時(shí)更新、主動(dòng)通知3種。通過CQRS架構(gòu),由于CQ兩端是事件驅(qū)動(dòng)的,當(dāng)C端有任何狀態(tài)變化,都會(huì)產(chǎn)生對應(yīng)的事件去通知Q端,所以我們幾乎可以做到Q端的準(zhǔn)實(shí)時(shí)更新。

同時(shí)由于CQ兩端的完全解耦,Q端我們可以設(shè)計(jì)多種存儲(chǔ),如數(shù)據(jù)庫和緩存(Redis等);數(shù)據(jù)庫用于線下維護(hù)關(guān)系型數(shù)據(jù),緩存用戶實(shí)時(shí)查詢。數(shù)據(jù)庫和緩存的更新速度相互不受影響,因?yàn)槭遣⑿械?。對同一個(gè)事件,可以10臺(tái)機(jī)器負(fù)責(zé)更新緩存,100臺(tái)機(jī)器負(fù)責(zé)更新數(shù)據(jù)庫。即便數(shù)據(jù)庫的更新很慢,也不會(huì)影響緩存的更新進(jìn)度。這就是CQRS架構(gòu)的好處,CQ的架構(gòu)完全不同,且我們隨時(shí)可以重建一種新的Q端存儲(chǔ)。不知道大家體會(huì)到了沒有?

關(guān)于緩存key的設(shè)計(jì),我覺得主要從查詢余票時(shí)傳遞的信息來考慮。12306的關(guān)鍵查詢是:出發(fā)地、目的地、出發(fā)日期三個(gè)信息。我覺得有兩種key的設(shè)計(jì)思路:1)直接設(shè)計(jì)了該查詢條件的key,然后快速拿到車次信息,直接返回;這種方式就是要求我們系統(tǒng)已經(jīng)枚舉了所有車次的所有可能出現(xiàn)的票(區(qū)間)的緩存key,相信你一定知道這樣的key是非常多的。2)不是枚舉所有區(qū)間,而是把每個(gè)車次的每個(gè)原子區(qū)間(相鄰的兩個(gè)站點(diǎn)所連成的直線)的可用票數(shù)作為key。這樣,key就非常少了,因?yàn)檐嚧渭偃缬?0000個(gè),然后每個(gè)車次平均15個(gè)區(qū)間,那也就15W個(gè)key而已。當(dāng)我們要查詢時(shí),只需要把用戶輸入的出發(fā)地和目的地之間的所有原子區(qū)間的可用票數(shù)都查出來,然后比較出最小可用票數(shù)的那個(gè)原子區(qū)間。則這個(gè)原子區(qū)間的可用票數(shù)就是用戶輸入的區(qū)間的可用票數(shù)了。當(dāng)然,到這里我提到考慮出發(fā)日期。我認(rèn)為出發(fā)日期是用來決定具體是哪個(gè)車次聚合根的。同一個(gè)車次,不同的日期,對應(yīng)的聚合根實(shí)例是不同的,即便是同一天,也可能有多個(gè)車次聚合根,因?yàn)橛行┸嚧我惶煊袔装嗟模热缟衔?點(diǎn)發(fā)車的一班,下午3點(diǎn)發(fā)車的一般。所以,我們也只要把日期也作為緩存key的一部分即可。

總結(jié)

本文完全是憑自己對12306這個(gè)網(wǎng)站的核心業(yè)務(wù)的簡單思考而得到的一些設(shè)計(jì)結(jié)果。如果真正的DDD領(lǐng)域建模,更多的是要和業(yè)務(wù)一線的工作人員、領(lǐng)域?qū)<疫M(jìn)行深入溝通,才能更深入的了解該領(lǐng)域內(nèi)的業(yè)務(wù)知識(shí),從而才能設(shè)計(jì)出更靠譜的領(lǐng)域模型和架構(gòu)設(shè)計(jì)。我本人非常慚愧因?yàn)闆]有上12306買過火車票,家離的比較近,就算要買也是家人給我買:)所以,本文所分享的內(nèi)容難免是紙上談兵。但我覺得12306這個(gè)系統(tǒng)的業(yè)務(wù)確實(shí)比傳統(tǒng)的電商系統(tǒng)要復(fù)雜,且并發(fā)又這么高。所以,我覺得這個(gè)系統(tǒng)真的很值得大家重視模型的設(shè)計(jì),而不只是只關(guān)注技術(shù)層面的實(shí)現(xiàn)。有興趣的朋友們可以聯(lián)系我。


做網(wǎng)站前的四點(diǎn)建議

2016年國內(nèi)SEM行業(yè)現(xiàn)狀調(diào)研報(bào)告

我們的位置

廣州 廣州市黃埔區(qū)科學(xué)城科學(xué)大道18號(hào)芯大廈 159 8916 9178

深圳 深圳市南山區(qū)大沖國際中心九樓 159 1543 2684

粵西 茂名市茂南區(qū)油城三路粵西創(chuàng)業(yè)創(chuàng)新孵化基地B110 157 6767 8148

我們的服務(wù)

網(wǎng)站及移動(dòng)應(yīng)用 高端品牌網(wǎng)站 APP開發(fā) 小程序開發(fā) 微信運(yùn)營

系統(tǒng)應(yīng)用開發(fā) OA/ERP/CRM/HR系統(tǒng)開發(fā) 教學(xué)管理系統(tǒng) 電商系統(tǒng) 應(yīng)用型軟件系統(tǒng)定制開發(fā)

了解我們

公司簡介 聯(lián)系我們 我們的案例 新聞資訊

使用條款 隱私聲明 Cookies

© 2009-2026 廣州睿網(wǎng)信息科技有限公司 版權(quán)所有 粵ICP備16051058號(hào)

tushy一区二区三区视频| 中国精品人妻一区二区| 9999久久久久老熟妇二区| 成人超碰一区二区三区| 男生用大肌巴操美女骚穴| 18禁网站在线点击观看| 老司机在线视频福利观看| 午夜在线成人免费电影| 69精品人妻久久久久久久久久久| 免费看日韩黄视频在线观看| 丰满人妻被猛烈进入中文字幕| 男生用大肌巴操美女骚穴| 天天色 天天操 天天好逼| 在线人成视频免费观看尤物| 猫咪亚洲中文在线中文字幕| 国产视频成人自拍蝌蚪视频| 91精品麻豆91夜夜骚| 人妻熟女 亚洲 一页二页| 夜夜躁av麻豆男| lutu玩弄人妻短视频| 黑人3p日本女优中出| 国产主播诱惑毛片av| 丰满放荡熟妇在线播放| 99精品久久精品一区二区| 大香蕉尹人在线最新| 国产精品剧情在线亚洲| 亚洲天堂色综合久久| 日韩一级视频一区二区三区| 搞乱在线在线观看视频| 国产91免费在线观看| 最新国产精品拍在线观看| 日本欧美亚洲国产啊啊啊| 午夜国产免费视频亚洲| 福利视频导航在线观看| 成年人免费福利在线| 狂操鸡巴小骚逼视频免费观看| 免费24小时人妻视频| 91美女在线观看视频| 内地精品毛片在线观看| 成人十欧美亚洲综合在线| 999精品视频免费在线观看| 日本黄色一级电影网址| 91九色91在线视频| 丰满少妇_区二区三区| 97人妻av人人澡人人爽| 亚洲一区二区精品在线播放| 中字幕人妻熟女人妻a62v网| 全球高清中文字幕av| 国产一级一国产一级毛片| 熟妇精品午夜久久久久| 男女插鸡巴视频软件| 中文字幕一区二区人妻视频| 午夜福利午夜福利影院| 国产高清视频www夜色资源| 久久视频 在线播放| 亚洲国产综合久久精品| 中字幕人妻熟女人妻a62v网| 亚洲精品国品乱码久久久久| 午夜福利在线不卡视频| 18福利视频在线观看| 男人和女人的逼视频| 天堂在线中文字幕av| 69国产精品成人aaaaa片| 果冻麻豆一区二区三区| 夜色福利视频免费观看| av日韩视频在线观看| 日韩av水蜜桃一区二区三区| 免费啪啪啪网站在线观看| 极品内射老女人操逼视频| 午夜精品视频免费观看| 欧美精品乱码99久久蜜桃免费 | 久久久亚洲综合国产精品| 999精品视频免费在线观看| 内地精品毛片在线观看| 日韩黄色在线观看网站上 | 午夜久久久久欠久久久久| 天天操天天舔天天爽| 亚洲美女露隐私av一区二区精品| 视频免费在线观看网站| 老鸭窝在线毛片观看免费播放| 黑人爆操女人免费视频| av天堂新资源在线| 成人精品动漫一区二区| 丰满人妻被猛烈进入中文字幕| 一区二区三区内射美女| 黄色网络中文字幕日本| 国产资源网站在线播放| 日韩三级精品电影久久久久| 亚洲综合一区二区三区四区| 天天操天天日天天碰| 色噜噜噜噜色噜噜色合久一| 岛国av成人午夜高清| 日韩久久九九精品视频| 18岁禁一二三区免费体验| 欧美操大黑鸡巴视频在线观看| 国产天堂av不卡网| 亚洲中文字幕在线av| 日本少妇熟女乱码一区二区| xxoo福利视频导航| 91人妻人人做人人爽高清| 首页欧美日韩中文字幕| 裸日本资源在线午夜| 中文字幕 首页 人妻| av丝袜免费在线观看| 亚洲天堂色综合久久| —区二区三区女厕偷拍| 视频在线+欧美十亚洲曰本| 亚洲乱熟女一区二区三区影片| 日本老熟老熟妇七十路| 亚洲精品综合欧美精品综合| 成人av中文字幕在线看| 亚洲人妻系列在线视频| 国产成人91色精品免费看片| 50熟妇一区二区三区| 中文字幕综合网91| 亚州av嫩草av极品在线观看| 亚洲第一区av中文字幕| 人妻人妻在线视频网站| 2026天天操天天干| 欧美激情视频第一页| 欧美最新一区二区三区| 中文字幕熟女人妻丝袜丝在线| 欧美一级aaaaaaa片| 亚洲精品9999蜜桃| 99色在线观看免费观看| 无人区一码二码三码区别在哪| 成人超碰一区二区三区| 亚洲成a人77777| 天天干夜夜爽狠狠操| 神马不卡视频在线视频| 91久久久久久最新网站| 东京热日韩av在线| 人人妻人人澡人人爽97| 四虎精品久久免费最新| 午夜国产精品免费视频| av天堂a亚洲va天堂va里番| 人妻女侠被擒受辱记| 欧美黑人性猛交小矮人| 一区二区在线观看视频网站| 中文字幕日韩人妻在线三区| 国产精品igao为爱寻找激情| 亚洲中文字幕在线视频观看二区| 国产一区二区三区四区精| 伊人免费观看视频一| 午夜国产精品免费视频| 美女激情久久久久久久| 大鸡扒操大逼大片免费关看| 午夜夫妻性生活视频| 欧美黑人性猛交小矮人| 美女把腿张开给男的捅| 亚洲欧美精品海量播放 | 国产白丝一区二区三区av| 成年人黄色日本视频| 亚洲欧美国产人成在线| 欧美男男在线观看视频网站| 亚洲成人自拍av在线| 亚洲一区二区在线激情| 亚洲欧美日韩中文在线观看| 亚洲一区二区三区国产精品电影 | 九色91操最新在线观看网址| 97cao在线视频| 亚洲欧美另类校园春色| 福利美女视频在线观看| 福利在线国产小视频| 国产黑色丝袜 在线日韩欧美| 人妻色综合aaaaaa网| jizzjizz国产精品传媒| 偷拍熟女大胆免费视频| 天堂网免费在线电影| 91色乱一区二区三区| ysl蜜桃色7425| 亚洲欧美精品海量播放| 亚欧洲乱码视频一二三区| 久久久久久久久久久久久国产| 成人做爰av在线观看网站| 999久久久人妻精品一区| 亚洲天堂av最新在线| 国产精品久久久99| 人妻女侠被擒受辱记| 精品欧美乱码久久久| 亚洲理论在线a中文字幕97| 顶级欧美色妇4khd| 亚洲无人区乱码中文字幕一区| ass亚洲熟女ass| 久久精品四虎夜夜拍拍拍| 91香蕉国产亚洲一二三区| 亚洲av在线免费播放| 日日夜夜免费视频精品| —区二区三区女厕偷拍| 久久久精品人妻无码专区不卡 | 97精品视频,全部免费| 夜色17s精品人妻熟女av| 久久精品四虎夜夜拍拍拍| 精品视频在线观看免费99| 欧美一区二区三区爽爽| 九九热精品视频在线播放| 夜色17s精品人妻熟女av| av在线免费在线观看| 美利坚合众国av天堂| 91进入蜜桃臀在线播放| 午夜福利片无码10000| 99精品视频在线在线观看| 久久国产半精品99精品国产| 亚洲少妇视频在线观看| 欧美黑人1区2区3区| 精品国产久久久久午夜精品av| 福利小视频免费在线| 日本老熟老熟妇七十路| 91性高湖久久久久久久久久| 熟女一区二区视频在线 | 成人午夜麻豆大胆视频| 日本四十路人妻熟女| 成年人黄色日本视频| 天天日 天天舔 天天射| 夏目彩春av在线看| 国语精品视频自产自拍| 日本少妇三级交换做爰做| 先锋人妻啪啪中文字幕| 在线看的免费网站黄| 日本香港韩国三级黄色| 美女欧美视频在线观看免费| 一区二区三区四区 在线播放| 99热99这里免费的精品| 日本一区二区三区调教性奴视频| 91超精品碰国产在线观看| 欧美日本在线免费视频| 欧美日韩国产在线中文字幕| 东京热日本一区二区三区| 亚洲熟女乱一区二区精品成人| 福利美女视频在线观看| 上床啪啪啪免费视频| 男人av一区二区三区| 日韩男女视频网站在线观看| 亚洲av激情综合网| 韩国在线播放一区二区三区| 亚洲在线观看中文字幕av| 三级欧美日韩一区二区三区| julia人妻av一区二区三区| 老司机免费视频福利0| 国产成人在线观看hd| 高清欧美色欧美综合网站| 麻豆白洁少妇在线播放| 强乱人妻中文字幕日本| 91国产精品乱码久久久久久| 日韩无码国产一区二区| 国内精品一区二区2021在线| 成人av在线视频免费| 天堂av在线最新地址| 亚洲人成小说网站色| 伊人网在线免费观看| 亚洲成a人77777| 韩国资源视频一区二区三区| 亚洲乱熟女一区二区三区影片| 久操资源在线免费播放| 最新日韩中文字幕啪啪啪| 夫亡人妻被强干中文字幕| 亚洲综合一区二区三区四区| 911精产国品一二三产区区| 人妻少妇精品二三区| 日韩欧美中文字幕老司机三分钟| 在线观看视频免费一区二区三区| 亚洲国产日韩a在线欧美| 九九九九九久久久国产| 男插女视频大全免费| 国产精品蝌蚪自拍视频| 日韩人妻中文字幕二区| 亚av一二三在线观看| 最新国产精品久久精品app| 久久午夜免费鲁丝片| 天堂av在线最新地址| 不卡视频在线 欧美日韩| 日本人妻熟妇丰满成熟HD系列| 91美女在线观看视频| 婷婷色综合五月天视频| 免费看日韩黄视频在线观看| 精品av天堂毛片久久久| 国产一区二区三区四区精| av在线观看视频免费| 日本高清在线观看不卡视频| 老熟妇一区二区三区v∧88| 久久av色噜噜ai换脸| 国产又粗又长又大视频| 国产91黑丝小视频在线观看| 999精品视频免费在线观看| 午夜3p福利视频合集| 黑鸡巴肏少妇逼视频| 久久亚洲国产成人精品麻豆| 亚洲乱熟女一区二区三区山| 亚洲午夜精品一级毛片app| 欧美亚洲另类精品第一页| 国长拍拍视频免费孕妇| 韩国在线播放一区二区三区| 欧美一级日韩一级亚洲一级va| 日本老熟老熟妇七十路| 国产激情免费在线视频| 伦理在线观看未删减中文字幕| 1级黄色片在线观看| 日本男女免费福利视频| 午夜在线观看一级毛| 午夜精品久久秘?18免费观看| 日本老熟妇av老熟妇| 最新日韩av电影在线播放| 亚洲午夜高清在线观看| 在宿舍强奷两个清纯校花| 国产最新av在线免费观看| 日本高清 中文字幕| 92午夜免费福利视频www| 久久99久久99久久97的人| 97精品国产91久久久| 亚洲欧美国产人成在线| 一区二区三区免费版在线| 中文字幕熟女乱一区二区| 亚洲自拍偷拍一区二区中文字幕 | 精产国品一二三产品区别91| 欧美一级日韩一级亚洲一级va| 精品精品精品精品精品污污污污| av里面的动作是真进去吗| 亚洲av手机免费在线| 亚洲黄色免费在线观看网站| 国产精品美女免费视频观看| 黄片视频免费观看视频| 成人av中文字幕在线看| 色老头一区二区三区四区五区| 91系列视频在线播放| 亚洲同性同志一二三专区| 日本美女爱爱视频网站| 91久久精品美女高潮喷水白浆| 北野中文字幕一区二区| 国产极品气质外围av| 国产夫妻视频在线观看免费| 九色91操最新在线观看网址| 亚av一二三在线观看| 美女av色播在线播放| 自拍偷拍 国产激情| 99精品久久99久久久久一| 亚洲美女色www色| 在线免费观看视频18| 大尺度久久久久久久| 女生抠逼自慰啊啊啊啊啊啊啊下载| 中文字幕免费啪啪啪| 国产成人在线观看hd| 精品视频在线观看免费99| 区一区二区三免费观看视频| 国产黄色主播网址大全在线播放| 91精品资源在线观看| 男插女视频大全免费| 午夜情色一区二区三区| 制服丝袜中文字幕熟女人妻| 亚洲国产精品一区51动漫| 玖辛奈18禁同人污本子| 亚洲欧美不卡专业视频| 夜夜操天天干夜夜操| 熟妇人妻av无码中文字幕| tushy一区二区三区视频| 先锋人妻啪啪中文字幕| 人妻少妇精品二三区| 欧美情色av在线观看| 亚洲高清一区二区三区久久| 69精品人妻久久久久久久久久久| 99国产精品久久99久久久| 18福利视频在线观看| 亚成区一区二区人妻熟女| 91九色人妻在线播放| 一区二区三区四区视频精品免费| 亚洲三级综合在线观看| 亚洲美女色www色| 亚洲精品久久久人妻| 久操资源在线免费播放| 国产一区二区三区四区精| 亚州av嫩草av极品在线观看| 啊不行啊操逼好爽大鸡吧视频| 玖玖资源站在线观看亚洲| 中文字幕日本一二三区| 蜜乳av中文字幕一区二区| 日本黄页在线观看视频| 人妻熟女 亚洲 一页二页| 成人黄色录像在线观看| 精产国品一二三77777| 欧美久久蜜臀蜜桃资源吧| 夜夜爽夜夜操夜夜爱| 亚洲国产日韩精品在线| 午夜呻吟亚洲精品中文字幕在上面| 99热在线只有的精品| 裸露视频免费在线观看| 日本老熟老熟妇七十路| 日韩人妻中文字幕二区| 老牛影视在线一区二区三区| 最新日韩中文字幕啪啪啪| 99国产精品久久99久久久| 午夜免费福利老司机| 深夜福利免费观看在线看| 亚洲国产日韩a在线欧美| 91超精品碰国产在线观看| 极品风骚人妻3p视频| 在线视频国产精品欧美| 黄片操操操操操操c| 精品人妻人人做人人爽| 成熟了的熟妇毛茸茸| 狠狠干狠狠操免费视频| 熟妇高潮久久久久久久| avjpm亚洲伊人久久| 亚洲熟女一区二区三区250p| 快色视频在线观看免费| 亚洲码av一区二区三区| 久久精品国产亚洲av清纯| 亚洲乱熟女一区二区三区山| 九九九九九久久久国产| 人人妻人人澡人人爽97| 伊人网在线欧美日韩在线| 自拍偷拍 国产激情| 丰满少妇高潮喷水视频| av大尺度一区二区三区| 91精品麻豆91夜夜骚| 开心激情五月天作爱片| 99热这里只有精品免费播放| 天天操天天舔天天爽| 国产精品 亚洲欧美 自拍偷拍 | 天天综合久久无人区| 18在线观看免费观看| 丰满人妻熟女aⅴ一区| 女人扒开逼让男人操| 色哟哟亚洲乱码国产乱码精品精| 中文字幕中文字幕在线中…一区| 成熟了的熟妇毛茸茸| 三级欧美日韩一区二区三区 | 中文在线字幕免费观看日韩视频| 大屁股熟女一区二区视频| 狠狠操av一区二区三区| 免费绝清毛片a在线播放| 午夜宅男电影av网站| 亚洲色图日韩在线视频观看| 天天摸天天干夜夜操| 欧美日韩成人高清中文网| 亚洲制服丝袜网站中文字幕| 一看就是假奶的av| 在线中文字幕人妻av| 韩国毛片w妈妈的朋友7| 亚洲综合熟女乱中文| 天堂在线中文字幕av| 人妻女侠被擒受辱记| 4438全国成人免费视频| 男人的天堂在线2025| 亚洲乱熟女一区二区三区影片| av里面的动作是真进去吗 | 亚洲成人偷拍自拍在线| 大乳丰满人妻中文字幕韩国hd| 顶级欧美色妇xxxx| 亚洲综合第一区二区| 婷婷色九月综合激情丁香| 国产av在线免费视频| 日韩人妻一区二区三区在线观看| 91精品国产人妻麻豆| 一区二区三区 国产日韩欧美| 视频免费在线观看网站| 午夜92福利1000| 国产精品中文字幕丝袜| 欧美一区日韩二区三区四区| 户外露出视频在线观看| 亚洲成人,国产精品| 欧洲成熟女人色惰片| xxxx69在线观看视频| 老司机免费视频福利0| 国产精品无码无卡免费观| 大成色亚洲一二三区| 美女一区二区四区六区八区| 国内精品一区二区2021在线| 国产精品成人免费电影| 亚洲成人自拍av在线| 69精品人妻久久久久久久久久久 | 美女精品久久久久久久久| 黑人爆操女人免费视频| 丰满少妇人妻一区二区三区蜜桃| 顶级欧美色妇4khd| 日本香港韩国三级黄色| 青青草一个释放的网站| 美利坚合众国av天堂| 福利视频导航在线观看| 伊人免费观看视频一| 人妻中文字幕亚洲在线 | 欧美久久一区二区伊人| 久久久国产精品免费视频网| 九九视频在线观看全部| 久久国产精品久精国产爱| 狠狠操深爱婷婷综合一区| 开心五月综合激情婷婷| 蜜桃tv一区二区三区| jizzjizz国产精品传媒| 国产伦理二区三区在干嘛呢| 精品一区二区三区免费毛片W| 国产91免费在线观看| 亚洲国产精品自拍偷拍视频在线| 美国男的操女孩的小嫩逼| 伊人久久综合国产精品 | 婷婷色综合五月天视频| 911美女片黄在线观看| 人妻在线中文视频视频| 国产精品国产三级在线高清观看| 久久久西西gogo日本美女人体| 青青青国产精品视频| 青娱乐免费视频一二三| 黄色网络中文字幕日本| 91激情四射婷婷综合| 伊人精品久久一区二区| 国产视频成人自拍蝌蚪视频| 中文字幕亚洲乱码精品无限| 91福利高清在线播放| 日本熟妇乱妇熟色视频| 九色porny91国产| 青青青青午夜手机国产视频| 手机视频在线观看一区| 天天插天天操天天射天天干| 国产成人在线观看hd| 天天干夜夜操夜夜骑| 五月激情婷婷四射基地| 东京热男人的天堂视频| 中出小骚货在线观看| 精品欧美乱码久久久| 亚洲精品1卡2卡3卡| 蜜桃tv一区二区三区| 九十九步都是爱最后一步是尊严 | 91精品在线视频免费视频| 久久久久久久岛国免费观看| 日韩男女视频网站在线观看| 亚成区一区二区人妻熟女| 日本不卡 中文字幕| 五月婷婷伊人久久中文字幕| 中文字幕一区二区三区久久久| 亚洲精品国品乱码久久久久| 美女露阴道让男人捅| 日韩久久九九精品视频| 不卡高清一区二区三区| 天天日天天玩天天摸| 国产精美视频精品视频精品| 欧美啪啪一区二区三区| 白白色在线免费视频发布视频| 国内销魂老女人老泬| 日本电影一级人妻在线播放四区| 欧美日韩成人高清中文网| 看女人大BB群伦交| 国产经典精品欧美日韩| 色老头一区二区三区四区五区| 国产在线观看一区二区三区四区| 亚洲成年人精品国产| 亚洲人成大片在线观看| 懂色av之国产精品| 可在线免费观看av| 玖玖资源站在线观看亚洲| 亚洲熟女少妇中文字幕系列| 伊人网在线观看 视频一区| 免费看一级高潮喷水片| 狠狠操狠狠操狠狠插| 久久久久性感美女偷拍视频| 日本韩国欧美在线视频| 丝袜美女诱惑佐佐三上| 亚洲精品综合欧美精品综合| 青青青在线观看国产| 60路70路日本熟妇| 大屁股熟女一区二区视频| 国产乱码有码一区二区三区| 亚洲精品国品乱码久久久久| 亚洲一区在线视频观看地址| 色哟哟亚洲乱码国产乱码精品精 | 婷婷综合缴情亚洲五月伊人| 亚洲天堂色综合久久| 亚洲熟女一区二区三区250p| 又爽又粗又猛又色又黄视频| 4438x亚洲最大的成人| 丰满人妻被猛烈进入中文字幕| 中文字幕日本一二三区| 亚洲午夜精品一级毛片app| 国产农村乱子伦精精品视频| 国产av剧变态维修工虐杀美女| 久久久久久久久久久久久国产| 高潮喷水在线视频观看| 在线观看免费啪啪啪| 91亚洲国产成人久久精品| 日本高清激情乱一区二区三区| 狠狠操深爱婷婷综合一区| 不用付费特黄特色亚洲特级黄色片| 男生用大肌巴操美女骚穴| 福利一二三在线视频观看| 真人一进一出抽搐大尺度视频| 青青青在线视频免费播放| 天天日 天天舔 天天射| 中文字幕在线字幕乱码怎么设置| 神马不卡视频在线视频| 99久久久久久久久久久久久| 天天日天天干天天日天天干天天| 在线视频自拍第三页| 日本高清激情乱一区二区三区 | 韩国在线播放一区二区三区| 天天爽天天操天天插| 黄版视频在线免费观看| 韩国毛片w妈妈的朋友7| 可以直接看av网站| www,日韩av,com| 免费啪啪啪网站在线观看| 免费的啪啪视频软件| 国产乱码有码一区二区三区| aa福利影视在线观看| 亚洲午夜高清在线观看| 午夜福利午夜福利影院| 天天做天天日天天搞| 99热99这里免费的精品| 亚州av嫩草av极品在线观看| 日本高清激情乱一区二区三区| 国产自拍偷拍视频在线免费观看| 色视频免费观看网址| 放荡人妻极品少妇全集| 中文字幕中文字幕在线中…一区| 91porny九色视频偷拍| 亚洲欧美成人午夜一区二区| 污网址在线观看视频| 天天日夜夜操人人爽| 天天干天天色综合久久| 91超碰九色porny| 亚洲永远av在线播放| 亚洲经典av中文字幕| 熟妇精品午夜久久久久| 亚洲情色777中文字幕| 国产肥胖熟女又色又爽免费视频| 日韩欧美黄色免费网站| 91精品国产欧美在线| 亚洲精品激情视频在线观看| 男人资源站中文字幕| 在线视频国产精品欧美| 九九六视频,这里只有精品| 4日日夜夜精品视频免费| 天天看天天爱天天日| 日韩三级黄色大片在线观看| 一区二区三区国产精华液区别大吗| 最新福利二区三区视频| 欧美一区日韩二区三区四区| 狠狠操狠狠操狠狠插| 久久视频 在线播放| 夜色17s精品人妻熟女av| 川上优所有中文字幕在线| 91精品国产91久久久久久密臀| 4438全国成人免费视频| 天天碰天天摸天天搞| 国产精品国产三级在线高清观看| 天天干天天操天天日天天日| 猫咪亚洲中文在线中文字幕| 国产,亚洲,欧美综合| 日韩激情亚洲国产欧美另类激情| 免费成人av麻豆| 不卡在线一区二区三区| 中文人妻av一区二区三区| 国产福利三级在线观看| 午夜免费福利老司机| www,日韩av,com| 男女69视频在线观看免费| 99久久国产精品免费热| 婷婷一区二区三区五月丁| 国产精品国产三级在线高清观看| 2020国产成人精品视频| 91精品国产综合99| 女人扒开逼让男人操| 一区二区三区四区视频精品免费| 青青操久久综合激情| 亚洲综合天堂av网站在线观看 | 超碰在线pro中文字幕| 69国产在线视频网站| 呻吟求饶的人妻中文字幕| 亚洲国产精品一区二区第二页| 91在线九色porny| 亚洲国产日韩精品在线| 日韩国产欧美一区二区三区粉嫩| 成人午夜av电影网| 偷拍欧美日韩另类图片| 亚洲成人激情在线综合| 91九色人妻在线播放| 欧美久久蜜臀蜜桃资源吧| avgo成人短视频| 免费成人av麻豆| 久久99久久99久久97的人| 日本四十路人妻熟女| 福利美女视频在线观看| 亚洲黄色免费在线观看网站| 青青在线免费手机播放视频| 大陆中文字幕视频在线| 久草久热这里只有精品| 92麻豆一区二区三区| 中文字幕综合网91| 天天夜夜久久精品综合| 69视频在线精品国自产拍| 久久久亚洲熟女一区二区| 亚洲制服丝袜在线看| 欧美最新一区二区三区| 性感人妻 中文字幕| 青青青在线视频免费播放| 九九热精品视频在线播放| 成人十欧美亚洲综合在线| 国产一区二区三区四区精| 91香蕉国产亚洲一二三区| 美女把腿张开给男的捅| 日本少妇熟女乱码一区二区| 久久视频 在线播放| 欧美大胆a级视频秒播| 琪琪日本福利伦理视频| 久久午夜免费鲁丝片| 美女黄色啊啊啊啊视频| 黄色片免费国产精品| 亚洲第一区av中文字幕| 韩国资源视频一区二区三区 | 99久久国语露脸国产精品| 国产精品成人免费电影| 日日躁夜夜躁狠狠操| 日韩欧美中文字幕老司机三分钟| 免费看日韩黄视频在线观看| 国产高清自拍偷拍在线| 久久久亚洲综合国产精品| 国产激情一区二区视频| 欧美视频亚洲视频在线| 自拍偷拍亚洲综合第一页| 丰满人妻被猛烈进入中文字幕| 男人资源站中文字幕| 日本a级2020在线观看| 亚洲欧美国产人成在线| 日本国产亚洲欧美色综合| 一二三四区国产在线观看| 欧美久久一区二区伊人| 亚洲色视频在线播放网站| 伊人网在线免费观看| 深夜福利免费观看在线看| 国产激情在线观看一区二区三区| 婷婷六月天在线视频| 妈妈的朋友中字在线免费观看| 亚洲国产电影的一区| 亚洲女人自熨在线视频| 手机看片福利一区二区三区四区 | 99久久免费播放在线观看视频| yellow在线亚洲精品一区| 人妻少妇视频系列视频在线| 亚洲中文字幕最新地址| 免费啪啪啪网站在线观看| 99在线视频精品观看高| —区二区三区女厕偷拍| 欧美巨大另类极品video| 青青操久久综合激情| 夫亡人妻被强干中文字幕| 大片a免费观看在线视频观看| 午夜精品视频免费观看| 青青青青午夜手机国产视频| 亚洲综合一区二区三区四区| 天天干天天操天天要| 黄色片免费国产精品| 二十四小时日本高清在线观看| 不卡在线一区二区三区| 天天操天天舔天天爽| 首页欧美日韩中文字幕| 亚洲乱码国产乱码精品精视频| 国产自拍偷拍在线精品| 亚洲美女a级黄色在线播放| 久久99精品热在线观看| 免费在线观看亚洲福利| 顶级欧美色妇xxxx| www,日韩av,com| 人人妻人人狠人人爽| 久久热在线免费观看| 18禁男女啪啪啪无遮挡| 91大神在线免费观看视频| 国产成人深夜福利短视频99| 久久久西西gogo日本美女人体| 91九色91在线视频| 欧美日韩亚洲国产视频二区| 5566熟女人妻人妻| 亚洲熟女一区二区六区| 免费中文三级在线观看| 亚洲一区二区三区国产精品电影| 免费看超污视频在线观看| 欧美成人少妇人妻精品| 97成人老师在线视频| 亚洲欧美综合另类最新| 国产剧情av在线免费观看| 熟女国内精品一区二区三区| 美女妩媚午夜诱惑网站| 国产主播诱惑毛片av| 黄色av日韩在线观看| 河北全程露脸对白自拍| 亚洲gay视频在线观看| 国产主播诱惑毛片av| 亚洲av毛片在在线播放| 国产精品性感美女视频| 鸡巴插进美女的嫩小穴视频| 日本高清激情乱一区二区三区| 日本黄页在线观看视频| 天天操天天舔天天爽| 午夜福利国产精品久久久久 | 欧美成人屋影院在线视频观看| 国模伊人久久精品一区二区三区| 欧美精品乱码99久久蜜桃免费 | 夏目彩春av在线看| 夜夜人人干人人爱人人操| 一区二区三区国产精华液区别大吗| 天天干天天操天天要| 国产精品成人免费电影| 欧美啪啪一区二区三区| 亚洲综合第一区二区| 欧美强奸视频在线观看| 久久精品久久久久观看99水蜜桃| 亚洲码av一区二区三区| 国产91精品福利系列| 欧美成人红桃视频在线观看| 精品国产污污污免费入口| 男人的天堂aⅴ在线| 亚洲欧美日韩中文视频| av日韩视频在线观看| 亚洲激情噜噜噜久久久| 日本午夜福利免费在线播放| 午夜精品久久久久久久精品乱码| 日日夜夜免费视频精品| 在线看的免费网站黄| 亚洲一区二区在线激情| 天天操天天射天天操天天日 | 欧美国产精品久久久免费| 69精品互换人妻4p| 日本一区二区三区调教性奴视频| 欧美日韩成人高清中文网| 91久久久久久最新网站| 最近日韩免费在线观看| 92午夜免费福利视频www| 国产精品亚洲精品亚洲| 黄版视频在线免费观看| 人妻超清中文字幕在线乱码| 亚洲男人的天堂最新网址| 亚洲一区二区三区国产精品电影| 国产一级一国产一级毛片| 99国产精品久久99久久久| 97精品视频,全部免费| 日本人妻熟妇丰满成熟HD系列| 波多野结衣在线一区别| 91精品资源在线观看| 欧美黄色性视频网站| 最新日韩av电影在线播放| 97cao在线视频| 亚洲一区二区在线激情| 桃色成人开心激情网| 高清欧美色欧美综合网站| 男人用大鸡巴狂操女人肉穴| 黄色av网址在线播放| 天天爱天天日天天爽| 亚洲同性同志一二三专区| 成人做爰av在线观看网站| 在线免费观看视频18| 蜜臀久久精品久久久久久av| xxoo福利视频导航| 成人做爰av在线观看网站| 啊~插得好快别揉我胸了视频| 九色porny91国产| 无码精品黑人一区二区老人| 搞乱在线在线观看视频| 91系列视频在线播放| 日本高清在线观看不卡视频| 啪啪啪网站免费在线看| 国产美女高潮精品视频| 国产视频成人一区二区| 99在线视频精品观看高| 全彩漫画口工18禁| 国产激情一区二区视频| 夫亡人妻被强干中文字幕| 三区美女视频在线观看| 久久sm人妻中出精品一区二区| 精品人妻人人做人人爽| 亚州av嫩草av极品在线观看| 国际日韩日韩日韩日韩日韩 | 亚洲制服丝袜网站中文字幕 | 黄色av 在线观看| 91九色人妻在线播放| 成人午夜麻豆大胆视频| 国产亚洲综合5388| 久久久久高潮白浆久久| 日韩女同与成人用品电影免费看| 1区3区4区产品乱入视频| 熟妇人妻av无码中文字幕| av人摸人人人澡人人超碰小说| 黄很色很在线免费视频网站| 蜜桃臀av在线一区二区| av毛片在线观看网址| 4438全国成人免费视频| 女人扒开逼让男人操| 亚洲欧美国产人成在线| 亚洲制服丝袜资源网| 二十四小时日本高清在线观看 | 人人妻人人澡人人爽97| 老鸭窝在线毛片观看免费播放| 4日日夜夜精品视频免费| 美女把腿张开给男的捅| 五十岁熟女高潮喷水| 成人av中文字幕在线看| 内地精品毛片在线观看| 日韩欧美黄色免费网站| 91日本精产品一区二区三区| av中文字幕国产精品| 68福利精品在线视频| 亚洲综合成人精品成人精品| 国际精品熟女一区二区| 91久久久精品成人国产| 女人扒开逼让男人操| www一区二区91| 免费成人av麻豆| 欧美黑人1区2区3区| 女人的天堂av在线网| 污网址在线观看视频| 天天干天天操天天日天天日| 亚洲成人三级黄色片| 污视频在线观看地址| 美女黄色啊啊啊啊视频| 在线看的免费网站黄| 日韩女同与成人用品电影免费看| 天天摸天天干夜夜操| 亚洲AV无码久久精品国产一区老| 国内精品一区二区2021在线| 国产欧美福利在线观看| 久草视频在线看免费| 又爽又粗又猛又色又黄视频| 午夜精品小视频在线播放| 成人av中文字幕在线看| 天天躁狠狠躁狠狠躁性色| 日韩激情亚洲国产欧美另类激情 | 好看的日本中文字幕在线观看二区| 亚洲精品激情视频在线观看| 真人一进一出抽搐大尺度视频| 欧美成人屋影院在线视频观看| 久久久久夜色国产精品电影| 国产亚洲精品啪啪视频| 欧洲亚洲一区二区三区四区| 在线免费观看视频18| 人人妻人人爽人人摸| 亚洲乱码国产乱码精品精视频| 亚洲综合天堂av网站在线观看| 黄色av日韩在线观看| 午夜免费福利老司机| 放荡人妻极品少妇全集| 日本人妻少妇xxxxxxx| 欧美操大黑鸡巴视频在线观看| 国长拍拍视频免费孕妇| 老司机伊人99久久精品| 国产成人综合久久婷婷| 日本香港韩国三级黄色| 午夜一区二区三区视频在线观看 | 可以免费观看日韩av| 国产高清视频www夜色资源| 亚洲 综合 欧美 一区| 中文字幕亚洲乱码精品无限| 92麻豆一区二区三区| 久久99嫩草99久久精品| 强乱人妻中文字幕日本| 欧美丝袜亚洲国产日韩| 天天看天天爱天天日| 亚洲国产日韩a在线欧美| 人妻超清中文字幕在线乱码| 最新国产精品综合网高清| 亚洲国产精品久久久久久无码| 国产精品成人免费电影| 亚洲av激情综合网| 久久人妻人人草人人爽| 一区二区三区四区久久久久韩日| 亚洲天堂色综合久久| 91佛爷视频在线观看| 91久久久精品成人国产| 91精品麻豆91夜夜骚| 国产主播诱惑毛片av| 网友自拍第一页99热| 港台美女明星av天堂| 日韩激情亚洲国产欧美另类激情| 精品国产污污污污免费观看| 高潮喷水在线视频观看| 亚洲欧美精品海量播放| 天天弄天天草天天日天天| 伊人网国产在线播放| 亚洲欧美日韩中文在线观看| 亚洲制服丝袜资源网| 午夜92福利1000| 天天操天天射天天操天天日| 国产亚洲精品啪啪视频| 日本久久久久久黄色| 中文字幕日韩首页欧美在线激情| 中文字幕国产一区在线视频| 成人午夜麻豆大胆视频| 日韩黄色在线观看网站上| 人妻激情偷乱一区二区三区av| 天天干天天操天天要| 久99久视频免费观看中文字幕| 亚洲成人五月婷婷久久综合| 老司机在线视频福利观看| 日本不卡 中文字幕| 夜夜操夜夜爱夜夜摸| 欧美精品激情在线不卡| 99久9在线视频播放| 青青操久久综合激情| 国产清纯一区二区在线观看 | 青青青国产精品视频| 亚洲美女色www色| 丰满少妇_区二区三区| ysl蜜桃色7425| 人人妻人人狠人人爽| 黑人大巨屌操美女逼| 韩国毛片w妈妈的朋友7| 97人妻av人人澡人人爽| 18禁网站在线点击观看| 夜夜人人干人人爱人人操| 欧美亚洲愉拍一区二区三区| 亚洲一区二区在线激情| 一区二区三区观看在线| 亚洲午夜国产末满十八岁勿进网站| 可在线免费观看av| 99精品久久一区二区| 天天综合久久无人区| 亚洲AV无码久久精品国产一区老| 午夜精品久久久久久久久久蜜桃| 91精品夜夜夜一区二区| 999精品视频免费在线观看| 成人av在线视频免费| 538欧美在线观看一区二区三区 | 视频自拍偷拍视频自拍| 一区二区在线观看视频网站| 亚洲人人爽人人澡起碰av| 北野中文字幕一区二区| av中文字幕国产精品| 无码精品黑人一区二区老人 | 五月的婷婷综合视频| 性感美女人妻久久久| 1区3区4区产品乱入视频| 一区二区欧美 国产日韩| 亚洲国产综合久久精品| 黑人侵犯人妻森泽佳奈| 久久99热精品免费观看视| 麻豆国产91制片厂| 91九色人妻在线播放| 久久av色噜噜ai换脸| 77亚洲视频在线观看| 天天干夜夜操91视频网站| 亚洲午夜精品视频节目| 制服丝袜中文字幕熟女人妻| 午夜国产精品免费视频| 无人区一码二码三码区别在哪| 人妻色综合aaaaaa网| avtt中文字幕手机版| 婷婷色九月综合激情丁香| 亚洲中文字幕在线视频观看二区 | 国产白丝一区二区三区av| aaaa级少妇高潮在线观看| 日本少妇人妻中文在线| 2018中文字字幕人妻| avtt中文字幕手机版| 男人的天堂aⅴ在线| 精品精品精品精品精品污污污污| 欧美日韩福利视频网| 公侵犯人妻中文字幕巨| 日本电影一级人妻在线播放四区| 亚洲综合色一区二区三区| 欧美亚洲精品色图网站| 欧美成人屋影院在线视频观看| 青青青青午夜手机国产视频| jiee日本美女视频网站| 97精品久久久久久无码人妻 | 亚洲国产日韩欧美一区二区三区,| 99精品久久精品一区二区| 国产igao激情在线视频入口| 91九色人妻在线播放| 久久99热精品免费观看视| 新香蕉视频香蕉视频2| 韩日一级人添人人澡人人妻精品| 2021国产在线视频| 猫咪亚洲中文在线中文字幕| 欧美成人久久久桃色aa| 日本高清在线观看不卡视频| 国产高清自拍偷拍在线| 手机视频在线观看一区| 天天曰天天摸天天爽| 国际日韩日韩日韩日韩日韩 | 先锋人妻啪啪中文字幕| 日韩成人在线电影首页| 日本男女免费福利视频| 最新激情中文字幕视频| 在线人成视频免费观看尤物| 天天摸天天舔天天操天天日| 97精品视频,全部免费| 免费看日韩黄视频在线观看| 亚洲理论在线a中文字幕97| 公侵犯人妻中文字幕巨| 美女黄色啊啊啊啊视频| 自拍偷拍色图亚洲天堂| 亚洲熟女在线免费观看| 婷婷色综合五月天视频| 午夜精品久久久久久久精品乱码| 秋霞成人午夜鲁丝一区二区三区| 福利视频免费在线播放| 黄片视频免费观看视频| 黄在线看片免费人成视频| 超级黄肉动漫在线观看| 老熟女xxxⅹhd老熟女性| 丰满少妇高潮喷水视频| 在线观看中文字幕精品av| 超级黄肉动漫在线观看| 久久视频 在线播放| 国产91精品福利系列| 青青在线免费手机播放视频| 老牛影视在线一区二区三区| 在线观看2022av| 久久国产精品久精国产爱| 欧美精品熟妇免费在线| 一区二区三区国产在线成人av | 国产激情视频在线观看的| 亚洲午夜精品视频节目| 大屁股熟女一区二区视频| 黄色片黄色片黄色片黄色片黄色 | 99久久国语露脸国产精品| 92在线播放观看视频| 欧洲成熟女人色惰片| 中文字幕亚洲乱码精品无限| 熟女一区二区三区综合| 成人免费电影二区三区| 在宿舍强奷两个清纯校花| 亚洲同性同志一二三专区| 99色在线观看免费观看| 快使劲弄我视频在线播放| 韩国在线播放一区二区三区| 国际精品熟女一区二区| 无码精品黑人一区二区老人| 欧美亚洲国产一区二区| 午夜久久久久久av五月| lutu玩弄人妻短视频| 美利坚合众国av天堂| 在线观看2022av| 在线观看中文字幕视频成人| 日本福利视频网站导航| av资源中文字幕在线观看 | 国语对白性爱三级片免费看| 中文字幕日韩人妻在线三区| 欧美男女一区二区三区| 伊人综合在线视频免费观看| 老鸭窝在线毛片观看免费播放| 人妻系列在线免费视频| 亚洲自拍偷拍av在线| 亚洲欧美成人激情在线| 国产大桥未久一区二区| 一区二区三区午夜福利在线| 久久久久性感美女偷拍视频| 日本黄色一级电影网址| 麻豆出品视频在线观看| 久久精品久久久久观看99水蜜桃| 日本亚洲午夜福利一区二区三区 | 伊人网在线免费观看| 亚洲精品国产99999| 成人av在线视频免费| 麻豆午夜激情在线观看| 免费成人av麻豆| 欧美黄色一区二区三区视频| 爱搞视频在线观看视频91| 偷拍欧美日韩另类图片| 国产 亚洲 欧美 自拍| 中文字幕欧美人妻在线.| 68福利精品在线视频| 天天搞天天操天天干| 亚洲成人 国产精品| 九九热视频1这里只有精品| 日本久久久久久黄色| 9999久久久久老熟妇二区| 日韩加勒比精品在线看| 青娱乐免费视频一二三| 国产极品气质外围av| 77亚洲视频在线观看| 一区二区三区资源视频| 老司机伊人99久久精品| 加勒比东京热绿帽人妻多人操| 日韩少妇免费在线播放| 日本人妻少妇xxxxxxx| jiee日本美女视频网站| 特级aaaaa黄色片| 黄色av 在线观看| av在线免费在线观看| 色欲AV蜜桃一区二区三| 午夜情色一区二区三区| 日本少妇人妻凌辱在线| 91超精品碰国产在线观看| 国产精品午夜无码AV体验区| 亚洲精品9999蜜桃| 老司机伊人99久久精品| 亚洲乱码av一区二区蜜桃av| 欧美一区二区三区爽爽| 国产黑色丝袜 在线日韩欧美| 最新国产午夜激情视频| 免费啪啪啪网站在线观看| 天海翼亚洲一区在线观看| 麻豆白洁少妇在线播放| 精产国品一二三产品区别97| 自拍偷拍色图亚洲天堂| 亚洲一区二区三区四区入口| 亚洲黄色免费在线观看网站| 青青草原在线播放日韩| 92午夜免费福利视频www| 日韩A级毛片免费视频| 亚洲熟女人妻自拍在线视频 | 在线中文字幕人妻av | 国产午夜在线播放视频| 日韩A级毛片免费视频| 最新免费在线观看污视频| 日本国产亚洲欧美色综合| 欧美黄色性视频网站| 色999日韩偷自拍拍免费| av在线免费在线观看| 999久久久人妻精品一区| 亚洲综合在线视频在线播放| 91精品综合久久久久久五月天| 手机视频在线观看一区| 亚洲精品中文字幕手机在线免费看| 成熟了的熟妇毛茸茸| 欧美成人红桃视频在线观看| 最近在线中文字幕免费| 欧洲精品在线免费观看| 在线观看免费啪啪啪| 偷拍欧美日韩另类图片| 区一区二区三免费观看视频| 高清av在线婷一区二区色日韩| av在线播放观看h| 91久久久久久最新网站| 亚洲全国精品女人久久久| 中国精品人妻一区二区| 亚洲午夜熟女在线观看| 欧美久久蜜臀蜜桃资源吧| 4438全国成人免费视频| 天天操天天日天天碰| 男女啪啪啪啪91av日韩| 久久久西西gogo日本美女人体| 蜜臀一区二区日韩美女少妇视频 | 亚洲欧美日韩电影一区| 91久久精品美女高潮喷水白浆| 国产91免费在线观看| 日本一本午夜在线播放| tushy一区二区三区视频| 午夜国产成人精品视频观看| 天天搞天天操天天干| 午夜精品久久久久久久精品乱码| 亚洲美女a级黄色在线播放| 最新国产精品综合网高清| —区二区三区女厕偷拍| 亚洲一区二区精品在线播放| 97人妻在线视频自拍| 亚洲人人爽人人澡起碰av| 黑人3p日本女优中出| 在线观看视频免费一区二区三区| 亚洲综合色一区二区三区| 青青草一个释放的网站| 国产男人的天堂一区| 黑人黄色免费一级av| 五月的婷婷综合视频| 熟女人妻精品视频一区| 美国男的操女孩的小嫩逼| 美女激情久久久久久久| 最新久久这里只有精品| 美女一区二区四区六区八区| 啪啪啪网站免费在线看| 黑人巨大精品一区二区在线| 久久久人妻免费视频| 在线人成视频免费观看尤物| 国产熟女五十路一区二区三区| 国产91九色视频在线观看| 99女福利女女视频在线播放| 中文字幕在线字幕乱码怎么设置| 夫亡人妻被强干中文字幕| 超级黄肉动漫在线观看| 国产农村乱子伦精精品视频| 在线观看黄页网站视频网站| 日本男女免费福利视频| 久久国产半精品99精品国产| 中文在线字幕免费观看日韩视频| 骚穴被阴茎插免费视频| 得得爱在线视频观看| 国产av剧变态维修工虐杀美女| 黑鸡巴肏少妇逼视频| 午夜精品视频免费观看| 美女精品久久久久久久久| 九九视频在线观看全部| 久久久久国产精品二区| 中文字幕人妻一区色偷偷久久| 顶级欧美色妇xxxx| 神马不卡视频在线视频| 中文字幕在线字幕乱码怎么设置| 超peng视频在线免费播放97| 天天夜夜久久精品综合| 中文字幕观看中文字幕免费| 99久久精品视频16| 97超碰人人爽人人做| 精品美女洗澡一区二区| 国产剧情av在线免费观看| 欧美大鸡吧男操女啊啊啊视频| 久久99国产中文丝袜| 精产国品一二三产品区别97| caopeng97在线观看视频| 亚洲第一区av中文字幕| 亚洲熟女少妇中文字幕系列| 自拍丝袜国产欧美日韩| 国产精品黄色片大全| 国产男女无套?免费网站下载| 乌克兰美女操逼高清内射视频| 东北老女人熟女啪啪视频| 欧美成人区一区二区三| 91精品91久久久久| 亚洲av网站一区二区三区| 五月天色婷婷狠狠爱| 狠狠操深爱婷婷综合一区| 亚洲字幕一区二区夜色av| 亚洲综合色一区二区三区| 国产精品网站亚洲发布| 国产成人深夜福利短视频99| 午夜情色一区二区三区| 一区二区三区四区久久久久韩日| 日本国产亚洲欧美色综合| 首页欧美日韩中文字幕| 亚洲欧美另类丝袜另类自拍| 黑人巨大精品一区二区在线| 夜夜爽夜夜操夜夜爱| 亚洲免费在线不卡视频| 黄色大片一级老太太操逼| 国产视频1区2区3区| 久久99嫩草99久久精品| 18禁网站在线点击观看| 青青青青青爽视频在线| 久久精品四虎夜夜拍拍拍| 台湾18禁久久久久久久激情视频| 中文字幕日本一二三区| 精品精品精品精品精品污污污污| 国产剧情av在线免费观看| 4438x亚洲最大的成人| 国产夫妻视频在线观看免费| 日本一本午夜在线播放| 2021国产在线视频| 欧美性受黑人猛交裸体视频| 亚洲美女色www色| 2020国产成人精品视频| 亚洲欧美精品海量播放| 久久内射天天玩天天懂色| 91九色91在线视频| 成人午夜麻豆大胆视频| 在线观看中文字幕视频成人| 中文字幕 中文字幕 亚洲| 新亚洲天堂男子av| 亚洲国产中文字幕在线看| 日韩免费黄色片在线观看| 后入日韩翘臀蜜桃臀美女| 国产精品剧情在线亚洲| 农村大炕有肉大屁股熟妇| 啊不行啊操逼好爽大鸡吧视频| 538欧美在线观看一区二区三区| 免费中文字幕a级激情| 99女福利女女视频在线播放| 一区二区三区不卡免费视频网站| 天天操天天干天天舔天天| 久久国产半精品99精品国产| 欧美不卡一二三区精品| 欧美亚洲国产一区二区| 国产激情免费在线视频| 欧美精品熟妇免费在线| 最新免费在线观看污视频| 久久精品国产亚洲av热软件| 国产男女无套?免费网站下载 | 青青青免费手机视频在线观看| av男人站在线观看| 日本高清 中文字幕| 人妻在线中文视频视频| 91亚洲精品久久蜜桃| 午夜五十路久久福利| 中文字幕 一区二区在线观看| 麻豆国产91制片厂| 欧美日本亚欧在线观看| 亚洲成人动漫av在线| 国产亚洲综合5388| 午夜免费福利老司机| 91偷拍被偷拍在线播放| 一区二区三区资源视频| 日韩久久不卡免费视频| 久久午夜免费鲁丝片| 女人高潮潮呻吟喷水网站| 黄片视频免费观看视频| 黑吊操欧美极品美女| 国产精品久久久久久成人久| 天天干天天日天天弄| 天天操天天舔天天射天天日天天干| 天天插天天干天天狠| 中文人妻av一区二区三区| 美国伦理片午夜理论片| 国产精品网站的黄色| 美女福利视频一区二区三区四区| 国内精品一区二区2021在线 | 亚洲欧美另类校园春色| 免费成人av麻豆| www一区二区91| 国产精品内射婷婷一级| 五月在线视频免费播放91| 中文字幕观看中文字幕免费 | 中文字幕av人妻一区二区三区| 99久久久久久久久久久久久| 大片a免费观看在线视频观看| 99免费观看在线视频| 国产自拍偷拍视频在线免费观看| 2020国产激情视频在线观看| 久久久久国产精品二区| 亚洲自拍偷拍av在线| 国产激情免费在线视频| 欧美成人红桃视频在线观看| 精品欧美黑人一区二区三区| 青青青青午夜手机国产视频| 久久久久久a女人处女| 成人黄色录像在线观看| 天天搞天天操天天干| 免费在线小视频你懂的| aaaa级少妇高潮在线观看| 久久久久久久岛国免费观看| 操烂你的骚逼天天欧美| 精品不卡一区二区三区| 欧美黑人性猛交小矮人| 日韩人妻中文字幕区| 精品人妻在线激情视频| 成人午夜高清福利视频| 日本香港韩国三级黄色| 漂亮人妻口爆久久精品| 中文字幕观看中文字幕免费| 天天透天天舔天天操| 九九六视频,这里只有精品| av在线观看视频免费| 2021国产在线视频| 国产乱码有码一区二区三区| 午夜呻吟亚洲精品中文字幕在上面| 午夜福利国产精品久久久久| 2026天天操天天干| 538欧美在线观看一区二区三区| 福利美女视频在线观看| 看女人大BB群伦交| 韩国一级片最火爆中文字幕| 色老头一区二区三区四区五区| 91精品夜夜夜一区二区| 日本一区二区三区区别| 日韩久久九九精品视频| 亚洲国产精品自产拍在线观看| 顶级欧美色妇4khd| 国产成人情侣激情视频| 欧美日韩黄片免费在线观看| 最新福利二区三区视频| 亚洲女人自熨在线视频| 偷拍欧美日韩另类图片| 国产资源在线观看二区| 日韩久久不卡免费视频| 国内精品一区二区2021在线| av网页免费在线观看| 大秀成年人国产精品视频| 国产农村乱子伦精精品视频| 美女扒开逼逼给你看| 欧美精品激情在线不卡| 人妻免费视频黄片在线视频| 亚av一二三在线观看| 久久99久久99久久97的人| 农村大炕有肉大屁股熟妇| 久久久国产精品免费视频网| 亚洲AV无码久久精品国产一区老| 免费在线小视频你懂的| 91精品一区一区三区| 天天日天天亲天天操| 日本国产亚洲欧美色综合| 一区二区三区 国产日韩欧美| 天天色 天天操 天天好逼| 日本熟妇乱妇熟色视频| 在线观看网站伊人网| 亚洲一区二区精品三区视频| 国产漂亮白嫩美女在线图片| 五月婷婷激情视频网| av在线播放观看h| 免费看一级高潮喷水片| 精品日本少妇久久久| 真人一进一出抽搐大尺度视频| 正在播放麻豆精品一区二区| 精品国产av虐杀两警花| 99精品久久99久久久久一| 熟女一区二区视频在线| 宅男噜噜噜66国产在线观看| 天天做天天日天天搞| 人妻超清中文字幕在线乱码| 亚洲精品1卡2卡3卡| 中文字幕人妻一区色偷偷久久| 国产成人情侣av在线|