国产精品探花熟女在线观看,2015超级碰碰免费观看视频,天天做天天日天天爱,日本韩国欧美在线视频,亚洲不卡在线小视频,中文字幕一区二区三区夫目前犯,av免费在线观看看看,亚洲日本日本精品二区一区,午夜欧美精品久久久久

主頁(yè) > 知識(shí)庫(kù) > 美團(tuán)點(diǎn)評(píng)對(duì)于網(wǎng)站性能優(yōu)化的經(jīng)驗(yàn)總結(jié)

美團(tuán)點(diǎn)評(píng)對(duì)于網(wǎng)站性能優(yōu)化的經(jīng)驗(yàn)總結(jié)

熱門標(biāo)簽:開地圖標(biāo)注公司掙錢嘛 canvas世界地圖標(biāo)注點(diǎn)線 蘭州銷售外呼系統(tǒng)加盟 寧夏手機(jī)自動(dòng)外呼系統(tǒng)好用嗎 合肥機(jī)器人外呼系統(tǒng) 地圖標(biāo)注新地點(diǎn) 地圖標(biāo)注難民 電銷機(jī)器人用戶反饋 沈陽(yáng)電話電銷機(jī)器人官網(wǎng)

性能優(yōu)化涉及面很廣。一般而言,性能優(yōu)化指降低響應(yīng)時(shí)間和提高系統(tǒng)吞吐量?jī)蓚€(gè)方面,但在流量高峰時(shí)候,性能問(wèn)題往往會(huì)表現(xiàn)為服務(wù)可用性下降,所以性能優(yōu)化也可以包括提高服務(wù)可用性。在某些情況下,降低響應(yīng)時(shí)間、提高系統(tǒng)吞吐量和提高服務(wù)可用性三者相互矛盾,不可兼得。例如:增加緩存可以降低平均響應(yīng)時(shí)間,但是處理線程數(shù)量會(huì)因?yàn)榫彺孢^(guò)大而有所限制,從而降低系統(tǒng)吞吐量;為了提高服務(wù)可用性,對(duì)異常請(qǐng)求重復(fù)調(diào)用是一個(gè)常用的做法,但是這會(huì)提高響應(yīng)時(shí)間并降低系統(tǒng)吞吐量。

對(duì)于很多像美團(tuán)這樣的公司,它們的系統(tǒng)會(huì)面臨如下三個(gè)挑戰(zhàn):1. 日益增長(zhǎng)的用戶數(shù)量,2. 日漸復(fù)雜的業(yè)務(wù),3. 急劇膨脹的數(shù)據(jù)。這些挑戰(zhàn)對(duì)于性能優(yōu)化而言表現(xiàn)為:在保持和降低系統(tǒng)TP95響應(yīng)時(shí)間(指的是將一段時(shí)間內(nèi)的請(qǐng)求響應(yīng)時(shí)間從低到高排序,高于95%請(qǐng)求響應(yīng)時(shí)間的下確界)的前提下,不斷提高系統(tǒng)吞吐量,提升流量高峰時(shí)期的服務(wù)可用性。這種場(chǎng)景下,三者的目標(biāo)和改進(jìn)方法取得了比較好的一致。本文主要目標(biāo)是為類似的場(chǎng)景提供優(yōu)化方案,確保系統(tǒng)在流量高峰時(shí)期的快速響應(yīng)和高可用。

文章第一部分是介紹,包括采用模式方式講解的優(yōu)點(diǎn),文章所采用案例的說(shuō)明,以及后面部分用到的一些設(shè)計(jì)原則;第二部分介紹幾種典型的“性能惡化模式”,闡述導(dǎo)致系統(tǒng)性能惡化,服務(wù)可用性降低的典型場(chǎng)景以及形成惡化循環(huán)的過(guò)程;第三部分是文章重點(diǎn),闡述典型的“性能優(yōu)化模式”,這些模式或者可以使服務(wù)遠(yuǎn)離“惡化模式”,或者直接對(duì)服務(wù)性能進(jìn)行優(yōu)化;文章最后一部分進(jìn)行總結(jié),并對(duì)未來(lái)可能出現(xiàn)的新模式進(jìn)行展望。

介紹
模式講解方式
關(guān)于性能優(yōu)化的文章和圖書已有很多,但就我所知,還沒有采用模式的方式去講解的。本文借鑒《設(shè)計(jì)模式》("Design Patterns-Elements of Reusable Object-Oriented Software")對(duì)設(shè)計(jì)模式的闡述方式,首先為每一種性能優(yōu)化模式取一個(gè)貼切的名字,便于讀者快速理解和深刻記憶,接著講解該模式的動(dòng)機(jī)和原理,然后結(jié)合作者在美團(tuán)的具體工作案例進(jìn)行深度剖析,最后總結(jié)采用該模式的優(yōu)點(diǎn)以及需要付出的代價(jià)。簡(jiǎn)而言之,本文采用“命名-->原理和動(dòng)機(jī)-->具體案例-->缺點(diǎn)和優(yōu)點(diǎn)”的四階段方式進(jìn)行性能優(yōu)化模式講解。與其他方式相比,采用模式進(jìn)行講解有兩個(gè)方面的優(yōu)點(diǎn):一方面,讀者不僅僅能夠掌握優(yōu)化手段,而且能夠了解采用該手段進(jìn)行性能優(yōu)化的場(chǎng)景以及所需付出的代價(jià),這有利于讀者全面理解和靈活應(yīng)用;另一方面,模式解決的是特定應(yīng)用場(chǎng)景下的一類問(wèn)題,所以應(yīng)用場(chǎng)景描述貫穿于模式講解之中。如此,即使讀者對(duì)原理不太了解,只要碰到的問(wèn)題符合某個(gè)特定模式的應(yīng)用場(chǎng)景(這往往比理解原理要簡(jiǎn)單),就可以采用對(duì)應(yīng)的手段進(jìn)行優(yōu)化,進(jìn)一步促進(jìn)讀者對(duì)模式的理解和掌握。

案例說(shuō)明
文章的所有案例都來(lái)自于美團(tuán)的真實(shí)項(xiàng)目。出于兩方面的考慮,作者做了一定的簡(jiǎn)化和抽象:一方面,系統(tǒng)可以優(yōu)化的問(wèn)題眾多,而一個(gè)特定的模式只能解決幾類問(wèn)題,所以在案例分析過(guò)程中會(huì)突出與模式相關(guān)的問(wèn)題;另一方面,任何一類問(wèn)題都需要多維度數(shù)據(jù)去描述,而應(yīng)用性能優(yōu)化模式的前提是多維度數(shù)據(jù)的組合值超過(guò)了某個(gè)臨界點(diǎn),但是精確定義每個(gè)維度數(shù)值的臨界點(diǎn)是一件很難的事情,更別說(shuō)多維度數(shù)據(jù)組合之后臨界點(diǎn)。因此有必要對(duì)案例做一些簡(jiǎn)化,確保相關(guān)取值范圍得到滿足?;谝陨弦约捌渌颍髡咚o出的解決方案只是可行性方案,并不保證其是所碰到問(wèn)題的最佳解決方案。

案例涉及的所有項(xiàng)目都是基于Java語(yǔ)言開發(fā)的,嚴(yán)格地講,所有模式適用的場(chǎng)景是基于Java語(yǔ)言搭建的服務(wù)。從另外一方面講,Java和C++的主要區(qū)別在于垃圾回收機(jī)制,所以,除去和垃圾回收機(jī)制緊密相關(guān)的模式之外,文章所描述的模式也適用于采用C++語(yǔ)言搭建的服務(wù)。對(duì)于基于其他語(yǔ)言開發(fā)的服務(wù),讀者在閱讀以及實(shí)踐的過(guò)程中需要考慮語(yǔ)言之間的差別。

設(shè)計(jì)原則
必須說(shuō)明,本文中各種模式所要解決的問(wèn)題之所以會(huì)出現(xiàn),部分是因?yàn)楣こ處熯\(yùn)用了某些深層次的設(shè)計(jì)原則。有些設(shè)計(jì)原則看上去和優(yōu)秀的設(shè)計(jì)理念相悖,模式所解決的問(wèn)題似乎完全可以避免,但是它們卻被廣泛使用。“存在即合理”,世界上沒有完美的設(shè)計(jì)方案,任何方案都是一系列設(shè)計(jì)原則的妥協(xié)結(jié)果,所以本文主要關(guān)注點(diǎn)是解決所碰到的問(wèn)題而不是如何繞過(guò)這些設(shè)計(jì)原則。下面對(duì)文中重要的設(shè)計(jì)原則進(jìn)行詳細(xì)闡述,在后面需要運(yùn)用該原則時(shí)將不再解釋。

最小可用原則
最小可用原則(快速接入原則)有兩個(gè)關(guān)注點(diǎn):1. 強(qiáng)調(diào)快速接入,快速完成;2. 實(shí)現(xiàn)核心功能可用。這是一個(gè)被普遍運(yùn)用的原則,其目標(biāo)是縮短測(cè)試周期,增加試錯(cuò)機(jī)會(huì),避免過(guò)度設(shè)計(jì)。為了快速接入就必須最大限度地利用已有的解決方案或系統(tǒng)。從另外一個(gè)角度講,一個(gè)解決方案或系統(tǒng)只要能夠滿足基本需求,就滿足最小可用原則的應(yīng)用需求。過(guò)度強(qiáng)調(diào)快速接入原則會(huì)導(dǎo)致重構(gòu)風(fēng)險(xiǎn)的增加,原則上講,基于該原則去設(shè)計(jì)系統(tǒng)需要為重構(gòu)做好準(zhǔn)備。

經(jīng)濟(jì)原則
經(jīng)濟(jì)原則關(guān)注的是成本問(wèn)題,看起來(lái)很像最小可用原則,但是它們之間關(guān)注點(diǎn)不同。最小可用原則的目標(biāo)是通過(guò)降低開發(fā)周期,快速接入而實(shí)現(xiàn)風(fēng)險(xiǎn)可控,而快速接入并不意味著成本降低,有時(shí)候?yàn)榱藢?shí)現(xiàn)快速接入可能需要付出巨大的成本。軟件項(xiàng)目的生命周期包括:預(yù)研、設(shè)計(jì)、開發(fā)、測(cè)試、運(yùn)行、維護(hù)等階段。最小可用原則主要運(yùn)用在預(yù)研階段,而經(jīng)濟(jì)原則可以運(yùn)用在整個(gè)軟件生命周期里,也可以只關(guān)注某一個(gè)或者幾個(gè)階段。例如:運(yùn)行時(shí)經(jīng)濟(jì)原則需要考慮的系統(tǒng)成本包括單次請(qǐng)求的CPU、內(nèi)存、網(wǎng)絡(luò)、磁盤消耗等;設(shè)計(jì)階段的經(jīng)濟(jì)原則要求避免過(guò)度設(shè)計(jì);開發(fā)階段的經(jīng)濟(jì)原則可能關(guān)注代碼復(fù)用,工程師資源復(fù)用等。

代碼復(fù)用原則
代碼復(fù)用原則分為兩個(gè)層次:第一個(gè)層次使用已有的解決方案或調(diào)用已存在的共享庫(kù)(Shared Library),也稱為方案復(fù)用;第二個(gè)層次是直接在現(xiàn)有的代碼庫(kù)中開發(fā),也稱之為共用代碼庫(kù)。

方案復(fù)用是一個(gè)非常實(shí)用主義的原則,它的出發(fā)點(diǎn)就是最大限度地利用手頭已有的解決方案,即使這個(gè)方案并不好。方案的形式可以是共享庫(kù),也可以是已存在的服務(wù)。方案復(fù)用的例子參見避免蚊子大炮模式的具體案例。用搜索引擎服務(wù)來(lái)解決查找附近商家的問(wèn)題是一個(gè)性能很差的方案,但仍被很多工程師使用。方案復(fù)用原則的一個(gè)顯著優(yōu)點(diǎn)就是提高生產(chǎn)效率,例如:Java之所以能夠得到如此廣泛應(yīng)用,原因之一就是有大量可以重復(fù)利用的開源庫(kù)。實(shí)際上“Write once, run anywhere”是Java語(yǔ)言最核心的設(shè)計(jì)理念之一?;贘ava語(yǔ)言開發(fā)的代碼庫(kù)因此得以在不同硬件平臺(tái)、不同操作系統(tǒng)上更廣泛地使用。

共用代碼庫(kù)要求在同一套代碼庫(kù)中完成所有功能開發(fā)。采用這個(gè)原則,代碼庫(kù)中的所有功能編譯時(shí)可見,新功能代碼可以無(wú)邊界的調(diào)用老代碼。另外,原代碼庫(kù)已存在的各種運(yùn)行、編譯、測(cè)試、配置環(huán)境可復(fù)用。主要有兩個(gè)方面地好處:1. 充分利用代碼庫(kù)中已有的基礎(chǔ)設(shè)施,快速接入新業(yè)務(wù);2. 直接調(diào)用原代碼中的基礎(chǔ)功能或原語(yǔ),避免網(wǎng)絡(luò)或進(jìn)程間調(diào)用開銷,性能更佳。共用代碼庫(kù)的例子參見垂直分割模式的具體案例。

從設(shè)計(jì)的角度上講,方案復(fù)用類似于微服務(wù)架構(gòu)(Microservice Architecture,有些觀點(diǎn)認(rèn)為這是一種形式的SOA),而共用代碼庫(kù)和Monolithic Architecture很接近??偟膩?lái)說(shuō),微服務(wù)傾向于面向接口編程,要求設(shè)計(jì)出可重用性的組件(Library或Service),通過(guò)分層組織各層組件來(lái)實(shí)現(xiàn)良好的架構(gòu)。與之相對(duì)應(yīng),Monolith Architecture則希望盡可能在一套代碼庫(kù)中開發(fā),通過(guò)直接調(diào)用代碼中的基礎(chǔ)功能或原語(yǔ)而實(shí)現(xiàn)性能的優(yōu)化和快速迭代。使用Monolith Architecture有很大的爭(zhēng)議,被認(rèn)為不符合“設(shè)計(jì)模式”的理念。參考文獻(xiàn)[4],Monolithic Design主要的缺點(diǎn)包括:1. 缺乏美感;2. 很難重構(gòu);3. 過(guò)早優(yōu)化(參見文獻(xiàn)[6]Optimize judiciously); 4. 不可重用;5. 限制眼界。微服務(wù)架構(gòu)是很多互聯(lián)網(wǎng)公司的主流架構(gòu),典型的運(yùn)用公司包括Amazon、美團(tuán)等。Monolithic Architecture也有其忠實(shí)的粉絲,例如:Tripadvisor的全球網(wǎng)站就共用一套代碼庫(kù);基于性能的考慮,Linux最終選擇的也是Monolithic kernel的模式。

奧卡姆剃刀原則
系統(tǒng)設(shè)計(jì)以及代碼編寫要遵循奧卡姆剃刀原則:Entities should not be multiplied unnecessarily。一般而言,一個(gè)系統(tǒng)的代碼量會(huì)隨著其功能增加而變多。系統(tǒng)的健壯性有時(shí)候也需要通過(guò)編寫異常處理代碼來(lái)實(shí)現(xiàn)。異??紤]越周全,異常處理代碼量越大。但是隨著代碼量的增大,引入Bug的概率也就越大,系統(tǒng)也就越不健壯。從另外一個(gè)角度來(lái)講,異常流程處理代碼也要考慮健壯性問(wèn)題,這就形成了無(wú)限循環(huán)。所以在系統(tǒng)設(shè)計(jì)和代碼編寫過(guò)程中,奧卡姆剃刀原則要求:一個(gè)功能模塊如非必要,就不要;一段代碼如非必寫,就不寫。

奧卡姆剃刀原則和最小可用原則有所區(qū)別。最小可用原則主要運(yùn)用于產(chǎn)品MVP階段,本文所指的奧卡姆剃刀原則主要指系統(tǒng)設(shè)計(jì)和代碼編寫兩個(gè)方面,這是完全不同的兩個(gè)概念。MVP包含系統(tǒng)設(shè)計(jì)和代碼編寫,但同時(shí),系統(tǒng)設(shè)計(jì)和代碼編寫也可以發(fā)生在成熟系統(tǒng)的迭代階段。

性能惡化模式
在講解性能優(yōu)化模式之前,有必要先探討一下性能惡化模式,因?yàn)椋?/p>

很多性能優(yōu)化模式的目標(biāo)之一就是避免系統(tǒng)進(jìn)入性能惡化模式;
不同性能優(yōu)化模式可能是避免同一種性能惡化模式;
同一種性能優(yōu)化模式可能在不同階段避免不同的性能惡化模式。
在此統(tǒng)一闡述性能惡化模式,避免下文重復(fù)解釋。為了便于讀者清晰識(shí)別惡化模式和優(yōu)化模式,惡化模式采用“XXX反模式”的方式進(jìn)行命名。
長(zhǎng)請(qǐng)求擁塞反模式(High Latency Invocating AntiPattern)
這是一種單次請(qǐng)求時(shí)延變長(zhǎng)而導(dǎo)致系統(tǒng)性能惡化甚至崩潰的惡化模式。對(duì)于多線程服務(wù),大量請(qǐng)求時(shí)間變長(zhǎng)會(huì)使線程堆積、內(nèi)存使用增加,最終可能會(huì)通過(guò)如下三種方式之一惡化系統(tǒng)性能:

線程數(shù)目變多導(dǎo)致線程之間CPU資源使用沖突,反過(guò)來(lái)進(jìn)一步延長(zhǎng)了單次請(qǐng)求時(shí)間;
線程數(shù)量增多以及線程中緩存變大,內(nèi)存消耗隨之劇增,對(duì)于基于Java語(yǔ)言的服務(wù)而言,又會(huì)更頻繁地full GC,反過(guò)來(lái)單次請(qǐng)求時(shí)間會(huì)變得更長(zhǎng);
內(nèi)存使用增多,會(huì)使操作系統(tǒng)內(nèi)存不足,必須使用Swap,可能導(dǎo)致服務(wù)徹底崩潰。
典型惡化流程圖如下圖:

長(zhǎng)請(qǐng)求擁塞反模式所導(dǎo)致的性能惡化現(xiàn)象非常普遍,所以識(shí)別該模式非常重要。典型的場(chǎng)景如下:某復(fù)雜業(yè)務(wù)系統(tǒng)依賴于多個(gè)服務(wù),其中某個(gè)服務(wù)的響應(yīng)時(shí)間變長(zhǎng),隨之系統(tǒng)整體響應(yīng)時(shí)間變長(zhǎng),進(jìn)而出現(xiàn)CPU、內(nèi)存、Swap報(bào)警。系統(tǒng)進(jìn)入長(zhǎng)請(qǐng)求擁塞反模式的典型標(biāo)識(shí)包括:被依賴服務(wù)可用性變低、響應(yīng)時(shí)間變長(zhǎng)、服務(wù)的某段計(jì)算邏輯時(shí)間變長(zhǎng)等。

多次請(qǐng)求杠桿反模式(Levered Multilayer Invocating AntiPattern)
客戶端一次用戶點(diǎn)擊行為往往會(huì)觸發(fā)多次服務(wù)端請(qǐng)求,這是一次請(qǐng)求杠桿;每個(gè)服務(wù)端請(qǐng)求進(jìn)而觸發(fā)多個(gè)更底層服務(wù)的請(qǐng)求,這是第二次請(qǐng)求杠桿。每一層請(qǐng)求可能導(dǎo)致一次請(qǐng)求杠桿,請(qǐng)求層級(jí)越多,杠桿效應(yīng)就越大。在多次請(qǐng)求杠桿反模式下運(yùn)行的分布式系統(tǒng),處于深層次的服務(wù)需要處理大量請(qǐng)求,容易會(huì)成為系統(tǒng)瓶頸。與此同時(shí),大量請(qǐng)求也會(huì)給網(wǎng)絡(luò)帶來(lái)巨大壓力,特別是對(duì)于單次請(qǐng)求數(shù)據(jù)量很大的情況,網(wǎng)絡(luò)可能會(huì)成為系統(tǒng)徹底崩潰的導(dǎo)火索。典型惡化流程圖如下圖:

多次請(qǐng)求杠桿所導(dǎo)致的性能惡化現(xiàn)象非常常見,例如:對(duì)于美團(tuán)推薦系統(tǒng),一個(gè)用戶列表請(qǐng)求會(huì)有多個(gè)算法參與,每個(gè)算法會(huì)召回多個(gè)列表單元(商家或者團(tuán)購(gòu)),每個(gè)列表單元有多種屬性和特征,而這些屬性和特征數(shù)據(jù)服務(wù)又分布在不同服務(wù)和機(jī)器上面,所以客戶端的一次用戶展現(xiàn)可能導(dǎo)致了成千上萬(wàn)的最底層服務(wù)調(diào)用。對(duì)于存在多次請(qǐng)求杠桿反模式的分布式系統(tǒng),性能惡化與流量之間往往遵循指數(shù)曲線關(guān)系。這意味著,在平常流量下正常運(yùn)行服務(wù)系統(tǒng),在流量高峰時(shí)通過(guò)線性增加機(jī)器解決不了可用性問(wèn)題。所以,識(shí)別并避免系統(tǒng)進(jìn)入多次請(qǐng)求杠桿反模式對(duì)于提高系統(tǒng)可用性而言非常關(guān)鍵。

反復(fù)緩存反模式(Recurrent Caching AntiPattern)
為了降低響應(yīng)時(shí)間,系統(tǒng)往往在本地內(nèi)存中緩存很多數(shù)據(jù)。緩存數(shù)據(jù)越多,命中率就越高,平均響應(yīng)時(shí)間就越快。為了降低平均響應(yīng)時(shí)間,有些開發(fā)者會(huì)不加限制地緩存各種數(shù)據(jù),在正常流量情況下,系統(tǒng)響應(yīng)時(shí)間和吞吐量都有很大改進(jìn)。但是當(dāng)流量高峰來(lái)臨時(shí),系統(tǒng)內(nèi)存使用開始增多,觸發(fā)了JVM進(jìn)行full GC,進(jìn)而導(dǎo)致大量緩存被釋放(因?yàn)橹髁鱆ava內(nèi)存緩存都采用SoftReference和WeakReference所導(dǎo)致的),而大量請(qǐng)求又使得緩存被迅速填滿,這就是反復(fù)緩存。反復(fù)緩存導(dǎo)致了頻繁的full GC,而頻繁full GC往往會(huì)導(dǎo)致系統(tǒng)性能急劇惡化。典型惡化流程圖如下圖:

反復(fù)緩存所導(dǎo)致性能惡化的原因是無(wú)節(jié)制地使用緩存。緩存使用的指導(dǎo)原則是:工程師們?cè)谑褂镁彺鏁r(shí)必須全局考慮,精細(xì)規(guī)劃,確保數(shù)據(jù)完全緩存的情況下,系統(tǒng)仍然不會(huì)頻繁full GC。為了確保這一點(diǎn),對(duì)于存在多種類型緩存以及系統(tǒng)流量變化很大的系統(tǒng),設(shè)計(jì)者必須嚴(yán)格控制緩存大小,甚至廢除緩存(這是典型為了提高流量高峰時(shí)可用性,而降低平均響應(yīng)時(shí)間的一個(gè)例子)。反復(fù)緩存反模式往往發(fā)生在流量高峰時(shí)候,通過(guò)線性增加機(jī)器和提高機(jī)器內(nèi)存可以大大減少系統(tǒng)崩潰的概率。

性能優(yōu)化模式
水平分割模式(Horizontal partitioning Pattern)
原理和動(dòng)機(jī)
典型的服務(wù)端運(yùn)行流程包含四個(gè)環(huán)節(jié):接收請(qǐng)求、獲取數(shù)據(jù)、處理數(shù)據(jù)、返回結(jié)果。在一次請(qǐng)求中,獲取數(shù)據(jù)和處理數(shù)據(jù)往往多次發(fā)生。在完全串行運(yùn)行的系統(tǒng)里,一次請(qǐng)求總響應(yīng)時(shí)間滿足如下公式:

一次請(qǐng)求總耗時(shí)=解析請(qǐng)求耗時(shí) + ∑(獲取數(shù)據(jù)耗時(shí)+處理數(shù)據(jù)耗時(shí)) + 組裝返回結(jié)果耗時(shí)

大部分耗時(shí)長(zhǎng)的服務(wù)主要時(shí)間都花在中間兩個(gè)環(huán)節(jié),即獲取數(shù)據(jù)和處理數(shù)據(jù)環(huán)節(jié)。對(duì)于非計(jì)算密集性的系統(tǒng),主要耗時(shí)都用在獲取數(shù)據(jù)上面。獲取數(shù)據(jù)主要有三個(gè)來(lái)源:本地緩存,遠(yuǎn)程緩存或者數(shù)據(jù)庫(kù),遠(yuǎn)程服務(wù)。三者之中,進(jìn)行遠(yuǎn)程數(shù)據(jù)庫(kù)訪問(wèn)或遠(yuǎn)程服務(wù)調(diào)用相對(duì)耗時(shí)較長(zhǎng),特別是對(duì)于需要進(jìn)行多次遠(yuǎn)程調(diào)用的系統(tǒng),串行調(diào)用所帶來(lái)的累加效應(yīng)會(huì)極大地延長(zhǎng)單次請(qǐng)求響應(yīng)時(shí)間,這就增大了系統(tǒng)進(jìn)入長(zhǎng)請(qǐng)求擁塞反模式的概率。如果能夠?qū)Σ煌臉I(yè)務(wù)請(qǐng)求并行處理,請(qǐng)求總耗時(shí)就會(huì)大大降低。例如下圖中,Client需要對(duì)三個(gè)服務(wù)進(jìn)行調(diào)用,如果采用順序調(diào)用模式,系統(tǒng)的響應(yīng)時(shí)間為18ms,而采用并行調(diào)用只需要7ms。

水平分割模式首先將整個(gè)請(qǐng)求流程切分為必須相互依賴的多個(gè)Stage,而每個(gè)Stage包含相互獨(dú)立的多種業(yè)務(wù)處理(包括計(jì)算和數(shù)據(jù)獲取)。完成切分之后,水平分割模式串行處理多個(gè)Stage,但是在Stage內(nèi)部并行處理。如此,一次請(qǐng)求總耗時(shí)等于各個(gè)Stage耗時(shí)總和,每個(gè)Stage所耗時(shí)間等于該Stage內(nèi)部最長(zhǎng)的業(yè)務(wù)處理時(shí)間。

水平分割模式有兩個(gè)關(guān)鍵優(yōu)化點(diǎn):減少Stage數(shù)量和降低每個(gè)Stage耗時(shí)。為了減少Stage數(shù)量,需要對(duì)一個(gè)請(qǐng)求中不同業(yè)務(wù)之間的依賴關(guān)系進(jìn)行深入分析并進(jìn)行解耦,將能夠并行處理的業(yè)務(wù)盡可能地放在同一個(gè)Stage中,最終將流程分解成無(wú)法獨(dú)立運(yùn)行的多個(gè)Stage。降低單個(gè)Stage耗時(shí)一般有兩種思路:1. 在Stage內(nèi)部再嘗試水平分割(即遞歸水平分割),2. 對(duì)于一些可以放在任意Stage中進(jìn)行并行處理的流程,將其放在耗時(shí)最長(zhǎng)的Stage內(nèi)部進(jìn)行并行處理,避免耗時(shí)較短的Stage被拉長(zhǎng)。

水平分割模式不僅可以降低系統(tǒng)平均響應(yīng)時(shí)間,而且可以降低TP95響應(yīng)時(shí)間(這兩者有時(shí)候相互矛盾,不可兼得)。通過(guò)降低平均響應(yīng)時(shí)間和TP95響應(yīng)時(shí)間,水平分割模式往往能夠大幅度提高系統(tǒng)吞吐量以及高峰時(shí)期系統(tǒng)可用性,并大大降低系統(tǒng)進(jìn)入長(zhǎng)請(qǐng)求擁塞反模式的概率。

具體案例:
我們的挑戰(zhàn)來(lái)自為用戶提供高性能的優(yōu)質(zhì)個(gè)性化列表服務(wù),每一次列表服務(wù)請(qǐng)求會(huì)有多個(gè)算法參與,而每個(gè)算法基本上都采用“召回->特征獲取->計(jì)算”的模式。 在進(jìn)行性能優(yōu)化之前,算法之間采用順序執(zhí)行的方式。伴隨著算法工程師的持續(xù)迭代,算法數(shù)量越來(lái)越多,隨之而來(lái)的結(jié)果就是客戶端響應(yīng)時(shí)間越來(lái)越長(zhǎng),系統(tǒng)很容易進(jìn)入長(zhǎng)請(qǐng)求擁塞反模式。曾經(jīng)有一段時(shí)間,一旦流量高峰來(lái)臨,出現(xiàn)整條服務(wù)鏈路的機(jī)器CPU、內(nèi)存報(bào)警。在對(duì)系統(tǒng)進(jìn)行分析之后,我們采取了如下三個(gè)優(yōu)化措施,最終使得系統(tǒng)TP95時(shí)間降低了一半:

算法之間并行計(jì)算;
每個(gè)算法內(nèi)部,多次特征獲取進(jìn)行了并行處理;
在調(diào)度線程對(duì)工作線程進(jìn)行調(diào)度的時(shí)候,耗時(shí)最長(zhǎng)的線程最先調(diào)度,最后處理。
缺點(diǎn)和優(yōu)點(diǎn)
對(duì)成熟系統(tǒng)進(jìn)行水平切割,意味著對(duì)原系統(tǒng)的重大重構(gòu),工程師必須對(duì)業(yè)務(wù)和系統(tǒng)非常熟悉,所以要謹(jǐn)慎使用。水平切割主要有兩方面的難點(diǎn):

并行計(jì)算將原本單一線程的工作分配給多線程處理,提高了系統(tǒng)的復(fù)雜度。而多線程所引入的安全問(wèn)題讓系統(tǒng)變得脆弱。與此同時(shí),多線程程序測(cè)試很難,因此重構(gòu)后系統(tǒng)很難與原系統(tǒng)在業(yè)務(wù)上保持一致。
對(duì)于一開始就基于單線程處理模式編寫的系統(tǒng),有些流程在邏輯上能夠并行處理,但是在代碼層次上由于相互引用已經(jīng)難以分解。所以并行重構(gòu)意味著對(duì)共用代碼進(jìn)行重復(fù)撰寫,增大系統(tǒng)的整體代碼量,違背奧卡姆剃刀原則。
對(duì)于上面提到的第二點(diǎn),舉例如下:A和B是邏輯可以并行處理的兩個(gè)流程,基于單線程設(shè)計(jì)的代碼,假定處理完A后再處理B。在編寫處理B邏輯代碼時(shí)候,如果B需要的資源已經(jīng)在處理A的過(guò)程中產(chǎn)生,工程師往往會(huì)直接使用A所產(chǎn)生的數(shù)據(jù),A和B之間因此出現(xiàn)了緊耦合。并行化需要對(duì)它們之間的公共代碼進(jìn)行拆解,這往往需要引入新的抽象,更改原數(shù)據(jù)結(jié)構(gòu)的可見域。
在如下兩種情況,水平切割所帶來(lái)的好處不明顯:

一個(gè)請(qǐng)求中每個(gè)處理流程需要獲取和緩存的數(shù)據(jù)量很大,而不同流程之間存在大量共享的數(shù)據(jù),但是請(qǐng)求之間數(shù)據(jù)共享卻很少。在這種情況下,流程處理完之后,數(shù)據(jù)和緩存都會(huì)清空。采用順序處理模式,數(shù)據(jù)可以被緩存在線程局部存儲(chǔ)(ThreadLocal)中而減少重復(fù)獲取數(shù)據(jù)的成本;如果采用水平切割的模式,在一次請(qǐng)求中,不同流程會(huì)多次獲取并緩存的同一類型數(shù)據(jù),對(duì)于內(nèi)存原本就很緊張的系統(tǒng),可能會(huì)導(dǎo)致頻繁full GC,進(jìn)入反復(fù)緩存反模式。
某一個(gè)處理流程所需時(shí)間遠(yuǎn)遠(yuǎn)大于其他所有流程所需時(shí)間的總和。這種情況下,水平切割不能實(shí)質(zhì)性地降低請(qǐng)求響應(yīng)時(shí)間。
采用水平切割的模式可以降低系統(tǒng)的平均響應(yīng)時(shí)間和TP95響應(yīng)時(shí)間,以及流量高峰時(shí)系統(tǒng)崩潰的概率。雖然進(jìn)行代碼重構(gòu)比較復(fù)雜,但是水平切割模式非常容易理解,只要熟悉系統(tǒng)的業(yè)務(wù),識(shí)別出可以并行處理的流程,就能夠進(jìn)行水平切割。有時(shí)候,即使少量的并行化也可以顯著提高整體性能。對(duì)于新系統(tǒng)而言,如果存在可預(yù)見的性能問(wèn)題,把水平分割模式作為一個(gè)重要的設(shè)計(jì)理念將會(huì)大大地提高系統(tǒng)的可用性、降低系統(tǒng)的重構(gòu)風(fēng)險(xiǎn)。總的來(lái)說(shuō),雖然存在一些具體實(shí)施的難點(diǎn),水平分割模式是一個(gè)非常有效、容易識(shí)別和理解的模式。

垂直分割模式(Vertical partitioning Pattern)
原理和動(dòng)機(jī):
對(duì)于移動(dòng)互聯(lián)網(wǎng)節(jié)奏的公司,新需求往往是一波接一波?;诖a復(fù)用原則,工程師們往往會(huì)在一個(gè)系統(tǒng)實(shí)現(xiàn)大量相似卻完全不相干的功能。伴隨著功能的增強(qiáng),系統(tǒng)實(shí)際上變得越來(lái)越脆弱。這種脆弱可能表現(xiàn)在系統(tǒng)響應(yīng)時(shí)間變長(zhǎng)、吞吐量降低或者可用性降低。導(dǎo)致系統(tǒng)脆弱原因主要來(lái)自兩方面的沖突:資源使用沖突和可用性不一致沖突。

資源使用沖突是導(dǎo)致系統(tǒng)脆弱的一個(gè)重要原因。不同業(yè)務(wù)功能并存于同一個(gè)運(yùn)行系統(tǒng)里面意味著資源共享,同時(shí)也意味著資源使用沖突??赡墚a(chǎn)生沖突的資源包括:CPU、內(nèi)存、網(wǎng)絡(luò)、I/O等。例如:一種業(yè)務(wù)功能,無(wú)論其調(diào)用量多么小,都有一些內(nèi)存開銷。對(duì)于存在大量緩存的業(yè)務(wù)功能,業(yè)務(wù)功能數(shù)量的增加會(huì)極大地提高內(nèi)存消耗,從而增大系統(tǒng)進(jìn)入反復(fù)緩存反模式的概率。對(duì)于CPU密集型業(yè)務(wù),當(dāng)產(chǎn)生沖突的時(shí)候,響應(yīng)時(shí)間會(huì)變慢,從而增大了系統(tǒng)進(jìn)入長(zhǎng)請(qǐng)求擁塞反模式的可能性。

不加區(qū)別地將不同可用性要求的業(yè)務(wù)功能放入一個(gè)系統(tǒng)里,會(huì)導(dǎo)致系統(tǒng)整體可用性變低。當(dāng)不同業(yè)務(wù)功能糅合在同一運(yùn)行系統(tǒng)里面的時(shí)候,在運(yùn)維和機(jī)器層面對(duì)不同業(yè)務(wù)的可用性、可靠性進(jìn)行調(diào)配將會(huì)變得很困難。但是,在高峰流量導(dǎo)致系統(tǒng)瀕臨崩潰的時(shí)候,最有效的解決手段往往是運(yùn)維,而最有效手段的失效也就意味著核心業(yè)務(wù)的可用性降低。

垂直分割思路就是將系統(tǒng)按照不同的業(yè)務(wù)功能進(jìn)行分割,主要有兩種分割模式:部署垂直分割和代碼垂直分割。部署垂直分割主要是按照可用性要求將系統(tǒng)進(jìn)行等價(jià)分類,不同可用性業(yè)務(wù)部署在不同機(jī)器上,高可用業(yè)務(wù)單獨(dú)部署;代碼垂直分割就是讓不同業(yè)務(wù)系統(tǒng)不共享代碼,徹底解決系統(tǒng)資源使用沖突問(wèn)題。

具體案例:
我們的挑戰(zhàn)來(lái)自于美團(tuán)推薦系統(tǒng),美團(tuán)客戶端的多個(gè)頁(yè)面都有推薦列表。雖然不同的推薦產(chǎn)品需求來(lái)源不同,但是為了實(shí)現(xiàn)快速的接入,基于共用代碼庫(kù)原則,所有的推薦業(yè)務(wù)共享同一套推薦代碼,同一套部署。在一段時(shí)間內(nèi),我們發(fā)現(xiàn)push推薦和首頁(yè)“猜你喜歡推薦”的資源消耗巨大。特別是在push推薦的高峰時(shí)刻,CPU和內(nèi)存頻繁報(bào)警,系統(tǒng)不停地full GC,造成美團(tuán)用戶進(jìn)入客戶端時(shí),首頁(yè)出現(xiàn)大片空白。

在對(duì)系統(tǒng)進(jìn)行分析之后,得出兩個(gè)結(jié)論:

首頁(yè)“猜你喜歡”對(duì)用戶體驗(yàn)影響更大,應(yīng)該給予最高可用性保障,而push推薦給予較低可用性保障;
首頁(yè)“猜你喜歡”和push推薦都需要很大的本地緩存,有較大的內(nèi)存使用沖突,并且響應(yīng)時(shí)間都很長(zhǎng),有嚴(yán)重的CPU使用沖突。
因此我們采取了如下措施,一方面,解決了首頁(yè)“猜你喜歡”的可用性低問(wèn)題,減少了未來(lái)出現(xiàn)可用性問(wèn)題的概率,最終將其TP95響應(yīng)時(shí)間降低了40%;另一方面也提高了其他推薦產(chǎn)品的服務(wù)可用性和高峰吞吐量。

將首頁(yè)“猜你喜歡”推薦進(jìn)行單獨(dú)部署,而將push推薦和其他對(duì)系統(tǒng)資源要求不高的推薦部署在另一個(gè)集群上面;
對(duì)于新承接的推薦業(yè)務(wù),新建一套代碼,避免影響首頁(yè)推薦這種最高可用性的業(yè)務(wù)。
缺點(diǎn)和優(yōu)點(diǎn):
垂直分割主要的缺點(diǎn)主要有兩個(gè):

增加了維護(hù)成本。一方面代碼庫(kù)數(shù)量增多提高了開發(fā)工程師的維護(hù)成本,另一方面,部署集群的變多會(huì)增加運(yùn)維工程師的工作量;
代碼不共享所導(dǎo)致的重復(fù)編碼工作。
解決重復(fù)編碼工作問(wèn)題的一個(gè)思路就是為不同的系統(tǒng)提供共享庫(kù)(Shared Library),但是這種耦合反過(guò)來(lái)可能導(dǎo)致部署機(jī)器中引入未部署業(yè)務(wù)的開銷。所以在共享庫(kù)中要減少靜態(tài)代碼的初始化開銷,并將類似緩存初始化等工作交給上層系統(tǒng)。總的來(lái)說(shuō),通過(guò)共享庫(kù)的方式引入的開銷可以得到控制。但是對(duì)于業(yè)務(wù)密集型的系統(tǒng),由于業(yè)務(wù)往往是高度定制化的,共用一套代碼庫(kù)的好處是開發(fā)工程師可以采用Copy-on-write的模式進(jìn)行開發(fā),需要修改的時(shí)候隨時(shí)拷貝并修改。共享庫(kù)中應(yīng)該存放不容易變化的代碼,避免使用者頻繁升級(jí),所以并不適合這種場(chǎng)景。因此,對(duì)于業(yè)務(wù)密集型的系統(tǒng),分代碼所導(dǎo)致的重復(fù)編碼量是需要權(quán)衡的一個(gè)因素。

垂直分割是一個(gè)非常簡(jiǎn)單而又有效的性能優(yōu)化模式,特別適用于系統(tǒng)已經(jīng)出現(xiàn)問(wèn)題而又需要快速解決的場(chǎng)景。部署層次的分割既安全又有效。需要說(shuō)明的是部署分割和簡(jiǎn)單意義上的加機(jī)器不是一回事,在大部分情況下,即使不增加機(jī)器,僅通過(guò)部署分割,系統(tǒng)整體吞吐量和可用性都有可能提升。所以就短期而言,這幾乎是一個(gè)零成本方案。對(duì)于代碼層次的分割,開發(fā)工程師需要在業(yè)務(wù)承接效率和系統(tǒng)可用性上面做一些折衷考慮。

恒變分離模式(Runtime 3NF Pattern)
原理和動(dòng)機(jī):
基于性能的設(shè)計(jì)要求變化的數(shù)據(jù)和不變的數(shù)據(jù)分開,這一點(diǎn)和基于面向?qū)ο蟮脑O(shè)計(jì)原則相悖。在面向?qū)ο蟮脑O(shè)計(jì)中,為了便于對(duì)一個(gè)對(duì)象有整體的把握,緊密相關(guān)的數(shù)據(jù)集合往往被組裝進(jìn)一個(gè)類,存儲(chǔ)在一個(gè)數(shù)據(jù)庫(kù)表,即使有部分?jǐn)?shù)據(jù)冗余(關(guān)于面向?qū)ο笈c性能沖突的討論網(wǎng)上有很多文章,本文不細(xì)講)。很多系統(tǒng)的主要工作是處理變化的數(shù)據(jù),如果變化的數(shù)據(jù)和不變的數(shù)據(jù)被緊密組裝在一起,系統(tǒng)對(duì)變化數(shù)據(jù)的操作將引入額外的開銷。而如果易變數(shù)據(jù)占總數(shù)據(jù)比例非常小,這種額外開銷將會(huì)通過(guò)杠桿效應(yīng)惡化系統(tǒng)性能。分離易變和恒定不變的數(shù)據(jù)在對(duì)象創(chuàng)建、內(nèi)存管理、網(wǎng)絡(luò)傳輸?shù)确矫娑加兄谛阅芴岣摺?/p>

恒變分離模式的原理非常類似與數(shù)據(jù)庫(kù)設(shè)計(jì)中的第三范式(3NF):第三范式主要解決的是靜態(tài)存儲(chǔ)中重復(fù)存儲(chǔ)的問(wèn)題,而恒變分離模式解決的是系統(tǒng)動(dòng)態(tài)運(yùn)行時(shí)候恒定數(shù)據(jù)重復(fù)創(chuàng)建、傳輸、存儲(chǔ)和處理的問(wèn)題。按照3NF,如果一個(gè)數(shù)據(jù)表的每一記錄都依賴于一些非主屬性集合,而這些非主屬性集合大量重復(fù)出現(xiàn),那么應(yīng)該考慮對(duì)被依賴的非主屬性集合定義一個(gè)新的實(shí)體(構(gòu)建一個(gè)新的數(shù)據(jù)表),原數(shù)據(jù)庫(kù)的記錄依賴于新實(shí)體的ID。如此一來(lái)數(shù)據(jù)庫(kù)重復(fù)存儲(chǔ)數(shù)據(jù)量將大大降低。類似的,按照恒變分離模式,對(duì)于一個(gè)實(shí)體,如果系統(tǒng)處理的只是這個(gè)實(shí)體的少量變化屬性,應(yīng)該將不變的屬性定義為一個(gè)新實(shí)體(運(yùn)行時(shí)的另一個(gè)類,數(shù)據(jù)庫(kù)中的另一個(gè)表),原來(lái)實(shí)體通過(guò)ID來(lái)引用新實(shí)體,那么原有實(shí)體在運(yùn)行系統(tǒng)中的數(shù)據(jù)傳輸、創(chuàng)建、網(wǎng)絡(luò)開銷都會(huì)大大降低。

案例分析:
我們的挑戰(zhàn)是提供一個(gè)高性能、高一致性要求的團(tuán)購(gòu)服務(wù)(DealService)。系統(tǒng)存在一些多次請(qǐng)求杠桿反模式問(wèn)題,客戶端一次請(qǐng)求會(huì)導(dǎo)致幾十次DealService讀取請(qǐng)求,每次獲取上百個(gè)團(tuán)購(gòu)詳情信息,服務(wù)端單機(jī)需要支持每秒萬(wàn)次級(jí)別的吞吐量?;谛枨?,系統(tǒng)大體框架設(shè)計(jì)如下:

每個(gè)DealService定期從持久層同步所有發(fā)生變化的deal信息,所有的deal信息保存在內(nèi)存里面。在最初的設(shè)計(jì)里面,數(shù)據(jù)庫(kù)只有一個(gè)數(shù)據(jù)表DealModelTable,程序里面也只有一個(gè)實(shí)體類DealModel。由于銷量、價(jià)格、用戶評(píng)價(jià)等信息的頻發(fā)變化,為了達(dá)到高一致性要求,服務(wù)系統(tǒng)每分鐘需要從數(shù)據(jù)庫(kù)同步幾萬(wàn)條記錄。隨著美團(tuán)團(tuán)購(gòu)數(shù)量的增多和用戶活躍度的增加,系統(tǒng)出現(xiàn)了三個(gè)問(wèn)題:

團(tuán)購(gòu)服務(wù)網(wǎng)卡頻繁報(bào)警,由于這是高性能低延時(shí)服務(wù),又導(dǎo)致了大量的客戶端超時(shí)異常;
頻繁的full GC,這是由于每條數(shù)據(jù)庫(kù)記錄更新都會(huì)導(dǎo)致運(yùn)行系統(tǒng)里面老的DealModel實(shí)體被銷毀,新的DealModels實(shí)體被創(chuàng)建;
數(shù)據(jù)庫(kù)從庫(kù)滯后主庫(kù),使得服務(wù)數(shù)據(jù)一致性降低,原因是數(shù)據(jù)庫(kù)系統(tǒng)寫數(shù)據(jù)量巨大。
在對(duì)系統(tǒng)進(jìn)行分析之后,我們采用了如下措施,大大降低了網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)量,緩解了主從數(shù)據(jù)庫(kù)同步壓力,使得客戶端的超時(shí)異常從高峰時(shí)候的9%降低到了小于0.01%(低于萬(wàn)分之一):

將DealModelTable中的銷量、價(jià)格、用戶評(píng)價(jià)等常變的信息單獨(dú)構(gòu)建一張數(shù)據(jù)表VariableDealModel;
同時(shí)在代碼中為銷量、價(jià)格、用戶評(píng)價(jià)等常變數(shù)據(jù)創(chuàng)建一個(gè)單獨(dú)的類VariableDealModel;
DealService對(duì)兩張表進(jìn)行分別同步;
如果DealModelTable的記錄產(chǎn)生了更新,運(yùn)行系統(tǒng)銷毀老的DealModel實(shí)體并創(chuàng)建新的DealModel實(shí)體;
如果只是VariableDealModel的記錄產(chǎn)生了更新,只對(duì)VariableDealModel的屬性進(jìn)行更改。
缺點(diǎn)和優(yōu)點(diǎn):
采用恒變分離模式,主要有三個(gè)缺點(diǎn):

不符合面向?qū)ο蟮脑O(shè)計(jì)原則。原本概念上統(tǒng)一的實(shí)體被切分成多個(gè)實(shí)體,會(huì)給開發(fā)工程師帶來(lái)一些理解上的困難,因此增加維護(hù)成本。進(jìn)一步而言,這會(huì)增加引入額外Bug的概率(實(shí)際上面向?qū)ο笾匀绱耸軞g迎的一個(gè)重要原因就是容易理解)。
增加了類不變量(Class invariant)的維護(hù)難度。很多情況下,Class invariant是通過(guò)語(yǔ)言所提供的封裝(Encapsulation)特性來(lái)維護(hù)的。當(dāng)一個(gè)類變成多個(gè)類,Class invariant可能會(huì)被破壞。如果必須維護(hù)Class invariant,而這種Class invariant又發(fā)生在不同實(shí)體之間,那么往往是把不變的屬性從不變實(shí)體移到易變的實(shí)體中去。
一張數(shù)據(jù)庫(kù)表變成多張,也會(huì)增加維護(hù)成本。
在如下兩種場(chǎng)景下,恒變分離模式所帶來(lái)的好處有限:

易變數(shù)據(jù)導(dǎo)致的操作和傳輸并不頻繁,不是系統(tǒng)主要操作;
易變數(shù)據(jù)占整體數(shù)據(jù)的比例很高,杠桿效應(yīng)不顯著,通過(guò)恒變分離模式不能根本性地解決系統(tǒng)性能問(wèn)題。
總的來(lái)說(shuō),恒變分離模式非常容易理解,其應(yīng)用往往需要滿足兩個(gè)條件:易變數(shù)據(jù)占整體數(shù)據(jù)比例很低(比例越低,杠桿效應(yīng)越大)和易變數(shù)據(jù)所導(dǎo)致的操作又是系統(tǒng)的主要操作。在該場(chǎng)景下,如果系統(tǒng)性能已經(jīng)出現(xiàn)問(wèn)題,犧牲一些可維護(hù)性就顯得物有所值。

大部分系統(tǒng)都是由多種類型的數(shù)據(jù)構(gòu)成,大多數(shù)數(shù)據(jù)類型的都包含易變、少變和不變的屬性。盲目地進(jìn)行恒變分離會(huì)導(dǎo)致系統(tǒng)的復(fù)雜度指數(shù)級(jí)別的增加,系統(tǒng)變得很難維護(hù),所以系統(tǒng)設(shè)計(jì)者必須在高性能和高維護(hù)性之間找到一個(gè)平衡點(diǎn)。作者的建議是:對(duì)于復(fù)雜的業(yè)務(wù)系統(tǒng),盡量按照面向?qū)ο蟮脑瓌t進(jìn)行設(shè)計(jì),只有在性能出現(xiàn)問(wèn)題的時(shí)候才開始考慮恒變分離模式;而對(duì)于高性能,業(yè)務(wù)簡(jiǎn)單的基礎(chǔ)數(shù)據(jù)服務(wù),恒變分離模式應(yīng)該是設(shè)計(jì)之初的一個(gè)重要原則。

數(shù)據(jù)局部性模式(Locality Pattern)
原理和動(dòng)機(jī):
數(shù)據(jù)局部性模式是多次請(qǐng)求杠桿反模式的針對(duì)性解決方案。在大數(shù)據(jù)和強(qiáng)調(diào)個(gè)性化服務(wù)的時(shí)代,一個(gè)服務(wù)消費(fèi)幾十種不同類型數(shù)據(jù)的現(xiàn)象非常常見,同時(shí)每一種類型的數(shù)據(jù)服務(wù)都有可能需要一個(gè)大的集群(多臺(tái)機(jī)器)提供服務(wù)。這就意味著客戶端的一次請(qǐng)求有可能會(huì)導(dǎo)致服務(wù)端成千上萬(wàn)次調(diào)用操作,很容易使系統(tǒng)進(jìn)入多次請(qǐng)求杠桿反模式。在具體開發(fā)過(guò)程中,導(dǎo)致數(shù)據(jù)服務(wù)數(shù)量暴增的主要原因有兩個(gè):1. 緩存濫用以及缺乏規(guī)劃,2. 數(shù)據(jù)量太大以至于無(wú)法在一臺(tái)機(jī)器上提供全量數(shù)據(jù)服務(wù)。數(shù)據(jù)局部性模的核心思想是合理組織數(shù)據(jù)服務(wù),減少服務(wù)調(diào)用次數(shù)。具體而言,可以從服務(wù)端和客戶端兩個(gè)方面進(jìn)行優(yōu)化。

服務(wù)端優(yōu)化方案的手段是對(duì)服務(wù)進(jìn)行重新規(guī)劃。對(duì)于數(shù)據(jù)量太大以至于無(wú)法在一臺(tái)機(jī)器上存儲(chǔ)全量數(shù)據(jù)的場(chǎng)景,建議采用Bigtable或類似的解決方案提供數(shù)據(jù)服務(wù)。典型的Bigtable的實(shí)現(xiàn)包括Hbase、Google Cloud Bigtable等。實(shí)際上數(shù)據(jù)局部性是Bigtable的一個(gè)重要設(shè)計(jì)原則,其原理是通過(guò)Row key和Column key兩個(gè)主鍵來(lái)對(duì)數(shù)據(jù)進(jìn)行索引,并確保同一個(gè)Row key索引的所有數(shù)據(jù)都在一臺(tái)服務(wù)器上面。通過(guò)這種數(shù)據(jù)組織方式,一次網(wǎng)絡(luò)請(qǐng)求可以獲取同一個(gè)Row key對(duì)應(yīng)的多個(gè)Column key索引的數(shù)據(jù)。缺乏規(guī)劃也是造成服務(wù)數(shù)量劇增的一個(gè)重要原因。很多通過(guò)統(tǒng)計(jì)和挖掘出來(lái)的特征數(shù)據(jù)往往是在漫長(zhǎng)的時(shí)間里由不同team獨(dú)立產(chǎn)生的。而對(duì)于每種類型數(shù)據(jù),在其產(chǎn)生之初,由于不確定其實(shí)際效果以及生命周期,基于快速接入原則,服務(wù)提供者往往會(huì)用手頭最容易實(shí)施的方案,例如采用Redis Cache(不加選擇地使用緩存會(huì)導(dǎo)致緩存濫用)。數(shù)據(jù)服務(wù)之間缺乏聯(lián)動(dòng)以及缺乏標(biāo)準(zhǔn)接入規(guī)劃流程就會(huì)導(dǎo)致數(shù)據(jù)服務(wù)數(shù)量膨脹。數(shù)據(jù)局部性原則對(duì)規(guī)劃的要求,具體而言是指:1. 數(shù)據(jù)由盡可能少的服務(wù)器來(lái)提供,2. 經(jīng)常被一起使用的數(shù)據(jù)盡可能放在同一臺(tái)服務(wù)器上。

客戶端優(yōu)化有如下幾個(gè)手段:

本地緩存,對(duì)于一致性要求不高且緩存命中率較高的數(shù)據(jù)服務(wù),本地緩存可以減少服務(wù)端調(diào)用次數(shù);
批處理,對(duì)于單機(jī)或者由等價(jià)的機(jī)器集群提供的數(shù)據(jù)服務(wù),盡可能采用批處理方式,將多個(gè)請(qǐng)求合成在一個(gè)請(qǐng)求中;
客戶端Hash,對(duì)于需要通過(guò)Hash將請(qǐng)求分配到不同數(shù)據(jù)服務(wù)機(jī)器的服務(wù),盡量在客戶端進(jìn)行Hash,對(duì)于落入同一等價(jià)集群的請(qǐng)求采用批處理方式進(jìn)行調(diào)用。
案例分析:
我們的挑戰(zhàn)來(lái)自于美團(tuán)的推薦、個(gè)性化列表和個(gè)性化搜索服務(wù)。這些個(gè)性化系統(tǒng)需要獲取各種用戶、商家和團(tuán)購(gòu)信息。信息類型包括基本屬性和統(tǒng)計(jì)屬性。最初,不同屬性數(shù)據(jù)由不同的服務(wù)提供,有些是RPC服務(wù),有些是Redis服務(wù),有些是HBase或者數(shù)據(jù)庫(kù),參見下圖:

通常而言,客戶端每個(gè)用戶請(qǐng)求都會(huì)觸發(fā)多個(gè)算法。一方面,每個(gè)算法都會(huì)召回幾十甚至幾百個(gè)團(tuán)購(gòu)或者商家ID,團(tuán)購(gòu)和商家基礎(chǔ)屬性被均勻地分配到幾十臺(tái)Redis里面(如下圖),產(chǎn)生了大量的Redis請(qǐng)求,極端情況下,一次客戶端請(qǐng)求所觸發(fā)的團(tuán)購(gòu)基礎(chǔ)數(shù)據(jù)請(qǐng)求就超過(guò)了上千次;另一方面,用戶特征屬性信息有十幾種,每種屬性也由單獨(dú)的服務(wù)提供,服務(wù)端網(wǎng)絡(luò)調(diào)用次數(shù)暴增。在一段時(shí)間里,很多系統(tǒng)都進(jìn)入了多次請(qǐng)求杠桿反模式,Redis服務(wù)器的網(wǎng)卡經(jīng)常被打死,多次進(jìn)行擴(kuò)容,提高線程池線程數(shù)量,絲毫沒有改善。

在對(duì)系統(tǒng)進(jìn)行分析之后,按照數(shù)據(jù)局部性模式的原則,我們采用了如下手段,徹底解決了系統(tǒng)多次請(qǐng)求杠桿反模式的問(wèn)題:

采用大內(nèi)存服務(wù)器存儲(chǔ)所有的團(tuán)購(gòu)和商家基礎(chǔ)信息,每個(gè)算法只要一次網(wǎng)絡(luò)請(qǐng)求就可以獲取所有的信息;
服務(wù)端采用多線程方式提供服務(wù),避免了Redis單一線程模式下單個(gè)請(qǐng)求慢所帶來(lái)的連鎖效應(yīng);
借鑒類似Bigtable的數(shù)據(jù)組織方式,將用戶的多種特征采用兩個(gè)維度(用戶維度和特征類型)進(jìn)行索引,確保同一用戶的信息只存放在一臺(tái)機(jī)器上面,減少網(wǎng)絡(luò)調(diào)用數(shù)量。
缺點(diǎn)和優(yōu)點(diǎn):
數(shù)據(jù)局部性模式并不適用于系統(tǒng)初級(jí)階段。在初級(jí)階段,最小可用原則往往是主要設(shè)計(jì)原則之一,出于兩方面的考慮:一方面,在初級(jí)階段,很難預(yù)測(cè)所要提供服務(wù)的數(shù)據(jù)是否有效而且能夠長(zhǎng)期使用,以及未來(lái)的調(diào)用量;另一方面,在初級(jí)階段,工程師可能無(wú)法預(yù)測(cè)最終的調(diào)用模式,而不同的調(diào)用模式會(huì)導(dǎo)致數(shù)據(jù)局部性方案的設(shè)計(jì)不同。對(duì)于已經(jīng)大量使用的數(shù)據(jù)服務(wù),采用數(shù)據(jù)局部性模式進(jìn)行重構(gòu)必然要改變老的調(diào)用模式,這一方面會(huì)引入新的Bug,另一方面也意味著巨大的工作量。需要特別強(qiáng)調(diào)的是,數(shù)據(jù)處于系統(tǒng)的最底層,對(duì)于結(jié)構(gòu)復(fù)雜而又重要的數(shù)據(jù),重構(gòu)所帶來(lái)可靠性、一致性和工作量都是需要權(quán)衡的因素。對(duì)于請(qǐng)求量比較小的數(shù)據(jù)服務(wù),即使一次請(qǐng)求會(huì)觸發(fā)嚴(yán)重的請(qǐng)求杠桿效應(yīng),但是如果原始觸發(fā)請(qǐng)求數(shù)量在可預(yù)見的時(shí)間內(nèi)沒有明顯變多的跡象,進(jìn)行數(shù)據(jù)服務(wù)重構(gòu)可能得不償失。

數(shù)據(jù)局部性模式能夠解決多次請(qǐng)求杠桿反模式所導(dǎo)致的問(wèn)題,但它并非大數(shù)據(jù)的產(chǎn)物,CPU、編譯器的設(shè)計(jì)理念里早就融入了該模式,所以很容易被工程師理解。雖然過(guò)度設(shè)計(jì)在系統(tǒng)初級(jí)階段是一個(gè)要盡量避免的事情,但是理解和掌握數(shù)據(jù)局部性模式對(duì)于設(shè)計(jì)出一個(gè)可擴(kuò)展、可重用的系統(tǒng)有很大幫助。很多成熟的系統(tǒng)因?yàn)槎啻握?qǐng)求杠桿反模式而導(dǎo)致系統(tǒng)頻繁崩潰,理解數(shù)據(jù)局部性模式的原則有助于提高工程師分析解決問(wèn)題的能力,而在確認(rèn)了系統(tǒng)存在請(qǐng)求杠桿問(wèn)題后,數(shù)據(jù)局部性原則是一件非常銳利的武器。

避免蚊子大炮模式(Avoiding Over-generalized Solution Pattern)
原理和動(dòng)機(jī):
“用大炮打蚊子”本來(lái)是大材小用的意思,但是細(xì)致想一想,用大炮打蚊子,成功率不高。對(duì)于開發(fā)工程師而言,一方面為了快速承接業(yè)務(wù),按照方案復(fù)用原則,總是盡可能地利用現(xiàn)有系統(tǒng),這使得系統(tǒng)功能越來(lái)越強(qiáng)大;另一方面,提高系統(tǒng)的通用性或可重用性也是工程師們?cè)谠O(shè)計(jì)系統(tǒng)的一個(gè)重要目標(biāo)。隨著這兩個(gè)過(guò)程的相互獨(dú)立演化,采用通用方案解決特定問(wèn)題的現(xiàn)象隨處可見,形象地說(shuō),這就像大炮打蚊子。大炮成本很高,蚊子的數(shù)量眾多,最終的結(jié)局往往是蚊子戰(zhàn)勝了大炮。

“避免蚊子大炮模式”是經(jīng)濟(jì)原則在運(yùn)行時(shí)系統(tǒng)的運(yùn)用,它要求采用最節(jié)省資源(CPU、內(nèi)存等)的方法來(lái)解決所面臨的問(wèn)題,資源浪費(fèi)會(huì)帶來(lái)未來(lái)潛在的風(fēng)險(xiǎn)。工程師接到一個(gè)需求的時(shí)候,需要思考的不僅僅是如何復(fù)用現(xiàn)有的系統(tǒng),減少開發(fā)時(shí)間,還需要考慮現(xiàn)有系統(tǒng)為處理每個(gè)新需求訪問(wèn)所需運(yùn)行時(shí)成本,以及新需求的預(yù)期訪問(wèn)量。否則,不加辨別地利用現(xiàn)有系統(tǒng),不僅僅增大了重構(gòu)風(fēng)險(xiǎn),還有可能交叉影響,對(duì)現(xiàn)有系統(tǒng)所支持的服務(wù)造成影響。從另外一個(gè)角度講,工程師在構(gòu)建一個(gè)可重用系統(tǒng)的時(shí)候,要明確其所不能解決和不建議解決的問(wèn)題,而對(duì)于不建議解決的問(wèn)題,在文檔中標(biāo)明潛在的風(fēng)險(xiǎn)。

案例分析:
我們的挑戰(zhàn)是為移動(dòng)用戶尋找其所在位置附近的商家信息。美團(tuán)有非常完善的搜索系統(tǒng),也有資深的搜索工程師,所以一個(gè)系統(tǒng)需要查找附近的商家的時(shí)候,往往第一方案就是調(diào)用搜索服務(wù)。但是在美團(tuán),太多的服務(wù)有基于LBS的查詢需求,導(dǎo)致搜索請(qǐng)求量直線上升,這本來(lái)不屬于搜索的主營(yíng)業(yè)務(wù),在一段時(shí)間里面反倒成了搜索的最多請(qǐng)求來(lái)源。而搜索引擎在如何從幾十萬(wàn)商家里面找最近的幾百商家方面的性能非常差,因此一段時(shí)間里,搜索服務(wù)頻繁報(bào)警。不僅僅搜索服務(wù)可用性受到了影響,所有依賴于LBS的服務(wù)的可用性都大大降低。

在對(duì)系統(tǒng)分析之后,我們認(rèn)為更適合解決最短直線距離的算法應(yīng)該是k-d tree,在快速實(shí)現(xiàn)了基于k-d tree的LBS Search解決方案之后,我們用4臺(tái)服務(wù)器輕松解決了30多臺(tái)搜索服務(wù)器無(wú)法解決的問(wèn)題,平均響應(yīng)時(shí)間從高峰時(shí)的100ms降低到300ns,性能取得了幾百倍的提高。

缺點(diǎn)和優(yōu)點(diǎn):
避免蚊子大炮模式的問(wèn)題和數(shù)據(jù)局部性模式類似,都與最小可用原則相沖突。在系統(tǒng)設(shè)計(jì)初級(jí)階段,尋求最優(yōu)方案往往意味著過(guò)度設(shè)計(jì),整個(gè)項(xiàng)目在時(shí)間和成本變得不可控,而為每個(gè)問(wèn)題去找最優(yōu)秀的解決方案是不現(xiàn)實(shí)的奢求。最優(yōu)化原則的要求是全面的,不僅僅要考慮的運(yùn)行時(shí)資源,還需要考慮工程師資源和時(shí)間成本等,而這些點(diǎn)往往相互矛盾。在如下情況下,避免蚊子大炮模式所帶來(lái)的好處有限:在可預(yù)見的未來(lái),某個(gè)業(yè)務(wù)請(qǐng)求量非常小,這時(shí)候花大量精力去找最優(yōu)技術(shù)方案效果不明顯。

在設(shè)計(jì)階段,避免蚊子大炮模式是一個(gè)需要工程師去權(quán)衡的選擇,需要在開發(fā)成本和系統(tǒng)運(yùn)行成本之間保持一個(gè)平衡點(diǎn)。當(dāng)很多功能融入到一個(gè)通用系統(tǒng)里而出現(xiàn)性能問(wèn)題的時(shí)候,要拆分出來(lái)每一個(gè)功能點(diǎn)所造成的影響也不是件輕易的事情,所以采用分開部署而共用代碼庫(kù)的原則可以快速定位問(wèn)題,然后有針對(duì)性地解決“蚊子大炮”問(wèn)題??偟膩?lái)說(shuō),在設(shè)計(jì)階段,避免蚊子大炮模式是工程師們進(jìn)行分析和設(shè)計(jì)的一個(gè)重要準(zhǔn)則,工程師可以暫時(shí)不解決潛在的問(wèn)題,但是一定要清楚潛在的危害。構(gòu)建可重用系統(tǒng)或方案,一定要明確其所不能解決和不建議解決的問(wèn)題,避免過(guò)度使用。

實(shí)時(shí)離線分離模式(Sandbox Pattern)
原理和動(dòng)機(jī):
本模式的極端要求是:離線服務(wù)永遠(yuǎn)不要調(diào)用實(shí)時(shí)服務(wù)。該模式比較簡(jiǎn)單也容易理解,但是,嚴(yán)格地講它不是一種系統(tǒng)設(shè)計(jì)模式,而是一種管理規(guī)范。離線服務(wù)和在線服務(wù)從可用性、可靠性、一致性的要求上完全不同。原則上,工程師在編寫離線服務(wù)代碼的時(shí)候,應(yīng)該遵循的就是離線服務(wù)編程規(guī)范,按照在線服務(wù)編程規(guī)范要求,成本就會(huì)大大提高,不符合經(jīng)濟(jì)原則;從另外一方面講,按照離線服務(wù)的需求去寫在線服務(wù)代碼,可用性、可靠性、一致性等往往得不到滿足。

具體而言,實(shí)時(shí)離線分離模式建議如下幾種規(guī)范:

如果離線程序需要訪問(wèn)在線服務(wù),應(yīng)該給離線程序單獨(dú)部署一套服務(wù);
類似于MapReduce的云端多進(jìn)程離線程序禁止直接訪問(wèn)在線服務(wù);
分布式系統(tǒng)永遠(yuǎn)不要直接寫傳統(tǒng)的DBMS。
案例分析:
因?yàn)檫`反實(shí)時(shí)離線分離模式而導(dǎo)致的事故非常常見。有一次,因?yàn)橐粋€(gè)離線程序頻繁的向Tair集群寫數(shù)據(jù),每一次寫10M數(shù)據(jù),使得整個(gè)Tair集群宕機(jī)。另一次,因?yàn)镾torm系統(tǒng)直接寫MySQL數(shù)據(jù)庫(kù)導(dǎo)致數(shù)據(jù)庫(kù)連接數(shù)耗盡,從而使在線系統(tǒng)無(wú)法連接數(shù)據(jù)庫(kù)。

缺點(diǎn)和優(yōu)點(diǎn):
為了實(shí)現(xiàn)實(shí)時(shí)在線分離,可能需要為在線環(huán)境和離線環(huán)境單獨(dú)部署,維護(hù)多套環(huán)境所帶來(lái)運(yùn)維成本是工程師需要考慮的問(wèn)題。另一方面,在線環(huán)境的數(shù)據(jù)在離線環(huán)境中可能很難獲取,這也是很多離線系統(tǒng)直接訪問(wèn)在線系統(tǒng)的原因。但是,遵從實(shí)時(shí)離線分離模式是一個(gè)非常重要的安全管理準(zhǔn)則,任何違背這個(gè)準(zhǔn)則的行為都意味著系統(tǒng)性安全漏洞,都會(huì)增大線上故障概率。

降級(jí)模式(Degradation Pattern)
原理和動(dòng)機(jī):
降級(jí)模式是系統(tǒng)性能保障的最后一道防線。理論上講,不存在絕對(duì)沒有漏洞的系統(tǒng),或者說(shuō),最好的安全措施就是為處于崩潰狀態(tài)的系統(tǒng)提供預(yù)案。從系統(tǒng)性能優(yōu)化的角度來(lái)講,不管系統(tǒng)設(shè)計(jì)地多么完善,總會(huì)有一些意料之外的情況會(huì)導(dǎo)致系統(tǒng)性能惡化,最終可能導(dǎo)致崩潰,所以對(duì)于要求高可用性的服務(wù),在系統(tǒng)設(shè)計(jì)之初,就必須做好降級(jí)設(shè)計(jì)。根據(jù)作者的經(jīng)驗(yàn),良好的降級(jí)方案應(yīng)該包含如下措施:

在設(shè)計(jì)階段,確定系統(tǒng)的開始惡化數(shù)值指標(biāo)(例如:響應(yīng)時(shí)間,內(nèi)存使用量);
當(dāng)系統(tǒng)開始惡化時(shí),需要第一時(shí)間報(bào)警;
在收到報(bào)警后,或者人工手動(dòng)控制系統(tǒng)進(jìn)入降級(jí)狀態(tài),或者編寫一個(gè)智能程序讓系統(tǒng)自動(dòng)降級(jí);
區(qū)分系統(tǒng)所依賴服務(wù)的必要性,一般分為:必要服務(wù)和可選服務(wù)。必要服務(wù)在降級(jí)狀態(tài)下需要提供一個(gè)快速返回結(jié)果的權(quán)宜方案(緩存是常見的一種方案),而對(duì)于可選服務(wù),在降級(jí)時(shí)系統(tǒng)果斷不調(diào)用;
在系統(tǒng)遠(yuǎn)離惡化情況時(shí),需要人工恢復(fù),或者智能程序自動(dòng)升級(jí)。
典型的降級(jí)策略有三種:流量降級(jí)、效果降級(jí)和功能性降級(jí)。流量降級(jí)是指當(dāng)通過(guò)主動(dòng)拒絕處理部分流量的方式讓系統(tǒng)正常服務(wù)未降級(jí)的流量,這會(huì)造成部分用戶服務(wù)不可用;效果降級(jí)表現(xiàn)為服務(wù)質(zhì)量的降級(jí),即在流量高峰時(shí)期用相對(duì)低質(zhì)量、低延時(shí)的服務(wù)來(lái)替換高質(zhì)量、高延時(shí)的服務(wù),保障所有用戶的服務(wù)可用性;功能性降級(jí)也表現(xiàn)為服務(wù)質(zhì)量的降級(jí),指的是通過(guò)減少功能的方式來(lái)提高用戶的服務(wù)可用性。效果降級(jí)和功能性降級(jí)比較接近,效果降級(jí)強(qiáng)調(diào)的是主功能服務(wù)質(zhì)量的下降,功能性降級(jí)更多強(qiáng)調(diào)的是輔助性功能的缺失。做一個(gè)類比如下:計(jì)劃將100個(gè)工程師從北京送到夏威夷度假,但是預(yù)算不夠。采用流量降級(jí)策略,只有50工程師做頭等艙去了夏威夷度假,其余工程師繼續(xù)編寫程序(這可不好);效果降級(jí)策略下,100個(gè)工程師都坐經(jīng)濟(jì)艙去夏威夷;采用功能性降級(jí)策略,100個(gè)工程師都坐頭等艙去夏威夷,但是飛機(jī)上不提供食品和飲料。

案例分析:
我們的系統(tǒng)大量使用了智能降級(jí)程序。在系統(tǒng)惡化的時(shí)候,智能降級(jí)程序自動(dòng)降級(jí)部分流量,當(dāng)系統(tǒng)恢復(fù)的時(shí)候,智能降級(jí)程序自動(dòng)升級(jí)為正常狀態(tài)。在采用智能降級(jí)程序之前,因?yàn)橄到y(tǒng)降級(jí)問(wèn)題,整體系統(tǒng)不可用的情況偶爾發(fā)生。采用智能降級(jí)程序之后,基本上沒有因?yàn)樾阅軉?wèn)題而導(dǎo)致的系統(tǒng)整體不可用。我們的智能降級(jí)程序的主要判定策略是服務(wù)響應(yīng)時(shí)間,如果出現(xiàn)大量長(zhǎng)時(shí)間的響應(yīng)異?;虺瑫r(shí)異常,系統(tǒng)就會(huì)走降級(jí)流程,如果異常數(shù)量變少,系統(tǒng)就會(huì)自動(dòng)恢復(fù)。

缺點(diǎn)和優(yōu)點(diǎn):
為了使系統(tǒng)具備降級(jí)功能,需要撰寫大量的代碼,而降級(jí)代碼往往比正常業(yè)務(wù)代碼更難寫,更容易出錯(cuò),所以并不符合奧卡姆剃刀原則。在確定使用降級(jí)模式的前提下,工程師需要權(quán)衡這三種降級(jí)策略的利弊。大多數(shù)面向C端的系統(tǒng)傾向于采用效果降級(jí)和功能性降級(jí)策略,但是有些功能性模塊(比如下單功能)是不能進(jìn)行效果和功能性降級(jí)的,只能采用流量降級(jí)策略。對(duì)于不能接受降級(jí)后果的系統(tǒng),必須要通過(guò)其他方式來(lái)提高系統(tǒng)的可用性。

總的來(lái)說(shuō),降級(jí)模式是一種設(shè)計(jì)安全準(zhǔn)則,任何高可用性要求的服務(wù),必須要按照降級(jí)模式的準(zhǔn)則去設(shè)計(jì)。對(duì)于違背這條設(shè)計(jì)原則的系統(tǒng),或早或晚,系統(tǒng)總會(huì)因?yàn)槟承﹩?wèn)題導(dǎo)致崩潰而降低可用性。不過(guò),降級(jí)模式并非不需要成本,也不符合最小可用原則,所以對(duì)于處于MVP階段的系統(tǒng),或者對(duì)于可用性要求不高的系統(tǒng),降級(jí)模式并非必須采納的原則。

其他性能優(yōu)化建議:
對(duì)于無(wú)法采用系統(tǒng)性的模式方式講解的性能優(yōu)化手段,作者也給出一些總結(jié)性的建議:

刪除無(wú)用代碼有時(shí)候可以解決性能問(wèn)題,例如:有些代碼已經(jīng)不再被調(diào)用但是可能被初始化,甚至占有大量?jī)?nèi)存;有些代碼雖然在調(diào)用但是對(duì)于業(yè)務(wù)而言已經(jīng)無(wú)用,這種調(diào)用占用CPU資源。
避免跨機(jī)房調(diào)用,跨機(jī)房調(diào)用經(jīng)常成為系統(tǒng)的性能瓶頸,特別是那些偽batch調(diào)用(在使用者看起來(lái)是一次性調(diào)用,但是內(nèi)部實(shí)現(xiàn)采用的是順序單個(gè)調(diào)用模式)對(duì)系統(tǒng)性能影響往往非常巨大
。


總結(jié)
Christopher Alexander曾說(shuō)過(guò):"Each pattern describes a problem which occurs over and over again in our environment, and then describes the core of the solution to that problem, in such a way that you can use this solution a million times over, without ever doing it the same way twice" 。 盡管Christopher Alexander指的是建筑模式,軟件設(shè)計(jì)模式適用,基于同樣的原因,性能優(yōu)化模式也適用。每個(gè)性能優(yōu)化模式描述的都是工程師們?nèi)粘9ぷ髦薪?jīng)常出現(xiàn)的問(wèn)題,一個(gè)性能優(yōu)化模式可以解決確定場(chǎng)景下的某一類型的問(wèn)題。所以要理解一個(gè)性能優(yōu)化模式不僅僅要了解性能模式的所能解決的問(wèn)題以及解決手段,還需要清楚該問(wèn)題所發(fā)生的場(chǎng)景和需要付出的代價(jià)。

最后,本文所描述的性能優(yōu)化模式只是作者的工作經(jīng)驗(yàn)總結(jié),都是為了解決由以下三種情況所造成的性能問(wèn)題:1. 日益增長(zhǎng)的用戶數(shù)量,2. 日漸復(fù)雜的業(yè)務(wù),3. 急劇膨脹的數(shù)據(jù),但是這些遠(yuǎn)非該領(lǐng)域里面的所有模式。對(duì)于文章中提到的其他性能優(yōu)化建議,以及現(xiàn)在和將來(lái)可能碰到的性能問(wèn)題,作者還會(huì)不斷抽象,在未來(lái)總結(jié)出更多的模式。性能問(wèn)題涉及領(lǐng)域非常廣泛,而模式是一個(gè)非常好的講解性能問(wèn)題以及解決方案的方式,作者有理由相信,無(wú)論是在作者所從事的工作領(lǐng)域里面還是在其他的領(lǐng)域里面,新的性能優(yōu)化模式會(huì)不斷涌現(xiàn)。希望通過(guò)本文的講述,對(duì)碰到同樣問(wèn)題的工程師們有所幫助,同時(shí)也拋磚引玉,期待出現(xiàn)更多的基于模式方式講解性能優(yōu)化的文章。

標(biāo)簽:郴州 克拉瑪依 昌都 烏海 上饒 萍鄉(xiāng) 黔南 曲靖

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《美團(tuán)點(diǎn)評(píng)對(duì)于網(wǎng)站性能優(yōu)化的經(jīng)驗(yàn)總結(jié)》,本文關(guān)鍵詞  美團(tuán),點(diǎn)評(píng),對(duì)于,網(wǎng)站,性能,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《美團(tuán)點(diǎn)評(píng)對(duì)于網(wǎng)站性能優(yōu)化的經(jīng)驗(yàn)總結(jié)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于美團(tuán)點(diǎn)評(píng)對(duì)于網(wǎng)站性能優(yōu)化的經(jīng)驗(yàn)總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    动漫美女的小穴视频| 91极品大一女神正在播放| 亚洲熟妇久久无码精品| 国产三级精品三级在线不卡| mm131美女午夜爽爽爽| 青草亚洲视频在线观看| 亚洲女人的天堂av| 婷婷综合蜜桃av在线| 日本a级视频老女人| 日本中文字幕一二区视频| 麻豆性色视频在线观看| www,久久久,com| 丝袜长腿第一页在线| 天天日天天干天天插舔舔| 好吊视频—区二区三区| av亚洲中文天堂字幕网| 91片黄在线观看喷潮| 啊啊啊想要被插进去视频| 成年人黄视频在线观看| 成人色综合中文字幕| 亚洲va国产va欧美精品88| yellow在线播放av啊啊啊| 在线观看视频一区麻豆| 一级黄片久久久久久久久| 秋霞午夜av福利经典影视| 超碰公开大香蕉97| 国产a级毛久久久久精品| 久久这里只有精彩视频免费| 久草视频福利在线首页| 人妻少妇av在线观看| 中文字幕国产专区欧美激情| 国产伊人免费在线播放| 欧洲国产成人精品91铁牛tv| 一区二区三区的久久的蜜桃的视频| 国产三级精品三级在线不卡| 综合国产成人在线观看| 亚洲天堂成人在线观看视频网站| 日韩欧美制服诱惑一区在线| 538精品在线观看视频| 亚洲熟女女同志女同| 久久免费看少妇高潮完整版| av中文字幕在线导航| www久久久久久久久久久| 少妇高潮无套内谢麻豆| 在线观看免费岛国av| 美女视频福利免费看| 欧美日本在线观看一区二区| 成人在线欧美日韩国产| 日韩北条麻妃一区在线| 日本韩国免费福利精品| 欧美成人综合视频一区二区| 久久久久久九九99精品| 99精品免费久久久久久久久a| 精品区一区二区三区四区人妻| 久久香蕉国产免费天天| v888av在线观看视频| 国产日韩欧美美利坚蜜臀懂色| 99热久久这里只有精品| 中文字幕日本人妻中出| 日韩欧美在线观看不卡一区二区| 亚洲国产40页第21页| 国产午夜亚洲精品麻豆| 日视频免费在线观看| 欧美日韩高清午夜蜜桃大香蕉| 青草青永久在线视频18| 天天插天天色天天日| 国产成人精品一区在线观看| 国产高清精品极品美女| 中文字幕一区二 区二三区四区| 特一级特级黄色网片| 男女第一次视频在线观看| 狠狠的往里顶撞h百合| 91www一区二区三区| 熟女人妻在线观看视频| 19一区二区三区在线播放| 午夜青青草原网在线观看| 夜色17s精品人妻熟女| 日日摸夜夜添夜夜添毛片性色av| 欧美另类重口味极品在线观看| 天天干天天搞天天摸| 亚洲综合在线观看免费| 福利视频一区二区三区筱慧| 午夜毛片不卡免费观看视频| 在线观看成人国产电影| 日本精品美女在线观看| 男生舔女生逼逼的视频| 亚洲中文字幕乱码区| 天天操天天爽天天干| 98精产国品一二三产区区别| 国产熟妇乱妇熟色T区| 久久三久久三久久三久久| 狠狠的往里顶撞h百合| 日韩a级黄色小视频| 国产高清精品极品美女| 99热久久这里只有精品| 黄片色呦呦视频免费看| 欧美综合婷婷欧美综合| 在线制服丝袜中文字幕| 老司机你懂得福利视频| 在线免费观看视频一二区| 久久精品亚洲成在人线a| 成人乱码一区二区三区av| 日本人妻少妇18—xx| caoporm超碰国产| 蜜桃视频17c在线一区二区| 国产精品女邻居小骚货| 国产性生活中老年人视频网站| 熟女国产一区亚洲中文字幕| 大陆胖女人与丈夫操b国语高清| 在线免费观看99视频| 欧美成人小视频在线免费看| 成人福利视频免费在线| 黄色无码鸡吧操逼视频| 青青草人人妻人人妻| 国产一区自拍黄视频免费观看| av中文字幕在线导航| 亚洲av日韩高清hd| 美女在线观看日本亚洲一区| 一区二区三区国产精选在线播放| 国产一级精品综合av| 在线新三级黄伊人网| 97色视频在线观看| 国产久久久精品毛片| 一区二区视频在线观看免费观看| 亚洲av男人天堂久久| 亚洲日本一区二区三区| 青草亚洲视频在线观看| 天天射夜夜操狠狠干| 亚洲一区av中文字幕在线观看| 999九九久久久精品| 激情五月婷婷免费视频| 高潮喷水在线视频观看| 大胸性感美女羞爽操逼毛片| 孕妇奶水仑乱A级毛片免费看| 北条麻妃肉色丝袜视频| 日本裸体熟妇区二区欧美| 国产又粗又黄又硬又爽| 国产真实乱子伦a视频| 92福利视频午夜1000看| 色狠狠av线不卡香蕉一区二区| 日本丰满熟妇BBXBBXHD| 久草电影免费在线观看| 天天日天天日天天射天天干| 在线观看的黄色免费网站| 国产黄色高清资源在线免费观看| 一区二区三区麻豆福利视频| 亚洲1区2区3区精华液| 粉嫩av蜜乳av蜜臀| 伊人成人综合开心网| 男生用鸡操女生视频动漫| 日韩精品中文字幕播放| 亚洲免费va在线播放| 熟女91pooyn熟女| 在线免费观看靠比视频的网站| 中英文字幕av一区| 97国产精品97久久| 五月天久久激情视频| 天天色天天操天天舔| 自拍偷拍亚洲精品第2页| 一区二区视频视频视频| 亚洲欧美自拍另类图片| 亚洲一区制服丝袜美腿| 久久精品36亚洲精品束缚| 亚洲美女自偷自拍11页| 亚洲偷自拍高清视频| 日本成人一区二区不卡免费在线 | 欧美精品中文字幕久久二区| 亚洲在线一区二区欧美| 天天日天天舔天天射进去| 久久99久久99精品影院| 日韩美女精品视频在线观看网站 | 欧美成人精品在线观看| 国产美女精品福利在线| 久久热久久视频在线观看| 2020久久躁狠狠躁夜夜躁| 男人的天堂一区二区在线观看| 内射久久久久综合网| 成人区人妻精品一区二视频| 欧美日韩不卡一区不区二区| 婷婷久久久久深爱网| 中文字幕第三十八页久久 | 青青草视频手机免费在线观看| 91she九色精品国产| 国产亚洲国产av网站在线| 97国产精品97久久| 男大肉棒猛烈插女免费视频| av天堂加勒比在线| 一区二区三区四区五区性感视频| 色呦呦视频在线观看视频| 欧洲黄页网免费观看| 3344免费偷拍视频| 不卡一不卡二不卡三| 99热久久极品热亚洲| 欧美成人小视频在线免费看| 在线观看视频 你懂的| 成人网18免费视频版国产| 天天干天天日天天谢综合156| 91色老99久久九九爱精品| 插小穴高清无码中文字幕| 亚洲一区久久免费视频| 久久久噜噜噜久久熟女av| 伊人成人在线综合网| 男人靠女人的逼视频| 亚洲另类图片蜜臀av| 日韩av中文在线免费观看| 人妻最新视频在线免费观看| 久久久久国产成人精品亚洲午夜| 亚洲图库另类图片区| 日本少妇在线视频大香蕉在线观看| 精品美女在线观看视频在线观看| 91自产国产精品视频| 最新日韩av传媒在线| 韩国三级aaaaa高清视频| 一区二区三区的久久的蜜桃的视频| a v欧美一区=区三区| 黄色片年轻人在线观看| okirakuhuhu在线观看| 欧美精品一二三视频| 国产黄色片蝌蚪九色91| 唐人色亚洲av嫩草| 天堂av中文在线最新版| 动漫av网站18禁| 五十路熟女av天堂| 边摸边做超爽毛片18禁色戒| 中文字幕人妻av在线观看| 91 亚洲视频在线观看| 国产精品自拍偷拍a| 青青青国产免费视频| 日韩中文字幕在线播放第二页| gogo国模私拍视频| 精内国产乱码久久久久久| 熟女人妻在线观看视频| 免费人成黄页网站在线观看国产| 激情国产小视频在线| 2017亚洲男人天堂| 老司机福利精品免费视频一区二区| 岛国毛片视频免费在线观看| 最新91精品视频在线| 自拍偷拍,中文字幕| 国产一区二区神马久久| 亚洲成人熟妇一区二区三区| 欧美一区二区三区激情啪啪啪| 欧美成人综合视频一区二区| 中国熟女一区二区性xx| 国产精品中文av在线播放| 欧美亚洲少妇福利视频| 人妻熟女中文字幕aⅴ在线| 欧亚日韩一区二区三区观看视频| 亚洲精品国产综合久久久久久久久| 欧洲亚洲欧美日韩综合| 中文字幕高清免费在线人妻 | chinese国产盗摄一区二区 | 久久麻豆亚洲精品av| 大鸡巴操b视频在线| 天天操天天干天天日狠狠插| 五十路在线观看完整版| 久草电影免费在线观看| 农村胖女人操逼视频| 狠狠躁夜夜躁人人爽天天天天97| 操的小逼流水的文章| 天堂中文字幕翔田av| 风流唐伯虎电视剧在线观看 | 婷婷色国产黑丝少妇勾搭AV| 精品黑人一区二区三区久久国产| 馒头大胆亚洲一区二区| 精产国品久久一二三产区区别| 综合激情网激情五月五月婷婷| 亚洲精品无码久久久久不卡| 91极品大一女神正在播放| 精品人人人妻人人玩日产欧| 18禁免费av网站| 亚洲激情偷拍一区二区| 亚洲欧美清纯唯美另类| 中文字幕免费在线免费| 色综合久久久久久久久中文| 性色蜜臀av一区二区三区| 香蕉91一区二区三区| 欧美xxx成人在线| 亚洲av在线观看尤物| 日本美女成人在线视频| 老鸭窝在线观看一区| 91麻豆精品传媒国产黄色片| 人妻少妇性色欲欧美日韩| 国产普通话插插视频| 亚洲护士一区二区三区| 免费一级黄色av网站| 成人免费公开视频无毒| 快插进小逼里大鸡吧视频| 国产一区av澳门在线观看| 日韩熟女av天堂系列| 亚洲1区2区3区精华液| 国产午夜激情福利小视频在线| 国产丰满熟女成人视频| 久久艹在线观看视频| 黄色黄色黄片78在线| 偷拍3456eee| 91精品国产观看免费| 日本少妇人妻xxxxx18| 国产一区二区火爆视频| 国产精品精品精品999| 中文字幕一区二区自拍| 欧美日韩人妻久久精品高清国产 | 99久久久无码国产精品性出奶水| 亚洲人妻30pwc| 亚洲精品无码久久久久不卡| 五十路av熟女松本翔子| 亚洲人妻30pwc| okirakuhuhu在线观看| 亚洲高清国产一区二区三区| 亚洲国产香蕉视频在线播放| 成人福利视频免费在线| 午夜成午夜成年片在线观看| 自拍偷拍亚洲另类色图| 欧美老妇精品另类不卡片| 欧美aa一级一区三区四区| 国产普通话插插视频| 亚洲中文字字幕乱码| free性日本少妇| 2020久久躁狠狠躁夜夜躁 | 国产精品黄大片在线播放| 久久久久久性虐视频| 久草视频首页在线观看| 在线观看av亚洲情色| 亚洲欧美清纯唯美另类| 动漫美女的小穴视频| 青青青青青青草国产| 夜女神免费福利视频| 97国产在线av精品| 日本精品美女在线观看| 亚洲精品国产在线电影| 91人妻人人做人人爽在线| 亚洲1区2区3区精华液| 含骚鸡巴玩逼逼视频| 天堂av在线播放免费| 欧美性受xx黑人性猛交| 日本一区精品视频在线观看| 亚洲一区二区三区精品视频在线 | 激情图片日韩欧美人妻| 日本欧美视频在线观看三区| 91av精品视频在线| 亚洲精品 欧美日韩| 成人av免费不卡在线观看| 天天日天天干天天插舔舔| 大香蕉日本伊人中文在线| 欧美 亚洲 另类综合| 亚洲天堂有码中文字幕视频| 青青伊人一精品视频| 2022精品久久久久久中文字幕| 亚洲欧美成人综合在线观看| 自拍偷拍日韩欧美一区二区| 人妻久久无码中文成人| 国产精品久久久久国产三级试频 | 肏插流水妹子在线乐播下载| 日本特级片中文字幕| 麻豆性色视频在线观看| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 97国产在线观看高清| 欧美日韩v中文在线| 黑人性生活视频免费看| 天天日天天干天天舔天天射| 干逼又爽又黄又免费的视频| 狍和女人的王色毛片| 不卡一区一区三区在线| 欧美地区一二三专区| 视频二区在线视频观看| 天天操天天爽天天干| 色av色婷婷人妻久久久精品高清 | 黑人变态深video特大巨大| 亚洲精品国品乱码久久久久| 欧美男人大鸡吧插女人视频| 97国产在线av精品| 男人天堂最新地址av| 亚洲久久午夜av一区二区| 抽查舔水白紧大视频| 亚洲欧美综合另类13p| 亚洲欧美日韩视频免费观看| 中文字幕—97超碰网| 69精品视频一区二区在线观看| 中文人妻AV久久人妻水| av老司机精品在线观看| 日本丰满熟妇大屁股久久| 人妻3p真实偷拍一二区| 国产91精品拍在线观看| 欧美日韩亚洲国产无线码| 年轻的人妻被夫上司侵犯| 国产精品久久久久久久女人18| 香蕉91一区二区三区| 521精品视频在线观看| 国产成人精品av网站| 亚洲另类图片蜜臀av| 大胸性感美女羞爽操逼毛片| 蜜桃视频在线欧美一区| 91色九色porny| 干逼又爽又黄又免费的视频| 绯色av蜜臀vs少妇| 欧美激情电影免费在线| 国产美女一区在线观看| 亚洲国产成人无码麻豆艾秋| 亚洲精品亚洲人成在线导航| 亚洲av自拍天堂网| 老师啊太大了啊啊啊尻视频| brazzers欧熟精品系列| 欧美男人大鸡吧插女人视频| 91亚洲精品干熟女蜜桃频道| 国产老熟女伦老熟妇ⅹ| 色婷婷综合激情五月免费观看| 午夜免费观看精品视频| 亚洲图库另类图片区| 18禁美女无遮挡免费| 国内精品在线播放第一页| 激情国产小视频在线| 午夜免费观看精品视频| 日韩无码国产精品强奸乱伦| 91免费观看国产免费| 91大神福利视频网| 水蜜桃一区二区三区在线观看视频 | 久久精品美女免费视频| 熟女少妇激情五十路| 这里有精品成人国产99| 久草视频 久草视频2| 经典国语激情内射视频| 四川乱子伦视频国产vip| 人妻丝袜榨强中文字幕| 熟女人妻在线中出观看完整版| 中文字幕高清在线免费播放| 视频久久久久久久人妻| 国产又粗又硬又猛的毛片视频 | 亚洲美女美妇久久字幕组| 免费观看污视频网站| 91综合久久亚洲综合| 老司机欧美视频在线看| 欲满人妻中文字幕在线| 2022中文字幕在线| 99热国产精品666| 久久精品在线观看一区二区 | 97精品人妻一区二区三区精品| 亚洲青青操骚货在线视频| 亚洲激情,偷拍视频| 天天操天天插天天色| 精品首页在线观看视频| 2020国产在线不卡视频| 久久久久91精品推荐99| 又色又爽又黄又刺激av网站| 五十路熟女av天堂| 伊人成人在线综合网| 2020中文字幕在线播放| 狠狠躁夜夜躁人人爽天天天天97| 黄片色呦呦视频免费看| 国产精品精品精品999| 午夜精品九一唐人麻豆嫩草成人| 六月婷婷激情一区二区三区| 亚洲女人的天堂av| 国产+亚洲+欧美+另类| 岛国青草视频在线观看| 天干天天天色天天日天天射| 亚洲少妇高潮免费观看| 视频久久久久久久人妻| japanese日本熟妇另类| 亚洲天堂av最新网址| 日本三极片视频网站观看| 亚洲欧美激情人妻偷拍| 国产麻豆国语对白露脸剧情| 日本一本午夜在线播放| 国产视频一区二区午夜| 国产精品一二三不卡带免费视频 | 四川乱子伦视频国产vip| 午夜精品一区二区三区城中村| 天天日天天爽天天爽| 适合午夜一个人看的视频| 2018在线福利视频| 久草视频中文字幕在线观看| 男人天堂最新地址av| 成年女人免费播放视频| 播放日本一区二区三区电影| 国产熟妇一区二区三区av| 黄色视频成年人免费观看| 超黄超污网站在线观看| 91精品国产麻豆国产| 2021年国产精品自拍| av中文在线天堂精品| 熟女国产一区亚洲中文字幕| v888av在线观看视频| 亚洲一级av大片免费观看| 小穴多水久久精品免费看| 亚洲精品色在线观看视频| 亚洲成人激情av在线| 制服丝袜在线人妻中文字幕| 青青操免费日综合视频观看| 欧美女同性恋免费a| av高潮迭起在线观看| 亚洲av可乐操首页| 国产成人精品午夜福利训2021| 日本韩国免费一区二区三区视频| 日日操夜夜撸天天干| 国产精品久久久久网| 亚洲午夜电影在线观看| 黄色视频成年人免费观看| 欧美日韩亚洲国产无线码| 午夜蜜桃一区二区三区| 2025年人妻中文字幕乱码在线| 在线观看视频 你懂的| 天天艹天天干天天操| 丰满少妇翘臀后进式| 久久久久五月天丁香社区| 中文乱理伦片在线观看| 亚洲另类综合一区小说| 丝袜肉丝一区二区三区四区在线看| 天天操天天爽天天干| a v欧美一区=区三区| 操操网操操伊剧情片中文字幕网| 538精品在线观看视频| 青娱乐最新视频在线| 天天日天天日天天射天天干| 大鸡吧插入女阴道黄色片 | 做爰视频毛片下载蜜桃视频1 | 国产高清精品一区二区三区| 青青操免费日综合视频观看| 绝色少妇高潮3在线观看| 亚洲精品国产久久久久久| 欧美一区二区三区乱码在线播放| 日本一区精品视频在线观看| gav成人免费播放| 人妻丝袜榨强中文字幕| 黄色在线观看免费观看在线| 天天通天天透天天插| 国产成人无码精品久久久电影| 国产成人精品亚洲男人的天堂| 青青青艹视频在线观看| 欧美成人综合色在线噜噜| 国产一级麻豆精品免费| 在线播放 日韩 av| 一级A一级a爰片免费免会员| 88成人免费av网站| 2021国产一区二区| 亚洲国产在线精品国偷产拍 | 中文字幕在线视频一区二区三区| 午夜免费体验区在线观看| 姐姐的朋友2在线观看中文字幕| 午夜精品九一唐人麻豆嫩草成人| 真实国模和老外性视频| 日本av熟女在线视频| 自拍 日韩 欧美激情| av森泽佳奈在线观看| 青青青青视频在线播放| 激情色图一区二区三区| 日韩近亲视频在线观看| 在线免费观看日本伦理| 国产第一美女一区二区三区四区| 日韩欧美高清免费在线| 欧美激情精品在线观看| 首之国产AV医生和护士小芳| 成人高潮aa毛片免费| 免费男阳茎伸入女阳道视频| 久久精品国产23696| 精品一区二区三区欧美| 国产av自拍偷拍盛宴| 偷偷玩弄新婚人妻h视频| 一区二区三区 自拍偷拍| 91麻豆精品传媒国产黄色片| 国产高清精品极品美女| 自拍偷拍,中文字幕| 亚洲成人激情av在线| 91she九色精品国产| 男女啪啪视频免费在线观看| av日韩在线免费播放| 亚洲国产第一页在线观看| 国产之丝袜脚在线一区二区三区| 中文字母永久播放1区2区3区| 老司机福利精品免费视频一区二区 | 日韩午夜福利精品试看| 天堂女人av一区二区| 亚洲欧美久久久久久久久| 男女啪啪啪啪啪的网站| 天天摸天天干天天操科普| 91老师蜜桃臀大屁股| 巨乳人妻日下部加奈被邻居中出| 免费在线看的黄片视频| 亚洲国际青青操综合网站| 一级黄片久久久久久久久| 日本男女操逼视频免费看| 日韩人妻在线视频免费| 一区二区三区四区视频| 精品国产在线手机在线| 国产综合高清在线观看| 久久麻豆亚洲精品av| 91香蕉成人app下载| 五十路av熟女松本翔子| 国产黄色高清资源在线免费观看| 欧洲日韩亚洲一区二区三区| 综合国产成人在线观看| 在线免费观看国产精品黄色| 日本少妇精品免费视频| 亚洲人妻视频在线网| 清纯美女在线观看国产| 中文字幕无码日韩专区免费| 国产aⅴ一线在线观看| 搡老熟女一区二区在线观看| 91精品国产91青青碰| 亚洲精品一区二区三区老狼| 亚洲蜜臀av一区二区三区九色| 国产第一美女一区二区三区四区| 亚洲免费国产在线日韩| 婷婷激情四射在线观看视频| 在线观看911精品国产| 亚洲一级 片内射视正片| 色综合久久久久久久久中文| 嫩草aⅴ一区二区三区| 中文字幕成人日韩欧美| 一区二区三区另类在线| 亚洲精品国产久久久久久| gav成人免费播放| 91she九色精品国产| 爱爱免费在线观看视频| 日韩中文字幕精品淫| 青青草原色片网站在线观看| 日本一二三区不卡无| 青青青aaaa免费| 一色桃子久久精品亚洲| 中文字幕在线免费第一页| 在线不卡成人黄色精品| 在线亚洲天堂色播av电影| 日本韩国免费福利精品| 天堂资源网av中文字幕| 亚洲免费福利一区二区三区| 在线免费观看黄页视频| 欧美日韩人妻久久精品高清国产| 久久99久久99精品影院| 日本乱人一区二区三区| 国产男女视频在线播放| 夜夜嗨av蜜臀av| 亚洲一区二区激情在线| 亚洲精品欧美日韩在线播放| 精品欧美一区二区vr在线观看| 精品亚洲国产中文自在线| 天天夜天天日天天日| 美女福利视频网址导航| 2022中文字幕在线| 在线免费观看靠比视频的网站| 99热这里只有精品中文| 国产麻豆国语对白露脸剧情| 成年人中文字幕在线观看| 在线视频这里只有精品自拍| 亚洲av天堂在线播放| 亚洲精品久久视频婷婷| 国产黄色a级三级三级三级| 国产福利小视频二区| 亚洲av日韩av第一区二区三区| 亚洲中文字幕综合小综合| 日韩不卡中文在线视频网站| 天天日天天干天天爱| 少妇高潮一区二区三区| 亚洲区欧美区另类最新章节| 干逼又爽又黄又免费的视频| 日韩美女福利视频网| 精品久久婷婷免费视频| 黄色大片免费观看网站| 日本午夜福利免费视频| 色偷偷伊人大杳蕉综合网| 黑人巨大的吊bdsm| 精品suv一区二区69| 亚洲一区二区三区久久受| 97成人免费在线观看网站| 一区二区三区日本伦理| 好男人视频在线免费观看网站| 操的小逼流水的文章| 国产欧美日韩在线观看不卡| 国产成人一区二区三区电影网站| 中文字幕国产专区欧美激情| 不卡精品视频在线观看| 成人亚洲精品国产精品| 日本午夜爽爽爽爽爽视频在线观看 | 日韩二区视频一线天婷婷五| 51国产成人精品视频| 97小视频人妻一区二区| 一二三中文乱码亚洲乱码one| 一区二区三区久久久91| 一个色综合男人天堂| 一级黄色片夫妻性生活| 亚洲激情唯美亚洲激情图片| 国产高清97在线观看视频| 夜色17s精品人妻熟女| 国产中文字幕四区在线观看| 欧美怡红院视频在线观看| 77久久久久国产精产品| 亚洲天堂第一页中文字幕| 天天日天天干天天插舔舔| 9色在线视频免费观看| 天天日天天干天天插舔舔| 成人24小时免费视频| 班长撕开乳罩揉我胸好爽| 超碰在线观看免费在线观看| 日本在线一区二区不卡视频| 中文字幕亚洲中文字幕| 国产精品女邻居小骚货| 免费无码人妻日韩精品一区二区| 黄色成年网站午夜在线观看| 91大神福利视频网| 视频 一区二区在线观看| 521精品视频在线观看| 日本午夜福利免费视频| 大香蕉大香蕉在线看| 老有所依在线观看完整版| 日日爽天天干夜夜操| 女同互舔一区二区三区| 免费看国产又粗又猛又爽又黄视频 | 欧美久久一区二区伊人| 最新中文字幕免费视频| 亚洲 中文 自拍 无码| 97瑟瑟超碰在线香蕉| 成年人的在线免费视频| 夜夜嗨av一区二区三区中文字幕| 亚洲av日韩精品久久久| 激情国产小视频在线| 一区二区三区国产精选在线播放| 日本女大学生的黄色小视频| 精品国产成人亚洲午夜| 天天射夜夜操狠狠干| 五十路人妻熟女av一区二区| 亚洲综合乱码一区二区| 四川五十路熟女av| 日本女大学生的黄色小视频| 哥哥姐姐综合激情小说| 在线观看视频网站麻豆| 韩国黄色一级二级三级| 精品人妻伦一二三区久| 青青热久免费精品视频在线观看| 一区二区三区另类在线| 国产高清女主播在线| 欧美黑人性猛交xxxxⅹooo| 大屁股熟女一区二区三区| 国产精品日韩欧美一区二区| 亚洲欧美人精品高清| 久久丁香婷婷六月天| 韩国亚洲欧美超一级在线播放视频| 国产精品人妻一区二区三区网站| 国产夫妻视频在线观看免费| av破解版在线观看| 日韩av免费观看一区| 日本黄在免费看视频| 国产亚州色婷婷久久99精品| 成人综合亚洲欧美一区 | 一区二区三区四区中文| 成年人黄视频在线观看| 日本性感美女视频网站| 国产va在线观看精品| 久精品人妻一区二区三区 | 久久艹在线观看视频| 亚洲欧美国产综合777| 少妇露脸深喉口爆吞精| 啊啊啊想要被插进去视频| 风流唐伯虎电视剧在线观看| 一区二区三区毛片国产一区| 青青草视频手机免费在线观看| 久久久噜噜噜久久熟女av| 男人天堂最新地址av| 午夜蜜桃一区二区三区| 亚洲欧美在线视频第一页| AV天堂一区二区免费试看| 黄片三级三级三级在线观看| 蜜桃色婷婷久久久福利在线| 蜜桃臀av蜜桃臀av| 大肉大捧一进一出好爽在线视频| 精品国产成人亚洲午夜| 人妻另类专区欧美制服| 午夜蜜桃一区二区三区| 北条麻妃av在线免费观看| 亚洲变态另类色图天堂网| 清纯美女在线观看国产| 欧美另类重口味极品在线观看| 91精品资源免费观看| 国产精品自偷自拍啪啪啪| 亚洲欧美清纯唯美另类| 2022国产精品视频| 97资源人妻免费在线视频| 男人操女人的逼免费视频| 日韩不卡中文在线视频网站| 在线观看黄色成年人网站| 午夜精品亚洲精品五月色| 一区二区三区日韩久久| 日本成人不卡一区二区| 婷婷六月天中文字幕| 国产精品黄大片在线播放| 免费黄页网站4188| 国产麻豆剧传媒精品国产av蜜桃| 在线观看911精品国产| 丝袜肉丝一区二区三区四区在线看| 精品首页在线观看视频| huangse网站在线观看| 天天操天天爽天天干| 欧美精产国品一二三区| 欧洲日韩亚洲一区二区三区| 把腿张开让我插进去视频| 黄色资源视频网站日韩| 精品高跟鞋丝袜一区二区| 天天躁夜夜躁日日躁a麻豆| 不卡一不卡二不卡三| 北条麻妃av在线免费观看| 久青青草视频手机在线免费观看| 国产亚洲成人免费在线观看| 黑人进入丰满少妇视频| 国产三级精品三级在线不卡| 国产精品成久久久久三级蜜臀av| 色花堂在线av中文字幕九九| 91老师蜜桃臀大屁股| 国产精品视频男人的天堂| av资源中文字幕在线观看| 男人的天堂一区二区在线观看| 亚洲第一黄色在线观看| 无码中文字幕波多野不卡| 激情五月婷婷综合色啪| 在线观看的a站 最新| 人人在线视频一区二区| 综合激情网激情五月五月婷婷| 人妻少妇性色欲欧美日韩| 亚洲一区二区三区偷拍女厕91| 天天色天天舔天天射天天爽| 男人靠女人的逼视频| 天天做天天干天天舔| 三级等保密码要求条款| 91国产在线免费播放| 国产精品熟女久久久久浪潮| 适合午夜一个人看的视频| 男人在床上插女人视频| 一区二区三区四区中文| 特级无码毛片免费视频播放| 日本午夜爽爽爽爽爽视频在线观看| 只有精品亚洲视频在线观看| 日韩a级精品一区二区| 国产真实灌醉下药美女av福利| 区一区二区三国产中文字幕| 亚洲护士一区二区三区| 中文字幕日韩精品就在这里| 亚洲国产欧美一区二区三区…| 爱有来生高清在线中文字幕| 久久久久五月天丁香社区| 偷拍美女一区二区三区| 91福利视频免费在线观看| 人妻熟女在线一区二区| 国产精品国产三级国产午| 午夜精品福利一区二区三区p| 国产美女一区在线观看| 亚洲熟妇久久无码精品| 青青青青在线视频免费观看| 天堂资源网av中文字幕| 最新97国产在线视频| 91久久人澡人人添人人爽乱| 亚洲中文字幕乱码区| 国产一区二区火爆视频 | 亚洲欧洲一区二区在线观看| 日本后入视频在线观看| 午夜在线观看一区视频| 97瑟瑟超碰在线香蕉| 亚洲成人三级在线播放| 很黄很污很色的午夜网站在线观看| 老师啊太大了啊啊啊尻视频| 久久久久只精品国产三级| 91试看福利一分钟| 亚洲熟女综合色一区二区三区四区| 91久久综合男人天堂| 91传媒一区二区三区| 91精品综合久久久久3d动漫| 五月天久久激情视频| 国产精品久久久久久久女人18| 无码中文字幕波多野不卡| 亚洲另类在线免费观看| 在线免费观看日本伦理| 色婷婷六月亚洲综合香蕉| 日韩一个色综合导航| rct470中文字幕在线| 欧美成人综合视频一区二区| 久久这里只有精彩视频免费| 日本韩国免费福利精品| 久久久久91精品推荐99| 精品久久久久久高潮| 老司机欧美视频在线看| 免费观看国产综合视频| 中文字幕人妻av在线观看| 一级黄色片夫妻性生活| 欧洲精品第一页欧洲精品亚洲 | 国产在线免费观看成人| 岛国免费大片在线观看| 男大肉棒猛烈插女免费视频 | 青青热久免费精品视频在线观看| 日韩欧美在线观看不卡一区二区| 99av国产精品欲麻豆| 亚洲av无硬久久精品蜜桃| 大黑人性xxxxbbbb| 亚洲成人激情视频免费观看了 | 91国内精品自线在拍白富美| 姐姐的朋友2在线观看中文字幕 | 免费观看成年人视频在线观看| 亚洲av第国产精品| 天天日天天日天天擦| 午夜国产免费福利av| 日日夜夜狠狠干视频| 不卡一不卡二不卡三| 青青草成人福利电影| 粉嫩欧美美人妻小视频| 国产成人一区二区三区电影网站 | 色呦呦视频在线观看视频| 日韩欧美一级精品在线观看| 亚洲码av无色中文| 久久艹在线观看视频| av老司机精品在线观看| 男人操女人的逼免费视频| 欲满人妻中文字幕在线| 密臀av一区在线观看| 91在线免费观看成人| 成人蜜桃美臀九一一区二区三区| 2017亚洲男人天堂| 午夜成午夜成年片在线观看| 同居了嫂子在线播高清中文| 亚洲中文精品人人免费| 欧美视频中文一区二区三区| 一区二区三区在线视频福利| 99精品国产aⅴ在线观看| 被大鸡吧操的好舒服视频免费| 丝袜亚洲另类欧美变态| 中文字幕在线免费第一页| 在线国产中文字幕视频| 国产又大又黄免费观看| 色呦呦视频在线观看视频| 超污视频在线观看污污污| 日韩加勒比东京热二区| eeuss鲁片一区二区三区| 97人妻色免费视频| 综合一区二区三区蜜臀| 欧美日韩激情啪啪啪| 精品黑人巨大在线一区| 在线观看黄色成年人网站| 久久这里有免费精品| 中文字幕—97超碰网| 视频在线免费观看你懂得| 亚洲Av无码国产综合色区| 国产精品午夜国产小视频| 久草视频在线免播放| 精品少妇一二三视频在线| 久久久极品久久蜜桃| 91麻豆精品91久久久久同性| 超污视频在线观看污污污 | 亚洲午夜福利中文乱码字幕| 国产精品人妻熟女毛片av久| 99精品视频之69精品视频| 青青草在观免费国产精品| 亚洲av可乐操首页| 国产午夜无码福利在线看| 淫秽激情视频免费观看| 夜夜嗨av蜜臀av| 激情色图一区二区三区| av新中文天堂在线网址| www天堂在线久久| 亚洲高清自偷揄拍自拍| 黑人借宿ntr人妻的沦陷2| 老熟妇凹凸淫老妇女av在线观看| 日本18禁久久久久久| 亚洲一区自拍高清免费视频| 成人综合亚洲欧美一区| 久久机热/这里只有| 中文字幕亚洲久久久| 日本阿v视频在线免费观看| 中字幕人妻熟女人妻a62v网| 视频二区在线视频观看| 韩国三级aaaaa高清视频 | 亚洲午夜电影之麻豆| 偷拍3456eee| 亚洲av一妻不如妾| 国产白嫩美女一区二区| 亚洲欧美色一区二区| 欧洲日韩亚洲一区二区三区 | 成熟丰满熟妇高潮xx×xx | 国产成人综合一区2区| 国产午夜男女爽爽爽爽爽视频| 天天干天天日天天干天天操| 日本成人一区二区不卡免费在线| 亚洲欧美一区二区三区爱爱动图| 极品粉嫩小泬白浆20p主播| 在线播放国产黄色av| av新中文天堂在线网址| 国产男女视频在线播放| 日本熟女50视频免费| 久久久久久97三级| 亚洲最大黄 嗯色 操 啊| 精品久久久久久久久久久a√国产| 天天干天天操天天玩天天射| 国产精品入口麻豆啊啊啊| 91香蕉成人app下载| 成年人黄视频在线观看| 在线观看视频网站麻豆| 人人妻人人爽人人澡人人精品| 在线国产中文字幕视频| 国产精品久久久久久美女校花| 蜜臀成人av在线播放| 亚洲va天堂va国产va久| 91快播视频在线观看| 天天摸天天亲天天舔天天操天天爽| 中文字幕在线观看极品视频| 粗大的内捧猛烈进出爽大牛汉子| 888欧美视频在线| 97黄网站在线观看| 在线观看视频网站麻豆| 精品成人啪啪18免费蜜臀| 欧美男同性恋69视频| 亚洲精品高清自拍av| 午夜精品一区二区三区4| 中文字幕午夜免费福利视频| 久久这里只有精品热视频| 亚洲特黄aaaa片| 丰满的子国产在线观看| 国产亚洲欧美视频网站| 国产视频一区在线观看| 手机看片福利盒子日韩在线播放 | 99久久超碰人妻国产| 大陆胖女人与丈夫操b国语高清| 欧美视频中文一区二区三区| 98视频精品在线观看| 日本啪啪啪啪啪啪啪| 亚洲变态另类色图天堂网| 中文字幕AV在线免费看 | 青青青视频手机在线观看| 在线视频免费观看网| 啊啊好大好爽啊啊操我啊啊视频| 东京热男人的av天堂| 青娱乐最新视频在线| 亚洲va欧美va人人爽3p| 色秀欧美视频第一页| 亚洲 中文 自拍 另类 欧美| 亚洲av日韩精品久久久久久hd| 91色九色porny| 中文字幕av熟女人妻| 中文字幕一区二区自拍| 99精品免费观看视频| 亚洲综合图片20p| 国产精品久久久久网| 少妇高潮无套内谢麻豆| 国产精品自拍在线视频| 亚洲国产成人无码麻豆艾秋| 在线播放国产黄色av| 亚洲综合乱码一区二区| 国产黄色大片在线免费播放 | 免费在线福利小视频| 黄色大片男人操女人逼| 91九色国产熟女一区二区| 男人天堂色男人av| 538精品在线观看视频| 欧美亚洲国产成人免费在线 | 2021年国产精品自拍| 午夜在线一区二区免费| 4个黑人操素人视频网站精品91| 中文字幕日韩精品就在这里| 男人的天堂av日韩亚洲| 欧美日韩激情啪啪啪| 2017亚洲男人天堂| 三上悠亚和黑人665番号| 38av一区二区三区| 美女在线观看日本亚洲一区| 国产精品黄页网站视频| 大肉大捧一进一出好爽在线视频 | 天天日天天爽天天爽| 欧美另类一区二区视频| 欧美日韩人妻久久精品高清国产| 亚洲美女自偷自拍11页| 老鸭窝日韩精品视频观看| 天天操天天干天天插| 欧美日韩高清午夜蜜桃大香蕉| 视频二区在线视频观看| 自拍偷拍vs一区二区三区| 2022中文字幕在线| 国产亚洲视频在线二区| 日本乱人一区二区三区| 日本少妇精品免费视频| 成人福利视频免费在线| 99亚洲美女一区二区三区| 精品国产乱码一区二区三区乱| 欧美乱妇无乱码一区二区| 啪啪啪啪啪啪啪免费视频| 夜夜躁狠狠躁日日躁麻豆内射 | 国产精品中文av在线播放| 国产成人综合一区2区| 九九视频在线精品播放| 精品suv一区二区69| 国产高清精品极品美女| 福利午夜视频在线合集| 黄色资源视频网站日韩| 欧美aa一级一区三区四区 | 免费看国产av网站| 亚洲欧洲一区二区在线观看| 在线免费观看靠比视频的网站| 亚洲国产精品久久久久久6| 91免费放福利在线观看| 99精品视频在线观看免费播放| 日韩美在线观看视频黄| 精品高潮呻吟久久av| 粗大的内捧猛烈进出爽大牛汉子| 中文字幕在线视频一区二区三区 | 国产精品视频资源在线播放| 日韩欧美一级黄片亚洲| 五月色婷婷综合开心网4438| 香蕉片在线观看av| 亚洲成高清a人片在线观看| 91大屁股国产一区二区| 综合精品久久久久97| 伊人日日日草夜夜草| 99久久成人日韩欧美精品| 一区二区三区综合视频| 在线 中文字幕 一区| 欧美黄片精彩在线免费观看| eeuss鲁片一区二区三区| 日本xx片在线观看| 人人在线视频一区二区| 国产一区二区久久久裸臀| 啪啪啪18禁一区二区三区| 一个人免费在线观看ww视频| 亚洲av无码成人精品区辽| 天堂av在线播放免费| 熟女少妇激情五十路| 视频 一区二区在线观看| 四虎永久在线精品免费区二区| 国产黄网站在线观看播放| 孕妇奶水仑乱A级毛片免费看| 97国产在线av精品| 国产成人自拍视频在线免费观看| 欧美色呦呦最新网址| 天堂av狠狠操蜜桃| 国产免费高清视频视频| 岛国青草视频在线观看| 亚洲成人激情av在线| 天天日天天日天天射天天干| 天天日夜夜操天天摸| 伊人日日日草夜夜草| 色综合色综合色综合色| 国产露脸对白在线观看| 日本熟妇丰满厨房55| 一个色综合男人天堂| 中文字幕最新久久久| 亚洲一区二区三区精品视频在线 | 老熟妇凹凸淫老妇女av在线观看| 18禁美女羞羞免费网站| 国产精品久久久久网| 男人和女人激情视频| 18禁美女黄网站色大片下载| 成人av在线资源网站| 亚洲卡1卡2卡三卡四老狼| 久久这里有免费精品| 最近中文2019年在线看| 91精品国产综合久久久蜜 | 91人妻精品一区二区久久| 中英文字幕av一区| 97年大学生大白天操逼| 男人插女人视频网站| 91桃色成人网络在线观看| 亚洲国产成人av在线一区| 国产午夜激情福利小视频在线| 中文字幕第一页国产在线| 亚洲欧美福利在线观看| 少妇人妻真实精品视频| 懂色av蜜桃a v| 欧美精品亚洲精品日韩在线| 91九色porny国产蝌蚪视频| 亚洲一区自拍高清免费视频| 欧美交性又色又爽又黄麻豆| 91人妻精品一区二区在线看| 亚洲 图片 欧美 图片| 55夜色66夜色国产精品站| 天堂av在线播放免费| 亚洲高清一区二区三区视频在线| 亚洲免费福利一区二区三区| 好了av中文字幕在线| 91久久综合男人天堂| 国产又色又刺激在线视频 | 国产精品人妻一区二区三区网站| 免费啪啪啪在线观看视频| 亚洲高清国产拍青青草原| 女蜜桃臀紧身瑜伽裤| 欧美va不卡视频在线观看 | 一区二区三区国产精选在线播放| avjpm亚洲伊人久久| 色综合久久五月色婷婷综合| 天天日天天鲁天天操| 97人妻夜夜爽二区欧美极品| 亚洲少妇人妻无码精品| 成人动漫大肉棒插进去视频| 婷婷六月天中文字幕| 99re国产在线精品| 青青操免费日综合视频观看| 日韩精品电影亚洲一区| 91中文字幕免费在线观看| 日本乱人一区二区三区| 青娱乐蜜桃臀av色| 青青草成人福利电影| 国产综合高清在线观看| 久久精品亚洲成在人线a| 中文字幕av熟女人妻| 少妇被强干到高潮视频在线观看| 亚洲精品乱码久久久久久密桃明 | 999久久久久999| 欧美另类一区二区视频| 11久久久久久久久久久| aaa久久久久久久久| 日本少妇精品免费视频| 青青色国产视频在线| 青青青青青青青青青青草青青| 不卡日韩av在线观看| 黄色无码鸡吧操逼视频| 欧美精品资源在线观看| 免费岛国喷水视频在线观看| 亚洲免费在线视频网站| 国产使劲操在线播放| 国产又粗又猛又爽又黄的视频美国| 久精品人妻一区二区三区| 亚洲精品 欧美日韩| 清纯美女在线观看国产| 精品一线二线三线日本| 人妻丝袜av在线播放网址| 少妇被强干到高潮视频在线观看 | 中文字幕网站你懂的| 中文字幕免费在线免费| 欧美精品伦理三区四区 | 3344免费偷拍视频| 亚洲综合另类精品小说| 一区二区熟女人妻视频| 亚洲av可乐操首页| 亚洲综合自拍视频一区| 日韩一区二区三区三州| 亚洲精品欧美日韩在线播放| 国产精品自拍在线视频| 天天摸天天亲天天舔天天操天天爽| 大鸡吧插逼逼视频免费看| 免费看美女脱光衣服的视频| 天天操天天操天天碰| av网址在线播放大全| 一级黄片大鸡巴插入美女| 啊啊好大好爽啊啊操我啊啊视频| 中文字幕人妻被公上司喝醉在线| 国产亚洲欧美45p| 中文字幕 亚洲av| 欧美精品一区二区三区xxxx| 国产亚洲国产av网站在线| 超级av免费观看一区二区三区| 91麻豆精品久久久久| 欧美亚洲一二三区蜜臀| 丝袜长腿第一页在线| 蜜桃视频在线欧美一区| 超级碰碰在线视频免费观看| 无码中文字幕波多野不卡| 亚洲国产精品久久久久久6| 免费看美女脱光衣服的视频| 在线观看av亚洲情色| 91av中文视频在线| 日本少妇人妻xxxxxhd| 亚洲va国产va欧美va在线| 成人av久久精品一区二区| 国产高清精品极品美女| 亚洲一区自拍高清免费视频| 天天日天天干天天爱| 人妻少妇性色欲欧美日韩| 国产之丝袜脚在线一区二区三区| 日视频免费在线观看| 亚洲午夜精品小视频| 欧美怡红院视频在线观看| 亚洲中文精品字幕在线观看| 亚洲午夜高清在线观看| 熟女妇女老妇一二三区| 57pao国产一区二区| 久久国产精品精品美女| 色花堂在线av中文字幕九九| 成人国产激情自拍三区| 人妻久久久精品69系列| 亚洲综合图片20p| 亚洲精品国产久久久久久| 早川濑里奈av黑人番号| 啊啊好大好爽啊啊操我啊啊视频 | 97小视频人妻一区二区| 亚洲av无码成人精品区辽| 欧美成人精品在线观看| avjpm亚洲伊人久久| 国产V亚洲V天堂无码欠欠| 欧美xxx成人在线| 亚洲蜜臀av一区二区三区九色| av男人天堂狠狠干| 视频一区二区综合精品| 日韩国产乱码中文字幕| 中文字幕一区二 区二三区四区| 三级等保密码要求条款| 国产黄色片蝌蚪九色91| 麻豆性色视频在线观看| av网站色偷偷婷婷网男人的天堂| 黄色在线观看免费观看在线| 亚洲卡1卡2卡三卡四老狼| 91麻豆精品久久久久| 午夜毛片不卡免费观看视频 | 亚洲 欧美 精品 激情 偷拍| 大陆精品一区二区三区久久| 欧美精品中文字幕久久二区| 大香蕉伊人中文字幕| 欧美韩国日本国产亚洲| 久久精品国产23696| 亚洲在线观看中文字幕av| 99亚洲美女一区二区三区| 成人24小时免费视频| 超碰97人人澡人人| 天天干天天日天天干天天操| 首之国产AV医生和护士小芳| 四川五十路熟女av| 98视频精品在线观看| 亚洲一区制服丝袜美腿| 91快播视频在线观看| 91chinese在线视频| 欧美另类z0z变态| 人妻久久无码中文成人| 国产精彩对白一区二区三区| 天堂av在线最新版在线| 视频在线亚洲一区二区| 老司机午夜精品视频资源| 乱亲女秽乱长久久久| 在线观看免费av网址大全| 在线观看日韩激情视频| 日本黄色特一级视频| 99re6热在线精品| 激情人妻校园春色亚洲欧美| 天天日天天日天天射天天干| 粉嫩欧美美人妻小视频| 亚洲成a人片777777| 日本三极片中文字幕| 日本一区精品视频在线观看| 黄色片黄色片wyaa| 色婷婷六月亚洲综合香蕉| 亚洲国产第一页在线观看| 亚洲一区二区三区在线高清| 黄色录像鸡巴插进去| 精品老妇女久久9g国产| 日韩一区二区电国产精品| 国产精品女邻居小骚货| 任你操任你干精品在线视频| 动色av一区二区三区| 色综合天天综合网国产成人| 国产亚州色婷婷久久99精品| 精品视频国产在线观看| 亚洲少妇人妻无码精品| 在线视频精品你懂的| 女同久久精品秋霞网| 亚洲视频乱码在线观看| 欧美精品欧美极品欧美视频 | 亚洲 欧美 自拍 偷拍 在线| 免费成人va在线观看| 欧美熟妇一区二区三区仙踪林| 天天躁夜夜躁日日躁a麻豆| 在线播放 日韩 av| 大陆av手机在线观看| 色婷婷久久久久swag精品| 国产一区自拍黄视频免费观看| 天天操天天干天天艹| 午夜精品亚洲精品五月色| 抽查舔水白紧大视频| 亚洲最大黄了色网站| 日韩激情文学在线视频| 天天做天天爽夜夜做少妇| av一本二本在线观看| 少妇人妻100系列| 青青青爽视频在线播放| 天天摸天天日天天操| 欧美日韩亚洲国产无线码| 日本18禁久久久久久| 人妻少妇一区二区三区蜜桃| aaa久久久久久久久| 欧美一级片免费在线成人观看 | 天天操天天射天天操天天天 | 国产实拍勾搭女技师av在线| 精品视频一区二区三区四区五区| 精品国产亚洲av一淫| 91p0rny九色露脸熟女| 啊啊好大好爽啊啊操我啊啊视频 | 中文字幕乱码人妻电影| 美洲精品一二三产区区别| 2020中文字幕在线播放| 亚洲卡1卡2卡三卡四老狼| 日本一本午夜在线播放| 福利在线视频网址导航| 国产亚洲欧美视频网站| 2022中文字幕在线| 亚洲天天干 夜夜操| av天堂中文免费在线| 亚洲精品午夜aaa久久| 精品一区二区三区三区88| 人妻丝袜精品中文字幕| 桃色视频在线观看一区二区| 久久久91蜜桃精品ad| 日本一二三中文字幕| 一区二区三区四区五区性感视频| 天天干天天操天天摸天天射| 中文字幕av熟女人妻| 18禁美女黄网站色大片下载| 91精品综合久久久久3d动漫| 国产极品精品免费视频| 欧美一级片免费在线成人观看| 亚洲高清国产自产av| 久久久久久久一区二区三| 人人妻人人爱人人草| 亚洲的电影一区二区三区| 天堂资源网av中文字幕| 换爱交换乱高清大片| 亚洲精品 日韩电影| 最后99天全集在线观看| 亚洲高清国产拍青青草原| 免费在线看的黄网站| 2020中文字幕在线播放| 欧美久久一区二区伊人| 亚洲国产精品久久久久蜜桃| av手机免费在线观看高潮| 少妇与子乱在线观看| 成年人午夜黄片视频资源| 久久久久久久精品成人热| 一区二区三区另类在线 | 一区二区三区综合视频| 人人妻人人人操人人人爽| 国产+亚洲+欧美+另类| 成人综合亚洲欧美一区| 欧美精品免费aaaaaa| 亚洲av黄色在线网站| 青青青青青青草国产| 99婷婷在线观看视频| 97年大学生大白天操逼| 精品视频中文字幕在线播放| 摧残蹂躏av一二三区| 一区二区三区国产精选在线播放| 91大屁股国产一区二区| 国产精品欧美日韩区二区| 97少妇精品在线观看| 午夜精品一区二区三区更新| 国产午夜激情福利小视频在线| 大鸡巴插入美女黑黑的阴毛| 大尺度激情四射网站| 性欧美日本大妈母与子| 少妇ww搡性bbb91| 国产熟妇乱妇熟色T区| 男大肉棒猛烈插女免费视频| 国产精品欧美日韩区二区| 精品成人午夜免费看| 国产大鸡巴大鸡巴操小骚逼小骚逼| 大白屁股精品视频国产| 亚洲国产美女一区二区三区软件| 成人亚洲精品国产精品| 香蕉片在线观看av| 高清一区二区欧美系列| 9久在线视频只有精品| 硬鸡巴动态操女人逼视频| 国产真实灌醉下药美女av福利| 人人妻人人爱人人草| 亚洲区欧美区另类最新章节| 日韩欧美亚洲熟女人妻| 色婷婷久久久久swag精品| av天堂中文字幕最新| 久久久精品欧洲亚洲av| 国产精品探花熟女在线观看| 偷拍自拍视频图片免费| 视频在线免费观看你懂得| 777奇米久久精品一区| 97人妻无码AV碰碰视频| 毛片一级完整版免费| 在线观看视频 你懂的| 免费人成黄页网站在线观看国产 | 精品人人人妻人人玩日产欧| 国产日韩av一区二区在线| 亚洲自拍偷拍综合色| 久久久久久久一区二区三| 亚洲精品一区二区三区老狼| 99精品国自产在线人| 精品成人午夜免费看| 成人av亚洲一区二区| 成年女人免费播放视频| 少妇人妻二三区视频| 精品乱子伦一区二区三区免费播| 国产精品黄大片在线播放| 在线观看亚洲人成免费网址| 天天射夜夜操综合网| 制丝袜业一区二区三区| 黑人乱偷人妻中文字幕| gav成人免费播放| 久久一区二区三区人妻欧美| 欧美日韩熟女一区二区三区| 2022精品久久久久久中文字幕| 自拍偷拍,中文字幕| 亚洲欧美另类自拍偷拍色图| 欧美一区二区三区在线资源| 青青青视频手机在线观看| 久草视频在线免播放| 国产亚洲国产av网站在线| 久久亚洲天堂中文对白| 美女操逼免费短视频下载链接| 亚洲中文字幕乱码区| 少妇高潮一区二区三区| 国产性色生活片毛片春晓精品 | 天天日天天日天天射天天干| 久久丁香婷婷六月天| 国产激情av网站在线观看| 亚洲国产欧美一区二区丝袜黑人| 国产亚洲精品视频合集| 中国把吊插入阴蒂的视频| 91高清成人在线视频| 在线观看亚洲人成免费网址| 五十路在线观看完整版| 欧美亚洲一二三区蜜臀| 夜色17s精品人妻熟女| 青青青激情在线观看视频| 欧美日本aⅴ免费视频| 在线免费观看99视频| 自拍偷拍vs一区二区三区| 久久这里只有精品热视频 | 绯色av蜜臀vs少妇| 黄色在线观看免费观看在线 | 亚洲福利精品视频在线免费观看| 五十路丰满人妻熟妇| 午夜免费体验区在线观看| 美洲精品一二三产区区别| 天天干夜夜操天天舔| 91国产在线免费播放| 蜜臀成人av在线播放| 亚洲国产40页第21页| a v欧美一区=区三区| 福利视频一区二区三区筱慧| 久久丁香花五月天色婷婷| 丰满少妇人妻xxxxx| 自拍偷拍日韩欧美一区二区| 激情啪啪啪啪一区二区三区| 国产白嫩美女一区二区| 中文字幕在线欧美精品| 91国内精品自线在拍白富美| 啊啊啊想要被插进去视频| 91免费福利网91麻豆国产精品| 久草视频在线看免费| 亚洲欧美国产麻豆综合| 18禁免费av网站| 免费观看污视频网站| 激情五月婷婷免费视频| 最后99天全集在线观看| 2025年人妻中文字幕乱码在线| 精品美女福利在线观看| 中文字幕在线视频一区二区三区| 在线免费观看日本片| 欧美第一页在线免费观看视频| 人妻少妇精品久久久久久| 亚洲av无女神免非久久| 青青青青爽手机在线| 色吉吉影音天天干天天操| 综合色区亚洲熟妇shxstz| 自拍偷区二区三区麻豆| 综合页自拍视频在线播放| 一级黄片大鸡巴插入美女| 日韩美女福利视频网| 91麻豆精品久久久久| 国产夫妻视频在线观看免费| 午夜久久香蕉电影网| 美女av色播在线播放| 久久久久久久99精品| 久草电影免费在线观看| 插逼视频双插洞国产操逼插洞| 偷拍自拍福利视频在线观看| 97成人免费在线观看网站| 伊人情人综合成人久久网小说| 91色九色porny| 骚货自慰被发现爆操| 人妻少妇精品久久久久久| 久久永久免费精品人妻专区| 亚洲成人国产综合一区| 亚洲中文精品人人免费| 精品一区二区三四区| 国产精品久久久久久美女校花| 成人国产小视频在线观看| 国产中文字幕四区在线观看| 青草亚洲视频在线观看| 中文字幕高清在线免费播放| 性色av一区二区三区久久久| 中文字幕人妻一区二区视频| 精品亚洲中文字幕av| 青青青国产片免费观看视频| 欧美一区二区三区激情啪啪啪| 日本a级视频老女人| 中文字幕亚洲中文字幕| 无码中文字幕波多野不卡| 大香蕉日本伊人中文在线| 东京干手机福利视频| 国产黑丝高跟鞋视频在线播放| 加勒比视频在线免费观看| 男人操女人的逼免费视频| 国产精品大陆在线2019不卡 | 久久久精品999精品日本| 久久久精品欧洲亚洲av| 久久久超爽一二三av| 天天日天天添天天爽| 东游记中文字幕版哪里可以看到| 亚洲成人国产av在线| 午夜激情久久不卡一区二区| 日本熟妇喷水xxx| 亚洲一区二区人妻av| 色婷婷综合激情五月免费观看| 国产在线观看免费人成短视频| 欧美精产国品一二三产品区别大吗| 亚洲人妻视频在线网| 免费在线观看污污视频网站| 天天干天天日天天干天天操| 天天日天天干天天搡| 一区二区三区在线视频福利| 美女在线观看日本亚洲一区| 成人伊人精品色xxxx视频| 在线新三级黄伊人网| 国产亚洲精品视频合集| 99久久超碰人妻国产| 青青热久免费精品视频在线观看 | 午夜精品九一唐人麻豆嫩草成人| 天天色天天舔天天射天天爽| 专门看国产熟妇的网站| 亚洲精品无码色午夜福利理论片| 欧美成人精品欧美一级黄色| 人妻少妇精品久久久久久| 老司机免费视频网站在线看| av俺也去在线播放| 青青青青青青青青青青草青青| 在线免费观看日本伦理| 欧美成人一二三在线网| 97精品综合久久在线| 日韩人妻xxxxx| 日本精品美女在线观看| 99国产精品窥熟女精品| 成人亚洲精品国产精品| 在线观看成人国产电影| 视频 国产 精品 熟女 | weyvv5国产成人精品的视频| 99视频精品全部15| 最新国产亚洲精品中文在线| 亚洲高清视频在线不卡| 91精品国产黑色丝袜| 国产又粗又硬又猛的毛片视频| 欧美香蕉人妻精品一区二区| 家庭女教师中文字幕在线播放| 亚洲一区二区三区uij| 色噜噜噜噜18禁止观看| 国产精品亚洲а∨天堂免| 91社福利《在线观看| 天天日天天天天天天天天天天 | 亚洲无线观看国产高清在线| 欧美精品一区二区三区xxxx| 欧美成一区二区三区四区| 日韩美女福利视频网| 91大屁股国产一区二区| 亚洲一区制服丝袜美腿| jiuse91九色视频| 五月天中文字幕内射| 国产激情av网站在线观看| 国产真实乱子伦a视频| 中文字幕,亚洲人妻| 国产刺激激情美女网站| 亚洲欧美激情中文字幕| 无忧传媒在线观看视频| av手机在线观播放网站| 免费成人av中文字幕| 亚洲最大黄了色网站| 我想看操逼黄色大片| 欧美视频综合第一页| 插逼视频双插洞国产操逼插洞| 天天干天天操天天插天天日| 亚洲国产精品久久久久蜜桃| av完全免费在线观看av| 成人乱码一区二区三区av| 人妻丝袜av在线播放网址| 五十路息与子猛烈交尾视频 | 一区二区三区四区视频在线播放| 女同久久精品秋霞网| av日韩在线观看大全| 六月婷婷激情一区二区三区| 中文字幕中文字幕人妻| 蜜臀av久久久久久久| 成年人中文字幕在线观看| 欧美日本aⅴ免费视频| 国产乱子伦精品视频潮优女| 青青草在观免费国产精品| 97黄网站在线观看| 天天色天天操天天舔| 国产免费高清视频视频| 嫩草aⅴ一区二区三区| 国产麻豆精品人妻av| 午夜场射精嗯嗯啊啊视频| 成人综合亚洲欧美一区| 91免费黄片可看视频| 91 亚洲视频在线观看| 国产午夜亚洲精品不卡在线观看| 天天日天天敢天天干| 一区二区三区国产精选在线播放| 中国黄片视频一区91| 日韩精品二区一区久久| 亚洲欧美另类手机在线| 18禁美女黄网站色大片下载| 国产精品午夜国产小视频| 日本免费午夜视频网站| 动色av一区二区三区| 蜜臀av久久久久蜜臀av麻豆| 天天做天天干天天舔| rct470中文字幕在线| 大胸性感美女羞爽操逼毛片| 中文字幕中文字幕人妻| 自拍偷拍亚洲另类色图| 欧美视频综合第一页| 超碰在线中文字幕一区二区| 插逼视频双插洞国产操逼插洞| 天天日天天敢天天干| 亚洲精品国产综合久久久久久久久| 97超碰最新免费在线观看| 国产日韩一区二区在线看| 成年人免费看在线视频| 日韩av有码一区二区三区4| 99精品视频在线观看婷婷| 天天日天天日天天射天天干| 天天射夜夜操狠狠干| 少妇人妻久久久久视频黄片| 久久精品36亚洲精品束缚| 影音先锋女人av噜噜色| 成年人啪啪视频在线观看| rct470中文字幕在线| 国产麻豆剧果冻传媒app| 鸡巴操逼一级黄色气| 国产中文精品在线观看| 男人和女人激情视频| 色哟哟在线网站入口| 91麻豆精品传媒国产黄色片| av完全免费在线观看av| 免费在线播放a级片| 久草视频首页在线观看| 成人激情文学网人妻| 国产精品人妻熟女毛片av久| 在线观看av观看av| 日韩欧美国产一区ab| 婷婷色国产黑丝少妇勾搭AV| 一区二区三区久久中文字幕| 99精品视频在线观看免费播放| 日韩美女福利视频网| 宅男噜噜噜666国产| 亚洲特黄aaaa片| 宅男噜噜噜666免费观看| 欧美亚洲国产成人免费在线| 精品高跟鞋丝袜一区二区| 欧美怡红院视频在线观看| 蜜臀成人av在线播放| 午夜国产免费福利av| 精品视频中文字幕在线播放| 丰满少妇翘臀后进式| 国产极品美女久久久久久| 欧美日本在线观看一区二区| 日韩欧美一级精品在线观看| 一级黄色片夫妻性生活| 沈阳熟妇28厘米大战黑人| 国产女人被做到高潮免费视频| 欧美怡红院视频在线观看| 日本欧美视频在线观看三区| www天堂在线久久| 1000部国产精品成人观看视频| 福利在线视频网址导航| 清纯美女在线观看国产| 老鸭窝日韩精品视频观看| 在线新三级黄伊人网| 久久久久久久久久久免费女人| 在线免费观看av日韩| 亚洲成人激情视频免费观看了| 久久久久久久久久性潮| 亚洲综合自拍视频一区| 免费一级黄色av网站| 亚洲综合在线观看免费| 国产麻豆91在线视频| 亚洲在线一区二区欧美| 精品一区二区三区三区色爱| av中文字幕网址在线| 美女少妇亚洲精选av| 欧美激情电影免费在线| 中文字幕在线第一页成人| 国产精品一二三不卡带免费视频 | 亚洲综合在线视频可播放| 免费男阳茎伸入女阳道视频 | gay gay男男瑟瑟在线网站| 亚洲 欧美 精品 激情 偷拍| 精品高跟鞋丝袜一区二区| 老鸭窝日韩精品视频观看| 一色桃子人妻一区二区三区| 亚洲成人av一区在线| 日日夜夜狠狠干视频| 一级a看免费观看网站| 日本黄在免费看视频| 免费在线观看视频啪啪| 日本一二三中文字幕| 综合页自拍视频在线播放| 91精品国产观看免费| 青青青激情在线观看视频| 欧美一区二区三区四区性视频| 欧美viboss性丰满| 顶级尤物粉嫩小尤物网站| 国产午夜亚洲精品不卡在线观看| av完全免费在线观看av| 午夜福利资源综合激情午夜福利资| a v欧美一区=区三区| 欧美在线精品一区二区三区视频 | 午夜dv内射一区区| 少妇与子乱在线观看| 天堂av中文在线最新版| 亚洲av男人的天堂你懂的| 亚洲精品国产久久久久久| 亚洲国产精品免费在线观看| 欧美黑人与人妻精品| 成人综合亚洲欧美一区| 亚洲公开视频在线观看| 国内自拍第一页在线观看| 淫秽激情视频免费观看| 最新97国产在线视频| 92福利视频午夜1000看| 国产精品视频资源在线播放| 91精品高清一区二区三区| 中文字幕一区二区人妻电影冢本 | 国产视频在线视频播放| 人人妻人人澡欧美91精品| 夜色17s精品人妻熟女| 日日爽天天干夜夜操| 激情五月婷婷综合色啪| 少妇人妻100系列| 精品亚洲在线免费观看| 不卡一区一区三区在线| 午夜精品福利91av| 久久精品美女免费视频| 91老师蜜桃臀大屁股| 国产av自拍偷拍盛宴| 99精品免费观看视频| 免费啪啪啪在线观看视频| 日本最新一二三区不卡在线| 一区二区三区另类在线| 中文字幕成人日韩欧美| 在线可以看的视频你懂的| 亚洲男人的天堂a在线| 日韩人妻xxxxx| 日本熟妇一区二区x x| 人人妻人人人操人人人爽| 少妇与子乱在线观看| 骚逼被大屌狂草视频免费看| 岛国一区二区三区视频在线| 国产麻豆91在线视频| 亚洲精品亚洲人成在线导航| 91人妻人人做人人爽在线| 亚洲激情偷拍一区二区| 亚洲熟色妇av日韩熟色妇在线| 97超碰人人搞人人| 日韩少妇人妻精品无码专区| 东游记中文字幕版哪里可以看到| 天天操天天污天天射| 国产九色91在线观看精品| 99视频精品全部15| 孕妇奶水仑乱A级毛片免费看| 精品一区二区三区在线观看| 最新国产亚洲精品中文在线| 亚洲av一妻不如妾| 最新中文字幕免费视频| 天码人妻一区二区三区在线看| 久草极品美女视频在线观看| 中文字幕一区二区三区蜜月| 一区二区熟女人妻视频| 日韩欧美亚洲熟女人妻| 日日操综合成人av| 日韩成人综艺在线播放| 欧美成人小视频在线免费看| 天天色天天操天天透| 亚洲一区二区三区精品乱码| 成人综合亚洲欧美一区| 免费人成黄页网站在线观看国产| 欧美精品国产综合久久| 老司机99精品视频在线观看| 亚洲男人的天堂a在线| 久久久久久性虐视频| 在线观看av观看av| 中国黄色av一级片| 边摸边做超爽毛片18禁色戒| 水蜜桃国产一区二区三区| 久草视频在线免播放| 日韩一区二区三区三州| 99精品免费久久久久久久久a| 国产性色生活片毛片春晓精品| 午夜激情久久不卡一区二区| 免费人成黄页网站在线观看国产| www骚国产精品视频| 久久机热/这里只有| 亚洲成人激情av在线| 夜夜嗨av一区二区三区中文字幕| 在线观看的黄色免费网站| 91大屁股国产一区二区| 激情小视频国产在线| 人妻另类专区欧美制服| 黄色录像鸡巴插进去| 亚洲综合自拍视频一区| 可以免费看的www视频你懂的 | 性感美女福利视频网站| 二区中出在线观看老师| 午夜国产福利在线观看| 亚洲一区久久免费视频| 一区二区三区在线视频福利| 国产成人精品亚洲男人的天堂| 91天堂精品一区二区| 五色婷婷综合狠狠爱| 黄色在线观看免费观看在线| 成人亚洲国产综合精品| 91p0rny九色露脸熟女| 韩国亚洲欧美超一级在线播放视频 | 阴茎插到阴道里面的视频| 人妻少妇亚洲一区二区| 精品人人人妻人人玩日产欧| 亚洲av可乐操首页| 国产高潮无码喷水AV片在线观看| 青青青青青手机视频| 搡老妇人老女人老熟女| 适合午夜一个人看的视频| 欧美成一区二区三区四区| 97青青青手机在线视频 | 国产麻豆国语对白露脸剧情| 色噜噜噜噜18禁止观看| 人人妻人人爽人人添夜| 日本av在线一区二区三区| 中国熟女一区二区性xx| 成人av免费不卡在线观看| 欧美性受xx黑人性猛交| 国产成人无码精品久久久电影| 国产精品成久久久久三级蜜臀av| 欧美偷拍自拍色图片| av在线shipin| 大鸡八强奸视频在线观看| 青青在线视频性感少妇和隔壁黑丝| 一级黄片大鸡巴插入美女| 久久香蕉国产免费天天| 久久久久久性虐视频| 自拍偷拍日韩欧美亚洲| 在线 中文字幕 一区| 国产女人露脸高潮对白视频| 激情五月婷婷综合色啪| 超级福利视频在线观看| 人人妻人人澡欧美91精品| 中文字幕欧美日韩射射一| 国产av国片精品一区二区| 一区二区三区四区五区性感视频 | 超碰中文字幕免费观看| 亚洲欧美综合另类13p| 男生舔女生逼逼的视频| 日韩av有码中文字幕| 成熟丰满熟妇高潮xx×xx| 福利午夜视频在线合集| 欧美成人一二三在线网| 偷拍自拍国产在线视频| 粉嫩av蜜乳av蜜臀| 岳太深了紧紧的中文字幕| 国产va精品免费观看| 老熟妇xxxhd老熟女| 91免费观看国产免费| 哥哥姐姐综合激情小说| 黄色大片免费观看网站| 亚洲av无乱一区二区三区性色| 日曰摸日日碰夜夜爽歪歪| 91免费福利网91麻豆国产精品| 在线观看免费av网址大全| 日韩一区二区电国产精品| 五月色婷婷综合开心网4438| 亚洲高清国产自产av| 9色在线视频免费观看| 亚洲国产中文字幕啊啊啊不行了| 国产在线观看黄色视频| 蜜臀成人av在线播放| 日韩精品中文字幕播放| 中国黄色av一级片| a v欧美一区=区三区| yy96视频在线观看| 黄色黄色黄片78在线| 超碰97人人澡人人| 午夜精品一区二区三区城中村| 任我爽精品视频在线播放| 中文字幕1卡1区2区3区| av成人在线观看一区| 黄色视频成年人免费观看| 粉嫩欧美美人妻小视频| 欧亚日韩一区二区三区观看视频 | yellow在线播放av啊啊啊| 天天日天天干天天插舔舔| av中文字幕在线观看第三页| 日韩国产乱码中文字幕| 免费看国产av网站| av日韩在线观看大全| 99精品视频在线观看婷婷| 国产片免费观看在线观看| 午夜精品一区二区三区福利视频| 黄色成人在线中文字幕| 51国产成人精品视频| 啪啪啪啪啪啪啪免费视频| 日韩欧美国产一区不卡| 色天天天天射天天舔| 中文亚洲欧美日韩无线码| 日本少妇人妻xxxxx18| 中出中文字幕在线观看| 成人性黑人一级av| 亚洲va天堂va国产va久| 四川乱子伦视频国产vip| 99国内小视频在现欢看| 久久这里有免费精品| 亚洲综合在线视频可播放| 绝色少妇高潮3在线观看| 亚洲天堂av最新网址| 在线成人日韩av电影| 激情人妻校园春色亚洲欧美| 最新日韩av传媒在线| 日本韩国在线观看一区二区| 首之国产AV医生和护士小芳| 一区二区三区毛片国产一区| 夜夜操,天天操,狠狠操| 夜色撩人久久7777| 亚洲男人在线天堂网| 综合国产成人在线观看| 欧美成人一二三在线网| 色97视频在线播放| 白嫩白嫩美女极品国产在线观看| 麻豆精品成人免费视频| 黄色录像鸡巴插进去| 欧美成人黄片一区二区三区| 无码精品一区二区三区人| 中文字幕日韩91人妻在线| 少妇人妻二三区视频| 天天躁夜夜躁日日躁a麻豆| 亚洲1区2区3区精华液| rct470中文字幕在线| 青青热久免费精品视频在线观看| 午夜精品福利一区二区三区p| 天天射夜夜操狠狠干| 欧美日韩不卡一区不区二区| 日日夜夜大香蕉伊人| 自拍偷区二区三区麻豆| 蜜桃专区一区二区在线观看| 1区2区3区4区视频在线观看| 国产一区二区视频观看| 欧美亚洲自偷自拍 在线| 99av国产精品欲麻豆| tube69日本少妇| 热思思国产99re| 国产在线免费观看成人| 91p0rny九色露脸熟女| 最新国产精品网址在线观看| 亚洲精品麻豆免费在线观看| 欧美日韩v中文在线| 国产麻豆91在线视频| 2021年国产精品自拍| 免费费一级特黄真人片| 色综合天天综合网国产成人| 中文字幕 码 在线视频| 综合色区亚洲熟妇shxstz| 很黄很污很色的午夜网站在线观看| 国产熟妇乱妇熟色T区| 熟女俱乐部一二三区| 国产+亚洲+欧美+另类| av网址在线播放大全| 性色av一区二区三区久久久| 国产一线二线三线的区别在哪| 喷水视频在线观看这里只有精品| 91麻豆精品久久久久| 操操网操操伊剧情片中文字幕网| 亚洲av天堂在线播放| 在线观看视频污一区| brazzers欧熟精品系列| 日韩欧美一级黄片亚洲| 日本一道二三区视频久久| 日本精品视频不卡一二三| 社区自拍揄拍尻屁你懂的| 青青青青草手机在线视频免费看| 国产自拍黄片在线观看| 日本一本午夜在线播放| 熟女俱乐部一二三区| 天天躁日日躁狠狠躁躁欧美av | 久久永久免费精品人妻专区| 欧美日韩激情啪啪啪| 亚洲成高清a人片在线观看| 欧美专区日韩专区国产专区| 亚洲国产香蕉视频在线播放| 中国视频一区二区三区| 欧洲精品第一页欧洲精品亚洲| 国际av大片在线免费观看| 色狠狠av线不卡香蕉一区二区| 日韩中文字幕在线播放第二页| 精品成人啪啪18免费蜜臀| 在线 中文字幕 一区| 97欧洲一区二区精品免费| 天天操天天干天天日狠狠插| 97超碰国语国产97超碰| 久久99久久99精品影院| 国产露脸对白在线观看| 天码人妻一区二区三区在线看| 超污视频在线观看污污污| 在线免费观看亚洲精品电影| 日本少妇精品免费视频| 一区二区视频在线观看免费观看| 播放日本一区二区三区电影| 亚洲精品福利网站图片| 国产精品一区二区av国| 女同互舔一区二区三区| 中文字幕一区二区三区人妻大片| 亚洲美女高潮喷浆视频| 特黄老太婆aa毛毛片| 久久国产精品精品美女| 久久热久久视频在线观看| 特级无码毛片免费视频播放| 欧美地区一二三专区| 亚洲高清视频在线不卡| 自拍 日韩 欧美激情| 99久久成人日韩欧美精品| 日本熟女50视频免费| 久久这里有免费精品| 美日韩在线视频免费看| 99精品国产免费久久| 一级黄片久久久久久久久| 天天操天天弄天天射| 男女第一次视频在线观看| 99热这里只有国产精品6| 男人的天堂一区二区在线观看| 国产大鸡巴大鸡巴操小骚逼小骚逼| 亚洲美女自偷自拍11页| 开心 色 六月 婷婷| 日日夜夜精品一二三| 蜜桃专区一区二区在线观看| 特黄老太婆aa毛毛片| 亚洲 欧美 精品 激情 偷拍 | 91精品资源免费观看| 不卡精品视频在线观看| weyvv5国产成人精品的视频| 中文字幕在线一区精品| 国产高清97在线观看视频| 亚洲免费视频欧洲免费视频| 国产综合高清在线观看| 人人妻人人爽人人添夜| 熟女人妻一区二区精品视频| 99精品久久久久久久91蜜桃| 日本熟妇一区二区x x| 欧美日韩人妻久久精品高清国产| 亚洲最大黄了色网站| 99国内小视频在现欢看| 久久永久免费精品人妻专区| 久久丁香婷婷六月天| 色秀欧美视频第一页| 九九视频在线精品播放| 哥哥姐姐综合激情小说| 亚洲av午夜免费观看| 深夜男人福利在线观看| 久久久久久九九99精品| 人人人妻人人澡人人| 欧美精品亚洲精品日韩在线| 色偷偷伊人大杳蕉综合网| 大鸡吧插入女阴道黄色片| 在线免费视频 自拍| 亚洲国产精品久久久久蜜桃| xxx日本hd高清| 亚洲欧美福利在线观看| 日本一区美女福利视频| 天天日夜夜干天天操| xxx日本hd高清| 午夜精彩视频免费一区| 水蜜桃国产一区二区三区| 精品日产卡一卡二卡国色天香| 久久精品国产亚洲精品166m| 亚洲欧美另类手机在线| 一色桃子人妻一区二区三区| 国产一级麻豆精品免费| 超碰在线观看免费在线观看| 19一区二区三区在线播放| 91欧美在线免费观看| 97香蕉碰碰人妻国产樱花| 天天草天天色天天干| 亚洲国产精品免费在线观看| 福利片区一区二体验区| 女生自摸在线观看一区二区三区| 91综合久久亚洲综合| 亚洲图片欧美校园春色| 早川濑里奈av黑人番号| 中文字幕一区二 区二三区四区| 国产精品人妻一区二区三区网站| 人妻少妇一区二区三区蜜桃| 男人的天堂一区二区在线观看| 中文字幕成人日韩欧美| gay gay男男瑟瑟在线网站| 色呦呦视频在线观看视频| 伊人开心婷婷国产av| 国产又色又刺激在线视频 | 欧洲精品第一页欧洲精品亚洲 | 自拍偷拍亚洲另类色图| 岳太深了紧紧的中文字幕| 国产成人精品亚洲男人的天堂| 亚洲国产最大av综合| 最新91九色国产在线观看| 干逼又爽又黄又免费的视频| 在线 中文字幕 一区| 成人亚洲国产综合精品| 亚洲一区二区三区精品视频在线| 好吊操视频这里只有精品| 天天日天天玩天天摸| 日日日日日日日日夜夜夜夜夜夜| 在线观看视频 你懂的| 美女张开腿让男生操在线看| 少妇露脸深喉口爆吞精| 国产va精品免费观看| 天堂资源网av中文字幕| 久草电影免费在线观看| 国产精品伦理片一区二区| 天堂av在线播放免费| 欧美va亚洲va天堂va| 可以免费看的www视频你懂的| 老有所依在线观看完整版| 又粗又硬又猛又爽又黄的| 欧美viboss性丰满| 久久人人做人人妻人人玩精品vr| 青青青aaaa免费| asmr福利视频在线观看| 99国产精品窥熟女精品| 日日操综合成人av| 亚洲中文字字幕乱码| 国产chinesehd精品麻豆| 国产精品系列在线观看一区二区| 天天做天天干天天操天天射| 亚洲 中文 自拍 另类 欧美| 精品首页在线观看视频| 老司机深夜免费福利视频在线观看| 99精品久久久久久久91蜜桃| 久久久久久性虐视频| 国产一区成人在线观看视频| 国产高清精品一区二区三区| 999九九久久久精品| av网址在线播放大全| 亚洲欧美色一区二区| av网址国产在线观看| 日本18禁久久久久久| 亚洲最大黄了色网站| 久久精品久久精品亚洲人| 亚洲激情,偷拍视频| 老熟妇凹凸淫老妇女av在线观看| 欧美黑人与人妻精品| 欧美爆乳肉感大码在线观看| 国产黄色片蝌蚪九色91| 特级欧美插插插插插bbbbb| 在线可以看的视频你懂的| 亚洲午夜电影在线观看| 成人国产小视频在线观看| 一区二区三区日本伦理| 国产日韩一区二区在线看 | av中文字幕电影在线看| caoporn蜜桃视频| 亚洲av可乐操首页| 扒开腿挺进肉嫩小18禁视频| 日韩少妇人妻精品无码专区| 同居了嫂子在线播高清中文| 999热精品视频在线| 亚洲午夜伦理视频在线| 三级av中文字幕在线观看| 国产乱子伦一二三区| 欧美成人综合视频一区二区| 日韩av熟妇在线观看| 免费看国产av网站| 精品视频国产在线观看| 中英文字幕av一区| 熟女国产一区亚洲中文字幕| 风流唐伯虎电视剧在线观看| av天堂加勒比在线| 人妻熟女在线一区二区| 无码中文字幕波多野不卡| 色天天天天射天天舔| 激情国产小视频在线| 天天干天天啪天天舔| 国产高清97在线观看视频| 在线观看亚洲人成免费网址| 亚洲熟妇无码一区二区三区| 青青青青青青草国产| 青青青青青手机视频| av在线免费中文字幕| 亚洲变态另类色图天堂网| 日本韩国在线观看一区二区| 日辽宁老肥女在线观看视频| 午夜精品久久久久久99热| 欧美一区二区三区乱码在线播放| 国产女人露脸高潮对白视频| 亚洲护士一区二区三区| 在线播放国产黄色av| 亚洲欧洲一区二区在线观看| 久久国产精品精品美女| 亚洲综合色在线免费观看| 国产九色91在线观看精品| 国产精品视频欧美一区二区| 亚洲成人av在线一区二区| 黄色成年网站午夜在线观看| 岛国免费大片在线观看| 在线观看视频一区麻豆| 99re6热在线精品| 欧美va亚洲va天堂va| 久久精品在线观看一区二区| 神马午夜在线观看视频| 亚洲国产成人av在线一区| 成年人黄色片免费网站| 免费成人av中文字幕| 超碰在线中文字幕一区二区| 超鹏97历史在线观看| 亚洲天天干 夜夜操| 青青青青青操视频在线观看| 人人妻人人人操人人人爽| 日本女人一级免费片| 中文字幕人妻三级在线观看| 黄色黄色黄片78在线| 75国产综合在线视频| 91一区精品在线观看| 涩涩的视频在线观看视频| 天天日夜夜操天天摸| 久久精品国产999| 大香蕉伊人国产在线| 久久久精品国产亚洲AV一| 91极品新人『兔兔』精品新作| 91自产国产精品视频| 亚洲综合乱码一区二区| 亚洲一区二区三区久久午夜| 黄片色呦呦视频免费看| av老司机亚洲一区二区| 操操网操操伊剧情片中文字幕网| 青青青青爽手机在线| 亚洲福利午夜久久久精品电影网 | 老司机福利精品免费视频一区二区 | 欧美男同性恋69视频| 2022国产综合在线干| 亚洲综合一区二区精品久久| 亚洲 中文 自拍 无码| 97国产在线观看高清| 沈阳熟妇28厘米大战黑人| 天堂av在线最新版在线| 国产精品sm调教视频| 午夜激情久久不卡一区二区| 一级A一级a爰片免费免会员| 亚洲一区二区三区五区| 久久久久久久精品老熟妇| 在线观看视频 你懂的| 国产成人自拍视频在线免费观看| 国产美女精品福利在线| 99精品亚洲av无码国产另类| 专门看国产熟妇的网站| 97人人模人人爽人人喊| 熟女人妻在线观看视频| 人妻无码色噜噜狠狠狠狠色| rct470中文字幕在线| 91麻豆精品91久久久久同性| 色伦色伦777国产精品| 人妻丝袜诱惑我操她视频| 日本在线一区二区不卡视频| 日韩人妻xxxxx| 91精品国产高清自在线看香蕉网| 香港一级特黄大片在线播放| 天美传媒mv视频在线观看| 成年人中文字幕在线观看| 亚洲免费va在线播放| 天天色天天舔天天射天天爽| 天码人妻一区二区三区在线看| 在线观看成人国产电影| 亚洲丝袜老师诱惑在线观看| av天堂加勒比在线| 国产97在线视频观看| 国产麻豆剧果冻传媒app| 中文字幕第三十八页久久 | 欧美精品黑人性xxxx| 亚洲在线观看中文字幕av| 国产亚洲成人免费在线观看 | 久久热这里这里只有精品| 91精品激情五月婷婷在线| 日本人竟这样玩学生妹| 中文字幕乱码人妻电影| 国产剧情演绎系列丝袜高跟| 91中文字幕最新合集| 姐姐的朋友2在线观看中文字幕 | 啊啊啊想要被插进去视频| 97青青青手机在线视频| 国产高清精品一区二区三区| 国产av一区2区3区| 好男人视频在线免费观看网站| av一本二本在线观看| 午夜美女福利小视频| 中文字幕+中文字幕| 久久国产精品精品美女| 人人妻人人人操人人人爽| 97超碰免费在线视频| 三上悠亚和黑人665番号| 蜜臀成人av在线播放| 中文字幕在线观看国产片| 成人性黑人一级av| 熟女人妻一区二区精品视频| 亚洲人妻30pwc| 午夜免费体验区在线观看| 亚洲自拍偷拍综合色| 91p0rny九色露脸熟女| 亚洲av无硬久久精品蜜桃| 国产视频在线视频播放| 欧美黑人巨大性xxxxx猛交| 91大屁股国产一区二区| 91中文字幕最新合集| 精品国产污污免费网站入口自| 亚洲欧美一卡二卡三卡| 大香蕉大香蕉大香蕉大香蕉大香蕉| 国产揄拍高清国内精品对白| 欧美视频中文一区二区三区| 国产超码片内射在线| 东游记中文字幕版哪里可以看到| 亚洲精品无码色午夜福利理论片| 最后99天全集在线观看| 青青青青青操视频在线观看| 伊人情人综合成人久久网小说| 亚洲国产欧美国产综合在线| 欧美成一区二区三区四区| 欧洲欧美日韩国产在线| av中文字幕网址在线| 亚洲Av无码国产综合色区| 国产精品久久久久久久久福交| 国产精品成人xxxx| 欧美男人大鸡吧插女人视频 | 人人妻人人澡人人爽人人dvl| www日韩毛片av| 国产成人精品亚洲男人的天堂| 晚上一个人看操B片| 黄色大片男人操女人逼| av手机在线免费观看日韩av| 久久麻豆亚洲精品av| 日韩精品中文字幕在线| 人妻在线精品录音叫床| 成人网18免费视频版国产| 91天堂天天日天天操| 日韩欧美在线观看不卡一区二区| 亚洲精品午夜aaa久久| gogo国模私拍视频| 在线免费观看黄页视频| 国产精品人久久久久久| 亚洲av第国产精品|