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

攜程基于BookKeeper的延遲消息架構(gòu)落地實(shí)踐

移動(dòng)開發(fā) 移動(dòng)應(yīng)用
目前bookie集群部署在物理機(jī)上,集群新建、擴(kuò)縮容相對(duì)比較麻煩,未來將考慮融入k8s體系;bookie的治理與平臺(tái)化也是需要考慮的;我們目前只具備同城多中心容災(zāi)能力,跨region容災(zāi)以及公/私混合云容災(zāi)等高可用架構(gòu)也需要進(jìn)一步補(bǔ)強(qiáng)。

本文作者magiccao、littleorca,來自攜程消息隊(duì)列團(tuán)隊(duì)。目前主要從事消息中間件的開發(fā)與彈性架構(gòu)演進(jìn)工作,同時(shí)對(duì)網(wǎng)絡(luò)/性能優(yōu)化、應(yīng)用監(jiān)控與云原生等領(lǐng)域保持關(guān)注。

一、背景

QMQ延遲消息是以服務(wù)形式獨(dú)立存在的一套不局限于消息廠商實(shí)現(xiàn)的解決方案,其架構(gòu)如下圖所示。

QMQ延遲消息服務(wù)架構(gòu)

延遲消息從生產(chǎn)者投遞至延遲服務(wù)后,堆積在服務(wù)器本地磁盤中。當(dāng)延遲消息調(diào)度時(shí)間過期后,延遲服務(wù)轉(zhuǎn)發(fā)至實(shí)時(shí)Broker供消費(fèi)方消費(fèi)。延遲服務(wù)采用主從架構(gòu),其中,Zone表示一個(gè)可用區(qū)(一般可以理解成一個(gè)IDC),為了保證單可用區(qū)故障后,歷史投遞的待調(diào)度消息正常調(diào)度,master和slave會(huì)跨可用區(qū)部署。

1.1 痛點(diǎn)

此架構(gòu)主要存在如下幾點(diǎn)問題:

  • 服務(wù)具有狀態(tài),無法彈性擴(kuò)縮容;
  • 主節(jié)點(diǎn)故障后,需要主從切換(自動(dòng)或手動(dòng));
  • 缺少一致性協(xié)調(diào)器保障數(shù)據(jù)的一致性。

如果將消息的業(yè)務(wù)層和存儲(chǔ)層分離出來,各自演進(jìn)協(xié)同發(fā)展,各自專注在擅長的領(lǐng)域。這樣,消息業(yè)務(wù)層可以做到無狀態(tài)化,輕松完成容器化改造,具備彈性擴(kuò)縮容能力;存儲(chǔ)層引入分布式文件存儲(chǔ)服務(wù),由存儲(chǔ)服務(wù)來保證高可用與數(shù)據(jù)一致性。

1.2 分布式文件存儲(chǔ)選型

對(duì)于存儲(chǔ)服務(wù)的選型,除了基本的高可用于數(shù)據(jù)一致性特點(diǎn)外,還有至關(guān)重要的一點(diǎn):高容錯(cuò)與低運(yùn)維成本特性。分布式系統(tǒng)最大的特點(diǎn)自然是對(duì)部分節(jié)點(diǎn)故障的容忍能力,畢竟任何硬件或軟件故障是不可百分百避免的。因此,高容錯(cuò)與低運(yùn)維成本將成為我們選型中最為看重的。

2016年由雅虎開源貢獻(xiàn)給Apache的Pulsar,因其云原生、低延遲分布式消息隊(duì)列與流式處理平臺(tái)的標(biāo)簽,在開源社區(qū)引發(fā)轟動(dòng)與追捧。在對(duì)其進(jìn)行相關(guān)調(diào)研后,發(fā)現(xiàn)恰好Pulsar也是消息業(yè)務(wù)與存儲(chǔ)分離的架構(gòu),而存儲(chǔ)層則是另一個(gè)Apache開源基金會(huì)的BookKeeper。

二、BookKeeper

BookKeeper作為一款可伸縮、高容錯(cuò)、低延遲的分布式強(qiáng)一致存儲(chǔ)服務(wù)已被部分公司應(yīng)用于生產(chǎn)環(huán)境部署使用,最佳實(shí)踐案例包括替代HDFS的namenode、Pulsar的消息存儲(chǔ)與消費(fèi)進(jìn)度持久化以及對(duì)象存儲(chǔ)。

2.1 基本架構(gòu)

BookKeeper基本架構(gòu)

  • Zookeeper集群用于存儲(chǔ)節(jié)點(diǎn)發(fā)現(xiàn)與元信息存儲(chǔ),提供強(qiáng)一致性保證;
  • Bookie存儲(chǔ)節(jié)點(diǎn),提供數(shù)據(jù)的存儲(chǔ)服務(wù)。寫入和讀取過程中,Bookie節(jié)點(diǎn)間彼此無須通信。Bookie啟動(dòng)時(shí)將自身注冊(cè)到Zookeeper集群,暴露服務(wù);
  • Client屬于胖客戶端類型,負(fù)責(zé)與Zookeeper集群和BookKeeper集群直接通信,且根據(jù)元信息完成多副本的寫入,保證數(shù)據(jù)可重復(fù)讀。

2.2 基本特性

a)基本概念

  • Entry:數(shù)據(jù)載體的基本單元
  • Ledger:entry集合的抽象,類似文件
  • Bookie:ledger集合的抽象,物理存儲(chǔ)節(jié)點(diǎn)
  • Ensemble:ledger的bookie集合

b)數(shù)據(jù)讀寫

BookKeeper數(shù)據(jù)讀寫

bookie客戶端通過創(chuàng)建而持有一個(gè)ledger后便可以進(jìn)行entry寫入操作,entry以帶狀方式分布在enemble的bookie中。entry在客戶端進(jìn)行編號(hào),每條entry會(huì)根據(jù)設(shè)置的副本數(shù)(Qw)要求判定寫入成功與否;

bookie客戶端通過打開一個(gè)已創(chuàng)建的ledger進(jìn)行entry讀取操作,entry的讀取順序與寫入保持一致,默認(rèn)從第一個(gè)副本中讀取,讀取失敗后順序從下一個(gè)副本重試。

c)數(shù)據(jù)一致性

持有可寫ledger的bookie客戶端稱為Writer,通過分布式鎖機(jī)制確保一個(gè)ledger全局只有一個(gè)Writer,Writer的唯一性保證了數(shù)據(jù)寫入一致性。Writer內(nèi)存中維護(hù)一個(gè)LAC(Last Add Confirmed),當(dāng)滿足Qw要求后,更新LAC。LAC隨下一次請(qǐng)求或定時(shí)持久化在bookie副本中,當(dāng)ledger關(guān)閉時(shí),持久化在Metadata Store(zookeeper或etcd)中;

持有可讀ledger的bookie客戶端稱為Reader,一個(gè)ledger可以有任意多個(gè)Reader。LAC的強(qiáng)一致性保證了不同Reader看到統(tǒng)一的數(shù)據(jù)視圖,亦可重復(fù)讀,從而保證了數(shù)據(jù)讀取一致性。

d)容錯(cuò)性

典型故障場(chǎng)景:Writer crash或restart、Bookie crash。

Writer故障,ledger可能未關(guān)閉,導(dǎo)致LAC未知。通過ledger recover機(jī)制,關(guān)閉ledger,修復(fù)LAC;

Bookie故障,entry寫入失敗。通過ensemble replace機(jī)制,更新一條新的entry路由信息到Metadata Store中,保障了新數(shù)據(jù)能及時(shí)成功寫入。歷史數(shù)據(jù),通過bookie recover機(jī)制,滿足Qw副本要求,夯實(shí)了歷史數(shù)據(jù)讀取的可靠性。至于副本所在的所有bookie節(jié)點(diǎn)全部故障場(chǎng)景,只能等待修復(fù)。

e)負(fù)載均衡

新擴(kuò)容進(jìn)集群的bookie,當(dāng)創(chuàng)建新的ledger時(shí),便自動(dòng)均衡流量。

2.3 同城多中心容災(zāi)

上海區(qū)域(region)存在多個(gè)可用區(qū)(az,available zone),各可用兩兩間網(wǎng)絡(luò)延遲低于2ms,此種網(wǎng)絡(luò)架構(gòu)下,多副本分散在不同的az間是一個(gè)可接受的高可用方案。BookKeeper基于Zone感知的ensemble替換策略便是應(yīng)對(duì)此種場(chǎng)景的解決方案。

基于Zone感知策略的同城多中心容災(zāi)

開啟Zone感知策略有兩個(gè)限制條件:a)E % Qw == 0;b)Qw > minNumOfZones。其中E表示ensemble大小,Qw表示副本數(shù),minNumOfZones表示ensemble中的最小zone數(shù)目。

譬如下面的例子:

minNumOfZones = 2
desiredNumZones = 3
E = 6
Qw = 3
[z1, z2, z3, z1, z2, z3]

故障前,每條數(shù)據(jù)具有三副本,且分布在三個(gè)可用區(qū)中;當(dāng)z1故障后,將以滿足minNumOfZones限制生成新的ensemble:[z1, z2, z3, z1, z2, z3] -> [z3, z2, z3, z3, z2, z3]。顯然對(duì)于三副本的每條數(shù)據(jù)仍將分布在兩個(gè)可用區(qū)中,仍能容忍一個(gè)可用區(qū)故障。

DNSResolver

客戶端在挑選bookie組成ensemble時(shí),需要通過ip反解出對(duì)應(yīng)的zone信息,需要用戶實(shí)現(xiàn)解析器。考慮到zone與zone間網(wǎng)段是認(rèn)為規(guī)劃且不重合的,因此,我們落地時(shí),簡單的實(shí)現(xiàn)了一個(gè)可動(dòng)態(tài)配置生效的子網(wǎng)解析器。示例給出的是ip精確匹配的實(shí)現(xiàn)方式。

public class ConfigurableDNSToSwitchMapping extends AbstractDNSToSwitchMapping {

private final Map<String, String> mappings = Maps.newHashMap();

public ConfigurableDNSToSwitchMapping() {
super();
mappings.put("192.168.0.1", "/z1/192.168.0.1"); // /zone/upgrade domain
mappings.put("192.168.1.1", "/z2/192.168.1.1");
mappings.put("192.168.2.1", "/z3/192.168.2.1");
}

@Override
public boolean useHostName() {
return false;
}

@Override
public List<String> resolve(List<String> names) {
List<String> rNames = Lists.newArrayList();
names.forEach(name -> {
String rName = mappings.getOrDefault(name, "/default-zone/default-upgradedomain");
rNames.add(rName);
});
return rNames;
}
}

可配置化DNS解析器示例

數(shù)據(jù)副本分布在單zone

當(dāng)某些原因(譬如可用區(qū)故障演練)導(dǎo)致只有一個(gè)可用區(qū)可用時(shí),新寫入的數(shù)據(jù)的全部副本都將落在單可用區(qū),當(dāng)故障可用區(qū)恢復(fù)后,仍然有部分歷史數(shù)據(jù)只存在于單可用區(qū),不滿足多可用區(qū)容災(zāi)的高可用需求。

AutoRecovery機(jī)制中有一個(gè)PlacementPolicy檢測(cè)機(jī)制,但缺少恢復(fù)機(jī)制。于是我們打了個(gè)patch,支持動(dòng)態(tài)機(jī)制開啟和關(guān)閉此功能。這樣,當(dāng)可用區(qū)故障恢復(fù)后可以自動(dòng)發(fā)現(xiàn)和修復(fù)數(shù)據(jù)全部副本分布在單可用區(qū)從而影響數(shù)據(jù)可用性的問題。

三、彈性架構(gòu)落地

引入BookKeeper后,延遲消息服務(wù)的架構(gòu)相對(duì)漂亮不少。消息業(yè)務(wù)層面和存儲(chǔ)層面完全分離,延遲消息服務(wù)本身無狀態(tài)化,可以輕易伸縮。當(dāng)可用區(qū)故障后,不再需要主從切換。

延遲消息服務(wù)新架構(gòu)

3.1 無狀態(tài)化改造

存儲(chǔ)層分離出去后,業(yè)務(wù)層實(shí)現(xiàn)無狀態(tài)化成為可能。要達(dá)成這一目標(biāo),還需解決一些問題。我們先看看BookKeeper使用上的一些約束:

  • BookKeeper不支持共享寫入的,也即業(yè)務(wù)層多個(gè)節(jié)點(diǎn)如果都寫數(shù)據(jù),則各自寫的必然是不同的ledger;
  • 雖然BookKeeper允許多讀,但多個(gè)應(yīng)用節(jié)點(diǎn)各自讀取的話,進(jìn)度是相互獨(dú)立的,應(yīng)用必須自行解決進(jìn)度協(xié)調(diào)問題。

上述兩個(gè)主要問題,決定我們實(shí)現(xiàn)無狀態(tài)和彈性擴(kuò)縮容時(shí),必需自行解決讀寫資源分配的問題。為此,我們引入了任務(wù)協(xié)調(diào)器。

我們首先將存儲(chǔ)資源進(jìn)行分片管理,每個(gè)分片上都支持讀寫操作,但同一時(shí)刻只能有一個(gè)業(yè)務(wù)層節(jié)點(diǎn)來讀寫。如果我們把分片看作資源,把業(yè)務(wù)層節(jié)點(diǎn)看作工作者,那么任務(wù)協(xié)調(diào)器的主要職責(zé)為:

  • 在盡可能平均的前提下以粘滯優(yōu)先的方式把資源分配給工作者;
  • 監(jiān)視資源和工作者的變化,如有增減,重新執(zhí)行職責(zé)1;
  • 在資源不夠用時(shí),根據(jù)具體策略配置,添加初始化新的資源。

由于是分布式環(huán)境,協(xié)調(diào)器自身完成上述職責(zé)時(shí)需要保證分布式一致性,當(dāng)然還要滿足可用性要求。我們選擇了基于ZooKeeper進(jìn)行選主的一主多從式架構(gòu)。

如圖所示,協(xié)調(diào)器對(duì)等部署在業(yè)務(wù)層應(yīng)用節(jié)點(diǎn)中。運(yùn)行時(shí),協(xié)調(diào)器通過基于ZooKeeper的leader競選機(jī)制決出leader節(jié)點(diǎn),并由leader節(jié)點(diǎn)負(fù)責(zé)前述任務(wù)分配工作。

協(xié)調(diào)器選舉的實(shí)現(xiàn)參考ZooKeeper官方文檔,這里不再贅述。

3.2 持久化數(shù)據(jù)

原有架構(gòu)將延遲消息根據(jù)調(diào)度時(shí)間按每10分鐘桶存儲(chǔ)在本地,時(shí)間臨近的桶加載到內(nèi)存中,使用HashedWheelTimer來調(diào)度。該設(shè)計(jì)存在兩個(gè)弊端:

  • 分桶較多(我們支持2年范圍的延遲,理論分桶數(shù)量達(dá)10萬多);
  • 單個(gè)桶的數(shù)據(jù)(10分鐘)如不能全部加載到內(nèi)存,則由于桶內(nèi)未按調(diào)度時(shí)間排序,可能出現(xiàn)未加載的部分包含了調(diào)度時(shí)間較早的數(shù)據(jù),等它被加載時(shí)已經(jīng)滯后了。

弊端1的話,單機(jī)本地10萬+文件還不算多大問題,但改造后這些桶信息以元信息的方式存儲(chǔ)在ZooKeeper上,我們的實(shí)現(xiàn)方案決定了每個(gè)桶至少占用3個(gè)ZooKeeper節(jié)點(diǎn)。假設(shè)我們要部署5個(gè)集群,平均每個(gè)集群有10個(gè)分片,每個(gè)分片有10萬個(gè)桶,那使用的ZooKeeper節(jié)點(diǎn)數(shù)量就是1500萬起,這個(gè)量級(jí)是ZooKeeper難以承受的。

弊端2則無論新老架構(gòu),都是個(gè)潛在問題。一旦某個(gè)10分鐘消息量多一些,就可能導(dǎo)致消息延遲。往內(nèi)存加載時(shí),應(yīng)該有更細(xì)的顆粒度才好。

基于以上問題分析,我們參考多級(jí)時(shí)間輪調(diào)度的思路,略加變化,設(shè)計(jì)了一套基于滑動(dòng)時(shí)間分桶的多級(jí)調(diào)度方案。

如上表所示,最大的桶是1周,其次是1天,1小時(shí),1分鐘。每個(gè)級(jí)別覆蓋不同的時(shí)間范圍,組合起來覆蓋2年的時(shí)間范圍理論上只需286個(gè)桶,相比原來的10萬多個(gè)桶有了質(zhì)的縮減。

同時(shí),只有L0m這一級(jí)調(diào)度器需要加載數(shù)據(jù)到HashedWheelTimer,故而加載粒度細(xì)化到了1分鐘,大大減少了因不能完整加載一個(gè)桶而導(dǎo)致的調(diào)度延遲。

多級(jí)調(diào)度器以類似串聯(lián)的方式協(xié)同工作。

每一級(jí)調(diào)度器收到寫入請(qǐng)求時(shí),首先嘗試委托給其上級(jí)(顆粒度更大)調(diào)度器處理。如果上級(jí)接受,則只需將上級(jí)的處理結(jié)果向下返回;如果上級(jí)不接受,再判斷是否歸屬本級(jí),是的話寫入桶中,否則打回給下級(jí)。

每一級(jí)調(diào)度器都會(huì)將時(shí)間臨近的桶打開并發(fā)送其中的數(shù)據(jù)到下一級(jí)調(diào)度器。比如L1h發(fā)現(xiàn)最小的桶到了預(yù)加載時(shí)間,則把該桶的數(shù)據(jù)讀出并發(fā)送給L0m調(diào)度器,最終該小時(shí)的數(shù)據(jù)被轉(zhuǎn)移到L0m并展開為(最多)60個(gè)分鐘級(jí)的桶。

四、未來規(guī)劃

目前bookie集群部署在物理機(jī)上,集群新建、擴(kuò)縮容相對(duì)比較麻煩,未來將考慮融入k8s體系;bookie的治理與平臺(tái)化也是需要考慮的;我們目前只具備同城多中心容災(zāi)能力,跨region容災(zāi)以及公/私混合云容災(zāi)等高可用架構(gòu)也需要進(jìn)一步補(bǔ)強(qiáng)。

責(zé)任編輯:未麗燕 來源: 攜程技術(shù)
相關(guān)推薦

2022-08-20 07:46:03

Dynamo攜程數(shù)據(jù)庫

2022-05-13 07:22:39

攜程微服務(wù)SOA

2023-07-07 12:19:43

攜程技術(shù)

2016-09-04 15:14:09

攜程實(shí)時(shí)數(shù)據(jù)數(shù)據(jù)平臺(tái)

2022-06-27 09:36:29

攜程度假GraphQL多端開發(fā)

2022-06-27 09:42:55

攜程金融nebula圖平臺(tái)

2024-04-26 09:38:36

2023-06-06 11:49:24

2022-07-15 12:58:02

鴻蒙攜程華為

2022-05-13 09:27:55

Widget機(jī)票業(yè)務(wù)App

2022-11-29 20:32:07

2023-06-28 14:01:13

攜程實(shí)踐

2023-07-07 12:26:39

攜程開發(fā)

2017-10-09 09:12:35

攜程運(yùn)維架構(gòu)

2016-12-15 21:41:15

大數(shù)據(jù)

2022-08-12 08:34:32

攜程數(shù)據(jù)庫上云

2023-02-08 16:34:05

數(shù)據(jù)庫工具

2022-07-08 09:38:27

攜程酒店Flutter技術(shù)跨平臺(tái)整合

2022-07-15 09:20:17

性能優(yōu)化方案

2023-11-24 09:44:07

數(shù)據(jù)攜程
點(diǎn)贊
收藏

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

黑人巨大精品欧美一区二区小视频| 亚洲国产欧美在线成人app| 日韩美女一区| av免费观看在线| 一区二区91| 国产亚洲美女久久| 韩国三级与黑人| 欧美无毛视频| 亚洲激情网站免费观看| 欧美日韩国产综合在线| 国产草草影院ccyycom| 久久九九电影| 久久国产色av| 夜夜春很很躁夜夜躁| 国产精品亚洲一区二区在线观看| 欧美日韩日本国产| 国产91porn| 国产福利第一视频在线播放| 国产成人精品在线看| 国产精品99久久99久久久二8| 精品无码久久久久成人漫画| 欧美人与拘性视交免费看| 欧美xxx久久| 污片在线免费看| 欧美aaaaa性bbbbb小妇| 亚洲精品免费在线播放| 先锋影音欧美| 久久国产精品高清一区二区三区| 国产91丝袜在线播放九色| 国产精品狼人色视频一区| 偷偷操不一样的久久| 中文字幕一区二区三区乱码图片| 亚洲视频自拍偷拍| 中文字幕av观看| 日韩精品中文字幕吗一区二区| 在线亚洲一区二区| 日韩av综合在线观看| 九色91在线| 亚洲欧美日韩在线不卡| 一本一本a久久| 国产免费av在线| 久久色视频免费观看| 国产伦精品一区二区三区高清版 | 欧美日韩亚洲一区| www.久久久久久.com| 美国一级黄色录像| 成人aaaa| 一区国产精品视频| 亚洲区自拍偷拍| 亚洲素人在线| 精品亚洲va在线va天堂资源站| 精品国产乱码久久久久夜深人妻| 免费精品一区二区三区在线观看| 欧美精品xxxxbbbb| 亚洲网中文字幕| 日韩中文字幕无砖| 精品少妇一区二区三区在线播放 | 亚洲精品久久久久avwww潮水| 六月丁香婷婷久久| 国产色视频一区| 一区二区三区精| 精品一区二区三区在线播放| 91久久国产婷婷一区二区| 国产精品久久综合青草亚洲AV| 久久69国产一区二区蜜臀| 成人在线播放av| av高清一区二区| 成人福利视频在线看| 国内视频一区| 每日更新av在线播放| 国产偷国产偷精品高清尤物| 亚洲国产一区二区三区在线播| 日韩av中文| 亚洲免费观看视频| 精品一区二区三区无码视频| 懂色av一区| 日韩欧美国产免费播放| 美女黄色片视频| 国产精品亚洲一区二区在线观看| 精品日韩成人av| 播金莲一级淫片aaaaaaa| 日韩精品久久| 欧美福利视频在线观看| 西西44rtwww国产精品| 日本亚洲一区二区| 亚洲综合日韩在线| 婷婷亚洲一区二区三区| 国产精品久久福利| 国产在线视频在线| 欧美色网在线| 91精品国模一区二区三区| 91九色蝌蚪porny| 国模精品一区| 久久久久久久久综合| 看黄色一级大片| 国产不卡在线视频| 日本一区美女| 丝袜国产在线| 欧美性videosxxxxx| 极品白嫩少妇无套内谢| 国产精品免费大片| 欧美激情aaaa| 中文字幕+乱码+中文| 成人丝袜高跟foot| 亚洲自拍三区| 夜鲁夜鲁夜鲁视频在线播放| 欧美丰满一区二区免费视频| 人妻巨大乳一二三区| 神马电影久久| 欧美精品久久久久a| 91video| 国内成人自拍视频| 国产一区自拍视频| 日韩免费视频网站| 国产最新精品免费| 欧美日韩综合久久| heyzo在线| 欧美一区二区三区啪啪| 免费一级做a爰片久久毛片潮| 黄色成人av网站| 国产日韩欧美另类| 国产女人在线视频| 色综合久久久网| 亚洲欧美日本一区| 国产一在线精品一区在线观看| 国产精品欧美一区二区三区奶水| 头脑特工队2在线播放| 亚洲已满18点击进入久久| 欧美午夜aaaaaa免费视频| 日韩精品福利一区二区三区| 欧美激情第6页| 99精品在线视频观看| 国产精品乱人伦一区二区| 国产v亚洲v天堂无码久久久| 亚洲精品一级二级三级| 97在线免费观看| 蜜桃av噜噜一区二区三区麻豆| 亚洲欧美成aⅴ人在线观看 | 成人深夜福利app| 大桥未久一区二区| 成人在线视频国产| 久久久国产精品x99av| 91麻豆国产视频| 国产精品三级视频| 亚洲欧美视频二区| 日韩免费特黄一二三区| 国产精品99久久久久久白浆小说| 欧美3p视频在线观看| 色综合中文字幕| mm131美女视频| 久热re这里精品视频在线6| 欧美精品二区三区四区免费看视频 | 国产精品aaaa| 可以直接在线观看的av| 色视频欧美一区二区三区| 国产免费一区二区三区网站免费| 免费在线观看成人av| 欧美日韩三区四区| 国产精品久久久久久吹潮| 色婷婷久久一区二区| 国产男女无套免费网站| 亚洲综合在线第一页| 中文字幕一区二区人妻电影丶| 在线亚洲成人| 日本欧洲国产一区二区| 久久精品xxxxx| 久久精品国产亚洲| 亚洲第一天堂网| 五月婷婷久久综合| 免费看污片网站| 毛片一区二区三区| 国产盗摄视频在线观看| av男人一区| 国产999在线观看| 日本三级视频在线观看| 日韩欧美国产三级| 亚洲欧美综合另类| 成人免费在线播放视频| 国产免费a级片| 玖玖在线精品| 精品一区二区成人免费视频| eeuss国产一区二区三区四区| 81精品国产乱码久久久久久| 成人在线观看免费| 欧美一级生活片| 99精品在线播放| ...xxx性欧美| 在线免费观看污视频| 美女精品自拍一二三四| 奇米777四色影视在线看| 欧美三级自拍| 成人在线激情视频| 偷拍自拍在线看| 久久亚洲国产精品| 欧美一区二区三区少妇| 欧美一级精品大片| 69亚洲精品久久久蜜桃小说 | 国产成人精品亚洲男人的天堂| 久久蜜桃av一区精品变态类天堂 | 成人在线激情网| 一区二区免费不卡在线| 欧洲高清一区二区| av毛片精品| 成人免费视频97| 日韩欧美看国产| 欧美精品精品精品精品免费| 日本天堂在线观看| 亚洲人成伊人成综合网久久久| 精品二区在线观看| 欧美三日本三级三级在线播放| 国产午夜久久久| 亚洲欧美影音先锋| 卡一卡二卡三在线观看| 95精品视频在线| 9191在线视频| 看国产成人h片视频| 国产1区2区在线| 激情视频一区| 黄色成人在线免费观看| 国产韩日影视精品| 日韩成人在线资源| 精品在线91| 久久99久久99精品蜜柚传媒| 伊人精品久久| 51蜜桃传媒精品一区二区| 精品亚洲a∨| 国产精品盗摄久久久| 国产直播在线| 亚州欧美日韩中文视频| 男插女视频久久久| 欧美精品手机在线| 成人日日夜夜| 久久精品欧美视频| 黄色在线论坛| 久久精品成人欧美大片| 天堂аⅴ在线地址8| 中文字幕久热精品在线视频| 国产在线观看免费| 亚洲视频在线播放| av色图一区| 在线播放国产精品| 国产免费a∨片在线观看不卡| 亚洲欧美在线免费观看| 青青草免费在线| 亚洲精品色婷婷福利天堂| 日韩国产福利| 亚洲人成电影在线播放| 男男电影完整版在线观看| 国产视频在线观看一区二区| 黄上黄在线观看| 国产午夜精品一区二区三区 | 国内精品偷拍视频| 精品国产凹凸成av人导航| 成人免费视频国产免费麻豆| 精品国产电影一区二区| 午夜av免费在线观看| 国产丝袜视频一区| 成人激情电影在线看| 深夜精品寂寞黄网站在线观看| 在线免费观看黄色| 久久精品亚洲精品| 男女在线观看视频| 全球成人中文在线| 99re久久| 97netav| 欧美电影免费网站| 日本亚洲欧洲精品| 希岛爱理一区二区三区| 国产av熟女一区二区三区| 亚洲乱亚洲高清| 国产精品人人妻人人爽人人牛| 精品一区二区在线观看| 动漫美女无遮挡免费| 久久久www成人免费毛片麻豆| 国产黄色大片免费看| 亚洲免费观看视频| 在线观看免费国产视频| 欧美性xxxxxxxx| 成人福利小视频| 亚洲色图第三页| av片在线观看网站| 欧日韩不卡在线视频| 亚洲男男av| 免费久久一级欧美特大黄| 色天天久久综合婷婷女18| 日韩国产成人无码av毛片| 日韩和的一区二区| 26uuu国产| 欧美经典一区二区| 久久机热这里只有精品| 在线精品视频小说1| 精品乱子伦一区二区| 亚洲欧洲黄色网| 欧美人与动牲性行为| 国产成人久久久精品一区| 视频国产精品| 亚洲成人午夜在线| 亚洲三级电影在线观看| 17c国产在线| 久久久噜噜噜久噜久久综合| 蜜臀久久精品久久久用户群体| 亚洲国产精品久久人人爱蜜臀| 国产在线观看第一页| 亚洲国内精品在线| 国产精品扒开做爽爽爽的视频| 欧美专区中文字幕| 91精品国产自产精品男人的天堂| 日本一区二区在线视频| 亚洲精品护士| 欧美日韩一区二区区| 中文成人av在线| 羞羞影院体验区| 欧美va亚洲va香蕉在线| 国精产品一区| 国产精品免费观看在线| 香蕉一区二区| 男人插女人视频在线观看| 国精产品一区一区三区mba视频| 中字幕一区二区三区乱码| 精品国产电影一区| www.中文字幕| 欧美成人国产va精品日本一级| 777午夜精品电影免费看| 久久精品一区二区三区不卡免费视频| 影音先锋成人在线电影| 亚洲欧美aaa| 国产精品久久三区| 国产亚洲久一区二区| 亚洲欧美国产制服动漫| 国产盗摄——sm在线视频| 岛国视频一区免费观看| 国内自拍一区| 久久国产免费视频| 亚洲国产精品一区二区www在线| www黄色网址| 精品自拍视频在线观看| 日本一区精品视频| 女同性恋一区二区| 国产一区亚洲一区| 中文字幕五月天| 欧美一级在线视频| 国产后进白嫩翘臀在线观看视频| 99久久精品无码一区二区毛片| 五月激情综合| 久久综合在线观看| 综合色天天鬼久久鬼色| 国产麻豆免费观看| 久久亚洲一区二区三区四区五区高| 欧美成人免费全部网站| 在线视频精品一区| 国产精品88av| 精品无码久久久久| 日韩国产高清污视频在线观看| 黄色软件视频在线观看| 久久99精品久久久久久三级 | 国产欧美精品日韩| 99精品全国免费观看视频软件| 在线观看日本www| 一区二区国产视频| 天堂网www中文在线| 青青草原一区二区| 欧美精品乱码| 亚洲高清在线不卡| 亚洲国产精品人人做人人爽| 欧美一区二区少妇| 国产人妖伪娘一区91| 女人香蕉久久**毛片精品| 国产av一区二区三区传媒| 黑人狂躁日本妞一区二区三区| 高清国产福利在线观看| 成人黄色免费片| 亚洲国产日韩欧美一区二区三区| aaaaaav| 欧美日韩国产精品自在自线| av黄色在线| 久久久综合香蕉尹人综合网| 日本不卡免费在线视频| 懂色av懂色av粉嫩av| 亚洲第一精品福利| 香蕉成人影院| 欧美 亚洲 视频| 久久伊人中文字幕| 91好色先生tv| 国产91av在线| 亚洲人体av| 玖玖爱在线观看| 日韩一卡二卡三卡四卡| 亚洲精品mv| 国产日韩第一页| 99久久久免费精品国产一区二区 | 美女福利一区二区| 樱空桃在线播放| 久久久久久久久久久黄色| 97在线公开视频| 亲爱的老师9免费观看全集电视剧| 91久久夜色精品国产按摩| 老熟妇精品一区二区三区| 欧美日韩电影在线播放| 新版的欧美在线视频| 好吊色视频988gao在线观看|