3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Storm源码分析之四: Trident源码分析

發布時間:2024/1/23 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Storm源码分析之四: Trident源码分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Storm源碼分析之四: Trident源碼分析

@(STORM)[storm]

  • Storm源碼分析之四 Trident源碼分析
  • 一概述
      • 0小結
      • 1簡介
      • 2關鍵類
        • 1Spout的創建
        • 2spout的消息流
      • 3spout調用的整體流程
      • 4spout如何被 加載到拓撲中
  • 二Spout
    • 一Spout的創建
      • 1ItridentSpout
      • 2BatchCoordinator
      • 3Emmitter
      • 4一個示例
    • 二spout實際的消息流
      • 1MasterBatchCoordinator
      • 2TridentSpoutCoordinator
      • 3TridentSpoutExecutor
  • 三bolt
    • 一概述
      • 1組件的基本關系
      • 2用戶視角與源碼視角
    • 二基礎類
      • 1Stream
        • 1成員變量
        • 2projectionValidation
        • 3project
      • 2Node SpoutNode PartitionNode ProcessorNode
      • 詳細分析見書
      • 3Group
        • 1成員變量
        • 2構造方法
        • 3outgoingNodes
        • 4incommingNodes
      • 4GraphGrouper
        • 1成員變量
        • 2構造方法
        • 3reindex
        • 4nodeGroup
        • 5outgoingGroups
        • 6incomingGroups
        • 7merge
        • 8mergeFully
  • 四在TridentTopologyBuilder中設置Spoutbolt
    • 一參考內容
    • 一概述
    • 二基礎類
      • 1GlobalStreamId
    • 三TridentTopology
      • 1生成bolt的名稱genBoltIds
      • 2添加節點addNode
      • 3添加節點addSourceNode
    • 四TridentTopologyBuilder

一、概述

0、小結

TridentTopologyBuilder與TridentTopology調用MBC/TSC/TSE設置spout與2個bolt,而這三個類通過調用用戶代碼Spout中定義的Coordinator與Emitter完成真正的邏輯。
最后構建好的拓撲會提交至nimbus,nimbus開始調度這個拓撲,開始運行。

1、簡介

trident是storm的更高層次抽象,相對storm,它主要提供了3個方面的好處:
(1)提供了更高層次的抽象,將常用的count,sum等封裝成了方法,可以直接調用,不需要自己實現。
(2)以批次代替單個元組,每次處理一個批次的數據。
(3)提供了事務支持,可以保證數據均處理且只處理了一次。

本文介紹了在一個Trident拓撲中,spout是如何被產生并被調用的。首先介紹了用戶如何創建一個Spout以及其基本原理,然后介紹了Spout的實際數據流,最后解釋了在創建topo時如何設置一個Spout。

2、關鍵類

MaterBatchCorodeinator —————> ITridentSpout.Coordinator#isReady
|
|
v
TridentSpoutCoordinator —————> ITridentSpout.Coordinator#[initialTransaction, success, close]
|
|
v
TridentSpoutExecutor —————> ITridentSpout.Emitter#(emitBatch, success(),close)

Spout中涉及2組類,第一組類定義了用戶如何創建一個Spout,這些用戶的代碼會被第二組的類調用。第二組類定義了實際的數據流是如何發起并傳送的。

(1)Spout的創建

涉及三個類:ItridentSpout, BatchCoordinator, Emitter,其中后面2個是第一個的內部類。
用戶創建一個Spout需要實現上述三個接口。比如storm-kafka中的Spout就是實現了這3個接口或者其子接口。

(2)spout的消息流

也是涉及三個類:MasterBatchCoordinator, TridentSpoutCoordinator, TridentSpoutExecutor。它們除了自身固定的邏輯以外,還會調用用戶的代碼,就是上面介紹的Spout代碼。
它們的定義分別為:

MasterBatchCoordinator extends BaseRichSpout TridentSpoutCoordinator implements IBasicBolt TridentSpoutExecutor implements ITridentBatchBolt

可以看出來,MasterBatchCoordinator才是真正的spout,另外2個都是bolt。
MasterBatchCoordinator會調用用戶定義的BatchCoordinator的isReady()方法,返回true的話,則會發送一個id為batch。TridentSpoutCoordinatorMBCbatch流后,會調用BatchCoordinator的initialTransaction()初始化一個消息,并繼續向外發送 batchTridentSpoutExecutorbatch流后,會調用用戶代碼中的TridentSpoutExecutor#emitBatch()方法,開始發送實際的業務數據。

3、spout調用的整體流程

1、MasterBatchCoordinator是Trident中真正的Spout,它可以包含多個TridentSpoutCoordinator的節點。MBC在nextTuple()中向外發送id為batch。MBCmaxTransactionActivebatch流。

if(_activeTx.size() < _maxTransactionActive) {Long curr = _currTransaction;for(int i=0; i<_maxTransactionActive; i++) {if(!_activeTx.containsKey(curr) && isReady(curr)) {// by using a monotonically increasing attempt id, downstream tasks// can be memory efficient by clearing out state for old attempts// as soon as they see a higher attempt id for a transactionInteger attemptId = _attemptIds.get(curr);if(attemptId==null) {attemptId = 0;} else {attemptId++;}_attemptIds.put(curr, attemptId);for(TransactionalState state: _states) {state.setData(CURRENT_ATTEMPTS, _attemptIds);}TransactionAttempt attempt = new TransactionAttempt(curr, attemptId);_activeTx.put(curr, new TransactionStatus(attempt));_collector.emit(BATCH_STREAM_ID, new Values(attempt), attempt);_throttler.markEvent();}curr = nextTransactionId(curr);} }

2、TSC收到batchexecute()batch流。

long txid = attempt.getTransactionId();Object prevMeta = _state.getPreviousState(txid);Object meta = _coord.initializeTransaction(txid, prevMeta, _state.getState(txid));_state.overrideState(txid, meta);collector.emit(MasterBatchCoordinator.BATCH_STREAM_ID, new Values(attempt, meta));

3、TSE收到$batch流后,調用用戶Emitter類中的emitBatch()方法,開始向外發送數據。

_collector.setBatch(info.batchId); _emitter.emitBatch(attempt, input.getValue(1), _collector); _activeBatches.put(attempt.getTransactionId(), attempt);

4、當整個消息被成功處理完后,會調用MBC的ack()方法,ack方法會將事務的狀態從PROCESSING改為PROCESSED:

if(status.status==AttemptStatus.PROCESSING) {status.status = AttemptStatus.PROCESSED; }

當然,如果fail掉了,則會調用fail()方法。
當sync()方法接收到事務狀態為PROCESSED時,將其改為COMMITTING的狀態,并向外發送id為$commit的流。

if(maybeCommit!=null && maybeCommit.status == AttemptStatus.PROCESSED) {maybeCommit.status = AttemptStatus.COMMITTING;_collector.emit(COMMIT_STREAM_ID, new Values(maybeCommit.attempt), maybeCommit.attempt);}

5、TSE處理$commit流

if(input.getSourceStreamId().equals(MasterBatchCoordinator.COMMIT_STREAM_ID)) {if(attempt.equals(_activeBatches.get(attempt.getTransactionId()))) {((ICommitterTridentSpout.Emitter) _emitter).commit(attempt);_activeBatches.remove(attempt.getTransactionId());} else {throw new FailedException("Received commit for different transaction attempt");}}

收到$commit流的節點會開始提交操作,但trident會按事務號順序提交事務的,所以由提交bolt來決定是否現在提交,還是先緩存下來之后再提交。

6、當$commit流處理完后,MBC的ack()方法會被再次調用,同時向外發送$success流

else if(status.status==AttemptStatus.COMMITTING) {//如果當前狀態是COMMITTING,則將事務從_activeTx及_attemptIds去掉,并發送$success流。_activeTx.remove(tx.getTransactionId());_attemptIds.remove(tx.getTransactionId());_collector.emit(SUCCESS_STREAM_ID, new Values(tx));_currTransaction = nextTransactionId(tx.getTransactionId());for(TransactionalState state: _states) {state.setData(CURRENT_TX, _currTransaction);}

7、TSC處理$commit流

if(tuple.getSourceStreamId().equals(MasterBatchCoordinator.SUCCESS_STREAM_ID)) {_state.cleanupBefore(attempt.getTransactionId());_coord.success(attempt.getTransactionId());}

8、TSE處理$success流

else if(input.getSourceStreamId().equals(MasterBatchCoordinator.SUCCESS_STREAM_ID)) {// valid to delete before what's been committed since // those batches will never be accessed again_activeBatches.headMap(attempt.getTransactionId()).clear();_emitter.success(attempt);}

至此整個流程全部完成。

總結說就是消息是從MasterBatchCoordinator開始的,它是一個真正的spout,而TridentSpoutCoordinator與TridentSpoutExecutor都是bolt,MasterBatchCoordinator發起協調消息,最后的結果是TridentSpoutExecutor發送業務消息。而發送協調消息與業務消息的都是調用用戶Spout中BatchCoordinator與Emitter中定義的代碼。

可以參考《storm源碼分析》P458的流程圖

4、spout如何被 加載到拓撲中

(1)在TridentTopologyBuilder的buildTopololg方法中設置了topo的相關信息
(2)在TridentTopology中調用newStream方法,將spout節點加入拓撲。
包括MBC, TSC, TSE等均是在上面2個類中被調用,從而形成一個完整的拓撲。

二、Spout

(一)Spout的創建

1、ItridentSpout

在Trident中用戶定義的Spout需要實現ItridentSpout接口。我們先看看ItridentSpout的定義

package storm.trident.spout;import backtype.storm.task.TopologyContext; import storm.trident.topology.TransactionAttempt; import backtype.storm.tuple.Fields; import java.io.Serializable; import java.util.Map; import storm.trident.operation.TridentCollector;public interface ITridentSpout<T> extends Serializable {public interface BatchCoordinator<X> {X initializeTransaction(long txid, X prevMetadata, X currMetadata); void success(long txid); boolean isReady(long txid)void close();}public interface Emitter<X> {void emitBatch(TransactionAttempt tx, X coordinatorMeta, TridentCollector collector);void success(TransactionAttempt tx);void close();}BatchCoordinator<T> getCoordinator(String txStateId, Map conf, TopologyContext context);Emitter<T> getEmitter(String txStateId, Map conf, TopologyContext context); Map getComponentConfiguration();Fields getOutputFields(); }

它有2個內部接口,分別是BatchCoordinator和Emitter,分別是用于協調的Spout接口和發送消息的Bolt接口。實現一個Spout的主要工作就在于實現這2個接口,創建實際工作的Coordinator和Emitter。Spout中提供了2個get方法用于分別用于指定使用哪個Coordinator和Emitter類,這些類會由用戶定義。稍后我們再分析Coordinator和Emitter的內容。
除此之外,還提供了getComponentConfiguration用于獲取配置信息,getOutputFields獲取輸出field。

我們再看看2個內部接口的代碼。

2、BatchCoordinator

public interface BatchCoordinator<X> {X initializeTransaction(long txid, X prevMetadata, X currMetadata);void success(long txid);boolean isReady(long txid);void close(); }

(1)initializeTransaction方法返回一個用戶定義的事務元數據。X是用戶自定義的與事務相關的數據類型,返回的數據會存儲到zk中。
其中txid為事務序列號,prevMetadata是前一個事務所對應的元數據。若當前事務為第一個事務,則其為空。currMetadata是當前事務的元數據,如果是當前事務的第一次嘗試,則為空,否則為事務上一次嘗試所產生的元數據。
(2)isReady方法用于判斷事務所對應的數據是否已經準備好,當為true時,表示可以開始一個新事務。其參數是當前的事務號。
BatchCoordinator中實現的方法會被部署到多個節點中運行,其中isReady是在真正的Spout(MasterBatchCoordinator)中執行的,其余方法在TridentSpoutCoordinator中執行。

3、Emmitter

public interface Emitter<X> {void emitBatch(TransactionAttempt tx, X coordinatorMeta, TridentCollector collector);void success(TransactionAttempt tx);void close(); }

消息發送節點會接收協調spout的$batch和$success流。
(1)當收到$batch消息時,節點便調用emitBatch方法來發送消息。
(2)當收到$success消息時,會調用success方法對事務進行后處理

4、一個示例

參考 DiagnosisEventSpout

(1)Spout的代碼

package com.packtpub.storm.trident.spout;import backtype.storm.task.TopologyContext; import backtype.storm.tuple.Fields; import storm.trident.spout.ITridentSpout;import java.util.Map;@SuppressWarnings("rawtypes") public class DiagnosisEventSpout implements ITridentSpout<Long> {private static final long serialVersionUID = 1L;BatchCoordinator<Long> coordinator = new DefaultCoordinator();Emitter<Long> emitter = new DiagnosisEventEmitter();@Overridepublic BatchCoordinator<Long> getCoordinator(String txStateId, Map conf, TopologyContext context) {return coordinator;}@Overridepublic Emitter<Long> getEmitter(String txStateId, Map conf, TopologyContext context) {return emitter;}@Overridepublic Map getComponentConfiguration() {return null;}@Overridepublic Fields getOutputFields() {return new Fields("event");} }

(2)BatchCoordinator的代碼

package com.packtpub.storm.trident.spout;import org.slf4j.Logger; import org.slf4j.LoggerFactory; import storm.trident.spout.ITridentSpout.BatchCoordinator;import java.io.Serializable;public class DefaultCoordinator implements BatchCoordinator<Long>, Serializable {private static final long serialVersionUID = 1L;private static final Logger LOG = LoggerFactory.getLogger(DefaultCoordinator.class);@Overridepublic boolean isReady(long txid) {return true;}@Overridepublic void close() {}@Overridepublic Long initializeTransaction(long txid, Long prevMetadata, Long currMetadata) {LOG.info("Initializing Transaction [" + txid + "]");return null;}@Overridepublic void success(long txid) {LOG.info("Successful Transaction [" + txid + "]");} }

(3)Emitter的代碼

package com.packtpub.storm.trident.spout;import com.packtpub.storm.trident.model.DiagnosisEvent; import storm.trident.operation.TridentCollector; import storm.trident.spout.ITridentSpout.Emitter; import storm.trident.topology.TransactionAttempt;import java.io.Serializable; import java.util.ArrayList; import java.util.List; import java.util.concurrent.atomic.AtomicInteger;public class DiagnosisEventEmitter implements Emitter<Long>, Serializable {private static final long serialVersionUID = 1L;AtomicInteger successfulTransactions = new AtomicInteger(0);@Overridepublic void emitBatch(TransactionAttempt tx, Long coordinatorMeta, TridentCollector collector) {for (int i = 0; i < 10000; i++) {List<Object> events = new ArrayList<Object>();double lat = new Double(-30 + (int) (Math.random() * 75));double lng = new Double(-120 + (int) (Math.random() * 70));long time = System.currentTimeMillis();String diag = new Integer(320 + (int) (Math.random() * 7)).toString();DiagnosisEvent event = new DiagnosisEvent(lat, lng, time, diag);events.add(event);collector.emit(events);}}@Overridepublic void success(TransactionAttempt tx) {successfulTransactions.incrementAndGet();}@Overridepublic void close() {}}

(4)最后,在創建topo時指定spout

TridentTopology topology = new TridentTopology();DiagnosisEventSpout spout = new DiagnosisEventSpout();Stream inputStream = topology.newStream("event", spout);

(二)spout實際的消息流

以上的內容說明了如何在用戶代碼中創建一個Spout,以及其基本原理。但創建Spout后,它是怎么被加載到拓撲真正的Spout中呢?我們繼續看trident的實現。

1、MasterBatchCoordinator

總體而言,MasterBatchCoordinator作為一個數據流的真正起點:
* 首先調用open方法完成初始化,包括讀取之前的拓撲處理到的事務序列號,最多同時處理的tuple數量,每個事務的嘗試次數等。
* 然后nextTuple會改變事務的狀態,或者是創建事務并發送$batch流。
* 最后,ack方法會根據流的狀態向外發送$commit流,或者是重新調用sync方法,開始創建新的事務。

總而言之,MasterBatchCoordinator作為拓撲數據流的真正起點,通過循環發送協調信息,不斷的處理數據流。MasterBatchCoordinator的真正作用在于協調消息的起點,里面所有的map,如_activeTx,_attemptIds等都只是為了保存當前正在處理的情況而已。

(1)MasterBatchCoordinator是一個真正的spout

public class MasterBatchCoordinator extends BaseRichSpout

一個Trident拓撲的真正邏輯就是從MasterBatchCoordinator開始的,先調用open方法完成一些初始化,然后是在nextTuple中發送$batch和$commit流。

(2)看一下open方法

@Overridepublic void open(Map conf, TopologyContext context, SpoutOutputCollector collector) {_throttler = new WindowedTimeThrottler((Number)conf.get(Config.TOPOLOGY_TRIDENT_BATCH_EMIT_INTERVAL_MILLIS), 1);for(String spoutId: _managedSpoutIds) {//每個MasterBatchSpout可以處理多個ITridentSpout,這里將多個spout的元數據放到_states這個Map中。稍后再看看放進來的是什么內容。_states.add(TransactionalState.newCoordinatorState(conf, spoutId));}//從zk中獲取當前的transation事務序號,當拓撲新啟動時,需要從zk恢復之前的狀態。也就是說zk存儲的是下一個需要提交的事務序號,而不是已經提交的事務序號。_currTransaction = getStoredCurrTransaction();_collector = collector;//任何時刻中,一個spout task最多可以同時處理的tuple數量,即已經emite,但未acked的tuple數量。Number active = (Number) conf.get(Config.TOPOLOGY_MAX_SPOUT_PENDING);if(active==null) {_maxTransactionActive = 1;} else {_maxTransactionActive = active.intValue();}//每一個事務的當前嘗試編號,即_currTransaction這個事務序號中,各個事務的嘗試次數。_attemptIds = getStoredCurrAttempts(_currTransaction, _maxTransactionActive);for(int i=0; i<_spouts.size(); i++) {//將各個Spout的Coordinator保存在_coordinators這個List中。String txId = _managedSpoutIds.get(i);_coordinators.add(_spouts.get(i).getCoordinator(txId, conf, context));}}

(3)再看一下nextTuple()方法,它只調用了sync()方法,主要完成了以下功能:
* 如果事務狀態是PROCESSED,則將其狀態改為COMMITTING,然后發送commit。commit流的節點會調用finishBatch方法,進行事務的提交和后處理
* 如果_activeTx.size()小于_maxTransactionActive,則新建事務,放到_activeTx中,同時向外發送$batch流,等待Coordinator的處理。( 當ack方法被 調用時,這個事務會被從_activeTx中移除)
注意:當前處于acitve狀態的應該是序列在[_currTransaction,_currTransaction+_maxTransactionActive-1]之間的事務。

private void sync() {// note that sometimes the tuples active may be less than max_spout_pending, e.g.// max_spout_pending = 3// tx 1, 2, 3 active, tx 2 is acked. there won't be a commit for tx 2 (because tx 1 isn't committed yet),// and there won't be a batch for tx 4 because there's max_spout_pending tx active//判斷當前事務_currTransaction是否為PROCESSED狀態,如果是的話,將其狀態改為COMMITTING,然后發送$commit流。接收到$commit流的節點會調用finishBatch方法,進行事務的提交和后處理。TransactionStatus maybeCommit = _activeTx.get(_currTransaction);if(maybeCommit!=null && maybeCommit.status == AttemptStatus.PROCESSED) {maybeCommit.status = AttemptStatus.COMMITTING;_collector.emit(COMMIT_STREAM_ID, new Values(maybeCommit.attempt), maybeCommit.attempt);}//用于產生一個新事務。最多存在_maxTransactionActive個事務同時運行,當前active的事務序號區間處于[_currTransaction,_currTransaction+_maxTransactionActive-1]之間。注意只有在當前//事務結束之后,系統才會初始化新的事務,所以系統中實際活躍的事務可能少于_maxTransactionActive。if(_active) {if(_activeTx.size() < _maxTransactionActive) {Long curr = _currTransaction;//創建_maxTransactionActive個事務。for(int i=0; i<_maxTransactionActive; i++) {//如果事務序號不存在_activeTx中,則創建新事務,并發送$batch流。當ack被調用時,這個序號會被remove掉,詳見ack方法。if(!_activeTx.containsKey(curr) && isReady(curr)) {// by using a monotonically increasing attempt id, downstream tasks// can be memory efficient by clearing out state for old attempts// as soon as they see a higher attempt id for a transactionInteger attemptId = _attemptIds.get(curr);if(attemptId==null) {attemptId = 0;} else {attemptId++;}//_activeTx記錄的是事務序號和事務狀態的map,而_activeTx則記錄事務序號與嘗試次數的map。_attemptIds.put(curr, attemptId);for(TransactionalState state: _states) {state.setData(CURRENT_ATTEMPTS, _attemptIds);}//TransactionAttempt包含事務序號和嘗試編號2個變量,對應于一個具體的事務。TransactionAttempt attempt = new TransactionAttempt(curr, attemptId);_activeTx.put(curr, new TransactionStatus(attempt));_collector.emit(BATCH_STREAM_ID, new Values(attempt), attempt);_throttler.markEvent();}//如果事務序號已經存在_activeTx中,則curr遞增,然后再循環檢查下一個。curr = nextTransactionId(curr);}}} }

完整代碼見最后。

(4)繼續往下,看看ack方法。

@Override public void ack(Object msgId) {//獲取某個事務的狀態TransactionAttempt tx = (TransactionAttempt) msgId;TransactionStatus status = _activeTx.get(tx.getTransactionId());if(status!=null && tx.equals(status.attempt)) {//如果當前狀態是PROCESSING,則改為PROCESSEDif(status.status==AttemptStatus.PROCESSING) {status.status = AttemptStatus.PROCESSED;} else if(status.status==AttemptStatus.COMMITTING) {//如果當前狀態是COMMITTING,則將事務從_activeTx及_attemptIds去掉,并發送$success流。_activeTx.remove(tx.getTransactionId());_attemptIds.remove(tx.getTransactionId());_collector.emit(SUCCESS_STREAM_ID, new Values(tx));_currTransaction = nextTransactionId(tx.getTransactionId());for(TransactionalState state: _states) {state.setData(CURRENT_TX, _currTransaction); }}//由于有些事務狀態已經改變,需要重新調用sync()繼續后續處理,或者發送新tuple。sync();} }

(5)還有fail方法和declareOutputFileds方法。

@Override public void fail(Object msgId) {TransactionAttempt tx = (TransactionAttempt) msgId;TransactionStatus stored = _activeTx.remove(tx.getTransactionId());if(stored!=null && tx.equals(stored.attempt)) {_activeTx.tailMap(tx.getTransactionId()).clear();sync();} }@Override public void declareOutputFields(OutputFieldsDeclarer declarer) {// in partitioned example, in case an emitter task receives a later transaction than it's emitted so far,// when it sees the earlier txid it should know to emit nothingdeclarer.declareStream(BATCH_STREAM_ID, new Fields("tx"));declarer.declareStream(COMMIT_STREAM_ID, new Fields("tx"));declarer.declareStream(SUCCESS_STREAM_ID, new Fields("tx")); }

2、TridentSpoutCoordinator

TridentSpoutCoordinator接收來自MasterBatchCoordinator的$success流與$batch流,并通過調用用戶代碼,實現真正的邏輯。此外還向TridentSpoutExecuter發送$batch流,以觸發后者開始真正發送業務數據流。

(1)TridentSpoutCoordinator是一個bolt

public class TridentSpoutCoordinator implements IBasicBolt

(2)在創建TridentSpoutCoordinator時,需要傳遞一個ITridentSpout對象,

public TridentSpoutCoordinator(String id, ITridentSpout spout) {_spout = spout;_id = id;}

然后使用這個對象來獲取到用戶定義的Coordinator:

_coord = _spout.getCoordinator(_id, conf, context);

(3)_state和_underlyingState保存了zk中的元數據信息

_underlyingState = TransactionalState.newCoordinatorState(conf, _id); _state = new RotatingTransactionalState(_underlyingState, META_DIR);

(4)在execute方法中,TridentSpoutCoordinator接收$success流與$batch流,先看看$success流:

if(tuple.getSourceStreamId().equals(MasterBatchCoordinator.SUCCESS_STREAM_ID)) { _state.cleanupBefore(attempt.getTransactionId()); _coord.success(attempt.getTransactionId()); }

即接收到$success流時,調用用戶定義的Coordinator中的success方法。同時還清理了zk中的數據。
(5)再看看$batch流

else {long txid = attempt.getTransactionId();Object prevMeta = _state.getPreviousState(txid);Object meta = _coord.initializeTransaction(txid, prevMeta, _state.getState(txid));_state.overrideState(txid, meta);collector.emit(MasterBatchCoordinator.BATCH_STREAM_ID, new Values(attempt, meta));}

當收到$batch流流時,初始化一個事務并將其發送出去。由于在trident中消息有可能是重放的,因此需要prevMeta。注意,trident是在bolt中初始化一個事務的。

3、TridentSpoutExecutor

TridentSpoutExecutor接收來自TridentSpoutCoordinator的消息流,包括$commit,$success與$batch流,前面2個分別調用emmitter的commit與success方法,$batch則調用emmitter的emitBatch方法,開始向外發送業務數據。

對于分區類型的spout,有可能是OpaquePartitionedTridentSpoutExecutor等分區類型的executor。

(1) TridentSpoutExecutor與是一個bolt

publicclassTridentSpoutExecutorimplementsITridentBatchBolt

(2)核心的execute方法

@Override public void execute(BatchInfo info, Tuple input) {// there won't be a BatchInfo for the success streamTransactionAttempt attempt = (TransactionAttempt) input.getValue(0);if(input.getSourceStreamId().equals(MasterBatchCoordinator.COMMIT_STREAM_ID)) {if(attempt.equals(_activeBatches.get(attempt.getTransactionId()))) {((ICommitterTridentSpout.Emitter) _emitter).commit(attempt);_activeBatches.remove(attempt.getTransactionId());} else {throw new FailedException("Received commit for different transaction attempt");}} else if(input.getSourceStreamId().equals(MasterBatchCoordinator.SUCCESS_STREAM_ID)) {// valid to delete before what's been committed since // those batches will never be accessed again_activeBatches.headMap(attempt.getTransactionId()).clear();_emitter.success(attempt);} else { _collector.setBatch(info.batchId);//發送業務消息_emitter.emitBatch(attempt, input.getValue(1), _collector);_activeBatches.put(attempt.getTransactionId(), attempt);} }

三、bolt

(一)概述

1、組件的基本關系

(1)trident拓撲最終會轉化為一個spout和多個bolt,每個bolt對應一個SubTopologyBolt,它通過TridentBoltExecutor適配成一個bolt。而每個SubTopologyBOlt則由很多節點組成,具體點說這個節點包括(Stream|Node)2部分,注意,Node不是Stream自身的成員變量,而是一個具體的處理節點。Stream定義了哪些數據流,Node定義和如何進行操作,Node包含了一個ProjectedProccessor等處理器,用于定義如何進行數據處理。
(2)一個SubTopologyBOlt包含多個Group,但大多數情況下是一個Group??碩ridentTopology#genBoltIds()的代碼。在一個SubTopologyBolt中,含有多個節點組是可能的。例如在含有DRPC的Topology中,查詢操作也存儲操作可以被分配到同一個SubTopologyBolt中。于是該bolt可能收到來自2個節點組的消息。
(3)一個Group有多個Node。符合一定條件的Node會被merge()成一個Group,每個Node表示一個操作。
(4)每個Node與一個Stream一一對應。注意Stream不是指端到端的完整流,而是每一個步驟的處理對象,所有的Stream組合起來才形成完整的流??碨tream的成員變量。
(5)每個Node可能有多個父stream,但多個的情況只在merge()調用multiReduce()時使用。每個Stream與node之間創建一條邊。見TridentTopology#addSourceNode()方法。

2、用戶視角與源碼視角

在用戶角度來看,他通過newStream(),each(),filter()待方案對Stream進行操作。而在代碼角度,這些操作會被轉化為各種Node節點,它些節點組合成一個SubTopologyBolt,然后經過TridentBoltExecutor適配后成為一個bolt。

從用戶層面來看TridentTopology,有兩個重要的概念一是Stream,另一個是作用于Stream上的各種Operation。在實現層面來看,無論是stream,還是后續的operation都會轉變成為各個Node,這些Node之間的關系通過重要的數據結構圖來維護。具體到TridentTopology,實現圖的各種操作的組件是jgrapht。

說到圖,兩個基本的概念會閃現出來,一是結點,二是描述結點之間關系的邊。要想很好的理解TridentTopology就需要緊盯圖中結點和邊的變化。

TridentTopology在轉換成為普通的StormTopology時,需要將原始的圖分成各個group,每個group將運行于一個獨立的bolt中。TridentTopology又是如何知道哪些node應該在同一個group,哪些應該處在另一個group中的呢;如何來確定每個group的并發度(parallismHint)的呢。這些問題的解決都與jgrapht分不開。

關于jgrapht的更多信息,請參考其官方網站 http://jgrapht.org

========================================================

在用戶看來,所有的操作就是各種各樣的數據流與operation的組合,這些組合會被封裝成一個Node(即一個Node包含輸入流+操作+輸出流),符合一定規則的Node會被組合與一個組,組會被放到一個bolt中。

一個blot節點中可能含有多個操作,各個操作間需要進行消息傳遞

(二)基礎類

1、Stream

Stream主要定義了數據流的各種操作,如each(),pproject()等。

(1)成員變量

Node _node; TridentTopology _topology; String _name;

三個成員變量:
* Node對象,這表明Stream與Node是一一對應的,每個節點對應一個Stream對象。
* name:這個Stream的名稱,也等于是這這個Node的名稱。
* TridentTopology: 這個Stram所屬的拓撲,使用這個變量,可以調用addSourceNode()等方法。

其中_node變量被使用很少。

(2)projectionValidation()

這個方法用于檢查是否對一個不存在的field進行了操作。

private void projectionValidation(Fields projFields) {if (projFields == null) {return;}Fields allFields = this.getOutputFields();for (String field : projFields) {if (!allFields.contains(field)) {throw new IllegalArgumentException("Trying to select non-existent field: '" + field + "' from stream containing fields fields: <" + allFields + ">");}} }

stream中定義了定義了各種各樣的trident操作,下面分別介紹

(3)project()

public Stream project(Fields keepFields) {projectionValidation(keepFields);return _topology.addSourcedNode(this, new ProcessorNode(_topology.getUniqueStreamId(), _name, keepFields, new Fields(), new ProjectedProcessor(keepFields))); }

首先檢查一下需要project的field是否存在。然后就在TridentTopology中新增一個節點。
第一個參數就是Stream自身,第二個參數是一個Node的子類–ProcessorNode。創建ProcessorNode時,最后一個參數ProjectedProcessor用于指定如何對流進行操作。

addSourcedNode把source和node同時添加進一個拓撲,即一個流與一個節點。注意這里的節點不是source這個Stream自身的成員變量_node,而是一個新建的節點,比如在project()方法中的節點就是一個使用ProjectedProcessor創建的ProcessorNode。

2、Node SpoutNode PartitionNode ProcessorNode

(1)Node表示拓撲中的一個節點,后面3個均是其子類。事實上拓撲中的節點均用于產生數據或者對數據進行處理。一個拓撲有多個spout/bolt,每個spout/bolt有一個或者多個Group,我個Group有多個Node。

詳細分析見書。

3、Group

節點組是構建SubTopologyBolt的基礎,也是Topology中執行優化的基本操作單元,Trident會通過不斷的合并節點組來達到最優處理的目的。Group中包含了一組連通的節點。

(1)成員變量

public final Set<Node> nodes = new HashSet<>(); private final DirectedGraph<Node, IndexedEdge> graph; private final String id = UUID.randomUUID().toString();

nodes表示節點組中含有的節點。
graph表示拓撲的有向圖。(是整個拓撲的構成的圖)
id用于唯一標識一個group。

(2)構造方法

public Group(DirectedGraph graph, List<Node> nodes) {this.graph = graph;this.nodes.addAll(nodes); }

初始狀態時,每個Group只有一個Node.

public Group(DirectedGraph graph, Node n) {this(graph, Arrays.asList(n)); }

將2個Group合成一個新的Group。

public Group(Group g1, Group g2) {this.graph = g1.graph;nodes.addAll(g1.nodes);nodes.addAll(g2.nodes); }

(3)outgoingNodes()

通過遍歷組中節點的方式來獲取該節點組所有節點的子節點,這些子節點可能屬于該節點組,也可能屬于其它節點組。

public Set<Node> outgoingNodes() {Set<Node> ret = new HashSet<>();for(Node n: nodes) {ret.addAll(TridentUtils.getChildren(graph, n));}return ret; }

(4)incommingNodes()

用于獲取該節點組中所有節點的父節點,這些父節點可能屬于該節點組,也可能屬于其它節點組。

4、GraphGrouper

GraphGrouper提供了對節點組進行操作及合并的基本方法。

(1)成員變量

final DirectedGraph<Node, IndexedEdge> graph; final Set<Group> currGroups; final Map<Node, Group> groupIndex = new HashMap<>();

graph:與Group相同,即這個拓撲的整個圖。
currGroups:當前graph對應的節點組。節點組之間是沒有交集的。
groupIndex:是一個反向索引,用于快速查詢每個節點所在的節點組。

(2)構造方法

public GraphGrouper(DirectedGraph<Node, IndexedEdge> graph, Collection<Group> initialGroups) {this.graph = graph;this.currGroups = new LinkedHashSet<>(initialGroups);reindex(); }

就是為上面幾個變量進行初始化。

(3)reindex()

public void reindex() {groupIndex.clear();for(Group g: currGroups) {for(Node n: g.nodes) {groupIndex.put(n, g);}} }

根據currGroups的內容重構groupIndex。

(4)nodeGroup()

public Group nodeGroup(Node n) {return groupIndex.get(n); }

查詢某個node屬于哪個group。

(5)outgoingGroups()

計算節點組與哪些節點組之間存在有向邊,即2個節點組是相連的。其基本算法是遍歷每一個節點的子節點,若該子節點所在的節點組與自身不同,則獲得子節點所在的節點組。

public Collection<Group> outgoingGroups(Group g) {Set<Group> ret = new HashSet<>();for(Node n: g.outgoingNodes()) {Group other = nodeGroup(n);if(other==null || !other.equals(g)) {ret.add(other); }}return ret; }

(6)incomingGroups()

用于獲取該節點組的父節點組,算法與上面類似。

public Collection<Group> incomingGroups(Group g) {Set<Group> ret = new HashSet<>();for(Node n: g.incomingNodes()) {Group other = nodeGroup(n);if(other==null || !other.equals(g)) {ret.add(other); }}return ret; }

(7)merge()

合并2個節點組。

private void merge(Group g1, Group g2) {Group newGroup = new Group(g1, g2);currGroups.remove(g1);currGroups.remove(g2);currGroups.add(newGroup);for(Node n: newGroup.nodes) {groupIndex.put(n, newGroup);} }

(8)mergeFully

這個方法是GraphGrouper的核心算法,它用來計算何時可以對2個節點組進行合并?;舅枷胧?#xff1a;如果一個節點組只有一個父節點組,那么將這個節點組與父節點組合并;如果一個節點組只有一個子節點組,那么將子節點組與自身節點組合并。反復進行這個過程。

public void mergeFully() {boolean somethingHappened = true;while(somethingHappened) {somethingHappened = false;for(Group g: currGroups) {Collection<Group> outgoingGroups = outgoingGroups(g);if(outgoingGroups.size()==1) {Group out = outgoingGroups.iterator().next();if(out!=null) {merge(g, out);somethingHappened = true;break;}}Collection<Group> incomingGroups = incomingGroups(g);if(incomingGroups.size()==1) {Group in = incomingGroups.iterator().next();if(in!=null) {merge(g, in);somethingHappened = true;break;}} }} }

四、在TridentTopologyBuilder中設置Spout、bolt

(一)參考內容

http://www.cnblogs.com/hseagle/p/3490635.html
TridentTopology是storm提供的高層使用接口,常見的一些SQL中的操作tridenttopology提供的api中都有類似的影射。
從TridentTopology到vanilla topology(普通的topology)由三個層次組
成:
1. 面向最終用戶的概念stream, operation
2. 利用planner將tridenttopology轉換成vanilla topology
3. 執行vanilla topology
從TridentTopology到基本的Topology有三層,下圖是一個全局視圖。

從用戶層面來看TridentTopology,有兩個重要的概念一是Stream,另一個是作用于Stream上的各種Operation。在實現層面來看,無論是stream,還是后續的operation都會轉變成為各個Node,這些Node之間的關系通過重要的數據結構圖來維護。具體到TridentTopology,實現圖的各種操作的組件是jgrapht。

說到圖,兩個基本的概念會閃現出來,一是結點,二是描述結點之間關系的邊。要想很好的理解TridentTopology就需要緊盯圖中結點和邊的變化。

TridentTopology在轉換成為普通的StormTopology時,需要將原始的圖分成各個group,每個group將運行于一個獨立的bolt中。TridentTopology又是如何知道哪些node應該在同一個group,哪些應該處在另一個group中的呢;如何來確定每個group的并發度(parallismHint)的呢。這些問題的解決都與jgrapht分不開。

關于jgrapht的更多信息,請參考其官方網站 http://jgrapht.org

========================================================
在用戶看來,所有的操作就是各種各樣的數據流與operation的組合,這些組合會被封裝成一個Node(即一個Node包含輸入流+操作+輸出流),符合一定規則的Node會被組合與一個組,組會被放到一個bolt中。

一個blot節點中可能含有多個操作,各個操作間需要進行消息傳遞。

=====================================
1、【待完善】通過上面的分析,一個Spout是準備好了,但如何將它加載到拓撲中,并開始真正的數據流:
(1)在TridentTopology中調用newStream方法,將spout節點加入拓撲。
(2)在TridentTopologyBuilder的buildTopololg方法中設置了topo的相關信息

2、拓撲創建的總體流程
(1)在用戶代碼中創建TridentTopology對象

TridentTopology topology = new TridentTopology();

(2)在用戶代碼中指定spout節點和bolt節點
比如:

topology.newStream("spout1", spout).parallelismHint(16).each(new Fields("sentence"), new Split(), new Fields("word")).groupBy(new Fields("word")).persistentAggregate(new MemoryMapState.Factory(), new Count(),new Fields("count")).parallelismHint(16);

(3)在用戶代碼中創建拓撲

topology.build();

(4)topology.build()會調用TridentTopologyBuilder#buildTopology()

(5)用戶代碼中提交拓撲

StormSubmitter.submitTopologyWithProgressBar(args[0], conf, buildTopology(null));

(一)概述

(二)基礎類

1、GlobalStreamId

這是由trift生成的類,有2個核心成員變量

public GlobalStreamId(String componentId,String streamId)

分別記錄了某個component的ID與其對應的streamId,如

"$mastercoord-" + batchGroup MasterBatchCoordinator.BATCH_STREAM_ID

表示這個component會消費這個stream的消息。

(三)TridentTopology

主要流程:
(1)創建各種各樣的節點,包括spout/bolt
(2)spout全部放到一個set中
(3)bolt的每一個節點放入一個group中
(4)對group進行各種的merge操作(如g1的所有輸出均到g2,則將它們合并)
(5)直到剩余少量的mergeGroup,作為bolt
(6)TridentTopologyBuilder.buildTopology()對這些spout/mergeGroup進行分組配置。

1、生成bolt的名稱:genBoltIds

genBoltIds用于為bolt生成一個唯一的id,它使用字母b開頭,然后是一個數字id,接著是group的名稱,然后是第2個id, 第2個group的名稱….。而group的名稱是由這個group包含的Node名稱組成的。

private static Map<Group, String> genBoltIds(Collection<Group> groups) {Map<Group, String> ret = new HashMap<>();int ctr = 0;for(Group g: groups) {if(!isSpoutGroup(g)) {List<String> name = new ArrayList<>();name.add("b");name.add("" + ctr);String groupName = getGroupName(g);if(groupName!=null && !groupName.isEmpty()) {name.add(getGroupName(g)); }ret.put(g, Utils.join(name, "-"));ctr++;}}return ret; }private static String getGroupName(Group g) {TreeMap<Integer, String> sortedNames = new TreeMap<>();for(Node n: g.nodes) {if(n.name!=null) {sortedNames.put(n.creationIndex, n.name);}}List<String> names = new ArrayList<>();String prevName = null;for(String n: sortedNames.values()) {if(prevName==null || !n.equals(prevName)) {prevName = n;names.add(n);}}return Utils.join(names, "-"); }

2、添加節點:addNode()

protected Stream addNode(Node n) {registerNode(n);return new Stream(this, n.name, n); }

這個方法很簡單,而且,它只在newStream()及newDRPCStream中調用,很明顯這是用于提供一個新的數據源的。而下面的addSourceNode()是用于在bolt中添加下一個處理節點的。

3、添加節點:addSourceNode()

創建一個新節點,指定新節點的父節點(可能多個)。指定多個sources的情況只在merge()方法中被調用multiReduce()時調用。因此這里只關注一個source的情形。

protected Stream addSourcedNode(Stream source, Node newNode) {return addSourcedNode(Arrays.asList(source), newNode); } protected Stream addSourcedNode(List<Stream> sources, Node newNode) {registerSourcedNode(sources, newNode);return new Stream(this, newNode.name, newNode); }

addSourcedNode把source和node同時添加進一個拓撲,即一個流與一個節點。注意這里的節點不是source這個Stream自身的成員變量_node,而是一個新建的節點,比如在project()方法中的節點就是一個使用ProjectedProcessor創建的ProcessorNode。

return _topology.addSourcedNode(this, new ProcessorNode(_topology.getUniqueStreamId(), _name, keepFields, new Fields(), new ProjectedProcessor(keepFields)));

除了注冊新節點 registerNode(newNode)以外,還在每個stream和節點間創建一條邊。

protected void registerSourcedNode(List<Stream> sources, Node newNode) {registerNode(newNode);int streamIndex = 0;for(Stream s: sources) {_graph.addEdge(s._node, newNode, new IndexedEdge(s._node, newNode, streamIndex));streamIndex++;} }

向圖中添加一個節點。然后若節點中的stateInfo成員不為空,則將該節點放入與存儲序號(StateId)相對應的哈希表_colocate中。_colocate變量將所有訪問同一存儲的節點關聯在一起,并將他們放在一個Bolt中執行。

protected void registerNode(Node n) {_graph.addVertex(n);if(n.stateInfo!=null) {String id = n.stateInfo.id;if(!_colocate.containsKey(id)) {_colocate.put(id, new ArrayList());}_colocate.get(id).add(n);} }

(四)TridentTopologyBuilder

總結

以上是生活随笔為你收集整理的Storm源码分析之四: Trident源码分析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

少妇无套内谢久久久久 | 亚洲高清偷拍一区二区三区 | 免费观看又污又黄的网站 | 亚洲一区二区三区无码久久 | 成人精品视频一区二区三区尤物 | 亚洲人成网站免费播放 | 久久国产精品萌白酱免费 | 疯狂三人交性欧美 | 99久久精品日本一区二区免费 | 国产在线精品一区二区高清不卡 | 亚洲精品无码国产 | 日日鲁鲁鲁夜夜爽爽狠狠 | 日韩欧美中文字幕公布 | 99精品国产综合久久久久五月天 | 国产极品视觉盛宴 | 九月婷婷人人澡人人添人人爽 | 东京热一精品无码av | 日本成熟视频免费视频 | 少妇无码吹潮 | 未满成年国产在线观看 | 国产激情精品一区二区三区 | 波多野结衣aⅴ在线 | 国语自产偷拍精品视频偷 | 日韩精品乱码av一区二区 | 88国产精品欧美一区二区三区 | 精品国产一区二区三区四区 | 搡女人真爽免费视频大全 | 国产九九九九九九九a片 | 国产69精品久久久久app下载 | 丰满岳乱妇在线观看中字无码 | 国内少妇偷人精品视频 | 国产亚洲精品久久久久久久 | 丰满少妇人妻久久久久久 | 大肉大捧一进一出好爽视频 | 成人试看120秒体验区 | 曰韩无码二三区中文字幕 | 自拍偷自拍亚洲精品被多人伦好爽 | 好屌草这里只有精品 | 久久久久免费看成人影片 | 亚洲日本一区二区三区在线 | 亚洲国产精品久久久天堂 | 99精品视频在线观看免费 | 久久久久久久久蜜桃 | 久久99精品久久久久久 | 中文字幕av日韩精品一区二区 | 午夜福利一区二区三区在线观看 | 欧美精品一区二区精品久久 | 亚洲精品成人av在线 | 成人欧美一区二区三区黑人 | 中文精品久久久久人妻不卡 | 377p欧洲日本亚洲大胆 | 久久综合激激的五月天 | 国产做国产爱免费视频 | 国产精品毛片一区二区 | 成人亚洲精品久久久久软件 | 伊人色综合久久天天小片 | 免费中文字幕日韩欧美 | 国产精品爱久久久久久久 | 中文字幕 亚洲精品 第1页 | 欧洲极品少妇 | 精品偷自拍另类在线观看 | 暴力强奷在线播放无码 | 亚洲精品久久久久avwww潮水 | 国产乱人伦偷精品视频 | 国产无遮挡吃胸膜奶免费看 | 天天摸天天碰天天添 | 国产精品无套呻吟在线 | 曰韩少妇内射免费播放 | 亚洲第一网站男人都懂 | 无码人妻出轨黑人中文字幕 | 国产精品无码mv在线观看 | 老太婆性杂交欧美肥老太 | 丝袜人妻一区二区三区 | 青青久在线视频免费观看 | 国产av一区二区精品久久凹凸 | 丝袜 中出 制服 人妻 美腿 | 日本高清一区免费中文视频 | 国产97人人超碰caoprom | 永久免费观看美女裸体的网站 | 色诱久久久久综合网ywww | 欧美亚洲日韩国产人成在线播放 | 免费看男女做好爽好硬视频 | 婷婷五月综合缴情在线视频 | 精品无人区无码乱码毛片国产 | 国产在线精品一区二区高清不卡 | 午夜丰满少妇性开放视频 | 国产又粗又硬又大爽黄老大爷视 | 亚洲成av人片天堂网无码】 | 中文字幕无码免费久久99 | 性欧美熟妇videofreesex | 欧美日韩在线亚洲综合国产人 | 免费看少妇作爱视频 | 国产精品久久久久7777 | 午夜福利试看120秒体验区 | 久久精品国产亚洲精品 | 久久精品人人做人人综合试看 | 一本无码人妻在中文字幕免费 | 精品欧美一区二区三区久久久 | 激情综合激情五月俺也去 | 人妻中文无码久热丝袜 | 国产精品国产三级国产专播 | 欧美精品一区二区精品久久 | 精品国产乱码久久久久乱码 | 中文字幕av日韩精品一区二区 | 精品亚洲韩国一区二区三区 | 中文字幕乱码中文乱码51精品 | 亚洲精品久久久久avwww潮水 | 男女下面进入的视频免费午夜 | 亚洲国产成人av在线观看 | 无码人妻出轨黑人中文字幕 | 波多野42部无码喷潮在线 | 九月婷婷人人澡人人添人人爽 | 国产色xx群视频射精 | 久久精品国产99久久6动漫 | 亚洲无人区午夜福利码高清完整版 | 国产在线精品一区二区三区直播 | 捆绑白丝粉色jk震动捧喷白浆 | v一区无码内射国产 | 又粗又大又硬又长又爽 | 午夜免费福利小电影 | 少妇无码一区二区二三区 | a片在线免费观看 | 欧美性生交活xxxxxdddd | 国精产品一品二品国精品69xx | 国产美女极度色诱视频www | 国产va免费精品观看 | 无码人妻丰满熟妇区五十路百度 | 国产成人精品无码播放 | 欧美日韩综合一区二区三区 | 欧美午夜特黄aaaaaa片 | 亚洲精品久久久久中文第一幕 | 国产婷婷色一区二区三区在线 | 亚洲精品久久久久久一区二区 | 国产精品人妻一区二区三区四 | 欧美精品无码一区二区三区 | 成人试看120秒体验区 | 亚洲午夜久久久影院 | 亚洲一区二区三区在线观看网站 | 亚洲国产精品一区二区第一页 | 亚洲区小说区激情区图片区 | 亚洲精品无码人妻无码 | 国产精品视频免费播放 | 青草视频在线播放 | 天天爽夜夜爽夜夜爽 | 亚洲无人区午夜福利码高清完整版 | 99精品无人区乱码1区2区3区 | 日本爽爽爽爽爽爽在线观看免 | 色偷偷人人澡人人爽人人模 | √天堂资源地址中文在线 | 狠狠色噜噜狠狠狠7777奇米 | 成熟人妻av无码专区 | 熟妇激情内射com | 性欧美牲交xxxxx视频 | 波多野42部无码喷潮在线 | 国产精品永久免费视频 | 成人片黄网站色大片免费观看 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 一二三四在线观看免费视频 | 中文毛片无遮挡高清免费 | 中文久久乱码一区二区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 久久国产精品_国产精品 | 老熟妇乱子伦牲交视频 | 国产午夜精品一区二区三区嫩草 | 少妇无码av无码专区在线观看 | 青青青爽视频在线观看 | 久久精品女人的天堂av | 中文无码成人免费视频在线观看 | 久久久亚洲欧洲日产国码αv | 日韩欧美成人免费观看 | 久久国产精品_国产精品 | 日韩精品无码一区二区中文字幕 | 又色又爽又黄的美女裸体网站 | 一本精品99久久精品77 | 国产精品久久久久无码av色戒 | аⅴ资源天堂资源库在线 | 丝袜美腿亚洲一区二区 | 俄罗斯老熟妇色xxxx | 久久久婷婷五月亚洲97号色 | 久久久久亚洲精品男人的天堂 | 一本久道久久综合狠狠爱 | 中文字幕无线码 | 亚洲欧美综合区丁香五月小说 | 亚洲精品一区二区三区大桥未久 | 国产亚洲人成在线播放 | 成熟女人特级毛片www免费 | 人妻aⅴ无码一区二区三区 | 久久午夜无码鲁丝片 | 一本久道久久综合婷婷五月 | 国模大胆一区二区三区 | 欧美日韩在线亚洲综合国产人 | 性生交大片免费看l | 日日夜夜撸啊撸 | 国内精品人妻无码久久久影院 | 国产熟妇另类久久久久 | ass日本丰满熟妇pics | 俺去俺来也在线www色官网 | 又大又硬又黄的免费视频 | 一本久久a久久精品vr综合 | 国产成人无码av在线影院 | 色窝窝无码一区二区三区色欲 | 亚洲a无码综合a国产av中文 | 四十如虎的丰满熟妇啪啪 | 亚洲国产精品久久久久久 | 欧美freesex黑人又粗又大 | 色婷婷久久一区二区三区麻豆 | 欧美精品一区二区精品久久 | 午夜精品一区二区三区在线观看 | 性欧美videos高清精品 | 国产成人精品视频ⅴa片软件竹菊 | 骚片av蜜桃精品一区 | 无码人妻久久一区二区三区不卡 | www一区二区www免费 | 亚洲色欲色欲欲www在线 | 97夜夜澡人人爽人人喊中国片 | 老司机亚洲精品影院 | 国产99久久精品一区二区 | 久久久久久久女国产乱让韩 | 伊人久久大香线蕉午夜 | 两性色午夜视频免费播放 | av无码电影一区二区三区 | 丰满人妻翻云覆雨呻吟视频 | 国产极品美女高潮无套在线观看 | 色老头在线一区二区三区 | 国产舌乚八伦偷品w中 | 久久亚洲a片com人成 | 成人动漫在线观看 | 一本久道久久综合狠狠爱 | 在线天堂新版最新版在线8 | 亚洲狠狠色丁香婷婷综合 | 国产精品无码mv在线观看 | 国产人妻人伦精品 | 亚洲色在线无码国产精品不卡 | 一二三四在线观看免费视频 | 亚洲日韩中文字幕在线播放 | 国产精品二区一区二区aⅴ污介绍 | 亚洲精品鲁一鲁一区二区三区 | 无码人妻久久一区二区三区不卡 | 无码人妻丰满熟妇区毛片18 | 欧洲熟妇色 欧美 | 亚洲男人av天堂午夜在 | 夜夜夜高潮夜夜爽夜夜爰爰 | 人人妻人人澡人人爽人人精品浪潮 | 伊人久久大香线蕉av一区二区 | 色老头在线一区二区三区 | 欧美zoozzooz性欧美 | 欧美精品在线观看 | 青青草原综合久久大伊人精品 | 色五月五月丁香亚洲综合网 | 国产色视频一区二区三区 | 国产精品高潮呻吟av久久4虎 | 午夜福利不卡在线视频 | 少妇性l交大片 | 国产福利视频一区二区 | 野外少妇愉情中文字幕 | 亚洲中文字幕av在天堂 | 久久精品99久久香蕉国产色戒 | 精品久久8x国产免费观看 | 欧美日韩在线亚洲综合国产人 | 性欧美videos高清精品 | 国产乱人伦偷精品视频 | 亚洲a无码综合a国产av中文 | 精品无码一区二区三区的天堂 | 福利一区二区三区视频在线观看 | 日本精品人妻无码免费大全 | 学生妹亚洲一区二区 | 亚洲精品一区国产 | 国产三级精品三级男人的天堂 | 1000部夫妻午夜免费 | 欧美老妇交乱视频在线观看 | 人妻插b视频一区二区三区 | 麻豆国产人妻欲求不满谁演的 | 高清不卡一区二区三区 | 成熟女人特级毛片www免费 | 国产色视频一区二区三区 | 精品日本一区二区三区在线观看 | 极品尤物被啪到呻吟喷水 | 久久久久se色偷偷亚洲精品av | 九九久久精品国产免费看小说 | 激情国产av做激情国产爱 | 无码人妻精品一区二区三区下载 | 天干天干啦夜天干天2017 | 丁香花在线影院观看在线播放 | 成在人线av无码免观看麻豆 | 四虎永久在线精品免费网址 | 一本久道高清无码视频 | 色婷婷综合中文久久一本 | 国产精品亚洲综合色区韩国 | 草草网站影院白丝内射 | 国产又粗又硬又大爽黄老大爷视 | 76少妇精品导航 | 亚洲国产精品久久久久久 | 国产麻豆精品精东影业av网站 | 大肉大捧一进一出好爽视频 | 精品国产一区二区三区四区在线看 | 国产亚洲欧美日韩亚洲中文色 | 亚洲精品综合一区二区三区在线 | 久久综合给合久久狠狠狠97色 | 免费观看黄网站 | 国产成人无码av一区二区 | 巨爆乳无码视频在线观看 | 天堂а√在线地址中文在线 | 99麻豆久久久国产精品免费 | 久久精品国产日本波多野结衣 | 精品国产一区二区三区av 性色 | 免费无码的av片在线观看 | 国产精品无码久久av | 久久精品中文字幕一区 | 熟妇人妻无乱码中文字幕 | 人妻无码久久精品人妻 | 性欧美熟妇videofreesex | 我要看www免费看插插视频 | 一本色道久久综合亚洲精品不卡 | 色欲综合久久中文字幕网 | 中文字幕色婷婷在线视频 | 荡女精品导航 | 亚洲a无码综合a国产av中文 | 国产色视频一区二区三区 | 欧美刺激性大交 | 精品无码一区二区三区爱欲 | 精品国产精品久久一区免费式 | 久久精品女人天堂av免费观看 | 亚洲毛片av日韩av无码 | 亚洲成av人在线观看网址 | 无码av免费一区二区三区试看 | 红桃av一区二区三区在线无码av | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产亚洲视频中文字幕97精品 | 欧美野外疯狂做受xxxx高潮 | 亚洲呦女专区 | 国产午夜福利亚洲第一 | 亚洲色在线无码国产精品不卡 | 亚洲欧洲中文日韩av乱码 | 国产成人无码av一区二区 | 欧美黑人巨大xxxxx | 国产福利视频一区二区 | aⅴ在线视频男人的天堂 | 在线视频网站www色 | 欧美 丝袜 自拍 制服 另类 | 激情人妻另类人妻伦 | 亚洲一区二区三区国产精华液 | aa片在线观看视频在线播放 | 中文字幕无码乱人伦 | 狠狠cao日日穞夜夜穞av | 亚洲性无码av中文字幕 | 丰满岳乱妇在线观看中字无码 | 国产精品久久久久无码av色戒 | 国内老熟妇对白xxxxhd | 夜夜高潮次次欢爽av女 | 一二三四在线观看免费视频 | 亚洲呦女专区 | 亚洲精品综合五月久久小说 | 国产精品人人爽人人做我的可爱 | 无码人妻久久一区二区三区不卡 | a国产一区二区免费入口 | 蜜桃无码一区二区三区 | 国内精品久久久久久中文字幕 | 国内精品人妻无码久久久影院蜜桃 | 牲欲强的熟妇农村老妇女 | 无码人妻丰满熟妇区五十路百度 | 国产成人精品优优av | 亚洲国产精品美女久久久久 | 日本精品高清一区二区 | 纯爱无遮挡h肉动漫在线播放 | 98国产精品综合一区二区三区 | 免费无码的av片在线观看 | 性欧美熟妇videofreesex | 午夜精品一区二区三区的区别 | 粗大的内捧猛烈进出视频 | 婷婷色婷婷开心五月四房播播 | 国产精品久久久久9999小说 | 亚洲无人区一区二区三区 | 日韩人妻无码一区二区三区久久99 | 久久综合网欧美色妞网 | 无套内射视频囯产 | 亚洲综合久久一区二区 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲国产av美女网站 | 无码任你躁久久久久久久 | av人摸人人人澡人人超碰下载 | 久久久婷婷五月亚洲97号色 | 日韩av无码一区二区三区 | 亚洲中文字幕无码一久久区 | 色偷偷人人澡人人爽人人模 | 日本一区二区三区免费播放 | 亚洲日韩av一区二区三区四区 | 小sao货水好多真紧h无码视频 | 国产精品亚洲一区二区三区喷水 | 日本精品人妻无码免费大全 | 日本一区二区更新不卡 | 精品亚洲成av人在线观看 | 色婷婷av一区二区三区之红樱桃 | 国产成人久久精品流白浆 | 色欲综合久久中文字幕网 | 精品乱码久久久久久久 | 1000部啪啪未满十八勿入下载 | 亚洲成在人网站无码天堂 | 国产精品.xx视频.xxtv | 国产免费久久久久久无码 | 国产成人亚洲综合无码 | 国产美女极度色诱视频www | 亚洲第一无码av无码专区 | 精品无码一区二区三区爱欲 | 一本色道久久综合亚洲精品不卡 | 2019nv天堂香蕉在线观看 | 夜夜高潮次次欢爽av女 | 女人被男人躁得好爽免费视频 | 精品久久久久久人妻无码中文字幕 | 黑人巨大精品欧美一区二区 | 欧美一区二区三区 | 日本大香伊一区二区三区 | 一本久久a久久精品亚洲 | 成年美女黄网站色大免费视频 | 亚洲一区二区三区含羞草 | 国产小呦泬泬99精品 | 欧美性黑人极品hd | 一本久久伊人热热精品中文字幕 | 国产精品第一区揄拍无码 | 97夜夜澡人人爽人人喊中国片 | 国内精品久久毛片一区二区 | 美女扒开屁股让男人桶 | 无码帝国www无码专区色综合 | 精品午夜福利在线观看 | 亚洲中文字幕无码一久久区 | 久久精品人人做人人综合 | 精品人人妻人人澡人人爽人人 | 国产成人精品三级麻豆 | 亚洲精品久久久久avwww潮水 | 亚洲中文字幕乱码av波多ji | 牲欲强的熟妇农村老妇女 | av在线亚洲欧洲日产一区二区 | 无码国产色欲xxxxx视频 | 欧美人与牲动交xxxx | 久久www免费人成人片 | 国产精品久久国产精品99 | 激情国产av做激情国产爱 | 日日夜夜撸啊撸 | 人妻少妇精品无码专区动漫 | www国产亚洲精品久久网站 | 强开小婷嫩苞又嫩又紧视频 | 四虎永久在线精品免费网址 | 成人无码视频免费播放 | 人妻互换免费中文字幕 | 久久99热只有频精品8 | 欧美人与动性行为视频 | 蜜桃视频韩日免费播放 | 日本一本二本三区免费 | 无码吃奶揉捏奶头高潮视频 | 久久无码中文字幕免费影院蜜桃 | 天堂在线观看www | v一区无码内射国产 | www国产精品内射老师 | 少妇久久久久久人妻无码 | 午夜福利不卡在线视频 | 亚洲日韩av一区二区三区中文 | 国产精品.xx视频.xxtv | 给我免费的视频在线观看 | 国产精品亚洲综合色区韩国 | 大肉大捧一进一出视频出来呀 | 一个人看的视频www在线 | 牲欲强的熟妇农村老妇女视频 | 国产乱子伦视频在线播放 | 无码av最新清无码专区吞精 | 无码免费一区二区三区 | 国产精品办公室沙发 | 亚洲日韩精品欧美一区二区 | 亚洲国产精品无码久久久久高潮 | 国产亚洲精品精品国产亚洲综合 | 日韩精品无码一本二本三本色 | 人人妻人人澡人人爽欧美精品 | 精品国产av色一区二区深夜久久 | 少妇一晚三次一区二区三区 | 天天av天天av天天透 | 国产精品久久久久9999小说 | 永久免费精品精品永久-夜色 | 天堂亚洲免费视频 | 精品一二三区久久aaa片 | 婷婷丁香五月天综合东京热 | 纯爱无遮挡h肉动漫在线播放 | 亚洲精品国产精品乱码不卡 | 任你躁国产自任一区二区三区 | 久久久久免费看成人影片 | 性欧美疯狂xxxxbbbb | 一本一道久久综合久久 | 熟妇女人妻丰满少妇中文字幕 | 人人妻人人澡人人爽欧美一区九九 | 日本熟妇人妻xxxxx人hd | 无码人妻精品一区二区三区下载 | 国产va免费精品观看 | 麻豆国产97在线 | 欧洲 | 国产无套内射久久久国产 | 亚洲成av人综合在线观看 | 97夜夜澡人人爽人人喊中国片 | 久久综合色之久久综合 | 国产成人精品一区二区在线小狼 | 亚洲精品一区二区三区在线 | 日本xxxx色视频在线观看免费 | 性色欲网站人妻丰满中文久久不卡 | 色综合久久88色综合天天 | 露脸叫床粗话东北少妇 | 少妇高潮喷潮久久久影院 | 小泽玛莉亚一区二区视频在线 | 免费男性肉肉影院 | 国产精品99久久精品爆乳 | 99久久婷婷国产综合精品青草免费 | 亚洲欧美精品aaaaaa片 | 亚洲区欧美区综合区自拍区 | 无套内谢老熟女 | 亚洲中文字幕无码中文字在线 | 麻豆人妻少妇精品无码专区 | 久9re热视频这里只有精品 | 三上悠亚人妻中文字幕在线 | 人人妻人人澡人人爽欧美一区 | 两性色午夜免费视频 | 久久无码专区国产精品s | 亚洲理论电影在线观看 | 麻豆国产人妻欲求不满谁演的 | 亚洲成av人片天堂网无码】 | 无码人妻精品一区二区三区下载 | 天天燥日日燥 | 欧美精品国产综合久久 | 国产 浪潮av性色四虎 | 狠狠cao日日穞夜夜穞av | 狠狠综合久久久久综合网 | 欧美乱妇无乱码大黄a片 | 亚洲成av人在线观看网址 | 免费无码一区二区三区蜜桃大 | 久久久精品成人免费观看 | 丰满肥臀大屁股熟妇激情视频 | 成人欧美一区二区三区黑人免费 | 天天拍夜夜添久久精品大 | 激情国产av做激情国产爱 | 毛片内射-百度 | 无套内射视频囯产 | 人妻aⅴ无码一区二区三区 | 国产精品久久久久久久9999 | 亚洲一区二区三区在线观看网站 | 国产香蕉97碰碰久久人人 | 永久免费精品精品永久-夜色 | 丰满少妇女裸体bbw | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产午夜精品一区二区三区嫩草 | 老熟妇仑乱视频一区二区 | 熟妇女人妻丰满少妇中文字幕 | 妺妺窝人体色www婷婷 | 精品国产一区二区三区av 性色 | 精品 日韩 国产 欧美 视频 | 熟女俱乐部五十路六十路av | 国产精品久久久久影院嫩草 | 午夜精品久久久内射近拍高清 | 少妇无套内谢久久久久 | 国产一区二区三区精品视频 | 国产精品沙发午睡系列 | 成熟女人特级毛片www免费 | 亚洲国产av美女网站 | 又黄又爽又色的视频 | 秋霞成人午夜鲁丝一区二区三区 | 国产偷国产偷精品高清尤物 | 国产精品久久久久久无码 | 人人妻人人藻人人爽欧美一区 | 日本精品少妇一区二区三区 | 激情国产av做激情国产爱 | 亚洲成色在线综合网站 | 无码播放一区二区三区 | 无码人妻精品一区二区三区不卡 | 黑人巨大精品欧美一区二区 | 亚洲国产日韩a在线播放 | 人人爽人人澡人人人妻 | 偷窥村妇洗澡毛毛多 | 国产成人人人97超碰超爽8 | 日韩少妇白浆无码系列 | 免费看少妇作爱视频 | 精品成在人线av无码免费看 | 国产人成高清在线视频99最全资源 | 亚洲一区二区三区偷拍女厕 | 精品国产青草久久久久福利 | 欧美第一黄网免费网站 | 色诱久久久久综合网ywww | 丰满少妇熟乱xxxxx视频 | 国产精品亚洲专区无码不卡 | 亚洲国产一区二区三区在线观看 | 国产高潮视频在线观看 | 亚洲午夜福利在线观看 | 国产明星裸体无码xxxx视频 | 麻豆国产人妻欲求不满 | 少妇无码av无码专区在线观看 | 亚洲国产av精品一区二区蜜芽 | 亚洲午夜福利在线观看 | 夜精品a片一区二区三区无码白浆 | 色情久久久av熟女人妻网站 | 国产午夜福利亚洲第一 | 午夜无码区在线观看 | 精品国偷自产在线 | 亚洲成在人网站无码天堂 | 理论片87福利理论电影 | 久久国内精品自在自线 | 99久久婷婷国产综合精品青草免费 | √8天堂资源地址中文在线 | 国产一区二区不卡老阿姨 | 在线成人www免费观看视频 | 99在线 | 亚洲 | 久久久久99精品国产片 | 无码免费一区二区三区 | 国产人妻精品一区二区三区 | 欧美 亚洲 国产 另类 | 人人妻人人澡人人爽欧美一区九九 | 成人精品天堂一区二区三区 | 成人动漫在线观看 | 一个人看的www免费视频在线观看 | 亚洲成av人片在线观看无码不卡 | 一个人看的www免费视频在线观看 | 亚洲精品国产第一综合99久久 | 亚洲码国产精品高潮在线 | 婷婷五月综合缴情在线视频 | 免费观看又污又黄的网站 | 国产极品视觉盛宴 | 人妻无码久久精品人妻 | 国产av一区二区精品久久凹凸 | 国产成人一区二区三区在线观看 | аⅴ资源天堂资源库在线 | 免费无码一区二区三区蜜桃大 | 丰满少妇熟乱xxxxx视频 | 国产在线一区二区三区四区五区 | 亚洲国产综合无码一区 | 久久综合给合久久狠狠狠97色 | 国产麻豆精品精东影业av网站 | 国产美女精品一区二区三区 | 久久人人爽人人爽人人片av高清 | 中文字幕人成乱码熟女app | 最近中文2019字幕第二页 | 国产精品自产拍在线观看 | 国产猛烈高潮尖叫视频免费 | 蜜桃臀无码内射一区二区三区 | 成人亚洲精品久久久久 | 丰满人妻精品国产99aⅴ | 国产超碰人人爽人人做人人添 | 狠狠噜狠狠狠狠丁香五月 | 动漫av一区二区在线观看 | 亚洲中文字幕在线无码一区二区 | 精品aⅴ一区二区三区 | 疯狂三人交性欧美 | 久久天天躁狠狠躁夜夜免费观看 | 国产精品久久久久久亚洲毛片 | 最新国产麻豆aⅴ精品无码 | 欧美人与动性行为视频 | 少妇久久久久久人妻无码 | 国产热a欧美热a在线视频 | 又粗又大又硬又长又爽 | 亚洲精品成a人在线观看 | 日本精品人妻无码免费大全 | 国产人妻人伦精品1国产丝袜 | 久久国产精品萌白酱免费 | 激情亚洲一区国产精品 | 熟女体下毛毛黑森林 | 亚洲爆乳精品无码一区二区三区 | 国产精品久久国产三级国 | 国产成人无码av片在线观看不卡 | 欧美35页视频在线观看 | 国语精品一区二区三区 | 澳门永久av免费网站 | 欧美黑人性暴力猛交喷水 | 国内老熟妇对白xxxxhd | 日本饥渴人妻欲求不满 | 人妻熟女一区 | 18黄暴禁片在线观看 | 88国产精品欧美一区二区三区 | 精品国产国产综合精品 | 夜先锋av资源网站 | 国产成人综合美国十次 | 兔费看少妇性l交大片免费 | 精品成在人线av无码免费看 | 久久97精品久久久久久久不卡 | 亚洲欧美日韩国产精品一区二区 | 无码成人精品区在线观看 | 又紧又大又爽精品一区二区 | 99精品久久毛片a片 | 性做久久久久久久免费看 | 日韩人妻无码一区二区三区久久99 | 男女爱爱好爽视频免费看 | 少妇太爽了在线观看 | 中文字幕无码日韩欧毛 | 极品尤物被啪到呻吟喷水 | 久久亚洲国产成人精品性色 | 国产97人人超碰caoprom | 国产综合在线观看 | 亚洲成a人片在线观看日本 | 久久久久亚洲精品男人的天堂 | 亚洲欧美精品aaaaaa片 | 精品夜夜澡人妻无码av蜜桃 | 美女张开腿让人桶 | 欧美xxxx黑人又粗又长 | 在线精品亚洲一区二区 | 一本大道久久东京热无码av | 鲁一鲁av2019在线 | 青青青手机频在线观看 | 999久久久国产精品消防器材 | 澳门永久av免费网站 | 乱人伦中文视频在线观看 | 少妇性l交大片欧洲热妇乱xxx | 亚洲精品国产精品乱码视色 | 88国产精品欧美一区二区三区 | 久久亚洲精品中文字幕无男同 | 亚洲区小说区激情区图片区 | 波多野结衣乳巨码无在线观看 | 久久亚洲精品成人无码 | 乱人伦人妻中文字幕无码 | 99久久精品午夜一区二区 | 免费无码av一区二区 | 久久久久成人精品免费播放动漫 | 天天拍夜夜添久久精品 | 东北女人啪啪对白 | 国产精品沙发午睡系列 | 国产疯狂伦交大片 | 国产精品第一国产精品 | 麻豆蜜桃av蜜臀av色欲av | 日本丰满熟妇videos | 亚无码乱人伦一区二区 | 中文字幕精品av一区二区五区 | 日本大香伊一区二区三区 | 午夜无码人妻av大片色欲 | 中文字幕乱码人妻二区三区 | 国精品人妻无码一区二区三区蜜柚 | 熟妇人妻中文av无码 | 国产精品亚洲专区无码不卡 | 欧洲精品码一区二区三区免费看 | 国产九九九九九九九a片 | 中文字幕无码乱人伦 | 老司机亚洲精品影院 | 欧美一区二区三区视频在线观看 | 国产人妻精品午夜福利免费 | 2019午夜福利不卡片在线 | 国产精品美女久久久久av爽李琼 | 免费播放一区二区三区 | 久久精品国产一区二区三区肥胖 | 亚洲成在人网站无码天堂 | 亚洲精品综合五月久久小说 | 亚洲乱码国产乱码精品精 | 亚洲中文无码av永久不收费 | 国产精华av午夜在线观看 | 欧美一区二区三区视频在线观看 | 国产精品第一国产精品 | 国产sm调教视频在线观看 | 中文无码伦av中文字幕 | 亚洲国产欧美国产综合一区 | 精品日本一区二区三区在线观看 | 乱码午夜-极国产极内射 | 日日碰狠狠躁久久躁蜜桃 | 高潮喷水的毛片 | 黑人巨大精品欧美黑寡妇 | 国产肉丝袜在线观看 | 欧美 亚洲 国产 另类 | 丰满人妻精品国产99aⅴ | 亚洲国产精品无码一区二区三区 | 国产成人av免费观看 | 一本大道伊人av久久综合 | 欧美性黑人极品hd | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 女人被爽到呻吟gif动态图视看 | 无人区乱码一区二区三区 | 狠狠色欧美亚洲狠狠色www | 漂亮人妻洗澡被公强 日日躁 | 婷婷综合久久中文字幕蜜桃三电影 | 国产精品丝袜黑色高跟鞋 | 日韩 欧美 动漫 国产 制服 | 成人亚洲精品久久久久软件 | 国内综合精品午夜久久资源 | 精品乱码久久久久久久 | 无码播放一区二区三区 | 亚洲国产成人a精品不卡在线 | 男人和女人高潮免费网站 | 在线a亚洲视频播放在线观看 | 久9re热视频这里只有精品 | 天天综合网天天综合色 | 欧美老人巨大xxxx做受 | 精品久久综合1区2区3区激情 | 一本大道久久东京热无码av | 国产熟妇另类久久久久 | 一本大道久久东京热无码av | 国产97在线 | 亚洲 | 西西人体www44rt大胆高清 | 无码福利日韩神码福利片 | 国产精品二区一区二区aⅴ污介绍 | 亚洲娇小与黑人巨大交 | 精品厕所偷拍各类美女tp嘘嘘 | 天天摸天天透天天添 | 国产乱人伦偷精品视频 | 毛片内射-百度 | 国产精品毛片一区二区 | 性欧美videos高清精品 | 伊在人天堂亚洲香蕉精品区 | 亚拍精品一区二区三区探花 | 一本久久伊人热热精品中文字幕 | 蜜桃臀无码内射一区二区三区 | 最新国产麻豆aⅴ精品无码 | 无人区乱码一区二区三区 | 精品国精品国产自在久国产87 | 亚洲国产精品无码一区二区三区 | 国产精品沙发午睡系列 | 亚洲无人区一区二区三区 | 国产两女互慰高潮视频在线观看 | 国产亚洲精品久久久久久久 | 国产精品多人p群无码 | 在线亚洲高清揄拍自拍一品区 | 亚洲精品国偷拍自产在线观看蜜桃 | 4hu四虎永久在线观看 | 青草青草久热国产精品 | 中文字幕 亚洲精品 第1页 | 一本大道久久东京热无码av | 久久精品中文闷骚内射 | 日韩成人一区二区三区在线观看 | 无码任你躁久久久久久久 | 中文字幕av无码一区二区三区电影 | 国产超级va在线观看视频 | 亚洲无人区午夜福利码高清完整版 | 久久精品国产日本波多野结衣 | 国产精品久久久久无码av色戒 | 亚洲午夜无码久久 | 久久人人爽人人人人片 | 99久久人妻精品免费二区 | 亚洲熟妇色xxxxx欧美老妇y | 亚洲国产一区二区三区在线观看 | 亚洲一区二区三区四区 | 日韩人妻无码一区二区三区久久99 | 国产亚洲人成在线播放 | 性生交片免费无码看人 | 色婷婷欧美在线播放内射 | 天天躁日日躁狠狠躁免费麻豆 | 国产精品无码永久免费888 | 精品国精品国产自在久国产87 | 一本大道伊人av久久综合 | 久久久久国色av免费观看性色 | 国产艳妇av在线观看果冻传媒 | 亚洲午夜久久久影院 | 粉嫩少妇内射浓精videos | 国产精品毛多多水多 | 婷婷五月综合缴情在线视频 | 无码一区二区三区在线观看 | 丰满少妇高潮惨叫视频 | 婷婷综合久久中文字幕蜜桃三电影 | 在线观看国产午夜福利片 | 亚洲精品一区国产 | 久久久精品欧美一区二区免费 | 久久久久av无码免费网 | а√天堂www在线天堂小说 | 国产人妻精品一区二区三区不卡 | 国产精品视频免费播放 | 少妇久久久久久人妻无码 | 国产精品人人妻人人爽 | 国产熟妇另类久久久久 | √天堂资源地址中文在线 | √天堂资源地址中文在线 | 夜夜夜高潮夜夜爽夜夜爰爰 | 色偷偷人人澡人人爽人人模 | 亚洲色欲色欲天天天www | 久激情内射婷内射蜜桃人妖 | 亚洲热妇无码av在线播放 | 未满小14洗澡无码视频网站 | 丰满少妇女裸体bbw | 国产片av国语在线观看 | 日产精品高潮呻吟av久久 | 对白脏话肉麻粗话av | 欧美性黑人极品hd | 免费观看的无遮挡av | 亚洲 日韩 欧美 成人 在线观看 | 国产精品久久国产三级国 | 国产人妻精品一区二区三区不卡 | 国产午夜无码视频在线观看 | 国内综合精品午夜久久资源 | 久久综合九色综合97网 | 婷婷丁香六月激情综合啪 | 熟妇人妻无乱码中文字幕 | 亚洲精品久久久久久一区二区 | 激情内射日本一区二区三区 | 狂野欧美性猛xxxx乱大交 | 一本加勒比波多野结衣 | √天堂中文官网8在线 | 国产人妻人伦精品1国产丝袜 | 人妻少妇精品无码专区动漫 | 成人精品一区二区三区中文字幕 | 国产福利视频一区二区 | 国产艳妇av在线观看果冻传媒 | 1000部啪啪未满十八勿入下载 | 成人av无码一区二区三区 | 麻豆av传媒蜜桃天美传媒 | 久久精品女人天堂av免费观看 | 国产人妖乱国产精品人妖 | 国内精品久久毛片一区二区 | 国产凸凹视频一区二区 | 兔费看少妇性l交大片免费 | 国产人妻久久精品二区三区老狼 | 76少妇精品导航 | 又色又爽又黄的美女裸体网站 | 天堂一区人妻无码 | 午夜精品久久久内射近拍高清 | 97久久超碰中文字幕 | 久久精品国产日本波多野结衣 | 97久久国产亚洲精品超碰热 | 精品无人区无码乱码毛片国产 | 亚洲春色在线视频 | 国产精品亚洲综合色区韩国 | 性欧美牲交在线视频 | 少妇性俱乐部纵欲狂欢电影 | 亚拍精品一区二区三区探花 | 18黄暴禁片在线观看 | 蜜臀aⅴ国产精品久久久国产老师 | 久久精品人人做人人综合试看 | 免费观看又污又黄的网站 | 成年美女黄网站色大免费视频 | 国产人妻精品一区二区三区不卡 | 97久久精品无码一区二区 | 熟女俱乐部五十路六十路av | 中文字幕人妻丝袜二区 | 国产一区二区三区四区五区加勒比 | 熟妇女人妻丰满少妇中文字幕 | 日韩欧美群交p片內射中文 | 无码人妻少妇伦在线电影 | 国产精品久久久av久久久 | 亚洲区小说区激情区图片区 | 99麻豆久久久国产精品免费 | 国内精品九九久久久精品 | 中文字幕乱码人妻二区三区 | 中文字幕av伊人av无码av | 国产性生交xxxxx无码 | 欧美性生交xxxxx久久久 | 在教室伦流澡到高潮hnp视频 | 狠狠色丁香久久婷婷综合五月 | 纯爱无遮挡h肉动漫在线播放 | 亚洲中文字幕无码中文字在线 | 老熟女重囗味hdxx69 | 18禁止看的免费污网站 | 欧洲美熟女乱又伦 | 国产女主播喷水视频在线观看 | 久久婷婷五月综合色国产香蕉 | 国产va免费精品观看 | 欧美大屁股xxxxhd黑色 | 精品欧洲av无码一区二区三区 | 亚洲欧美国产精品久久 | 97夜夜澡人人爽人人喊中国片 | 综合人妻久久一区二区精品 | 亚洲另类伦春色综合小说 | 久久国语露脸国产精品电影 | 国产精品.xx视频.xxtv | 国产xxx69麻豆国语对白 | 377p欧洲日本亚洲大胆 | 成人aaa片一区国产精品 | 中文字幕色婷婷在线视频 | 欧美日韩色另类综合 | 99国产精品白浆在线观看免费 | 波多野结衣高清一区二区三区 | 国产av一区二区三区最新精品 | 欧美人与禽猛交狂配 | 国产亚洲精品精品国产亚洲综合 | 亚拍精品一区二区三区探花 | 鲁鲁鲁爽爽爽在线视频观看 | 午夜熟女插插xx免费视频 | 在线看片无码永久免费视频 | 午夜无码人妻av大片色欲 | 久久人妻内射无码一区三区 | 人人澡人摸人人添 | 免费中文字幕日韩欧美 | 欧美激情综合亚洲一二区 | 欧美日韩色另类综合 | 亚洲日韩一区二区 | 精品无码一区二区三区爱欲 | 中文字幕无码乱人伦 | 亚洲中文字幕无码中文字在线 | 牛和人交xxxx欧美 | 久久久婷婷五月亚洲97号色 | 国产肉丝袜在线观看 | 麻豆果冻传媒2021精品传媒一区下载 | 成熟女人特级毛片www免费 | 国产97人人超碰caoprom | 国产成人精品一区二区在线小狼 | 国产一区二区三区日韩精品 | 色婷婷久久一区二区三区麻豆 | 国产精品亚洲lv粉色 | 成人亚洲精品久久久久软件 | 久久亚洲日韩精品一区二区三区 | 免费国产黄网站在线观看 | 亚洲精品久久久久中文第一幕 | 久久久久久av无码免费看大片 | 国产精品久久久久影院嫩草 | 成人性做爰aaa片免费看不忠 | 午夜福利一区二区三区在线观看 | 国产精品99爱免费视频 | 国产精品久久久久9999小说 | 无码国产乱人伦偷精品视频 | 双乳奶水饱满少妇呻吟 | 久久午夜无码鲁丝片 | 久久久www成人免费毛片 | 亚洲精品午夜国产va久久成人 | 无码午夜成人1000部免费视频 | 4hu四虎永久在线观看 | 一二三四社区在线中文视频 | 国产精品久久久av久久久 | 欧美性猛交xxxx富婆 | а√天堂www在线天堂小说 | 扒开双腿吃奶呻吟做受视频 | 4hu四虎永久在线观看 | 久久精品一区二区三区四区 | 天天爽夜夜爽夜夜爽 | 高潮毛片无遮挡高清免费视频 | 亚洲欧美中文字幕5发布 | 久久午夜无码鲁丝片 | 日日麻批免费40分钟无码 | 日韩精品无码免费一区二区三区 | 欧美国产日韩久久mv | 久久国产36精品色熟妇 | 日韩av激情在线观看 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 鲁大师影院在线观看 | 少妇高潮一区二区三区99 | 成人亚洲精品久久久久 | 久久久久久亚洲精品a片成人 | 婷婷六月久久综合丁香 | 131美女爱做视频 | 水蜜桃亚洲一二三四在线 | 国产女主播喷水视频在线观看 | 内射巨臀欧美在线视频 | 初尝人妻少妇中文字幕 | 日韩人妻少妇一区二区三区 | 狠狠综合久久久久综合网 | 亚洲国精产品一二二线 | 四虎4hu永久免费 | 久久久久久a亚洲欧洲av冫 | 天天综合网天天综合色 | 双乳奶水饱满少妇呻吟 | 又黄又爽又色的视频 | 日本一卡2卡3卡四卡精品网站 | 日韩精品无码免费一区二区三区 | 精品 日韩 国产 欧美 视频 | 少妇邻居内射在线 | 99久久人妻精品免费一区 | 成年美女黄网站色大免费视频 | 久久综合九色综合欧美狠狠 | 久久久中文字幕日本无吗 | 国产人成高清在线视频99最全资源 | 欧美日韩精品 | 国产午夜无码视频在线观看 | 欧美日本精品一区二区三区 | 蜜桃视频韩日免费播放 | 国产日产欧产精品精品app | 日产精品99久久久久久 | 99精品国产综合久久久久五月天 | 好男人www社区 | 亚洲区小说区激情区图片区 | 国产精品鲁鲁鲁 | 久久久久se色偷偷亚洲精品av | 欧美日韩视频无码一区二区三 | 亚洲区欧美区综合区自拍区 | 精品国产一区二区三区av 性色 | 丝袜美腿亚洲一区二区 | 高清无码午夜福利视频 | 国产麻豆精品一区二区三区v视界 | 青青久在线视频免费观看 | 成人精品视频一区二区 | 大地资源网第二页免费观看 | 男人和女人高潮免费网站 | 人人妻人人澡人人爽欧美一区九九 | 欧美刺激性大交 | 国产精品久久国产三级国 | 亚洲s色大片在线观看 | 国产极品美女高潮无套在线观看 | 在线看片无码永久免费视频 | 成人免费视频一区二区 | 男女猛烈xx00免费视频试看 | 四虎4hu永久免费 | 欧美35页视频在线观看 | 色综合久久久无码中文字幕 | 久久综合色之久久综合 | 夜先锋av资源网站 | 爽爽影院免费观看 | 性生交大片免费看l | 欧美精品一区二区精品久久 | 蜜臀av在线播放 久久综合激激的五月天 | 无遮挡国产高潮视频免费观看 | 真人与拘做受免费视频一 | 性生交大片免费看l | 日韩人妻系列无码专区 | 午夜时刻免费入口 | 国产精品第一国产精品 | 亚洲色大成网站www | 日本精品少妇一区二区三区 | 无码任你躁久久久久久久 | 六十路熟妇乱子伦 | 国产精品国产三级国产专播 | 欧美日韩久久久精品a片 | 国产色在线 | 国产 | 男女性色大片免费网站 | 亚洲gv猛男gv无码男同 | 日产精品高潮呻吟av久久 | 久久久婷婷五月亚洲97号色 | 国产熟妇另类久久久久 | 风流少妇按摩来高潮 | 成年女人永久免费看片 | 久久综合狠狠综合久久综合88 | 久久无码中文字幕免费影院蜜桃 | 亚洲精品国产精品乱码视色 | 色综合久久中文娱乐网 | 伊人久久大香线蕉亚洲 | 午夜精品久久久久久久久 | 高潮毛片无遮挡高清免费视频 | 人妻少妇精品久久 | 色欲人妻aaaaaaa无码 | 97人妻精品一区二区三区 | 亚洲s码欧洲m码国产av | 欧美成人高清在线播放 | 无码人妻出轨黑人中文字幕 | 日韩人妻无码中文字幕视频 | 国产精品18久久久久久麻辣 | 亚洲欧美精品aaaaaa片 | 少妇被黑人到高潮喷出白浆 | 日韩精品无码一区二区中文字幕 | 日韩人妻无码中文字幕视频 | 乱码av麻豆丝袜熟女系列 | 中文精品无码中文字幕无码专区 | 国产午夜无码精品免费看 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 一本久久a久久精品vr综合 | 正在播放老肥熟妇露脸 | 我要看www免费看插插视频 | 亚洲欧美精品aaaaaa片 | 国产亚洲视频中文字幕97精品 | 成年美女黄网站色大免费全看 | 天天拍夜夜添久久精品 | av无码电影一区二区三区 | 无码人妻少妇伦在线电影 | 国产麻豆精品一区二区三区v视界 | 亚洲人成无码网www | 精品无人区无码乱码毛片国产 | 欧美成人免费全部网站 | 日本熟妇大屁股人妻 | 人妻aⅴ无码一区二区三区 | 成人动漫在线观看 | 真人与拘做受免费视频 | 思思久久99热只有频精品66 | 亚洲一区二区观看播放 | 2020最新国产自产精品 | 沈阳熟女露脸对白视频 | 成人三级无码视频在线观看 | 久久久久久a亚洲欧洲av冫 | 亚洲а∨天堂久久精品2021 | 欧美老妇交乱视频在线观看 | 久久久成人毛片无码 | 国产欧美亚洲精品a | 国产在线精品一区二区高清不卡 | 亚洲国产av美女网站 | 欧美激情内射喷水高潮 | 午夜熟女插插xx免费视频 | 无码任你躁久久久久久久 | 久久精品国产一区二区三区肥胖 | 国产精品视频免费播放 | 精品一区二区不卡无码av | 亚洲精品国偷拍自产在线观看蜜桃 | 国内综合精品午夜久久资源 | 亚洲一区二区三区含羞草 | 欧美第一黄网免费网站 | 我要看www免费看插插视频 | 亚洲精品中文字幕乱码 | 老子影院午夜精品无码 | 午夜精品一区二区三区在线观看 | 亚洲另类伦春色综合小说 | 激情爆乳一区二区三区 | 亚洲中文字幕在线无码一区二区 | 高清国产亚洲精品自在久久 | 中文字幕无码av波多野吉衣 | 亚洲国产成人a精品不卡在线 | 国产无遮挡吃胸膜奶免费看 | 奇米影视7777久久精品人人爽 | 97无码免费人妻超级碰碰夜夜 | 国产又爽又黄又刺激的视频 | 白嫩日本少妇做爰 | 国产精品香蕉在线观看 | 荫蒂添的好舒服视频囗交 | 中文字幕无码乱人伦 | 国产极品视觉盛宴 | 岛国片人妻三上悠亚 | 青草青草久热国产精品 | 大肉大捧一进一出视频出来呀 | 国产九九九九九九九a片 | 无码人妻丰满熟妇区毛片18 | 国产亚洲欧美在线专区 | 亚洲国产一区二区三区在线观看 | 最新国产麻豆aⅴ精品无码 | 亚洲乱码国产乱码精品精 | 久久精品成人欧美大片 | 免费国产成人高清在线观看网站 | 亚洲综合伊人久久大杳蕉 | 欧美老熟妇乱xxxxx | 国模大胆一区二区三区 | 六月丁香婷婷色狠狠久久 | 国产av一区二区精品久久凹凸 | 亚洲伊人久久精品影院 | 亚洲熟妇色xxxxx亚洲 | 国产suv精品一区二区五 | 中文精品无码中文字幕无码专区 | 国产精品久久久av久久久 | 国产又爽又黄又刺激的视频 | 18黄暴禁片在线观看 | 国产乱人无码伦av在线a | 一本久道久久综合婷婷五月 | 少女韩国电视剧在线观看完整 | 少妇性俱乐部纵欲狂欢电影 | 中文字幕久久久久人妻 | 国产极品美女高潮无套在线观看 | 99久久精品国产一区二区蜜芽 | 男女猛烈xx00免费视频试看 | 九月婷婷人人澡人人添人人爽 | 亚洲第一无码av无码专区 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 国产福利视频一区二区 | 亚洲精品久久久久久久久久久 | www国产亚洲精品久久久日本 | 欧美成人高清在线播放 | 亚洲国产综合无码一区 | 成人精品视频一区二区三区尤物 | 四虎国产精品免费久久 | 国产综合久久久久鬼色 | 亚洲综合在线一区二区三区 | 精品久久久久香蕉网 | 国内精品人妻无码久久久影院 | 国产成人综合美国十次 | 娇妻被黑人粗大高潮白浆 | 中文字幕 亚洲精品 第1页 | 最近免费中文字幕中文高清百度 | 国产色精品久久人妻 | 伊人色综合久久天天小片 | 伊人色综合久久天天小片 | 人人妻人人藻人人爽欧美一区 | 双乳奶水饱满少妇呻吟 | 中文字幕av伊人av无码av | 人人妻人人澡人人爽欧美一区 | 亚洲日本在线电影 | 性生交大片免费看l | 日本精品高清一区二区 | 国产超级va在线观看视频 | 风流少妇按摩来高潮 | 曰韩无码二三区中文字幕 | 亚洲中文字幕在线观看 | 中文字幕亚洲情99在线 | 亚洲精品成a人在线观看 | 牲交欧美兽交欧美 | 熟妇人妻中文av无码 | 人妻少妇精品无码专区二区 | 亚洲欧美日韩成人高清在线一区 | 国产亚洲日韩欧美另类第八页 | 高清无码午夜福利视频 | 高清不卡一区二区三区 | 伊人久久大香线焦av综合影院 | 精品少妇爆乳无码av无码专区 | 亚洲成av人片在线观看无码不卡 | 欧美性生交xxxxx久久久 | 亚洲理论电影在线观看 | 成人精品一区二区三区中文字幕 | 欧美自拍另类欧美综合图片区 | 东京热无码av男人的天堂 | 鲁鲁鲁爽爽爽在线视频观看 | 日韩精品无码一本二本三本色 | 中文字幕av无码一区二区三区电影 | 女高中生第一次破苞av | 国产亚洲精品精品国产亚洲综合 | 久久精品女人天堂av免费观看 | 成人无码视频在线观看网站 | 国产卡一卡二卡三 | 人人妻在人人 | 久激情内射婷内射蜜桃人妖 | 午夜时刻免费入口 | 精品无人区无码乱码毛片国产 | 高清无码午夜福利视频 | 国产精品二区一区二区aⅴ污介绍 | 国产精品鲁鲁鲁 | 性色欲网站人妻丰满中文久久不卡 | 国产性生交xxxxx无码 | 成人三级无码视频在线观看 | 欧美激情综合亚洲一二区 | 午夜嘿嘿嘿影院 | 丁香花在线影院观看在线播放 | 精品水蜜桃久久久久久久 | 老头边吃奶边弄进去呻吟 | 任你躁在线精品免费 | 55夜色66夜色国产精品视频 | 无码纯肉视频在线观看 | 乱中年女人伦av三区 | 久久精品国产一区二区三区 | 久久精品人妻少妇一区二区三区 | 国产精品无套呻吟在线 | 亚洲中文字幕av在天堂 | 欧美人与牲动交xxxx | 欧美日韩一区二区综合 | 久久久国产精品无码免费专区 | 熟妇人妻无码xxx视频 | 色综合久久久无码中文字幕 | 中文字幕日韩精品一区二区三区 | 国产黄在线观看免费观看不卡 | 老司机亚洲精品影院无码 | 牛和人交xxxx欧美 | 丝袜人妻一区二区三区 | 欧美亚洲国产一区二区三区 | 2019午夜福利不卡片在线 | 精品国产精品久久一区免费式 | 天天躁夜夜躁狠狠是什么心态 | 狠狠cao日日穞夜夜穞av | 日本肉体xxxx裸交 | 国产亚洲tv在线观看 | 亚洲日韩精品欧美一区二区 | 国产午夜亚洲精品不卡下载 | 一个人看的www免费视频在线观看 | 亚洲成a人片在线观看无码 | 在线a亚洲视频播放在线观看 | 免费看少妇作爱视频 | 国内丰满熟女出轨videos | 国产精品99爱免费视频 | 午夜丰满少妇性开放视频 | 亚洲色大成网站www | 亚洲精品一区二区三区四区五区 | 西西人体www44rt大胆高清 | 牲交欧美兽交欧美 | 亚洲一区二区三区无码久久 | 免费观看黄网站 | 76少妇精品导航 | 精品国产aⅴ无码一区二区 | 偷窥村妇洗澡毛毛多 | 曰韩无码二三区中文字幕 | 亚洲熟女一区二区三区 | 精品久久久无码人妻字幂 | 欧美 亚洲 国产 另类 | 国产三级久久久精品麻豆三级 | 日韩成人一区二区三区在线观看 | 国产av久久久久精东av | 国产成人av免费观看 | 国产精品无码久久av | 国产无遮挡吃胸膜奶免费看 | 国产成人久久精品流白浆 | 午夜性刺激在线视频免费 | 噜噜噜亚洲色成人网站 | 波多野结衣av一区二区全免费观看 | 色婷婷综合中文久久一本 | 黑人大群体交免费视频 | 亚洲一区二区三区 | 无码国内精品人妻少妇 | 奇米影视7777久久精品 | 久久亚洲日韩精品一区二区三区 | av在线亚洲欧洲日产一区二区 | 久久精品国产一区二区三区肥胖 | 亚洲国产精品成人久久蜜臀 | 国产成人无码av在线影院 | 一本久道久久综合婷婷五月 | 精品无码成人片一区二区98 | 久久久久久久久蜜桃 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲精品久久久久avwww潮水 | 少妇高潮喷潮久久久影院 | 久久综合香蕉国产蜜臀av | 正在播放东北夫妻内射 | 九一九色国产 | 国产麻豆精品精东影业av网站 | 国产偷自视频区视频 | 无码中文字幕色专区 | 久精品国产欧美亚洲色aⅴ大片 | 欧美性色19p | 无码午夜成人1000部免费视频 | 少女韩国电视剧在线观看完整 | 扒开双腿疯狂进出爽爽爽视频 | 亚洲成av人片在线观看无码不卡 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产午夜手机精彩视频 | 日日干夜夜干 | 亚洲精品一区二区三区婷婷月 | 理论片87福利理论电影 | 少妇厨房愉情理9仑片视频 | 麻豆果冻传媒2021精品传媒一区下载 | 无码人妻丰满熟妇区毛片18 | 熟女体下毛毛黑森林 | 日本熟妇乱子伦xxxx | 中文字幕无码免费久久99 | 日本精品少妇一区二区三区 | 免费人成在线观看网站 | 中文字幕日韩精品一区二区三区 | 精品乱子伦一区二区三区 | 强辱丰满人妻hd中文字幕 | 欧美日本日韩 | 国内精品久久毛片一区二区 | 亚洲熟悉妇女xxx妇女av | 国产熟妇高潮叫床视频播放 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产无套内射久久久国产 | 欧美三级不卡在线观看 | 亚洲色大成网站www国产 | 午夜男女很黄的视频 | 97久久国产亚洲精品超碰热 | 久久99精品国产.久久久久 | 国产精品高潮呻吟av久久4虎 | 国产精品人人爽人人做我的可爱 | 精品成人av一区二区三区 | 激情爆乳一区二区三区 | 任你躁在线精品免费 | 国产av无码专区亚洲awww | 国产激情一区二区三区 | 午夜丰满少妇性开放视频 | 亚洲乱码日产精品bd | 国产精品久久久久久亚洲影视内衣 | 亚洲综合色区中文字幕 | 亚洲爆乳精品无码一区二区三区 | 精品国产av色一区二区深夜久久 | 亚洲 高清 成人 动漫 | 一本色道婷婷久久欧美 | 人人妻人人澡人人爽欧美一区九九 | 窝窝午夜理论片影院 | 免费国产成人高清在线观看网站 | 51国偷自产一区二区三区 | 男人扒开女人内裤强吻桶进去 | 国产办公室秘书无码精品99 | 国产av无码专区亚洲awww | 蜜桃臀无码内射一区二区三区 | 男人的天堂av网站 | 宝宝好涨水快流出来免费视频 | 永久免费精品精品永久-夜色 | 奇米影视7777久久精品人人爽 | 久久久久久久人妻无码中文字幕爆 | 强开小婷嫩苞又嫩又紧视频 | 天干天干啦夜天干天2017 | 野狼第一精品社区 | 久久久精品456亚洲影院 | 成熟女人特级毛片www免费 | 亚洲精品一区二区三区大桥未久 | 中国女人内谢69xxxx | 国产av无码专区亚洲awww | 中文字幕无码热在线视频 | 天堂无码人妻精品一区二区三区 | 三级4级全黄60分钟 | 欧美一区二区三区 | 国产精品久久久久久久影院 | 亚洲色www成人永久网址 | 中文字幕乱妇无码av在线 | 国产精品久久久av久久久 | 国产亚洲精品久久久久久 | 亚洲色无码一区二区三区 | 日韩av无码一区二区三区不卡 | 欧美丰满少妇xxxx性 | 日本va欧美va欧美va精品 | 六月丁香婷婷色狠狠久久 | 久久国产自偷自偷免费一区调 | 中文字幕无码av激情不卡 | 97夜夜澡人人爽人人喊中国片 | 国产超碰人人爽人人做人人添 | 国产精品亚洲五月天高清 | 国产av人人夜夜澡人人爽麻豆 | 日韩欧美中文字幕公布 | 日日麻批免费40分钟无码 | 亲嘴扒胸摸屁股激烈网站 | 国产麻豆精品一区二区三区v视界 | 无码人妻av免费一区二区三区 | 亚洲欧洲中文日韩av乱码 | 国产做国产爱免费视频 | 图片小说视频一区二区 | 沈阳熟女露脸对白视频 | 国产成人无码一二三区视频 | 精品国精品国产自在久国产87 | 亚洲欧美精品伊人久久 | 少妇久久久久久人妻无码 | 午夜时刻免费入口 | 国产精品第一区揄拍无码 | 国产香蕉尹人综合在线观看 | 少妇性荡欲午夜性开放视频剧场 | 亚洲国产综合无码一区 | 精品欧洲av无码一区二区三区 | 1000部啪啪未满十八勿入下载 | 亚洲区小说区激情区图片区 | 老头边吃奶边弄进去呻吟 | 97夜夜澡人人爽人人喊中国片 | 亚洲欧美国产精品久久 | 天堂亚洲免费视频 | 亚洲国产精品成人久久蜜臀 | 欧美老妇交乱视频在线观看 | 中文字幕乱码亚洲无线三区 | 日本丰满熟妇videos | 永久免费观看国产裸体美女 | 无码av免费一区二区三区试看 | 日本护士毛茸茸高潮 | 亚洲最大成人网站 | 国产后入清纯学生妹 | 福利一区二区三区视频在线观看 | 精品无码国产一区二区三区av | 无码毛片视频一区二区本码 | 久久zyz资源站无码中文动漫 | 鲁鲁鲁爽爽爽在线视频观看 | 精品国偷自产在线 | 色噜噜亚洲男人的天堂 | 亚洲一区二区观看播放 | 国产精品亚洲综合色区韩国 | 国产精品无码mv在线观看 | 玩弄中年熟妇正在播放 | 亚洲精品一区二区三区在线观看 | 成年美女黄网站色大免费视频 | 黑人大群体交免费视频 | 亚洲人成影院在线无码按摩店 | 国内精品九九久久久精品 | 中文无码伦av中文字幕 | 国产精品办公室沙发 | 国产精品办公室沙发 | 少妇激情av一区二区 | 欧美日韩人成综合在线播放 | 在教室伦流澡到高潮hnp视频 | 又大又硬又爽免费视频 | 欧美变态另类xxxx | 亚洲中文字幕无码一久久区 | 色欲av亚洲一区无码少妇 | 在线亚洲高清揄拍自拍一品区 | 2019nv天堂香蕉在线观看 | 国内丰满熟女出轨videos | 人人超人人超碰超国产 | 黑人大群体交免费视频 | 亚洲熟妇自偷自拍另类 | 亚洲精品国偷拍自产在线观看蜜桃 | 亚洲娇小与黑人巨大交 | 国产成人久久精品流白浆 | 成人av无码一区二区三区 | 99久久精品无码一区二区毛片 | 一区二区传媒有限公司 | 日本免费一区二区三区最新 | 精品国产乱码久久久久乱码 | 亚洲精品国产精品乱码不卡 | 国产精品人妻一区二区三区四 | 一本久久a久久精品vr综合 | 一个人看的视频www在线 | 久久亚洲中文字幕无码 | 欧美人妻一区二区三区 | 亚洲精品www久久久 | 九月婷婷人人澡人人添人人爽 | 大屁股大乳丰满人妻 | 人妻无码αv中文字幕久久琪琪布 | 国产精品无码成人午夜电影 | 玩弄少妇高潮ⅹxxxyw | 久久久久久国产精品无码下载 | 丰满人妻精品国产99aⅴ | 国产三级精品三级男人的天堂 | 国产精品久久久久无码av色戒 | 日日干夜夜干 | 亚洲综合无码久久精品综合 | 久久综合激激的五月天 | 无码人妻av免费一区二区三区 | 男女爱爱好爽视频免费看 | 国产av一区二区精品久久凹凸 | 大地资源网第二页免费观看 | 3d动漫精品啪啪一区二区中 | 99久久精品午夜一区二区 | 欧洲精品码一区二区三区免费看 | 亚洲一区二区三区无码久久 | 日本丰满护士爆乳xxxx | 精品日本一区二区三区在线观看 | 人妻互换免费中文字幕 | 免费网站看v片在线18禁无码 | 精品国产av色一区二区深夜久久 | 天天做天天爱天天爽综合网 | 国产性生交xxxxx无码 | 男人扒开女人内裤强吻桶进去 | 日本丰满护士爆乳xxxx | 久久精品女人天堂av免费观看 | 熟妇人妻无码xxx视频 | 女人和拘做爰正片视频 | 欧美日韩在线亚洲综合国产人 | 亚洲乱码中文字幕在线 | 一二三四在线观看免费视频 | 国产在线aaa片一区二区99 | 无码人妻丰满熟妇区五十路百度 | 亚洲精品国产品国语在线观看 | 无码人妻出轨黑人中文字幕 | 一本久道久久综合婷婷五月 | 中文字幕精品av一区二区五区 | 在线观看国产一区二区三区 | 国产国语老龄妇女a片 | 成人片黄网站色大片免费观看 | 2020久久香蕉国产线看观看 | 色诱久久久久综合网ywww | 国产成人无码av片在线观看不卡 | 国产疯狂伦交大片 | 任你躁国产自任一区二区三区 | 国产亚洲欧美在线专区 | 2020最新国产自产精品 | 又紧又大又爽精品一区二区 | 一本色道久久综合狠狠躁 | 日本一卡2卡3卡四卡精品网站 | 任你躁国产自任一区二区三区 | 丰满妇女强制高潮18xxxx | 亚洲欧美国产精品久久 | 亚洲小说春色综合另类 | 蜜臀av无码人妻精品 | 激情综合激情五月俺也去 | 动漫av网站免费观看 | av小次郎收藏 | 久久精品国产一区二区三区肥胖 | 久久精品国产精品国产精品污 | 最近免费中文字幕中文高清百度 | 日本成熟视频免费视频 | 99久久99久久免费精品蜜桃 | 波多野结衣av一区二区全免费观看 | 亚洲欧美国产精品久久 | 亚洲国产欧美日韩精品一区二区三区 | 成在人线av无码免观看麻豆 | 伊人久久大香线蕉午夜 | 荫蒂添的好舒服视频囗交 | 成人无码视频在线观看网站 | 永久免费精品精品永久-夜色 | 国产精品国产自线拍免费软件 | 国产精品沙发午睡系列 | 激情五月综合色婷婷一区二区 | 国产精品美女久久久 | 波多野结衣乳巨码无在线观看 | 熟妇人妻无码xxx视频 | 亚洲 高清 成人 动漫 | 夜先锋av资源网站 | 99麻豆久久久国产精品免费 | 欧美一区二区三区视频在线观看 | 亚洲爆乳无码专区 | 久久天天躁夜夜躁狠狠 | 欧美freesex黑人又粗又大 | 国产亚洲日韩欧美另类第八页 | 亚洲爆乳精品无码一区二区三区 | 精品无码av一区二区三区 | 无码av最新清无码专区吞精 | 日本在线高清不卡免费播放 | 一本久久伊人热热精品中文字幕 | 狠狠cao日日穞夜夜穞av | 免费观看激色视频网站 | 国产精品国产自线拍免费软件 | 亚洲精品一区二区三区四区五区 | 暴力强奷在线播放无码 | 国产精品无码永久免费888 | 亚洲精品国产品国语在线观看 | 正在播放东北夫妻内射 | 亚洲精品一区二区三区在线 | 日韩无套无码精品 | 牲欲强的熟妇农村老妇女视频 | 国产精品资源一区二区 | 国产精品.xx视频.xxtv | 动漫av一区二区在线观看 | 天堂а√在线地址中文在线 | 国产综合久久久久鬼色 | 久久久久免费看成人影片 | 波多野结衣av一区二区全免费观看 | 国产高清av在线播放 | 蜜臀av在线播放 久久综合激激的五月天 | 精品人妻人人做人人爽夜夜爽 | 色偷偷人人澡人人爽人人模 | 秋霞成人午夜鲁丝一区二区三区 | 久久久精品国产sm最大网站 | 99久久精品日本一区二区免费 | 午夜福利一区二区三区在线观看 | 玩弄中年熟妇正在播放 | 日本一卡二卡不卡视频查询 | 亚洲一区二区三区国产精华液 | 澳门永久av免费网站 | 免费中文字幕日韩欧美 | 欧美野外疯狂做受xxxx高潮 | 欧美变态另类xxxx | 国内少妇偷人精品视频免费 | 999久久久国产精品消防器材 | 国产在线一区二区三区四区五区 | 亚洲成a人片在线观看无码 | 天天做天天爱天天爽综合网 | 色一情一乱一伦 | 乱码午夜-极国产极内射 | 天天av天天av天天透 | 免费乱码人妻系列无码专区 | 亚洲一区二区三区香蕉 | 妺妺窝人体色www婷婷 | 国产av人人夜夜澡人人爽麻豆 | 国产成人无码a区在线观看视频app | 久久国产精品_国产精品 | 精品国产aⅴ无码一区二区 | 国产亚洲精品精品国产亚洲综合 | 亚洲一区二区观看播放 | аⅴ资源天堂资源库在线 | 婷婷色婷婷开心五月四房播播 | √天堂资源地址中文在线 | 黑人巨大精品欧美黑寡妇 |