久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

掌握 Kafka

發(fā)布時間:2024/1/23 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 掌握 Kafka 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Apache Kafka 是一個快速、可擴(kuò)展的、高吞吐的、可容錯的分布式“發(fā)布-訂閱”消息系統(tǒng), 使用 Scala 與 Java 語言編寫,能夠?qū)⑾囊粋€端點傳遞到另一個端點。較之傳統(tǒng)的消息中間件(例如 ActiveMQ、RabbitMQ),Kafka 具有高吞吐量、內(nèi)置分區(qū)、支持消息副本和高容錯的特性,非常適合大規(guī)模消息處理應(yīng)用程序。

?

Kafka 官網(wǎng):http://kafka.apache.org/

?

Kafka 主要設(shè)計目標(biāo)如下:

?

  • 以時間復(fù)雜度為 O(1) 的方式提供消息持久化能力,即使對 TB 級以上數(shù)據(jù)也能保證常數(shù)時間的訪問性能。

  • 高吞吐率。即使在非常廉價的商用機(jī)器上也能做到單機(jī)支持每秒 100K 條消息的傳輸。

  • 支持 Kafka Server 間的消息分區(qū),及分布式消費(fèi),同時保證每個 Partition 內(nèi)的消息順序傳輸。

  • 同時支持離線數(shù)據(jù)處理和實時數(shù)據(jù)處理。

  • 支持在線水平擴(kuò)展。

?

Kafka 通常用于兩大類應(yīng)用程序:

?

  • 建立實時流數(shù)據(jù)管道,以可靠地在系統(tǒng)或應(yīng)用程序之間獲取數(shù)據(jù)。

  • 構(gòu)建實時流應(yīng)用程序,以轉(zhuǎn)換或響應(yīng)數(shù)據(jù)流。

?

要了解 Kafka 如何執(zhí)行這些操作,讓我們從頭開始深入研究 Kafka 的功能。

?

首先幾個概念:

?

  • Kafka 在一個或多個可以跨越多個數(shù)據(jù)中心的服務(wù)器上作為集群運(yùn)行。

  • Kafka 集群將記錄流存儲在稱為主題的類別中。

  • 每個記錄由一個鍵,一個值和一個時間戳組成。

?

Kafka 架構(gòu)體系如下圖:

?

?

Kafka 的應(yīng)用場景非常多, 下面我們就來舉幾個我們最常見的場景:

?

①用戶的活動跟蹤:用戶在網(wǎng)站的不同活動消息發(fā)布到不同的主題中心,然后可以對這些消息進(jìn)行實時監(jiān)測、實時處理。

?

當(dāng)然,也可以加載到 Hadoop 或離線處理數(shù)據(jù)倉庫,對用戶進(jìn)行畫像。像淘寶、天貓、京東這些大型電商平臺,用戶的所有活動都要進(jìn)行追蹤的。

?

②日志收集如下圖:

?

?

③限流削峰如下圖:

?

?

④高吞吐率實現(xiàn):Kafka 與其他 MQ 相比,最大的特點就是高吞吐率。為了增加存儲能力,Kafka 將所有的消息都寫入到了低速大容量的硬盤。

?

按理說,這將導(dǎo)致性能損失,但實際上,Kafka 仍然可以保持超高的吞吐率,并且其性能并未受到影響。

?

其主要采用如下方式實現(xiàn)了高吞吐率:

?

  • 順序讀寫:Kafka 將消息寫入到了分區(qū) Partition 中,而分區(qū)中的消息又是順序讀寫的。順序讀寫要快于隨機(jī)讀寫。

  • 零拷貝:生產(chǎn)者、消費(fèi)者對于 Kafka 中的消息是采用零拷貝實現(xiàn)的。

  • 批量發(fā)送:Kafka 允許批量發(fā)送模式。

  • 消息壓縮:Kafka 允許對消息集合進(jìn)行壓縮。

?

Kafka的優(yōu)點如下:

?

①解耦:在項目啟動之初來預(yù)測將來項目會碰到什么需求,是極其困難的。

?

消息系統(tǒng)在處理過程中間插入了一個隱含的、基于數(shù)據(jù)的接口層,兩邊的處理過程都要實現(xiàn)這一接口。

?

這允許你獨立的擴(kuò)展或修改兩邊的處理過程,只要確保它們遵守同樣的接口約束。

?

②冗余(副本):有些情況下,處理數(shù)據(jù)的過程會失敗。除非數(shù)據(jù)被持久化,否則將造成丟失。

?

消息隊列把數(shù)據(jù)進(jìn)行持久化直到它們已經(jīng)被完全處理,通過這一方式規(guī)避了數(shù)據(jù)丟失風(fēng)險。

?

許多消息隊列所采用的"插入-獲取-刪除"范式中,在把一個消息從隊列中刪除之前,需要你的處理系統(tǒng)明確的指出該消息已經(jīng)被處理完畢,從而確保你的數(shù)據(jù)被安全的保存直到你使用完畢。

?

③擴(kuò)展性:因為消息隊列解耦了你的處理過程,所以增大消息入隊和處理的頻率是很容易的,只要另外增加處理過程即可。不需要改變代碼、不需要調(diào)節(jié)參數(shù)。擴(kuò)展就像調(diào)大電力按鈕一樣簡單。

?

④靈活性&峰值處理能力:在訪問量劇增的情況下,應(yīng)用仍然需要繼續(xù)發(fā)揮作用,但是這樣的突發(fā)流量并不常見;如果為以能處理這類峰值訪問為標(biāo)準(zhǔn)來投入資源隨時待命無疑是巨大的浪費(fèi)。

?

使用消息隊列能夠使關(guān)鍵組件頂住突發(fā)的訪問壓力,而不會因為突發(fā)的超負(fù)荷的請求而完全崩潰。

?

⑤可恢復(fù)性:系統(tǒng)的一部分組件失效時,不會影響到整個系統(tǒng)。消息隊列降低了進(jìn)程間的耦合度,所以即使一個處理消息的進(jìn)程掛掉,加入隊列中的消息仍然可以在系統(tǒng)恢復(fù)后被處理。

?

⑥順序保證:在大多使用場景下,數(shù)據(jù)處理的順序都很重要。大部分消息隊列本來就是排序的,并且能保證數(shù)據(jù)會按照特定的順序來處理。Kafka 保證一個 Partition 內(nèi)的消息的有序性。

?

⑦緩沖:在任何重要的系統(tǒng)中,都會有需要不同的處理時間的元素。例如,加載一張圖片比應(yīng)用過濾器花費(fèi)更少的時間。

?

消息隊列通過一個緩沖層來幫助任務(wù)最高效率的執(zhí)行,寫入隊列的處理會盡可能的快速。該緩沖有助于控制和優(yōu)化數(shù)據(jù)流經(jīng)過系統(tǒng)的速度。

?

⑧異步通信:很多時候,用戶不想也不需要立即處理消息。消息隊列提供了異步處理機(jī)制,允許用戶把一個消息放入隊列,但并不立即處理它。想向隊列中放入多少消息就放多少,然后在需要的時候再去處理它們。

?

Kafka 與其他 MQ 對比如下:

?

①RabbitMQ:RabbitMQ 是使用 Erlang 編寫的一個開源的消息隊列,本身支持很多的協(xié)議:AMQP,XMPP,SMTP,STOMP,也正因如此,它非常重量級,更適合于企業(yè)級的開發(fā)。

?

同時實現(xiàn)了 Broker 構(gòu)架,這意味著消息在發(fā)送給客戶端時先在中心隊列排隊。對路由,負(fù)載均衡或者數(shù)據(jù)持久化都有很好的支持。

?

②Redis:Redis 是一個基于 Key-Value 對的 NoSQL 數(shù)據(jù)庫,開發(fā)維護(hù)很活躍。

?

雖然它是一個 Key-Value 數(shù)據(jù)庫存儲系統(tǒng),但它本身支持 MQ 功能,所以完全可以當(dāng)做一個輕量級的隊列服務(wù)來使用。

?

對于 RabbitMQ 和 Redis 的入隊和出隊操作,各執(zhí)行 100 萬次,每 10 萬次記錄一次執(zhí)行時間。測試數(shù)據(jù)分為 128Bytes、512Bytes、1K 和 10K 四個不同大小的數(shù)據(jù)。

?

實驗表明:入隊時,當(dāng)數(shù)據(jù)比較小時 Redis 的性能要高于 RabbitMQ,而如果數(shù)據(jù)大小超過了 10K,Redis 則慢的無法忍受;出隊時,無論數(shù)據(jù)大小,Redis 都表現(xiàn)出非常好的性能,而 RabbitMQ 的出隊性能則遠(yuǎn)低于 Redis。

?

③ZeroMQ:ZeroMQ 號稱最快的消息隊列系統(tǒng),尤其針對大吞吐量的需求場景。

?

ZeroMQ 能夠?qū)崿F(xiàn) RabbitMQ 不擅長的高級/復(fù)雜的隊列,但是開發(fā)人員需要自己組合多種技術(shù)框架,技術(shù)上的復(fù)雜度是對這 MQ 能夠應(yīng)用成功的挑戰(zhàn)。

?

ZeroMQ 具有一個獨特的非中間件的模式,你不需要安裝和運(yùn)行一個消息服務(wù)器或中間件,因為你的應(yīng)用程序?qū)缪葸@個服務(wù)器角色。

?

你只需要簡單的引用 ZeroMQ 程序庫,可以使用 NuGet 安裝,然后你就可以愉快的在應(yīng)用程序之間發(fā)送消息了。

?

但是 ZeroMQ 僅提供非持久性的隊列,也就是說如果宕機(jī),數(shù)據(jù)將會丟失。其中,Twitter 的 Storm 0.9.0 以前的版本中默認(rèn)使用 ZeroMQ 作為數(shù)據(jù)流的傳輸(Storm 從 0.9 版本開始同時支持 ZeroMQ 和 Netty 作為傳輸模塊)。

?

④ActiveMQ:ActiveMQ 是 Apache 下的一個子項目。類似于 ZeroMQ,它能夠以代理人和點對點的技術(shù)實現(xiàn)隊列。同時類似于 RabbitMQ,它少量代碼就可以高效地實現(xiàn)高級應(yīng)用場景。

?

⑤Kafka/Jafka:Kafka 是 Apache 下的一個子項目,是一個高性能跨語言分布式發(fā)布/訂閱消息隊列系統(tǒng),而 Jafka 是在 Kafka 之上孵化而來的,即 Kafka 的一個升級版。

?

具有以下特性:

?

  • 快速持久化,可以在 O(1) 的系統(tǒng)開銷下進(jìn)行消息持久化。

  • 高吞吐,在一臺普通的服務(wù)器上既可以達(dá)到 10W/s 的吞吐速率。

  • 完全的分布式系統(tǒng),Broker、Producer、Consumer 都原生自動支持分布式,自動實現(xiàn)負(fù)載均衡。

  • 支持 Hadoop 數(shù)據(jù)并行加載,對于像 Hadoop 的一樣的日志數(shù)據(jù)和離線分析系統(tǒng),但又要求實時處理的限制,這是一個可行的解決方案。

?

Kafka 通過 Hadoop 的并行加載機(jī)制統(tǒng)一了在線和離線的消息處理。Apache Kafka 相對于 ActiveMQ 是一個非常輕量級的消息系統(tǒng),除了性能非常好之外,還是一個工作良好的分布式系統(tǒng)。

?

Kafka的幾種重要角色如下:

?

①Kafka 作為存儲系統(tǒng):任何允許發(fā)布與使用無關(guān)的消息發(fā)布的消息隊列都有效地充當(dāng)了運(yùn)行中消息的存儲系統(tǒng)。Kafka 的不同之處在于它是一個非常好的存儲系統(tǒng)。

?

寫入 Kafka 的數(shù)據(jù)將寫入磁盤并進(jìn)行復(fù)制以實現(xiàn)容錯功能。Kafka 允許生產(chǎn)者等待確認(rèn),以便直到完全復(fù)制并確保即使寫入服務(wù)器失敗的情況下寫入也不會完成。

?

Kafka 的磁盤結(jié)構(gòu)可以很好地擴(kuò)展使用-無論服務(wù)器上有 50KB 還是 50TB 的持久數(shù)據(jù),Kafka 都將執(zhí)行相同的操作。

?

由于認(rèn)真對待存儲并允許客戶端控制其讀取位置,因此您可以將 Kafka 視為一種專用于高性能,低延遲提交日志存儲,復(fù)制和傳播的專用分布式文件系統(tǒng)。

?

②Kafka 作為消息傳遞系統(tǒng):Kafka 的流概念與傳統(tǒng)的企業(yè)消息傳遞系統(tǒng)相比如何?

?

傳統(tǒng)上,消息傳遞具有兩種模型:排隊和發(fā)布訂閱。在隊列中,一組使用者可以從服務(wù)器中讀取內(nèi)容,并且每條記錄都將轉(zhuǎn)到其中一個。

?

在發(fā)布-訂閱記錄中廣播給所有消費(fèi)者。這兩個模型中的每一個都有優(yōu)點和缺點。

?

排隊的優(yōu)勢在于,它允許您將數(shù)據(jù)處理劃分到多個使用者實例上,從而擴(kuò)展處理量。

?

不幸的是,隊列不是多用戶的—一次進(jìn)程讀取了丟失的數(shù)據(jù)。發(fā)布-訂閱允許您將數(shù)據(jù)廣播到多個進(jìn)程,但是由于每條消息都傳遞給每個訂閱者,因此無法擴(kuò)展處理。

?

Kafka 的消費(fèi)者群體概念概括了這兩個概念。與隊列一樣,使用者組允許您將處理劃分為一組進(jìn)程(使用者組的成員)。與發(fā)布訂閱一樣,Kafka 允許您將消息廣播到多個消費(fèi)者組。

?

Kafka 模型的優(yōu)點在于,每個主題都具有這些屬性-可以擴(kuò)展處理范圍,并且是多訂閱者,無需選擇其中一個。

?

與傳統(tǒng)的消息傳遞系統(tǒng)相比,Kafka 還具有更強(qiáng)的訂購保證。傳統(tǒng)隊列將記錄按順序保留在服務(wù)器上,如果多個使用者從隊列中消費(fèi),則服務(wù)器將按記錄的存儲順序分發(fā)記錄。

?

但是,盡管服務(wù)器按順序分發(fā)記錄,但是這些記錄是異步傳遞給使用者的,因此它們可能在不同的使用者上亂序到達(dá)。

?

這實際上意味著在并行使用的情況下會丟失記錄的順序。消息傳遞系統(tǒng)通常通過“專有使用者”的概念來解決此問題,該概念僅允許一個進(jìn)程從隊列中使用,但是,這當(dāng)然意味著在處理中沒有并行性。

?

Kafka 做得更好,通過在主題內(nèi)具有并行性(即分區(qū))的概念,Kafka 能夠在用戶進(jìn)程池中提供排序保證和負(fù)載均衡。

?

這是通過將主題中的分區(qū)分配給消費(fèi)者組中的消費(fèi)者來實現(xiàn)的,以便每個分區(qū)都由組中的一個消費(fèi)者完全消費(fèi)。

?

通過這樣做,我們確保使用者是該分區(qū)的唯一讀取器,并按順序使用數(shù)據(jù)。由于存在許多分區(qū),因此仍然可以平衡許多使用者實例上的負(fù)載。但是請注意,使用者組中的使用者實例不能超過分區(qū)。

?

③Kafka 用作流處理:僅讀取,寫入和存儲數(shù)據(jù)流是不夠的,目的是實現(xiàn)對流的實時處理。

?

在 Kafka 中,流處理器是指從輸入主題中獲取連續(xù)數(shù)據(jù)流,對該輸入進(jìn)行一些處理并生成連續(xù)數(shù)據(jù)流以輸出主題的任何東西。

?

例如,零售應(yīng)用程序可以接受銷售和裝運(yùn)的輸入流,并輸出根據(jù)此數(shù)據(jù)計算出的重新訂購和價格調(diào)整流。

?

可以直接使用生產(chǎn)者和消費(fèi)者 API 進(jìn)行簡單處理。但是,對于更復(fù)雜的轉(zhuǎn)換,Kafka 提供了完全集成的 Streams API。

?

這允許構(gòu)建執(zhí)行非重要處理的應(yīng)用程序,這些應(yīng)用程序計算流的聚合或?qū)⒘鬟B接在一起。

?

該功能有助于解決此類應(yīng)用程序所面臨的難題:處理無序數(shù)據(jù),在代碼更改時重新處理輸入,執(zhí)行狀態(tài)計算等。

?

流 API 建立在 Kafka 提供的核心原語之上:它使用生產(chǎn)者和使用者 API 進(jìn)行輸入,使用 Kafka 進(jìn)行狀態(tài)存儲,并使用相同的組機(jī)制來實現(xiàn)流處理器實例之間的容錯。

?

Kafka 中的關(guān)鍵術(shù)語解釋

?

Topic:主題。在 Kafka 中,使用一個類別屬性來劃分消息的所屬類,劃分消息的這個類稱為 Topic。Topic 相當(dāng)于消息的分類標(biāo)簽,是一個邏輯概念。

?

物理上不同 Topic 的消息分開存儲,邏輯上一個 Topic 的消息雖然保存于一個或多個 Broker 上但用戶只需指定消息的 Topic 即可生產(chǎn)或消費(fèi)數(shù)據(jù)而不必關(guān)心數(shù)據(jù)存于何處。

?

Partition:分區(qū)。Topic 中的消息被分割為一個或多個 Partition,其是一個物理概念,對應(yīng)到系統(tǒng)上 就是一個或若干個目錄。Partition 內(nèi)部的消息是有序的,但 Partition 間的消息是無序的。

?

Segment 段。將 Partition 進(jìn)一步細(xì)分為了若干的 Segment,每個 Segment 文件的大小相等。

?

Broker:Kafka 集群包含一個或多個服務(wù)器,每個服務(wù)器節(jié)點稱為一個 Broker。

?

Broker 存儲 Topic 的數(shù)據(jù)。如果某 Topic 有 N 個 Partition,集群有 N 個 Broker,那么每個 Broker 存儲該 Topic 的一個 Partition。

?

如果某 Topic 有 N 個 Partition,集群有(N+M)個 Broker,那么其中有 N 個 Broker 存儲該 Topic 的一個 Partition,剩下的 M 個 Broker 不存儲該 Topic 的 Partition 數(shù)據(jù)。

?

如果某 Topic 有 N 個 Partition,集群中 Broker 數(shù)目少于 N 個,那么一個 Broker 存儲該 Topic 的一個或多個 Partition。

?

在實際生產(chǎn)環(huán)境中,盡量避免這種情況的發(fā)生,這種情況容易導(dǎo)致 Kafka 集群數(shù)據(jù)不均衡。

?

Producer:生產(chǎn)者。即消息的發(fā)布者,生產(chǎn)者將數(shù)據(jù)發(fā)布到他們選擇的主題。

生產(chǎn)者負(fù)責(zé)選擇將哪個記錄分配給主題中的哪個分區(qū)。即:生產(chǎn)者生產(chǎn)的一條消息,會被寫入到某一個 Partition。

?

Consumer:消費(fèi)者。可以從 Broker 中讀取消息。一個消費(fèi)者可以消費(fèi)多個 Topic 的消息;一個消費(fèi)者可以消費(fèi)同一個 Topic 中的多個 Partition 中的消息;一個 Partiton 允許多個 Consumer 同時消費(fèi)。

?

Consumer Group:Consumer Group 是 Kafka 提供的可擴(kuò)展且具有容錯性的消費(fèi)者機(jī)制。

?

組內(nèi)可以有多個消費(fèi)者,它們共享一個公共的 ID,即 Group ID。組內(nèi)的所有消費(fèi)者協(xié)調(diào)在一起來消費(fèi)訂閱主題 的所有分區(qū)。

?

Kafka 保證同一個 Consumer Group 中只有一個 Consumer 會消費(fèi)某條消息。

?

實際上,Kafka 保證的是穩(wěn)定狀態(tài)下每一個 Consumer 實例只會消費(fèi)某一個或多個特定的 Partition,而某個 Partition 的數(shù)據(jù)只會被某一個特定的 Consumer 實例所消費(fèi)。

?

下面我們用官網(wǎng)的一張圖, 來標(biāo)識 Consumer 數(shù)量和 Partition 數(shù)量的對應(yīng)關(guān)系。

?

?

由兩臺服務(wù)器組成的 Kafka 群集,其中包含四個帶有兩個使用者組的分區(qū)(P0-P3)。消費(fèi)者組 A 有兩個消費(fèi)者實例,組 B 有四個。

?

對于這個消費(fèi)組, 以前一直搞不明白, 我自己的總結(jié)是:Topic 中的 Partitoin 到 Group 是發(fā)布訂閱的通信方式。

?

即一條 Topic 的 Partition 的消息會被所有的 Group 消費(fèi),屬于一對多模式;Group 到 Consumer 是點對點通信方式,屬于一對一模式。

?

舉個例子:不使用 Group 的話,啟動 10 個 Consumer 消費(fèi)一個 Topic,這 10 個 Consumer 都能得到 Topic 的所有數(shù)據(jù),相當(dāng)于這個 Topic 中的任一條消息被消費(fèi) 10 次。

?

使用 Group 的話,連接時帶上 groupid,Topic 的消息會分發(fā)到 10 個 Consumer 上,每條消息只被消費(fèi) 1 次。

?

Replizcas of partition:分區(qū)副本。副本是一個分區(qū)的備份,是為了防止消息丟失而創(chuàng)建的分區(qū)的備份。

?

Partition Leader:每個 Partition 有多個副本,其中有且僅有一個作為 Leader,Leader 是當(dāng)前負(fù)責(zé)消息讀寫 的 Partition。即所有讀寫操作只能發(fā)生于 Leader 分區(qū)上。

?

Partition Follower:所有 Follower 都需要從 Leader 同步消息,Follower 與 Leader 始終保持消息同步。Leader 與 Follower 的關(guān)系是主備關(guān)系,而非主從關(guān)系。

?

ISR:

?

  • ISR,In-Sync Replicas,是指副本同步列表。ISR 列表是由 Leader 負(fù)責(zé)維護(hù)。

  • AR,Assigned Replicas,指某個 Partition 的所有副本, 即已分配的副本列表。

  • OSR,Outof-Sync Replicas,即非同步的副本列表。

  • AR=ISR+OSR

?

Offset:偏移量。每條消息都有一個當(dāng)前 Partition 下唯一的 64 字節(jié)的 Offset,它是相當(dāng)于當(dāng)前分區(qū)第一條消息的偏移量。

?

Broker Controller:Kafka集群的多個 Broker 中,有一個會被選舉 Controller,負(fù)責(zé)管理整個集群中 Partition 和 Replicas 的狀態(tài)。

?

只有 Broker Controller 會向 Zookeeper 中注冊 Watcher,其他 Broker 及分區(qū)無需注冊。即 Zookeeper 僅需監(jiān)聽 Broker Controller 的狀態(tài)變化即可。

?

HW 與 LEO:

?

  • HW,HighWatermark,高水位,表示 Consumer 可以消費(fèi)到的最高 Partition 偏移量。HW 保證了 Kafka 集群中消息的一致性。確切地說,是保證了 Partition 的 Follower 與 Leader 間數(shù) 據(jù)的一致性。

  • LEO,Log End Offset,日志最后消息的偏移量。消息是被寫入到 Kafka 的日志文件中的, 這是當(dāng)前最后一個寫入的消息在 Partition 中的偏移量。

  • 對于 Leader 新寫入的消息,Consumer 是不能立刻消費(fèi)的。Leader 會等待該消息被所有 ISR 中的 Partition Follower 同步后才會更新 HW,此時消息才能被 Consumer 消費(fèi)。

?

我相信你看完上面的概念還是懵逼的,好吧!下面我們就用圖來形象話的表示兩者的關(guān)系吧:

?

?

ZooKeeper:ZooKeeper 負(fù)責(zé)維護(hù)和協(xié)調(diào) Broker,負(fù)責(zé) Broker Controller 的選舉。在 Kafka 0.9 之前版本,Offset 是由 ZK 負(fù)責(zé)管理的。

?

總結(jié):ZooKeeper 負(fù)責(zé) Controller 的選舉,Controller 負(fù)責(zé) Leader 的選舉。

?

Coordinator:一般指的是運(yùn)行在每個 Broker 上的 Group Coordinator 進(jìn)程,用于管理 Consumer Group 中的各個成員,主要用于 Offset 位移管理和 Rebalance。一個 Coordinator 可以同時管理多個消費(fèi)者組。

?

Rebalance:當(dāng)消費(fèi)者組中的數(shù)量發(fā)生變化,或者 Topic 中的 Partition 數(shù)量發(fā)生了變化時,Partition 的所有權(quán)會在消費(fèi)者間轉(zhuǎn)移,即 Partition 會重新分配,這個過程稱為再均衡 Rebalance。

?

再均衡能夠給消費(fèi)者組及 Broker 帶來高性能、高可用性和伸縮,但在再均衡期間消費(fèi)者是無法讀取消息的,即整個 Broker 集群有小一段時間是不可用的。因此要避免不必要的再均衡。

?

Offset Commit:Consumer 從 Broker 中取一批消息寫入 Buffer 進(jìn)行消費(fèi),在規(guī)定的時間內(nèi)消費(fèi)完消息后,會自動將其消費(fèi)消息的 Offset 提交給 Broker,以記錄下哪些消息是消費(fèi)過的。當(dāng)然,若在時限內(nèi)沒有消費(fèi)完畢,其是不會提交 Offset 的。

?

Kafka的工作原理和過程

?

消息寫入算法

?

消息發(fā)送者將消息發(fā)送給 Broker, 并形成最終的可供消費(fèi)者消費(fèi)的 log,是已給比較復(fù)雜的過程:

?

  • Producer 先從 ZooKeeper 中找到該 Partition 的 Leader。

  • Producer將消息發(fā)送給該 Leader。

  • Leader 將消息接入本地的 log,并通知 ISR 的 Followers。

  • ISR 中的 Followers 從 Leader 中 Pull 消息, 寫入本地 log 后向 Leader 發(fā)送 Ack。

  • Leader 收到所有 ISR 中的 Followers 的 Ack 后,增加 HW 并向 Producer 發(fā)送 Ack,表示消息寫入成功。

?

消息路由策略

?

在通過 API 方式發(fā)布消息時,生產(chǎn)者是以 Record 為消息進(jìn)行發(fā)布的。

?

Record 中包含 Key 與 Value,Value 才是我們真正的消息本身,而 Key 用于路由消息所要存放的 Partition。

?

消息要寫入到哪個 Partition 并不是隨機(jī)的,而是有路由策略的:

?

  • 若指定了 Partition,則直接寫入到指定的 Partition。

  • 若未指定 Partition 但指定了 Key,則通過對 Key 的 Hash 值與 Partition 數(shù)量取模,該取模。

  • 結(jié)果就是要選出的 Partition 索引。

  • 若 Partition 和 Key 都未指定,則使用輪詢算法選出一個 Partition。

?

HW 截斷機(jī)制

?

如果 Partition Leader 接收到了新的消息, ISR 中其它 Follower 正在同步過程中,還未同步完畢時 Leader 宕機(jī)。

?

此時就需要選舉出新的 Leader。若沒有 HW 截斷機(jī)制,將會導(dǎo)致 Partition 中 Leader 與 Follower 數(shù)據(jù)的不一致。

?

當(dāng)原 Leader 宕機(jī)后又恢復(fù)時,將其 LEO 回退到其宕機(jī)時的 HW,然后再與新的 Leader 進(jìn)行數(shù)據(jù)同步,這樣就可以保證老 Leader 與新 Leader 中數(shù)據(jù)一致了,這種機(jī)制稱為 HW 截斷機(jī)制。

?

消息發(fā)送的可靠性

?

生產(chǎn)者向 Kafka 發(fā)送消息時,可以選擇需要的可靠性級別。通過 request.required.acks 參數(shù)的值進(jìn)行設(shè)置。

?

0 值:異步發(fā)送。生產(chǎn)者向 Kafka 發(fā)送消息而不需要 Kafka 反饋成功 Ack。該方式效率最高,但可靠性最低。

?

其可能會存在消息丟失的情況:

?

  • 在傳輸過程中會出現(xiàn)消息丟失。

  • 在 Broker 內(nèi)部會出現(xiàn)消息丟失。

  • 會出現(xiàn)寫入到 Kafka 中的消息的順序與生產(chǎn)順序不一致的情況。

?

1 值:同步發(fā)送。生產(chǎn)者發(fā)送消息給 Kafka,Broker 的 Partition Leader 在收到消息后馬上發(fā)送成功 Ack(無需等等 ISR 中的 Follower 同步)。

?

生產(chǎn)者收到后知道消息發(fā)送成功,然后會再發(fā)送消息。如果一直未收到 Kafka 的 Ack,則生產(chǎn)者會認(rèn)為消息發(fā)送失敗,會重發(fā)消息。

?

該方式對于 Producer 來說,若沒有收到 Ack,一定可以確認(rèn)消息發(fā)送失敗了,然后可以重發(fā)。

?

但是,即使收到了 ACK,也不能保證消息一定就發(fā)送成功了。故,這種情況,也可能會發(fā)生消息丟失的情況。

?

-1 值:同步發(fā)送。生產(chǎn)者發(fā)送消息給 Kafka,Kafka 收到消息后要等到 ISR 列表中的所有副本都 同步消息完成后,才向生產(chǎn)者發(fā)送成功 Ack。

?

如果一直未收到 Kafka 的 Ack,則認(rèn)為消息發(fā)送 失敗,會自動重發(fā)消息。該方式會出現(xiàn)消息重復(fù)接收的情況。

?

消費(fèi)者消費(fèi)過程解析

?

生產(chǎn)者將消息發(fā)送到 Topitc 中,消費(fèi)者即可對其進(jìn)行消費(fèi),其消費(fèi)過程如下:

?

  • Consumer 向 Broker 提交連接請求,其所連接上的 Broker 都會向其發(fā)送Broker Controller 的通信 URL,即配置文件中的 Listeners 地址。

  • 當(dāng) Consumer 指定了要消費(fèi)的 Topic 后,會向 Broker Controller 發(fā)送消費(fèi)請求。

  • Broker Controller 會為 Consumer 分配一個或幾個 Partition Leader,并將該 Partition 的當(dāng)前 Offset 發(fā)送給 Consumer。

  • Consumer 會按照 Broker Controller 分配的 Partition 對其中的消息進(jìn)行消費(fèi)。

  • 當(dāng) Consumer 消費(fèi)完該條消息后,Consumer 會向 Broker 發(fā)送一個消息已經(jīng)被消費(fèi)反饋,即該消息的 Offset。

  • 在 Broker 接收到 Consumer 的 Offset 后,會更新相應(yīng)的 __consumer_offset 中。

  • 以上過程會一直重復(fù),知道消費(fèi)者停止請求消費(fèi)。

  • Consumer 可以重置 Offset,從而可以靈活消費(fèi)存儲在 Broker 上的消息。

?

Partition Leader 選舉范圍

?

當(dāng) Leader 宕機(jī)后,Broker Controller 會從 ISR 中挑選一個 Follower 成為新的 Leader。

?

如果 ISR 中沒有其他副本怎么辦?可以通過 unclean.leader.election.enable 的值來設(shè)置 Leader 選舉范圍。

?

False:必須等到 ISR 列表中所有的副本都活過來才進(jìn)行新的選舉。該策略可靠性有保證,但可用性低。

?

True:在 ISR 列表中沒有副本的情況下,可以選擇任意一個沒有宕機(jī)的主機(jī)作為新的 Leader,該策略可用性高,但可靠性沒有保證。

?

重復(fù)消費(fèi)問題的解決方案

?

同一個 Consumer 重復(fù)消費(fèi):當(dāng) Consumer 由于消費(fèi)能力低而引發(fā)了消費(fèi)超時,則可能會形成重復(fù)消費(fèi)。

?

在某數(shù)據(jù)剛好消費(fèi)完畢,但是正準(zhǔn)備提交 Offset 時候,消費(fèi)時間超時,則 Broker 認(rèn)為這條消息未消費(fèi)成功。這時就會產(chǎn)生重復(fù)消費(fèi)問題。其解決方案:延長 Offset 提交時間。

?

不同的 Consumer 重復(fù)消費(fèi):當(dāng) Consumer 消費(fèi)了消息,但還沒有提交 Offset 時宕機(jī),則這些已經(jīng)被消費(fèi)過的消息會被重復(fù)消費(fèi)。其解決方案:將自動提交改為手動提交。

?

從架構(gòu)設(shè)計上解決 Kafka 重復(fù)消費(fèi)的問題

?

我們在設(shè)計程序的時候,比如考慮到網(wǎng)絡(luò)故障等一些異常的情況,我們都會設(shè)置消息的重試次數(shù),可能還有其他可能出現(xiàn)消息重復(fù),那我們應(yīng)該如何解決呢?下面提供三個方案:

?

方案一:保存并查詢

?

給每個消息都設(shè)置一個獨一無二的 uuid,所有的消息,我們都要存一個 uuid。

?

我們在消費(fèi)消息的時候,首先去持久化系統(tǒng)中查詢一下看這個看是否以前消費(fèi)過,如沒有消費(fèi)過,在進(jìn)行消費(fèi),如果已經(jīng)消費(fèi)過,丟棄就好了。

?

下圖表明了這種方案:

?

?

方案二:利用冪等

?

冪等(Idempotence)在數(shù)學(xué)上是這樣定義的,如果一個函數(shù) f(x) 滿足:f(f(x)) = f(x),則函數(shù) f(x) 滿足冪等性。

?

這個概念被拓展到計算機(jī)領(lǐng)域,被用來描述一個操作、方法或者服務(wù)。一個冪等操作的特點是,其任意多次執(zhí)行所產(chǎn)生的影響均與一次執(zhí)行的影響相同。

?

一個冪等的方法,使用同樣的參數(shù),對它進(jìn)行多次調(diào)用和一次調(diào)用,對系統(tǒng)產(chǎn)生的影響是一樣的。所以,對于冪等的方法,不用擔(dān)心重復(fù)執(zhí)行會對系統(tǒng)造成任何改變。

?

我們舉個例子來說明一下。在不考慮并發(fā)的情況下,“將 X 老師的賬戶余額設(shè)置為 100 萬元”,執(zhí)行一次后對系統(tǒng)的影響是,X 老師的賬戶余額變成了 100 萬元。

?

只要提供的參數(shù) 100 萬元不變,那即使再執(zhí)行多少次,X 老師的賬戶余額始終都是 100 萬元,不會變化,這個操作就是一個冪等的操作。

?

再舉一個例子,“將 X 老師的余額加 100 萬元”,這個操作它就不是冪等的,每執(zhí)行一次,賬戶余額就會增加 100 萬元,執(zhí)行多次和執(zhí)行一次對系統(tǒng)的影響(也就是賬戶的余額)是不一樣的。

?

所以,通過這兩個例子,我們可以想到如果系統(tǒng)消費(fèi)消息的業(yè)務(wù)邏輯具備冪等性,那就不用擔(dān)心消息重復(fù)的問題了,因為同一條消息,消費(fèi)一次和消費(fèi)多次對系統(tǒng)的影響是完全一樣的。也就可以認(rèn)為,消費(fèi)多次等于消費(fèi)一次。

?

那么,如何實現(xiàn)冪等操作呢?最好的方式就是,從業(yè)務(wù)邏輯設(shè)計上入手,將消費(fèi)的業(yè)務(wù)邏輯設(shè)計成具備冪等性的操作。

?

但是,不是所有的業(yè)務(wù)都能設(shè)計成天然冪等的,這里就需要一些方法和技巧來實現(xiàn)冪等。

?

下面我們介紹一種常用的方法:利用數(shù)據(jù)庫的唯一約束實現(xiàn)冪等。

?

例如,我們剛剛提到的那個不具備冪等特性的轉(zhuǎn)賬的例子:將 X 老師的賬戶余額加 100 萬元。在這個例子中,我們可以通過改造業(yè)務(wù)邏輯,讓它具備冪等性。

?

首先,我們可以限定,對于每個轉(zhuǎn)賬單每個賬戶只可以執(zhí)行一次變更操作,在分布式系統(tǒng)中,這個限制實現(xiàn)的方法非常多,最簡單的是我們在數(shù)據(jù)庫中建一張轉(zhuǎn)賬流水表。

?

這個表有三個字段:轉(zhuǎn)賬單 ID、賬戶 ID 和變更金額,然后給轉(zhuǎn)賬單 ID 和賬戶 ID 這兩個字段聯(lián)合起來創(chuàng)建一個唯一約束,這樣對于相同的轉(zhuǎn)賬單 ID 和賬戶 ID,表里至多只能存在一條記錄。

?

這樣,我們消費(fèi)消息的邏輯可以變?yōu)?#xff1a;“在轉(zhuǎn)賬流水表中增加一條轉(zhuǎn)賬記錄,然后再根據(jù)轉(zhuǎn)賬記錄,異步操作更新用戶余額即可?!?/p>

?

在轉(zhuǎn)賬流水表增加一條轉(zhuǎn)賬記錄這個操作中,由于我們在這個表中預(yù)先定義了“賬戶 ID 轉(zhuǎn)賬單 ID”的唯一約束,對于同一個轉(zhuǎn)賬單同一個賬戶只能插入一條記錄,后續(xù)重復(fù)的插入操作都會失敗,這樣就實現(xiàn)了一個冪等的操作。

?

?

方案三:設(shè)置前提條件

?

為更新的數(shù)據(jù)設(shè)置前置條件另外一種實現(xiàn)冪等的思路是,給數(shù)據(jù)變更設(shè)置一個前置條件,如果滿足條件就更新數(shù)據(jù),否則拒絕更新數(shù)據(jù),在更新數(shù)據(jù)的時候,同時變更前置條件中需要判斷的數(shù)據(jù)。

?

這樣,重復(fù)執(zhí)行這個操作時,由于第一次更新數(shù)據(jù)的時候已經(jīng)變更了前置條件中需要判斷的數(shù)據(jù),不滿足前置條件,則不會重復(fù)執(zhí)行更新數(shù)據(jù)操作。

?

比如,剛剛我們說過,“將 X 老師的賬戶的余額增加 100 萬元”這個操作并不滿足冪等性,我們可以把這個操作加上一個前置條件,變?yōu)?#xff1a;“如果 X 老師的賬戶當(dāng)前的余額為 500 萬元,將余額加 100 萬元”,這個操作就具備了冪等性。

?

對應(yīng)到消息隊列中的使用時,可以在發(fā)消息時在消息體中帶上當(dāng)前的余額,在消費(fèi)的時候進(jìn)行判斷數(shù)據(jù)庫中,當(dāng)前余額是否與消息中的余額相等,只有相等才執(zhí)行變更操作。

?

但是,如果我們要更新的數(shù)據(jù)不是數(shù)值,或者我們要做一個比較復(fù)雜的更新操作怎么辦?用什么作為前置判斷條件呢?

?

更加通用的方法是,給你的數(shù)據(jù)增加一個版本號屬性,每次更數(shù)據(jù)前,比較當(dāng)前數(shù)據(jù)的版本號是否和消息中的版本號一致,如果不一致就拒絕更新數(shù)據(jù),更新數(shù)據(jù)的同時將版本號 +1,一樣可以實現(xiàn)冪等。

?

?

Kafka 集群搭建

?

我們在工作中,為了保證環(huán)境的高可用,防止單點,Kafka 都是以集群的方式出現(xiàn)的,下面就帶領(lǐng)大家一起搭建一套 Kafka 集群環(huán)境。

?

我們在官網(wǎng)下載 Kafka,下載地址為:http://kafka.apache.org/downloads,下載我們需要的版本,推薦使用穩(wěn)定的版本。

搭建集群

?

①下載并解壓

?

  • cd /usr/local/src

  • wget http://mirrors.tuna.tsinghua.edu.cn/apache/kafka/2.4.0/kafka_2.11-2.4.0.tgz

  • mkdir /data/servers

  • tar xzvf kafka_2.11-2.4.0.tgz -C /data/servers/

  • cd /data/servers/kafka_2.11-2.4.0

  • ?

    ②修改配置文件

    ?

    Kafka 的配置文件 $KAFKA_HOME/config/server.properties,主要修改一下下面幾項:

    ?

  • 確保每個機(jī)器上的id不一樣

  • broker.id=0

  • 配置服務(wù)端的監(jiān)控地址

  • listeners=PLAINTEXT://192.168.51.128:9092

  • kafka 日志目錄

  • log.dirs=/data/servers/kafka_2.11-2.4.0/logs

  • #kafka設(shè)置的partitons的個數(shù)

  • num.partitions=1

  • ?

  • ZooKeeper的連接地址,如果有自己的 ZooKeeper 集群,請直接使用自己搭建的zookeeper集群

  • zookeeper.connect=192.168.51.128:2181

  • ?

    因為我自己是本機(jī)做實驗,所有使用的是一個主機(jī)的不同端口,在線上,就是不同的機(jī)器,大家參考即可。

    ?

    我們這里使用 Kafka 的 ZooKeeper,只啟動一個節(jié)點,但是正真的生產(chǎn)過程中,是需要 Zookeeper 集群,自己搭建就好,后期我們也會出 Zookeeper 的教程,大家請關(guān)注就好了。

    ?

    ③拷貝 3 份配置文件

    ?

  • #創(chuàng)建對應(yīng)的日志目錄

  • mkdir -p /data/servers/kafka_2.11-2.4.0/logs/9092

  • mkdir -p /data/servers/kafka_2.11-2.4.0/logs/9093

  • mkdir -p /data/servers/kafka_2.11-2.4.0/logs/9094

  • ?

  • #拷貝三份配置文件

  • cp server.properties server_9092.properties

  • cp server.properties server_9093.properties

  • cp server.properties server_9094.properties

  • ?

    ④修改不同端口對應(yīng)的文件

    ?

  • #9092的id為0, 9093的id為1, 9094的id為2

  • broker.id=0

  • # 配置服務(wù)端的監(jiān)控地址, 分別在不通的配置文件中寫入不同的端口

  • listeners=PLAINTEXT://192.168.51.128:9092

  • # kafka 日志目錄, 目錄也是對應(yīng)不同的端口

  • log.dirs=/data/servers/kafka_2.11-2.4.0/logs/9092

  • # kafka設(shè)置的partitons的個數(shù)

  • num.partitions=1

  • # ZooKeeper 的連接地址, 如果有自己的 ZooKeeper 集群, 請直接使用自己搭建的 ZooKeeper 集群

  • zookeeper.connect=192.168.51.128:2181

  • ?

    修改 ZooKeeper 的配置文件:

    ?

  • dataDir=/data/servers/zookeeper

  • server.1=192.168.51.128:2888:3888

  • ?

    然后創(chuàng)建 ZooKeeper 的 myid?文件

    ?

  • #創(chuàng)建對應(yīng)的日志目錄

  • mkdir -p /data/servers/kafka_2.11-2.4.0/logs/9092

  • mkdir -p /data/servers/kafka_2.11-2.4.0/logs/9093

  • mkdir -p /data/servers/kafka_2.11-2.4.0/logs/9094

  • ?

  • #拷貝三份配置文件

  • cp server.properties server_9092.properties

  • cp server.properties server_9093.properties

  • cp server.properties server_9094.properties

  • ?

    ④修改不同端口對應(yīng)的文件

    ?

  • #9092的id為0, 9093的id為1, 9094的id為2

  • broker.id=0

  • # 配置服務(wù)端的監(jiān)控地址, 分別在不通的配置文件中寫入不同的端口

  • listeners=PLAINTEXT://192.168.51.128:9092

  • # kafka 日志目錄, 目錄也是對應(yīng)不同的端口

  • log.dirs=/data/servers/kafka_2.11-2.4.0/logs/9092

  • # kafka設(shè)置的partitons的個數(shù)

  • num.partitions=1

  • # ZooKeeper 的連接地址, 如果有自己的 ZooKeeper 集群, 請直接使用自己搭建的 ZooKeeper 集群

  • zookeeper.connect=192.168.51.128:2181

  • ?

    修改 ZooKeeper 的配置文件:

    ?

  • dataDir=/data/servers/zookeeper

  • server.1=192.168.51.128:2888:3888

  • ?

    然后創(chuàng)建 ZooKeeper 的 myid 文件:

    ?

  • echo "1"> /data/servers/zookeeper/myid

  • ?

    ⑤啟動 ZooKeeper

    ?

    使用 Kafka 內(nèi)置的 ZooKeeper:

    ?

  • cd /data/servers/kafka_2.11-2.4.0/bin

  • zookeeper-server-start.sh -daemon ../config/zookeeper.properties

  • netstat -anp |grep 2181

  • ?

    啟動 Kafka:

    ?

  • ./kafka-server-start.sh -daemon ../config/server_9092.properties

  • ./kafka-server-start.sh -daemon ../config/server_9093.properties

  • ./kafka-server-start.sh -daemon ../config/server_9094.properties

  • ?

    Kafka 的操作

    ?

    ①Topic

    ?

    我們先來看一下創(chuàng)建 Topic 常用的參數(shù)吧:

    ?

    • --create:創(chuàng)建 topic

    • --delete:刪除 topic

    • --alter:修改 topic 的名字或者 partition 個數(shù)

    • --list:查看 topic

    • --describe:查看 topic 的詳細(xì)信息

    • --topic <String: topic>:指定 topic 的名字

    • --zookeeper <String: hosts>:指定 ZooKeeper 的連接地址參數(shù)提示并不贊成這樣使用(DEPRECATED, The connection string for the zookeeper connection in the form host:port. Multiple hosts can be given to allow fail-over.)

    • --bootstrap-server <String: server to connect to>:指定 Kafka 的連接地址,推薦使用這個,參數(shù)的提示信息顯示(REQUIRED: The Kafka server to connect to. In case of providing this, a direct Zookeeper connection won't be required.)。

    • --replication-factor <Integer: replication factor> : 對于每個 Partiton 的備份個數(shù)。(The replication factor for each partition in the topic being created. If not supplied, defaults to the cluster default.)

    • --partitions <Integer: # of partitions>:指定該 topic 的分區(qū)的個數(shù)。

    ?

    示例:

    ?

  • cd /data/servers/kafka_2.11-2.4.0/bin

  • # 創(chuàng)建topic test1

  • kafka-topics.sh --create --bootstrap-server=192.168.51.128:9092,10.231.128.96:9093,192.168.51.128:9094 --replication-factor 1 --partitions 1 --topic test1

  • # 創(chuàng)建topic test2

  • kafka-topics.sh --create --bootstrap-server=192.168.51.128:9092,10.231.128.96:9093,192.168.51.128:9094 --replication-factor 1 --partitions 1 --topic test2

  • # 查看topic

  • kafka-topics.sh --list --bootstrap-server=192.168.51.128:9092,10.231.128.96:9093,192.168.51.128:9094

  • ?

    自動創(chuàng)建 Topic

    ?

    我們在工作中,如果我們不想去管理 Topic,可以通過 Kafka 的配置文件來管理。

    ?

    我們可以讓 Kafka 自動創(chuàng)建 Topic,需要在我們的 Kafka 配置文件中加入如下

    ?

    配置文件:

    ?

  • auto.create.topics.enable=true

  • ?

    如果刪除 Topic 想達(dá)到物理刪除的目的,也是需要配置的:

    ?

  • delete.topic.enable=true

  • ?

    發(fā)送消息

    ?

    他們可以通過客戶端的命令生產(chǎn)消息,先來看看 kafka-console-producer.sh 常用的幾個參數(shù)吧:

    ?

    • --topic <String: topic>:指定 topic

    • --timeout <Integer: timeout_ms>:超時時間

    • --sync:異步發(fā)送消息

    • --broker-list <String: broker-list>:官網(wǎng)提示: REQUIRED: The broker list string in the form HOST1:PORT1,HOST2:PORT2.

    ?

    這個參數(shù)是必須的:

    ?

  • kafka-console-producer.sh --broker-list 192.168.51.128:9092,192.168.51.128:9093,192.168.51.128:9094 --topic test1

  • ?

    消費(fèi)消息

    ?

    我們也還是先來看看 kafka-console-consumer.sh 的參數(shù)吧:

    ?

    • --topic <String: topic>:指定 topic

    • --group <String: consumer group id>:指定消費(fèi)者組

    • --from-beginning:指定從開始進(jìn)行消費(fèi), 如果不指定, 就從當(dāng)前進(jìn)行消費(fèi)

    • --bootstrap-server:Kafka 的連接地址

    ?

  • kafka-console-consumer.sh --bootstrap-server 192.168.51.128:9092,192.168.51.128:9093,192.168.51.128:9094 --topic test1 ---beginning

  • ?

    ?

    Kafka 的日志

    ?

    Kafka 的日志分兩種:

    ?

    • 第一種日志是我們的 Kafka 的啟動日志,就是我們排查問題,查看報錯信息的日志。

    • 第二種日志就是我們的數(shù)據(jù)日志,Kafka 是我們的數(shù)據(jù)是以日志的形式存在存盤中的,我們第二種所說的日志就是我們的 Partiton 與 Segment。

    ?

    那我們就來說說備份和分區(qū)吧:我們創(chuàng)建一個分區(qū),一個備份,那么 test 就應(yīng)該在三臺機(jī)器上或者三個數(shù)據(jù)目錄只有一個 test-0。(分區(qū)的下標(biāo)是從 0 開始的)

    ?

    如果我們創(chuàng)建 N 個分區(qū),我們就會在三個服務(wù)器上發(fā)現(xiàn),test_0-n,如果我們創(chuàng)建 M 個備份,我們就會在發(fā)現(xiàn),test_0 到 test_n 每一個都是 M 個。

    ?

    Kafka API

    ?

    使用 Kafka 原生的 API

    ?

    ①消費(fèi)者自動提交

    ?

    定義自己的生產(chǎn)者:

    ?

  • import org.apache.kafka.clients.producer.Callback;

  • import org.apache.kafka.clients.producer.KafkaProducer;

  • import org.apache.kafka.clients.producer.ProducerRecord;

  • import org.apache.kafka.clients.producer.RecordMetadata;

  • ?

  • import java.util.Properties;

  • ?

  • /**

  • * @ClassName MyKafkaProducer

  • * @Description TODO

  • * @Author lingxiangxiang

  • * @Date 3:37 PM

  • * @Version 1.0

  • **/

  • public class MyKafkaProducer {

  • private org.apache.kafka.clients.producer.KafkaProducer<Integer, String> producer;

  • ?

  • public MyKafkaProducer() {

  • Properties properties = new Properties();

  • properties.put("bootstrap.servers", "192.168.51.128:9092,192.168.51.128:9093,192.168.51.128:9094");

  • properties.put("key.serializer", "org.apache.kafka.common.serialization.IntegerSerializer");

  • properties.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");

  • // 設(shè)置批量發(fā)送

  • properties.put("batch.size", 16384);

  • // 批量發(fā)送的等待時間50ms, 超過50ms, 不足批量大小也發(fā)送

  • properties.put("linger.ms", 50);

  • this.producer = new org.apache.kafka.clients.producer.KafkaProducer<Integer, String>(properties);

  • }

  • ?

  • public boolean sendMsg() {

  • boolean result = true;

  • try {

  • // 正常發(fā)送, test2是topic, 0代表的是分區(qū), 1代表的是key, hello world是發(fā)送的消息內(nèi)容

  • final ProducerRecord<Integer, String> record = new ProducerRecord<Integer, String>("test2", 0, 1, "hello world");

  • producer.send(record);

  • // 有回調(diào)函數(shù)的調(diào)用

  • producer.send(record, new Callback() {

  • @Override

  • public void onCompletion(RecordMetadata recordMetadata, Exception e) {

  • System.out.println(recordMetadata.topic());

  • System.out.println(recordMetadata.partition());

  • System.out.println(recordMetadata.offset());

  • }

  • });

  • // 自己定義一個類

  • producer.send(record, new MyCallback(record));

  • } catch (Exception e) {

  • result = false;

  • }

  • return result;

  • }

  • }

  • ?

    定義生產(chǎn)者發(fā)送成功的回調(diào)函數(shù):

    ?

  • import org.apache.kafka.clients.producer.Callback;

  • import org.apache.kafka.clients.producer.RecordMetadata;

  • ?

  • /**

  • * @ClassName MyCallback

  • * @Description TODO

  • * @Author lingxiangxiang

  • * @Date 3:51 PM

  • * @Version 1.0

  • **/

  • public class MyCallback implements Callback {

  • private Object msg;

  • ?

  • public MyCallback(Object msg) {

  • this.msg = msg;

  • }

  • ?

  • @Override

  • public void onCompletion(RecordMetadata metadata, Exception e) {

  • System.out.println("topic = " + metadata.topic());

  • System.out.println("partiton = " + metadata.partition());

  • System.out.println("offset = " + metadata.offset());

  • System.out.println(msg);

  • }

  • }

  • ?

    生產(chǎn)者測試類:在生產(chǎn)者測試類中,自己遇到一個坑,就是最后自己沒有加 sleep,就是怎么檢查自己的代碼都沒有問題,但是最后就是沒法發(fā)送成功消息,最后加了一個 sleep 就可以了。

    ?

    因為主函數(shù) main 已經(jīng)執(zhí)行完退出,但是消息并沒有發(fā)送完成,需要進(jìn)行等待一下。當(dāng)然,你在生產(chǎn)環(huán)境中可能不會遇到這樣問題,呵呵!

    ?

    代碼如下:

    ?

  • import static java.lang.Thread.sleep;

  • ?

  • /**

  • * @ClassName MyKafkaProducerTest

  • * @Description TODO

  • * @Author lingxiangxiang

  • * @Date 3:46 PM

  • * @Version 1.0

  • **/

  • public class MyKafkaProducerTest {

  • public static void main(String[] args) throws InterruptedException {

  • MyKafkaProducer producer = new MyKafkaProducer();

  • boolean result = producer.sendMsg();

  • System.out.println("send msg " + result);

  • sleep(1000);

  • }

  • }

  • ?

    消費(fèi)者類:

    ?

  • import kafka.utils.ShutdownableThread;

  • import org.apache.kafka.clients.consumer.ConsumerRecord;

  • import org.apache.kafka.clients.consumer.ConsumerRecords;

  • import org.apache.kafka.clients.consumer.KafkaConsumer;

  • ?

  • import java.util.Arrays;

  • import java.util.Collections;

  • import java.util.Properties;

  • ?

  • /**

  • * @ClassName MyKafkaConsumer

  • * @Description TODO

  • * @Author lingxiangxiang

  • * @Date 4:12 PM

  • * @Version 1.0

  • **/

  • public class MyKafkaConsumer extends ShutdownableThread {

  • ?

  • private KafkaConsumer<Integer, String> consumer;

  • ?

  • public MyKafkaConsumer() {

  • super("KafkaConsumerTest", false);

  • Properties properties = new Properties();

  • properties.put("bootstrap.servers", "192.168.51.128:9092,192.168.51.128:9093,192.168.51.128:9094");

  • properties.put("group.id", "mygroup");

  • properties.put("enable.auto.commit", "true");

  • properties.put("auto.commit.interval.ms", "1000");

  • properties.put("session.timeout.ms", "30000");

  • properties.put("heartbeat.interval.ms", "10000");

  • properties.put("auto.offset.reset", "earliest");

  • properties.put("key.deserializer", "org.apache.kafka.common.serialization.IntegerDeserializer");

  • properties.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

  • this.consumer = new KafkaConsumer<Integer, String>(properties);

  • }

  • ?

  • @Override

  • public void doWork() {

  • consumer.subscribe(Arrays.asList("test2"));

  • ConsumerRecords<Integer, String>records = consumer.poll(1000);

  • for (ConsumerRecord record : records) {

  • System.out.println("topic = " + record.topic());

  • System.out.println("partition = " + record.partition());

  • System.out.println("key = " + record.key());

  • System.out.println("value = " + record.value());

  • }

  • }

  • }

  • ?

    消費(fèi)者的測試類:

    ?

  • /**

  • * @ClassName MyConsumerTest

  • * @Description TODO

  • * @Author lingxiangxiang

  • * @Date 4:23 PM

  • * @Version 1.0

  • **/

  • public class MyConsumerTest {

  • public static void main(String[] args) {

  • MyKafkaConsumer consumer = new MyKafkaConsumer();

  • consumer.start();

  • System.out.println("==================");

  • }

  • }

  • ?

    ?

    ②消費(fèi)者同步手動提交

    ?

    前面的消費(fèi)者都是以自動提交 Offset 的方式對 Broker 中的消息進(jìn)行消費(fèi)的,但自動提交 可能會出現(xiàn)消息重復(fù)消費(fèi)的情況。

    ?

    所以在生產(chǎn)環(huán)境下,很多時候需要對 Offset 進(jìn)行手動提交, 以解決重復(fù)消費(fèi)的問題。

    ?

    手動提交又可以劃分為同步提交、異步提交,同異步聯(lián)合提交。這些提交方式僅僅是 doWork() 方法不相同,其構(gòu)造器是相同的。

    ?

    所以下面首先在前面消費(fèi)者類的基礎(chǔ)上進(jìn)行構(gòu)造器的修改,然后再分別實現(xiàn)三種不同的提交方式。

    ?

    同步提交方式是,消費(fèi)者向 Broker 提交 Offset 后等待 Broker 成功響應(yīng)。若沒有收到響應(yīng),則會重新提交,直到獲取到響應(yīng)。

    ?

    而在這個等待過程中,消費(fèi)者是阻塞的。其嚴(yán)重影響了消費(fèi)者的吞吐量。

    ?

    修改前面的 MyKafkaConsumer.java, 主要修改下面的配置:

    ?

  • import kafka.utils.ShutdownableThread;

  • import org.apache.kafka.clients.consumer.ConsumerRecord;

  • import org.apache.kafka.clients.consumer.ConsumerRecords;

  • import org.apache.kafka.clients.consumer.KafkaConsumer;

  • ?

  • import java.util.Arrays;

  • import java.util.Collections;

  • import java.util.Properties;

  • ?

  • /**

  • * @ClassName MyKafkaConsumer

  • * @Description TODO

  • * @Author lingxiangxiang

  • * @Date 4:12 PM

  • * @Version 1.0

  • **/

  • public class MyKafkaConsumer extends ShutdownableThread {

  • ?

  • private KafkaConsumer<Integer, String> consumer;

  • ?

  • public MyKafkaConsumer() {

  • super("KafkaConsumerTest", false);

  • Properties properties = new Properties();

  • properties.put("bootstrap.servers", "192.168.51.128:9092,192.168.51.128:9093,192.168.51.128:9094");

  • properties.put("group.id", "mygroup");

  • // 這里要修改成手動提交

  • properties.put("enable.auto.commit", "false");

  • // properties.put("auto.commit.interval.ms", "1000");

  • properties.put("session.timeout.ms", "30000");

  • properties.put("heartbeat.interval.ms", "10000");

  • properties.put("auto.offset.reset", "earliest");

  • properties.put("key.deserializer", "org.apache.kafka.common.serialization.IntegerDeserializer");

  • properties.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

  • this.consumer = new KafkaConsumer<Integer, String>(properties);

  • }

  • @Override

  • public void doWork() {

  • consumer.subscribe(Arrays.asList("test2"));

  • ConsumerRecords<Integer, String>records = consumer.poll(1000);

  • for (ConsumerRecord record : records) {

  • System.out.println("topic = " + record.topic());

  • System.out.println("partition = " + record.partition());

  • System.out.println("key = " + record.key());

  • System.out.println("value = " + record.value());

  • ?

  • //手動同步提交

  • consumer.commitSync();

  • }

  • ?

  • }

  • }

  • ?

    消費(fèi)者異步手工提交

    ?

    手動同步提交方式需要等待 Broker 的成功響應(yīng),效率太低,影響消費(fèi)者的吞吐量。

    ?

    異步提交方式是,消費(fèi)者向 Broker 提交 Offset 后不用等待成功響應(yīng),所以其增加了消費(fèi)者的吞吐量。

    ?

  • import kafka.utils.ShutdownableThread;

  • import org.apache.kafka.clients.consumer.ConsumerRecord;

  • import org.apache.kafka.clients.consumer.ConsumerRecords;

  • import org.apache.kafka.clients.consumer.KafkaConsumer;

  • ?

  • import java.util.Arrays;

  • import java.util.Collections;

  • import java.util.Properties;

  • ?

  • /**

  • * @ClassName MyKafkaConsumer

  • * @Description TODO

  • * @Author lingxiangxiang

  • * @Date 4:12 PM

  • * @Version 1.0

  • **/

  • public class MyKafkaConsumer extends ShutdownableThread {

  • ?

  • private KafkaConsumer<Integer, String> consumer;

  • ?

  • public MyKafkaConsumer() {

  • super("KafkaConsumerTest", false);

  • Properties properties = new Properties();

  • properties.put("bootstrap.servers", "192.168.51.128:9092,192.168.51.128:9093,192.168.51.128:9094");

  • properties.put("group.id", "mygroup");

  • // 這里要修改成手動提交

  • properties.put("enable.auto.commit", "false");

  • // properties.put("auto.commit.interval.ms", "1000");

  • properties.put("session.timeout.ms", "30000");

  • properties.put("heartbeat.interval.ms", "10000");

  • properties.put("auto.offset.reset", "earliest");

  • properties.put("key.deserializer", "org.apache.kafka.common.serialization.IntegerDeserializer");

  • properties.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

  • this.consumer = new KafkaConsumer<Integer, String>(properties);

  • }

  • ?

  • @Override

  • public void doWork() {

  • consumer.subscribe(Arrays.asList("test2"));

  • ConsumerRecords<Integer, String>records = consumer.poll(1000);

  • for (ConsumerRecord record : records) {

  • System.out.println("topic = " + record.topic());

  • System.out.println("partition = " + record.partition());

  • System.out.println("key = " + record.key());

  • System.out.println("value = " + record.value());

  • ?

  • //手動同步提交

  • // consumer.commitSync();

  • //手動異步提交

  • // consumer.commitAsync();

  • // 帶回調(diào)公共的手動異步提交

  • consumer.commitAsync((offsets, e) -> {

  • if(e != null) {

  • System.out.println("提交次數(shù), offsets = " + offsets);

  • System.out.println("exception = " + e);

  • }

  • });

  • }

  • }

  • }

  • ?

    Spring Boot 使用 Kafka

    ?

    現(xiàn)在大家的開發(fā)過程中,很多都用的是 Spring Boot 的項目,直接啟動了,如果還是用原生的 API,就是有點 Low 了啊,那 Kafka 是如何和 Spring Boot 進(jìn)行聯(lián)合的呢?

    ?

    maven 配置:

    ?

  • <!-- https://mvnrepository.com/artifact/org.apache.kafka/kafka-clients -->

  • <dependency>

  • <groupId>org.apache.kafka</groupId>

  • <artifactId>kafka-clients</artifactId>

  • <version>2.1.1</version>

  • </dependency>

  • ?

    添加配置文件,在 application.properties 中加入如下配置信息:

    ?

    Kafka 連接地址:

    ?

  • spring.kafka.bootstrap-servers = 192.168.51.128:9092,10.231.128.96:9093,192.168.51.128:9094

  • ?

    生產(chǎn)者:

    ?

  • spring.kafka.producer.acks = 0

  • spring.kafka.producer.key-serializer = org.apache.kafka.common.serialization.StringSerializer

  • spring.kafka.producer.value-serializer = org.apache.kafka.common.serialization.StringSerializer

  • spring.kafka.producer.retries = 3

  • spring.kafka.producer.batch-size = 4096

  • spring.kafka.producer.buffer-memory = 33554432

  • spring.kafka.producer.compression-type = gzip

  • ?

    消費(fèi)者:

    ?

  • spring.kafka.consumer.group-id = mygroup

  • spring.kafka.consumer.auto-commit-interval = 5000

  • spring.kafka.consumer.heartbeat-interval = 3000

  • spring.kafka.consumer.key-deserializer = org.apache.kafka.common.serialization.StringDeserializer

  • spring.kafka.consumer.value-deserializer = org.apache.kafka.common.serialization.StringDeserializer

  • spring.kafka.consumer.auto-offset-reset = earliest

  • spring.kafka.consumer.enable-auto-commit = true

  • # listenner, 標(biāo)識消費(fèi)者監(jiān)聽的個數(shù)

  • spring.kafka.listener.concurrency = 8

  • # topic的名字

  • kafka.topic1 = topic1

  • ?

    生產(chǎn)者:

    ?

  • import lombok.extern.slf4j.Slf4j;

  • import org.springframework.beans.factory.annotation.Value;

  • import org.springframework.kafka.core.KafkaTemplate;

  • ?

  • @Service

  • @Slf4j

  • public class MyKafkaProducerServiceImpl implements MyKafkaProducerService {

  • @Resource

  • private KafkaTemplate<String, String> kafkaTemplate;

  • // 讀取配置文件

  • @Value("${kafka.topic1}")

  • private String topic;

  • ?

  • @Override

  • public void sendKafka() {

  • kafkaTemplate.send(topic, "hell world");

  • }

  • }

  • ?

    消費(fèi)者:

    ?

  • @Component

  • @Slf4j

  • public class MyKafkaConsumer {

  • @KafkaListener(topics = "${kafka.topic1}")

  • public void listen(ConsumerRecord<?, ?> record) {

  • Optional<?> kafkaMessage = Optional.ofNullable(record.value());

  • if (kafkaMessage.isPresent()) {

  • log.info("----------------- record =" + record);

  • log.info("------------------ message =" + kafkaMessage.get());

  • }

  • 總結(jié)

    以上是生活随笔為你收集整理的掌握 Kafka的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    久久国产劲爆∧v内射 | 国产乱人伦偷精品视频 | 欧美成人家庭影院 | 久久人人爽人人爽人人片ⅴ | 亚洲一区二区三区香蕉 | 成人女人看片免费视频放人 | 久久无码人妻影院 | 综合网日日天干夜夜久久 | 国产精品永久免费视频 | 中国女人内谢69xxxx | 3d动漫精品啪啪一区二区中 | 麻豆av传媒蜜桃天美传媒 | 丰满人妻一区二区三区免费视频 | 蜜桃视频韩日免费播放 | 亚洲男女内射在线播放 | 无码一区二区三区在线观看 | 鲁一鲁av2019在线 | 久久99国产综合精品 | 男人扒开女人内裤强吻桶进去 | 无码乱肉视频免费大全合集 | 中文字幕乱码亚洲无线三区 | 亚洲国产av美女网站 | 国产极品美女高潮无套在线观看 | 国产极品视觉盛宴 | 999久久久国产精品消防器材 | 亚洲精品一区二区三区大桥未久 | 全球成人中文在线 | 精品久久久无码中文字幕 | 久久亚洲a片com人成 | 精品无码国产一区二区三区av | 人人妻人人澡人人爽人人精品浪潮 | 国产亚洲人成在线播放 | 久久午夜无码鲁丝片秋霞 | 午夜精品一区二区三区在线观看 | 午夜精品一区二区三区在线观看 | 俺去俺来也www色官网 | 亚洲の无码国产の无码步美 | 欧美精品国产综合久久 | 人妻少妇精品视频专区 | 色综合天天综合狠狠爱 | 小鲜肉自慰网站xnxx | 亚洲日韩精品欧美一区二区 | 国产av无码专区亚洲a∨毛片 | 亚洲色偷偷男人的天堂 | 久久99久久99精品中文字幕 | 中文字幕无码乱人伦 | 福利一区二区三区视频在线观看 | 国产精品久久久一区二区三区 | 久久精品人妻少妇一区二区三区 | 黄网在线观看免费网站 | 国产精品亚洲五月天高清 | 亚洲人成影院在线无码按摩店 | 四虎永久在线精品免费网址 | 亚洲国产成人a精品不卡在线 | 老熟妇仑乱视频一区二区 | 亚洲国产欧美在线成人 | 熟女少妇在线视频播放 | 欧美35页视频在线观看 | 亚拍精品一区二区三区探花 | 97久久国产亚洲精品超碰热 | 欧美精品一区二区精品久久 | 国产真实乱对白精彩久久 | 国模大胆一区二区三区 | 色综合久久中文娱乐网 | 日韩在线不卡免费视频一区 | 色婷婷久久一区二区三区麻豆 | 亚洲欧美精品aaaaaa片 | 久久精品人人做人人综合试看 | 欧美自拍另类欧美综合图片区 | 国产av无码专区亚洲a∨毛片 | 色偷偷人人澡人人爽人人模 | 日本一区二区三区免费高清 | 俺去俺来也www色官网 | 麻豆人妻少妇精品无码专区 | 国产极品视觉盛宴 | 午夜无码区在线观看 | 亚洲乱码中文字幕在线 | 精品欧洲av无码一区二区三区 | 国产网红无码精品视频 | 国内精品久久毛片一区二区 | 久久国产精品二国产精品 | 东京热一精品无码av | 久久久久成人精品免费播放动漫 | 精品国产一区二区三区四区 | 中文字幕乱码人妻无码久久 | 老司机亚洲精品影院 | 欧美国产日韩久久mv | 国产精品福利视频导航 | 无码任你躁久久久久久久 | 亚洲国产高清在线观看视频 | 人妻熟女一区 | 国精品人妻无码一区二区三区蜜柚 | 国产超碰人人爽人人做人人添 | 色欲久久久天天天综合网精品 | 精品亚洲成av人在线观看 | 亚洲成色在线综合网站 | 国产精品久久久久久亚洲毛片 | 欧美日韩一区二区三区自拍 | 久久综合香蕉国产蜜臀av | 无码av免费一区二区三区试看 | 欧洲精品码一区二区三区免费看 | 伦伦影院午夜理论片 | 亚洲色成人中文字幕网站 | 美女极度色诱视频国产 | 麻豆国产丝袜白领秘书在线观看 | 男人的天堂av网站 | 亚洲国产欧美国产综合一区 | 人人爽人人澡人人人妻 | 青青久在线视频免费观看 | 少妇人妻偷人精品无码视频 | 色综合久久久无码中文字幕 | 久久国产精品萌白酱免费 | 99精品国产综合久久久久五月天 | aⅴ亚洲 日韩 色 图网站 播放 | 丰满岳乱妇在线观看中字无码 | 青青青手机频在线观看 | 无码人妻精品一区二区三区下载 | 亚洲国产精品无码久久久久高潮 | 少妇高潮一区二区三区99 | 国内精品久久久久久中文字幕 | 精品无人区无码乱码毛片国产 | 亚洲国产精品久久人人爱 | 国产亚洲精品久久久久久久 | 欧美日韩一区二区免费视频 | 天海翼激烈高潮到腰振不止 | а√资源新版在线天堂 | 亚洲爆乳大丰满无码专区 | 漂亮人妻洗澡被公强 日日躁 | 色婷婷香蕉在线一区二区 | 久久久亚洲欧洲日产国码αv | 国产亚洲欧美日韩亚洲中文色 | 国产成人精品优优av | 国产手机在线αⅴ片无码观看 | 青草视频在线播放 | 性生交大片免费看女人按摩摩 | 日韩人妻无码中文字幕视频 | 亚洲精品国产精品乱码视色 | 亚洲精品鲁一鲁一区二区三区 | 亚洲另类伦春色综合小说 | 午夜精品久久久久久久久 | 无码精品人妻一区二区三区av | 国产精品-区区久久久狼 | 美女黄网站人色视频免费国产 | 少妇人妻av毛片在线看 | 成人女人看片免费视频放人 | 曰本女人与公拘交酡免费视频 | 女人被男人爽到呻吟的视频 | 日本免费一区二区三区最新 | 中文字幕中文有码在线 | 亚洲小说春色综合另类 | 欧美自拍另类欧美综合图片区 | 亚洲精品无码国产 | 搡女人真爽免费视频大全 | 国产精品久久久久无码av色戒 | 成人女人看片免费视频放人 | 久久精品国产一区二区三区肥胖 | 人妻少妇精品视频专区 | 国产精品美女久久久网av | 亚洲一区av无码专区在线观看 | 少妇邻居内射在线 | 亚洲色偷偷偷综合网 | 亚洲 高清 成人 动漫 | 国产va免费精品观看 | 亚洲精品欧美二区三区中文字幕 | www国产亚洲精品久久网站 | 亚洲精品综合一区二区三区在线 | 精品厕所偷拍各类美女tp嘘嘘 | 成人亚洲精品久久久久 | 男女性色大片免费网站 | 性欧美牲交在线视频 | 久久国产精品萌白酱免费 | 免费网站看v片在线18禁无码 | 国产三级久久久精品麻豆三级 | 帮老师解开蕾丝奶罩吸乳网站 | 欧美变态另类xxxx | 天堂无码人妻精品一区二区三区 | 麻豆国产人妻欲求不满谁演的 | 伊人久久大香线蕉亚洲 | 国产亚洲人成在线播放 | 午夜精品久久久久久久 | 麻豆国产97在线 | 欧洲 | 欧美国产日韩久久mv | 女人被男人爽到呻吟的视频 | 亚洲欧美日韩成人高清在线一区 | 美女黄网站人色视频免费国产 | 高清不卡一区二区三区 | 国产高清av在线播放 | 欧美日韩综合一区二区三区 | 亚洲欧美精品aaaaaa片 | 国产后入清纯学生妹 | 偷窥日本少妇撒尿chinese | 久久无码专区国产精品s | 国产又粗又硬又大爽黄老大爷视 | 亚洲精品国产精品乱码视色 | 亚洲日韩精品欧美一区二区 | 亚洲熟熟妇xxxx | 好男人www社区 | 亚洲中文字幕在线观看 | av香港经典三级级 在线 | 丰满妇女强制高潮18xxxx | 图片小说视频一区二区 | 一本色道婷婷久久欧美 | 久久久亚洲欧洲日产国码αv | 国产成人精品视频ⅴa片软件竹菊 | 国语精品一区二区三区 | 两性色午夜视频免费播放 | 亚洲一区二区三区含羞草 | 人妻体内射精一区二区三四 | 精品无码国产自产拍在线观看蜜 | 天天拍夜夜添久久精品 | 国产一精品一av一免费 | 久久精品无码一区二区三区 | 好男人社区资源 | 娇妻被黑人粗大高潮白浆 | 亚洲精品一区二区三区在线 | 97色伦图片97综合影院 | 人妻aⅴ无码一区二区三区 | 377p欧洲日本亚洲大胆 | 亚洲色欲久久久综合网东京热 | 成 人 网 站国产免费观看 | 窝窝午夜理论片影院 | 色婷婷综合激情综在线播放 | 狂野欧美性猛xxxx乱大交 | 天天拍夜夜添久久精品 | 国产香蕉尹人视频在线 | 国产性生大片免费观看性 | 图片区 小说区 区 亚洲五月 | 日韩精品一区二区av在线 | 久久综合网欧美色妞网 | 久久久国产精品无码免费专区 | 欧美性猛交内射兽交老熟妇 | 国产精品va在线播放 | 精品午夜福利在线观看 | 国产无套内射久久久国产 | 亚洲综合另类小说色区 | 国产综合在线观看 | 精品亚洲成av人在线观看 | 丰满人妻精品国产99aⅴ | 99久久精品午夜一区二区 | 久久久久人妻一区精品色欧美 | 精品国产一区二区三区四区在线看 | 中文字幕日产无线码一区 | 成人免费视频在线观看 | 粗大的内捧猛烈进出视频 | 草草网站影院白丝内射 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 久久99久久99精品中文字幕 | 精品国产一区二区三区av 性色 | 日本丰满护士爆乳xxxx | 精品久久久久久亚洲精品 | 亚洲精品午夜国产va久久成人 | 国产精品丝袜黑色高跟鞋 | 动漫av网站免费观看 | 人人超人人超碰超国产 | 骚片av蜜桃精品一区 | 亚洲日韩精品欧美一区二区 | 日日橹狠狠爱欧美视频 | 婷婷丁香六月激情综合啪 | 日本高清一区免费中文视频 | 精品水蜜桃久久久久久久 | 欧美性生交活xxxxxdddd | 久久久久久久久888 | 精品久久久无码中文字幕 | 午夜理论片yy44880影院 | 又湿又紧又大又爽a视频国产 | 亚洲精品欧美二区三区中文字幕 | 亚洲国产精品一区二区美利坚 | 久久精品中文闷骚内射 | 国产一区二区三区日韩精品 | 国产精品久久精品三级 | 国产人妻人伦精品 | 欧美三级a做爰在线观看 | 色诱久久久久综合网ywww | 国产精品毛片一区二区 | 日本护士毛茸茸高潮 | 精品无人区无码乱码毛片国产 | 无码av中文字幕免费放 | 内射巨臀欧美在线视频 | 丁香花在线影院观看在线播放 | 精品成人av一区二区三区 | 99视频精品全部免费免费观看 | 久久人人97超碰a片精品 | 国产亚洲精品久久久闺蜜 | 少妇愉情理伦片bd | 国产成人综合美国十次 | 漂亮人妻洗澡被公强 日日躁 | 亚洲色偷偷偷综合网 | 久久久久成人精品免费播放动漫 | 亚洲一区二区观看播放 | 亚洲精品国产精品乱码视色 | 六十路熟妇乱子伦 | 无码人妻精品一区二区三区不卡 | 玩弄少妇高潮ⅹxxxyw | а√资源新版在线天堂 | 狠狠cao日日穞夜夜穞av | 欧美成人家庭影院 | 奇米影视7777久久精品 | 亚洲国产精品无码久久久久高潮 | 免费人成在线视频无码 | 熟女俱乐部五十路六十路av | 粉嫩少妇内射浓精videos | 久久久久久av无码免费看大片 | 国产一区二区三区四区五区加勒比 | 夜先锋av资源网站 | aⅴ亚洲 日韩 色 图网站 播放 | 伊人久久大香线焦av综合影院 | 免费乱码人妻系列无码专区 | 无人区乱码一区二区三区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 性欧美牲交在线视频 | 狂野欧美性猛xxxx乱大交 | 亚洲精品国偷拍自产在线观看蜜桃 | 天海翼激烈高潮到腰振不止 | 波多野结衣高清一区二区三区 | 欧美黑人巨大xxxxx | 亚洲va中文字幕无码久久不卡 | 青草青草久热国产精品 | 国产乱人伦av在线无码 | 久久99热只有频精品8 | 婷婷五月综合激情中文字幕 | 露脸叫床粗话东北少妇 | 国产av久久久久精东av | av无码不卡在线观看免费 | 精品久久8x国产免费观看 | 欧美兽交xxxx×视频 | 国产精品久久久午夜夜伦鲁鲁 | 四虎影视成人永久免费观看视频 | 精品 日韩 国产 欧美 视频 | 美女极度色诱视频国产 | 久久综合狠狠综合久久综合88 | 日韩精品无码免费一区二区三区 | 暴力强奷在线播放无码 | 亚洲色偷偷男人的天堂 | 欧美激情一区二区三区成人 | 欧美日本免费一区二区三区 | 秋霞特色aa大片 | а√天堂www在线天堂小说 | 欧美日韩视频无码一区二区三 | 国产精品久久久久影院嫩草 | 大肉大捧一进一出视频出来呀 | 福利一区二区三区视频在线观看 | 无码精品人妻一区二区三区av | 国产成人久久精品流白浆 | 欧美精品免费观看二区 | 日本又色又爽又黄的a片18禁 | 国产精品无码久久av | 国产成人av免费观看 | 午夜精品久久久久久久 | 丰满人妻翻云覆雨呻吟视频 | 国产在线精品一区二区三区直播 | 人人澡人人透人人爽 | 中文字幕无码视频专区 | 国产精品自产拍在线观看 | 久久人妻内射无码一区三区 | 女人高潮内射99精品 | 精品少妇爆乳无码av无码专区 | 亚洲精品国产精品乱码不卡 | 亚洲中文字幕av在天堂 | 中文久久乱码一区二区 | 午夜免费福利小电影 | 日日摸日日碰夜夜爽av | 99视频精品全部免费免费观看 | 欧美精品无码一区二区三区 | 中文字幕无码乱人伦 | 久久国产劲爆∧v内射 | 我要看www免费看插插视频 | 色婷婷香蕉在线一区二区 | 久久无码人妻影院 | 亚洲色欲久久久综合网东京热 | 亚洲一区二区观看播放 | 俺去俺来也www色官网 | 国产乱人偷精品人妻a片 | 成人精品视频一区二区三区尤物 | 精品国产一区二区三区av 性色 | 亚洲狠狠婷婷综合久久 | 国产偷自视频区视频 | 色欲久久久天天天综合网精品 | 无码人妻黑人中文字幕 | 色婷婷久久一区二区三区麻豆 | 老司机亚洲精品影院无码 | 欧美性猛交内射兽交老熟妇 | 国产精品亚洲一区二区三区喷水 | 在线观看免费人成视频 | 久久久久人妻一区精品色欧美 | 国产女主播喷水视频在线观看 | 欧美人与禽猛交狂配 | 国产熟女一区二区三区四区五区 | 免费乱码人妻系列无码专区 | 人妻少妇被猛烈进入中文字幕 | 国产精品久久久久9999小说 | aa片在线观看视频在线播放 | 色情久久久av熟女人妻网站 | 性色欲情网站iwww九文堂 | 波多野结衣aⅴ在线 | 亚洲中文字幕在线无码一区二区 | 精品人妻人人做人人爽夜夜爽 | 丰满人妻翻云覆雨呻吟视频 | 亚洲经典千人经典日产 | 亚洲一区二区观看播放 | 色综合久久网 | 人妻与老人中文字幕 | 俄罗斯老熟妇色xxxx | 丰满岳乱妇在线观看中字无码 | 又大又黄又粗又爽的免费视频 | 国产高清av在线播放 | 日本成熟视频免费视频 | 无码人妻黑人中文字幕 | 日本一区二区三区免费高清 | 丰满人妻一区二区三区免费视频 | 成人欧美一区二区三区 | 色婷婷综合激情综在线播放 | 久久久久亚洲精品男人的天堂 | 中文字幕av无码一区二区三区电影 | 鲁鲁鲁爽爽爽在线视频观看 | 夜精品a片一区二区三区无码白浆 | 国产亚洲精品久久久久久大师 | 国产激情综合五月久久 | 中文无码成人免费视频在线观看 | 99er热精品视频 | 久久人人爽人人爽人人片av高清 | 麻豆精品国产精华精华液好用吗 | 亚洲阿v天堂在线 | 亚洲の无码国产の无码影院 | 人人妻人人澡人人爽人人精品 | 中文字幕人妻丝袜二区 | 精品无码一区二区三区爱欲 | 麻豆成人精品国产免费 | 精品国产麻豆免费人成网站 | 东京热无码av男人的天堂 | 亚洲欧美精品伊人久久 | 丰满诱人的人妻3 | 久久 国产 尿 小便 嘘嘘 | 无码中文字幕色专区 | 波多野42部无码喷潮在线 | 98国产精品综合一区二区三区 | 熟妇激情内射com | 日日噜噜噜噜夜夜爽亚洲精品 | 久久99精品久久久久久动态图 | 亚洲 高清 成人 动漫 | 乱码午夜-极国产极内射 | a在线观看免费网站大全 | а天堂中文在线官网 | 精品一二三区久久aaa片 | 国产一区二区三区四区五区加勒比 | 色窝窝无码一区二区三区色欲 | 日韩成人一区二区三区在线观看 | 色 综合 欧美 亚洲 国产 | 熟妇女人妻丰满少妇中文字幕 | 一个人看的www免费视频在线观看 | 国产一区二区不卡老阿姨 | 日韩av无码中文无码电影 | 99久久婷婷国产综合精品青草免费 | 夜夜影院未满十八勿进 | 无码av岛国片在线播放 | 免费国产成人高清在线观看网站 | 国产精品久久国产精品99 | 麻豆果冻传媒2021精品传媒一区下载 | 99精品久久毛片a片 | 亚洲精品久久久久avwww潮水 | 精品人妻人人做人人爽 | 欧美日本免费一区二区三区 | 国产精品丝袜黑色高跟鞋 | 欧美 亚洲 国产 另类 | 兔费看少妇性l交大片免费 | 亚洲毛片av日韩av无码 | 天天躁夜夜躁狠狠是什么心态 | 蜜臀aⅴ国产精品久久久国产老师 | 又紧又大又爽精品一区二区 | 国产人妻精品午夜福利免费 | 玩弄人妻少妇500系列视频 | 大乳丰满人妻中文字幕日本 | 波多野结衣高清一区二区三区 | 亚洲色成人中文字幕网站 | 黑人玩弄人妻中文在线 | 波多野结衣高清一区二区三区 | 熟妇人妻无码xxx视频 | 婷婷色婷婷开心五月四房播播 | 亚洲色欲久久久综合网东京热 | 久久99精品久久久久久动态图 | 亚洲の无码国产の无码步美 | 国产 浪潮av性色四虎 | 日韩亚洲欧美精品综合 | 最近中文2019字幕第二页 | 自拍偷自拍亚洲精品10p | 久久精品一区二区三区四区 | 九九在线中文字幕无码 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产深夜福利视频在线 | 小sao货水好多真紧h无码视频 | 内射后入在线观看一区 | 性生交大片免费看l | 又大又硬又爽免费视频 | 午夜无码人妻av大片色欲 | 日韩精品无码一区二区中文字幕 | 精品国产国产综合精品 | 国产成人精品久久亚洲高清不卡 | 99久久99久久免费精品蜜桃 | 亚洲欧美国产精品久久 | 国产精品第一区揄拍无码 | 欧美国产日产一区二区 | 久久亚洲日韩精品一区二区三区 | 麻豆成人精品国产免费 | 中文字幕 人妻熟女 | 日本熟妇浓毛 | 一二三四在线观看免费视频 | 性开放的女人aaa片 | 久久天天躁夜夜躁狠狠 | 中文字幕av无码一区二区三区电影 | 女人被男人爽到呻吟的视频 | 亚洲精品欧美二区三区中文字幕 | 沈阳熟女露脸对白视频 | 蜜臀av在线播放 久久综合激激的五月天 | 高清无码午夜福利视频 | 国产精品对白交换视频 | 性欧美牲交xxxxx视频 | 蜜臀aⅴ国产精品久久久国产老师 | 日日夜夜撸啊撸 | 55夜色66夜色国产精品视频 | 亚洲欧美色中文字幕在线 | 无码国产乱人伦偷精品视频 | 奇米影视7777久久精品人人爽 | 久久国语露脸国产精品电影 | 久久久久免费精品国产 | 久久无码中文字幕免费影院蜜桃 | 国产综合色产在线精品 | 欧美老熟妇乱xxxxx | 久久天天躁狠狠躁夜夜免费观看 | 在线播放免费人成毛片乱码 | 亚洲人成网站免费播放 | 亚洲熟妇色xxxxx欧美老妇y | 夫妻免费无码v看片 | 18精品久久久无码午夜福利 | 天堂亚洲2017在线观看 | 成人三级无码视频在线观看 | 无人区乱码一区二区三区 | 激情人妻另类人妻伦 | 国产精品久久久久9999小说 | 中文字幕无线码 | 在线观看国产午夜福利片 | 成人一区二区免费视频 | 图片小说视频一区二区 | 大地资源网第二页免费观看 | 无码精品人妻一区二区三区av | 国产精品久久久一区二区三区 | 日本熟妇人妻xxxxx人hd | 人人妻人人澡人人爽欧美一区 | 国产亚洲人成在线播放 | 精品国精品国产自在久国产87 | 久久久久免费看成人影片 | 无套内谢的新婚少妇国语播放 | 双乳奶水饱满少妇呻吟 | 无套内谢老熟女 | 亚洲成a人片在线观看无码3d | 亚洲人成网站色7799 | 日本丰满护士爆乳xxxx | 伊人久久大香线焦av综合影院 | 欧美国产日韩久久mv | 国精产品一品二品国精品69xx | 女人和拘做爰正片视频 | 中文字幕精品av一区二区五区 | 国产精品自产拍在线观看 | 两性色午夜免费视频 | 任你躁在线精品免费 | 国产亚洲美女精品久久久2020 | 18精品久久久无码午夜福利 | 欧美freesex黑人又粗又大 | 亚洲精品国偷拍自产在线麻豆 | 国产人妻人伦精品 | 亚洲精品中文字幕乱码 | 欧美 丝袜 自拍 制服 另类 | 久久精品国产亚洲精品 | 高清国产亚洲精品自在久久 | 久久精品中文字幕大胸 | 久久精品99久久香蕉国产色戒 | 图片小说视频一区二区 | 国产一区二区三区精品视频 | 天天做天天爱天天爽综合网 | 真人与拘做受免费视频一 | 欧洲极品少妇 | 麻豆成人精品国产免费 | 国内揄拍国内精品少妇国语 | 丰腴饱满的极品熟妇 | 一个人看的视频www在线 | 欧美 丝袜 自拍 制服 另类 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产午夜精品一区二区三区嫩草 | 国精品人妻无码一区二区三区蜜柚 | 嫩b人妻精品一区二区三区 | 国内少妇偷人精品视频免费 | 欧洲精品码一区二区三区免费看 | 午夜肉伦伦影院 | 欧美性生交活xxxxxdddd | 国产精品久久久久9999小说 | 亚洲日韩一区二区三区 | 国产精品内射视频免费 | 白嫩日本少妇做爰 | 日本xxxx色视频在线观看免费 | 国产精品无码久久av | 大肉大捧一进一出好爽视频 | 中文字幕无码乱人伦 | 一本久道高清无码视频 | 国产猛烈高潮尖叫视频免费 | 亚洲色无码一区二区三区 | 丰满岳乱妇在线观看中字无码 | 亚洲精品久久久久久一区二区 | 亚洲色欲久久久综合网东京热 | 欧美人妻一区二区三区 | 亚洲国产精品美女久久久久 | 无码国产乱人伦偷精品视频 | 玩弄中年熟妇正在播放 | 西西人体www44rt大胆高清 | 伊人久久大香线蕉午夜 | 300部国产真实乱 | 秋霞特色aa大片 | 成人一区二区免费视频 | 国产精品人妻一区二区三区四 | 97精品国产97久久久久久免费 | 中文字幕亚洲情99在线 | 99久久无码一区人妻 | 一本久久a久久精品vr综合 | 97夜夜澡人人爽人人喊中国片 | 大胆欧美熟妇xx | 无套内射视频囯产 | 精品人妻人人做人人爽 | 欧美肥老太牲交大战 | 天干天干啦夜天干天2017 | 国产亚洲欧美在线专区 | 久久精品中文字幕一区 | 亚洲色大成网站www国产 | 久久综合激激的五月天 | 任你躁国产自任一区二区三区 | 一本久久伊人热热精品中文字幕 | 一个人免费观看的www视频 | 人人爽人人澡人人人妻 | 少妇太爽了在线观看 | 在线观看国产午夜福利片 | 成年女人永久免费看片 | 欧美日韩亚洲国产精品 | 中文字幕日韩精品一区二区三区 | 丰满人妻翻云覆雨呻吟视频 | 色欲av亚洲一区无码少妇 | 国产办公室秘书无码精品99 | 亚洲色大成网站www | 亚洲人成影院在线无码按摩店 | 日本乱人伦片中文三区 | 国产明星裸体无码xxxx视频 | 精品久久久久久人妻无码中文字幕 | 久久精品女人天堂av免费观看 | 日日摸天天摸爽爽狠狠97 | 性做久久久久久久免费看 | 日本在线高清不卡免费播放 | 国产亚av手机在线观看 | 无码精品人妻一区二区三区av | 精品无人区无码乱码毛片国产 | 狠狠色丁香久久婷婷综合五月 | 亚洲毛片av日韩av无码 | 久久精品国产大片免费观看 | 九月婷婷人人澡人人添人人爽 | 乱中年女人伦av三区 | 亚洲七七久久桃花影院 | 中文字幕乱码人妻二区三区 | 领导边摸边吃奶边做爽在线观看 | 荫蒂被男人添的好舒服爽免费视频 | 色欲人妻aaaaaaa无码 | 久久综合久久自在自线精品自 | 久久精品人人做人人综合 | 内射老妇bbwx0c0ck | 亚洲国产精品成人久久蜜臀 | 日韩人妻无码一区二区三区久久99 | 伊人久久大香线蕉av一区二区 | 日欧一片内射va在线影院 | 国产乱人无码伦av在线a | 精品成人av一区二区三区 | 国产另类ts人妖一区二区 | 国产精品亚洲а∨无码播放麻豆 | 亚洲中文字幕av在天堂 | 亚洲欧美色中文字幕在线 | 极品尤物被啪到呻吟喷水 | 免费看男女做好爽好硬视频 | 激情内射亚州一区二区三区爱妻 | 思思久久99热只有频精品66 | 无码国模国产在线观看 | 欧美日韩视频无码一区二区三 | 图片小说视频一区二区 | 亚洲春色在线视频 | 人妻人人添人妻人人爱 | 亚洲中文字幕久久无码 | 啦啦啦www在线观看免费视频 | 成人免费视频视频在线观看 免费 | 东京一本一道一二三区 | 国产精品欧美成人 | 免费无码肉片在线观看 | 国内精品久久毛片一区二区 | 宝宝好涨水快流出来免费视频 | 学生妹亚洲一区二区 | 女人被男人爽到呻吟的视频 | 久精品国产欧美亚洲色aⅴ大片 | 夜夜影院未满十八勿进 | 无码人妻丰满熟妇区五十路百度 | 亚洲中文字幕乱码av波多ji | 国产99久久精品一区二区 | 动漫av网站免费观看 | 午夜嘿嘿嘿影院 | 丰满诱人的人妻3 | 久久国产精品萌白酱免费 | 未满小14洗澡无码视频网站 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 六月丁香婷婷色狠狠久久 | 无码人妻av免费一区二区三区 | 欧美性猛交内射兽交老熟妇 | 国产在线一区二区三区四区五区 | 少妇被黑人到高潮喷出白浆 | 婷婷五月综合激情中文字幕 | 在线亚洲高清揄拍自拍一品区 | 日本成熟视频免费视频 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 亚洲乱码日产精品bd | 日韩精品成人一区二区三区 | 人人爽人人澡人人高潮 | 亚洲国产精品毛片av不卡在线 | 小sao货水好多真紧h无码视频 | 国产乱码精品一品二品 | 国产精品亚洲一区二区三区喷水 | 欧美性生交xxxxx久久久 | 精品国产aⅴ无码一区二区 | 中文字幕无码日韩专区 | 人妻少妇被猛烈进入中文字幕 | 麻豆果冻传媒2021精品传媒一区下载 | 少妇被粗大的猛进出69影院 | 亚洲色大成网站www国产 | 亚洲日韩av片在线观看 | 99久久精品国产一区二区蜜芽 | 在线播放亚洲第一字幕 | а√天堂www在线天堂小说 | 亚洲欧美国产精品久久 | 成人欧美一区二区三区黑人 | 我要看www免费看插插视频 | 国产一区二区三区日韩精品 | 成熟人妻av无码专区 | 全黄性性激高免费视频 | 少妇高潮喷潮久久久影院 | 国产又爽又黄又刺激的视频 | 中文久久乱码一区二区 | 日本欧美一区二区三区乱码 | 成 人影片 免费观看 | 日本欧美一区二区三区乱码 | 亚洲 高清 成人 动漫 | 亚洲国精产品一二二线 | 小鲜肉自慰网站xnxx | 曰本女人与公拘交酡免费视频 | √天堂资源地址中文在线 | 男女下面进入的视频免费午夜 | 99国产精品白浆在线观看免费 | 嫩b人妻精品一区二区三区 | 日韩人妻系列无码专区 | 97夜夜澡人人爽人人喊中国片 | 老熟女重囗味hdxx69 | 国产午夜福利亚洲第一 | 国产人妻精品一区二区三区 | 色欲久久久天天天综合网精品 | 色诱久久久久综合网ywww | 亚洲国产精品久久人人爱 | 激情国产av做激情国产爱 | 中文字幕无码av激情不卡 | 亚洲色成人中文字幕网站 | 最新国产乱人伦偷精品免费网站 | 又湿又紧又大又爽a视频国产 | 麻豆av传媒蜜桃天美传媒 | 国产一区二区不卡老阿姨 | 麻豆国产人妻欲求不满 | 亚洲国产欧美国产综合一区 | 全黄性性激高免费视频 | 扒开双腿吃奶呻吟做受视频 | 美女极度色诱视频国产 | 国产在线精品一区二区三区直播 | 亚洲精品国产第一综合99久久 | 99久久精品无码一区二区毛片 | 亚洲精品国产第一综合99久久 | 97无码免费人妻超级碰碰夜夜 | 美女黄网站人色视频免费国产 | 日韩无套无码精品 | 狂野欧美性猛xxxx乱大交 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | а√天堂www在线天堂小说 | 蜜桃无码一区二区三区 | 日韩少妇内射免费播放 | 曰韩少妇内射免费播放 | 亚洲爆乳大丰满无码专区 | 国产精品理论片在线观看 | 亚洲区欧美区综合区自拍区 | 特黄特色大片免费播放器图片 | 亚洲男女内射在线播放 | 2020久久香蕉国产线看观看 | 国产精品亚洲专区无码不卡 | 荫蒂添的好舒服视频囗交 | 国产精华av午夜在线观看 | 久久精品人人做人人综合 | 一本精品99久久精品77 | 亚洲日本va中文字幕 | 97无码免费人妻超级碰碰夜夜 | 人妻少妇精品无码专区动漫 | 高中生自慰www网站 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产亚洲精品久久久久久大师 | 久久久久久a亚洲欧洲av冫 | 国产免费久久精品国产传媒 | 日本精品人妻无码免费大全 | 欧美日韩在线亚洲综合国产人 | 无码人妻久久一区二区三区不卡 | 内射后入在线观看一区 | 成人aaa片一区国产精品 | 高中生自慰www网站 | 色欲久久久天天天综合网精品 | 无码精品人妻一区二区三区av | 人妻少妇精品视频专区 | 极品嫩模高潮叫床 | 国产av一区二区三区最新精品 | 欧美大屁股xxxxhd黑色 | 又大又黄又粗又爽的免费视频 | 一本色道婷婷久久欧美 | 88国产精品欧美一区二区三区 | 亚洲国产成人a精品不卡在线 | 丰满少妇弄高潮了www | 日韩 欧美 动漫 国产 制服 | 国产成人无码av一区二区 | 久久99精品久久久久久 | 麻豆国产人妻欲求不满 | 黑人玩弄人妻中文在线 | 国产熟妇高潮叫床视频播放 | 国产精品国产三级国产专播 | 人人澡人人透人人爽 | 久久综合九色综合97网 | 亚洲爆乳无码专区 | 日韩人妻无码一区二区三区久久99 | 免费无码肉片在线观看 | 精品国产av色一区二区深夜久久 | 久久久久久a亚洲欧洲av冫 | 午夜性刺激在线视频免费 | 无码国模国产在线观看 | 国产香蕉尹人综合在线观看 | 国产特级毛片aaaaaaa高清 | 国产精品18久久久久久麻辣 | 亚洲日本一区二区三区在线 | 55夜色66夜色国产精品视频 | 99久久亚洲精品无码毛片 | 国产精品99爱免费视频 | 亚洲日本在线电影 | 亚洲乱码日产精品bd | 日本在线高清不卡免费播放 | 欧美喷潮久久久xxxxx | 宝宝好涨水快流出来免费视频 | 男女下面进入的视频免费午夜 | 久久精品国产日本波多野结衣 | 免费播放一区二区三区 | 67194成是人免费无码 | 欧美35页视频在线观看 | 久久精品国产日本波多野结衣 | 精品一区二区不卡无码av | 一本色道久久综合亚洲精品不卡 | 午夜时刻免费入口 | 美女张开腿让人桶 | 久久视频在线观看精品 | 国产性生大片免费观看性 | 精品乱子伦一区二区三区 | 无码国产乱人伦偷精品视频 | 男女猛烈xx00免费视频试看 | 动漫av一区二区在线观看 | 美女黄网站人色视频免费国产 | 夜夜影院未满十八勿进 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 亚洲国产成人av在线观看 | 国产精品无码成人午夜电影 | 中文字幕乱码人妻二区三区 | 人人澡人人透人人爽 | 国产真实伦对白全集 | 亚拍精品一区二区三区探花 | 亚洲一区av无码专区在线观看 | 强辱丰满人妻hd中文字幕 | 成人无码视频在线观看网站 | 99久久久无码国产aaa精品 | 国产色在线 | 国产 | 亚洲の无码国产の无码影院 | 2019nv天堂香蕉在线观看 | 国产亚洲精品久久久久久 | 精品国产一区av天美传媒 | 久久精品女人天堂av免费观看 | √8天堂资源地址中文在线 | 鲁鲁鲁爽爽爽在线视频观看 | 成人欧美一区二区三区黑人免费 | 久久久婷婷五月亚洲97号色 | www国产亚洲精品久久网站 | 亚洲成av人片在线观看无码不卡 | 亚洲自偷自偷在线制服 | 女人被男人躁得好爽免费视频 | 乱人伦中文视频在线观看 | 欧美性猛交xxxx富婆 | 暴力强奷在线播放无码 | 伊人久久大香线蕉av一区二区 | 亚洲精品综合五月久久小说 | 国产成人无码午夜视频在线观看 | 日本一卡二卡不卡视频查询 | 亚洲一区av无码专区在线观看 | 亚洲а∨天堂久久精品2021 | 久久精品国产99精品亚洲 | 日本精品人妻无码免费大全 | 精品水蜜桃久久久久久久 | 欧美肥老太牲交大战 | 亚洲综合在线一区二区三区 | 免费人成在线观看网站 | 在线播放免费人成毛片乱码 | 亚洲爆乳无码专区 | 国产美女极度色诱视频www | 亚洲国精产品一二二线 | 国产精品国产自线拍免费软件 | 人人妻人人澡人人爽人人精品浪潮 | 欧洲精品码一区二区三区免费看 | 三级4级全黄60分钟 | aⅴ在线视频男人的天堂 | 亚洲乱码中文字幕在线 | 秋霞成人午夜鲁丝一区二区三区 | 国产熟妇另类久久久久 | 水蜜桃亚洲一二三四在线 | 伦伦影院午夜理论片 | 丰满少妇弄高潮了www | 极品嫩模高潮叫床 | 久久午夜无码鲁丝片秋霞 | 亚洲精品中文字幕久久久久 | 天堂а√在线中文在线 | 亚洲国产精品无码久久久久高潮 | 久久久精品456亚洲影院 | 大色综合色综合网站 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产精品久久久久无码av色戒 | 综合人妻久久一区二区精品 | 无码人妻精品一区二区三区下载 | 青青久在线视频免费观看 | 久久精品国产日本波多野结衣 | 蜜桃无码一区二区三区 | 性欧美熟妇videofreesex | 成 人影片 免费观看 | 国产免费久久精品国产传媒 | 青草青草久热国产精品 | 人人妻人人澡人人爽欧美一区九九 | 最近中文2019字幕第二页 | 国産精品久久久久久久 | 国产在线一区二区三区四区五区 | 亚洲中文字幕无码中文字在线 | 国产精品怡红院永久免费 | 77777熟女视频在线观看 а天堂中文在线官网 | 性做久久久久久久免费看 | 亚洲一区av无码专区在线观看 | 国内少妇偷人精品视频免费 | 亚洲成av人在线观看网址 | 亚洲精品久久久久avwww潮水 | 久久99精品久久久久久 | 国产情侣作爱视频免费观看 | 亚洲综合在线一区二区三区 | 老司机亚洲精品影院无码 | 免费人成在线视频无码 | 亚洲色欲久久久综合网东京热 | 亚洲欧美日韩成人高清在线一区 | 国产午夜无码视频在线观看 | 丝袜足控一区二区三区 | 亚洲国产精品久久人人爱 | 99久久婷婷国产综合精品青草免费 | 在教室伦流澡到高潮hnp视频 | 亚洲aⅴ无码成人网站国产app | 亚洲日韩av一区二区三区四区 | 97精品人妻一区二区三区香蕉 | 国产午夜精品一区二区三区嫩草 | 国产无遮挡吃胸膜奶免费看 | 国产农村妇女高潮大叫 | 国产免费久久久久久无码 | 人妻夜夜爽天天爽三区 | 国产成人久久精品流白浆 | 午夜丰满少妇性开放视频 | 好爽又高潮了毛片免费下载 | 美女黄网站人色视频免费国产 | av小次郎收藏 | 欧美 日韩 亚洲 在线 | 国内精品人妻无码久久久影院蜜桃 | 色欲综合久久中文字幕网 | 久久伊人色av天堂九九小黄鸭 | 久久综合激激的五月天 | 丰满人妻精品国产99aⅴ | 妺妺窝人体色www在线小说 | 国产精品嫩草久久久久 | 人人妻在人人 | 免费国产成人高清在线观看网站 | 国产人妻精品午夜福利免费 | 国产乱人无码伦av在线a | a在线亚洲男人的天堂 | 在线精品亚洲一区二区 | 少妇被黑人到高潮喷出白浆 | 欧美人与禽zoz0性伦交 | 精品无码一区二区三区爱欲 | 国产av久久久久精东av | 女人被男人爽到呻吟的视频 | 国产色视频一区二区三区 | 狠狠亚洲超碰狼人久久 | 强辱丰满人妻hd中文字幕 | 国产精品久久久久7777 | 日本www一道久久久免费榴莲 | 欧美日韩久久久精品a片 | 中文精品无码中文字幕无码专区 | 国产激情综合五月久久 | 日本www一道久久久免费榴莲 | 国产极品美女高潮无套在线观看 | 色一情一乱一伦 | 中文字幕亚洲情99在线 | 午夜精品久久久内射近拍高清 | 日本成熟视频免费视频 | av在线亚洲欧洲日产一区二区 | 无码人妻精品一区二区三区不卡 | 亚洲精品久久久久久久久久久 | 欧洲熟妇精品视频 | 扒开双腿吃奶呻吟做受视频 | 午夜福利电影 | 久久午夜无码鲁丝片秋霞 | 国产精品永久免费视频 | 又色又爽又黄的美女裸体网站 | 国产无av码在线观看 | 国内精品久久毛片一区二区 | 精品国产一区二区三区av 性色 | 熟妇女人妻丰满少妇中文字幕 | 捆绑白丝粉色jk震动捧喷白浆 | 精品久久久中文字幕人妻 | 国産精品久久久久久久 | 亚洲午夜福利在线观看 | 在线视频网站www色 | 色欲综合久久中文字幕网 | 国产手机在线αⅴ片无码观看 | 国产精品.xx视频.xxtv | 国精产品一区二区三区 | 国产精品久久久久久久9999 | 香港三级日本三级妇三级 | 无码福利日韩神码福利片 | 久久精品99久久香蕉国产色戒 | 久久精品一区二区三区四区 | 国产凸凹视频一区二区 | 夜夜高潮次次欢爽av女 | 亚洲欧美中文字幕5发布 | 欧美人与物videos另类 | 亚洲欧洲中文日韩av乱码 | 一本大道伊人av久久综合 | 丰满诱人的人妻3 | 国产成人一区二区三区在线观看 | 又大又黄又粗又爽的免费视频 | 搡女人真爽免费视频大全 | 麻豆国产人妻欲求不满谁演的 | 国产免费久久精品国产传媒 | 性欧美videos高清精品 | 日本xxxx色视频在线观看免费 | 欧美freesex黑人又粗又大 | 久久国产劲爆∧v内射 | 色欲av亚洲一区无码少妇 | 成人动漫在线观看 | 午夜无码人妻av大片色欲 | 中文字幕av无码一区二区三区电影 | 成人免费视频一区二区 | 久久精品中文字幕大胸 | 色婷婷综合激情综在线播放 | 波多野结衣aⅴ在线 | 极品嫩模高潮叫床 | av香港经典三级级 在线 | 久久久久久久女国产乱让韩 | 中文字幕中文有码在线 | 丰满诱人的人妻3 | 久久精品国产99精品亚洲 | 夜夜高潮次次欢爽av女 | 国产偷自视频区视频 | 中文字幕乱码人妻无码久久 | 婷婷五月综合缴情在线视频 | 国产成人无码av在线影院 | 牲欲强的熟妇农村老妇女 | 亚洲 日韩 欧美 成人 在线观看 | 中文字幕亚洲情99在线 | 国产手机在线αⅴ片无码观看 | 久久久久久久人妻无码中文字幕爆 | 人妻天天爽夜夜爽一区二区 | 久久综合狠狠综合久久综合88 | 欧洲vodafone精品性 | 男女爱爱好爽视频免费看 | 老熟女重囗味hdxx69 | 在线视频网站www色 | 亚洲熟熟妇xxxx | 欧洲熟妇精品视频 | 亚洲另类伦春色综合小说 | 中文字幕 亚洲精品 第1页 | 国产精品无码久久av | 国产熟女一区二区三区四区五区 | 久久婷婷五月综合色国产香蕉 | 国产精品久久久av久久久 | 亚洲精品一区二区三区在线观看 | 精品一区二区三区波多野结衣 | 精品国产精品久久一区免费式 | 国产精品99久久精品爆乳 | 日日摸日日碰夜夜爽av | 一本久久伊人热热精品中文字幕 | 中国大陆精品视频xxxx | 国产超级va在线观看视频 | 天堂亚洲免费视频 | 在线欧美精品一区二区三区 | 精品国产国产综合精品 | 99精品视频在线观看免费 | 性生交大片免费看女人按摩摩 | 国内揄拍国内精品人妻 | 欧美人与禽zoz0性伦交 | 国产精品亚洲五月天高清 | 乱人伦人妻中文字幕无码 | 色偷偷人人澡人人爽人人模 | 一区二区三区乱码在线 | 欧洲 | 国产suv精品一区二区五 | 中文字幕人妻无码一夲道 | 久久久精品欧美一区二区免费 | 天天躁夜夜躁狠狠是什么心态 | 亚洲精品欧美二区三区中文字幕 | 国产乡下妇女做爰 | 国产精品久久久久影院嫩草 | 亚洲色大成网站www国产 | 国产成人精品优优av | 国产色在线 | 国产 | 无码毛片视频一区二区本码 | 欧美三级不卡在线观看 | 澳门永久av免费网站 | 国产成人综合在线女婷五月99播放 | 国产乱人伦偷精品视频 | 日日噜噜噜噜夜夜爽亚洲精品 | 成人综合网亚洲伊人 | 无码人妻久久一区二区三区不卡 | 国产熟女一区二区三区四区五区 | 国产精品无码mv在线观看 | 夜夜夜高潮夜夜爽夜夜爰爰 | 欧美成人午夜精品久久久 | 国产精品亚洲一区二区三区喷水 | 国产精品沙发午睡系列 | 亚洲欧美精品伊人久久 | 国产色xx群视频射精 | 中文字幕无码乱人伦 | 亚洲精品一区二区三区大桥未久 | 午夜理论片yy44880影院 | 国产农村乱对白刺激视频 | 国产小呦泬泬99精品 | 国产乱人伦偷精品视频 | 午夜精品一区二区三区在线观看 | 国产97人人超碰caoprom | 5858s亚洲色大成网站www | 熟女体下毛毛黑森林 | 欧美xxxxx精品 | 欧美黑人性暴力猛交喷水 | 又大又黄又粗又爽的免费视频 | 在教室伦流澡到高潮hnp视频 | 国产免费无码一区二区视频 | 亚洲 高清 成人 动漫 | 亚洲精品美女久久久久久久 | 国产精品视频免费播放 | 欧美xxxxx精品 | 伦伦影院午夜理论片 | 精品无码成人片一区二区98 | 青青草原综合久久大伊人精品 | 国产情侣作爱视频免费观看 | 免费人成网站视频在线观看 | 国产又爽又猛又粗的视频a片 | 久久久久久a亚洲欧洲av冫 | 乱人伦中文视频在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 欧美日本精品一区二区三区 | 玩弄中年熟妇正在播放 | 国产亚洲精品久久久久久大师 | 青草青草久热国产精品 | 成人无码视频在线观看网站 | 亚洲一区二区三区国产精华液 | 无码人妻久久一区二区三区不卡 | 少妇愉情理伦片bd | 国产成人综合美国十次 | 国产精品-区区久久久狼 | 强奷人妻日本中文字幕 | 国产精品无码一区二区三区不卡 | 国产艳妇av在线观看果冻传媒 | 国模大胆一区二区三区 | 亚洲第一无码av无码专区 | 亚洲国产精品毛片av不卡在线 | 国产精品美女久久久久av爽李琼 | 国内精品久久久久久中文字幕 | 国产精品久久久av久久久 | 精品无码av一区二区三区 | 亚洲国产精品无码久久久久高潮 | 成人无码影片精品久久久 | 国产区女主播在线观看 | 色综合久久网 | 久久精品一区二区三区四区 | 久久久久久久人妻无码中文字幕爆 | 亚洲一区二区三区在线观看网站 | 国产三级久久久精品麻豆三级 | 亚洲呦女专区 | 亚洲精品中文字幕久久久久 | 久久综合激激的五月天 | 久久亚洲精品成人无码 | 领导边摸边吃奶边做爽在线观看 | 麻豆md0077饥渴少妇 | 国产av剧情md精品麻豆 | 99久久99久久免费精品蜜桃 | 无码国产色欲xxxxx视频 | 国产精品-区区久久久狼 | 亚洲热妇无码av在线播放 | 色综合久久88色综合天天 | 国产 精品 自在自线 | 亚洲熟妇色xxxxx亚洲 | 国产口爆吞精在线视频 | 久久综合激激的五月天 | 性欧美牲交在线视频 | 十八禁真人啪啪免费网站 | 亚洲中文字幕在线无码一区二区 | 黄网在线观看免费网站 | 人人妻人人澡人人爽欧美一区 | а√天堂www在线天堂小说 | 无码中文字幕色专区 | 牲交欧美兽交欧美 | 精品无码成人片一区二区98 | 国产sm调教视频在线观看 | 人妻无码αv中文字幕久久琪琪布 | 亚洲欧洲日本无在线码 | 动漫av网站免费观看 | 老司机亚洲精品影院无码 | 99国产精品白浆在线观看免费 | 美女张开腿让人桶 | 精品水蜜桃久久久久久久 | 成人无码精品一区二区三区 | 色婷婷香蕉在线一区二区 | 亚洲日韩一区二区三区 | 国产无套内射久久久国产 | 欧美老妇与禽交 | 午夜福利电影 | 波多野结衣乳巨码无在线观看 | 国产高清av在线播放 | 大色综合色综合网站 | 亚洲人成影院在线无码按摩店 | 亚洲人成影院在线观看 | 国产av人人夜夜澡人人爽麻豆 | 亚洲狠狠色丁香婷婷综合 | 亚洲欧美综合区丁香五月小说 | 日韩人妻少妇一区二区三区 | 夜精品a片一区二区三区无码白浆 | 欧美亚洲日韩国产人成在线播放 | 国产成人av免费观看 | 久久国产精品萌白酱免费 | 2020久久超碰国产精品最新 | 日本xxxx色视频在线观看免费 | 一本久道久久综合婷婷五月 | 亚洲日韩中文字幕在线播放 | 成 人影片 免费观看 | 天堂亚洲免费视频 | 日本一卡二卡不卡视频查询 | 极品尤物被啪到呻吟喷水 | 青春草在线视频免费观看 | 亚洲一区二区三区无码久久 | 麻豆国产人妻欲求不满谁演的 | 亚洲色欲久久久综合网东京热 | 樱花草在线播放免费中文 | 成人无码视频在线观看网站 | 在线精品亚洲一区二区 | 无码国产激情在线观看 | 成人动漫在线观看 | 亚洲自偷精品视频自拍 | 少妇无码一区二区二三区 | 国产内射老熟女aaaa | 国内精品久久久久久中文字幕 | 日韩欧美群交p片內射中文 | 国产成人无码午夜视频在线观看 | 国产一区二区三区影院 | 亚洲中文字幕在线无码一区二区 | 在线精品亚洲一区二区 | 久久久久久a亚洲欧洲av冫 | 国产情侣作爱视频免费观看 | 国产成人精品视频ⅴa片软件竹菊 | 国产片av国语在线观看 | 亚洲国产日韩a在线播放 | 在线看片无码永久免费视频 | 国产在线精品一区二区高清不卡 | 男女下面进入的视频免费午夜 | 丰满少妇弄高潮了www | 国产成人无码av一区二区 | 国产乱码精品一品二品 | 欧美人与牲动交xxxx | 国产特级毛片aaaaaa高潮流水 | 亚洲欧美日韩国产精品一区二区 | 亚洲熟女一区二区三区 | 亚洲精品中文字幕乱码 | 中文字幕日产无线码一区 | 福利一区二区三区视频在线观看 | 国产高潮视频在线观看 | 日韩人妻无码中文字幕视频 | 无码国内精品人妻少妇 | 性啪啪chinese东北女人 | 久久视频在线观看精品 | 久久99热只有频精品8 | 日本va欧美va欧美va精品 | 亚洲综合另类小说色区 | 欧美黑人乱大交 | 国产人妻大战黑人第1集 | 国产内射爽爽大片视频社区在线 | 丰满人妻翻云覆雨呻吟视频 | 波多野结衣av一区二区全免费观看 | 精品 日韩 国产 欧美 视频 | 日韩成人一区二区三区在线观看 | 国产精品18久久久久久麻辣 | 少妇高潮喷潮久久久影院 | 亚洲欧美日韩成人高清在线一区 | 久久综合九色综合欧美狠狠 | 精品无码一区二区三区爱欲 | a在线观看免费网站大全 | 熟女俱乐部五十路六十路av | 久久 国产 尿 小便 嘘嘘 | 青草视频在线播放 | 久久国语露脸国产精品电影 | 中文字幕无线码免费人妻 | 国产精品二区一区二区aⅴ污介绍 | 男女作爱免费网站 | 久久午夜夜伦鲁鲁片无码免费 | 精品 日韩 国产 欧美 视频 | 熟妇人妻无乱码中文字幕 | 丰满人妻被黑人猛烈进入 | 国产香蕉尹人视频在线 | 狂野欧美性猛交免费视频 | 精品国精品国产自在久国产87 | 欧美精品一区二区精品久久 | 精品久久久久久亚洲精品 | 国产激情精品一区二区三区 | 国产精品亚洲lv粉色 | 国产精品久久久久久亚洲影视内衣 | 又粗又大又硬又长又爽 | 国产99久久精品一区二区 | 美女张开腿让人桶 | 国产片av国语在线观看 | 无码人妻少妇伦在线电影 | 日韩人妻少妇一区二区三区 | 99精品无人区乱码1区2区3区 | 日产国产精品亚洲系列 | 色妞www精品免费视频 | 亚洲小说春色综合另类 | 国精产品一品二品国精品69xx | 午夜嘿嘿嘿影院 | 国内精品一区二区三区不卡 | 亚洲国产欧美日韩精品一区二区三区 | 欧美人妻一区二区三区 | 六月丁香婷婷色狠狠久久 | 人妻体内射精一区二区三四 | 国产成人一区二区三区别 | 学生妹亚洲一区二区 | 青青草原综合久久大伊人精品 | 国内少妇偷人精品视频免费 | 最新国产乱人伦偷精品免费网站 | 一二三四社区在线中文视频 | 特级做a爰片毛片免费69 | 久久国产精品萌白酱免费 | 乱码av麻豆丝袜熟女系列 | 女人被男人躁得好爽免费视频 | 欧美精品国产综合久久 | 亚洲精品一区国产 | 亚洲成av人片在线观看无码不卡 | 久久亚洲精品中文字幕无男同 | 黑人粗大猛烈进出高潮视频 | 国产精品对白交换视频 | 免费无码午夜福利片69 | 国产精品久久久久影院嫩草 | 无码任你躁久久久久久久 | 无码人妻丰满熟妇区毛片18 | 无码av岛国片在线播放 | 中文字幕无码免费久久9一区9 | 国色天香社区在线视频 | 中文字幕乱码中文乱码51精品 | 爽爽影院免费观看 | 国产乱人伦偷精品视频 | 又大又黄又粗又爽的免费视频 | 免费男性肉肉影院 | 丰满少妇女裸体bbw | 日本护士xxxxhd少妇 | 国产精品-区区久久久狼 | 日韩欧美中文字幕公布 | 99riav国产精品视频 | 亚洲中文字幕av在天堂 | 精品国产麻豆免费人成网站 | 精品水蜜桃久久久久久久 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 18禁黄网站男男禁片免费观看 | 成人无码精品1区2区3区免费看 | 性色欲情网站iwww九文堂 | 大地资源网第二页免费观看 | 国精品人妻无码一区二区三区蜜柚 | 青青青手机频在线观看 | 国产乱人无码伦av在线a | 国精产品一品二品国精品69xx | 久在线观看福利视频 | 人人澡人人透人人爽 | 国产无套内射久久久国产 | 日本免费一区二区三区最新 | 欧美激情一区二区三区成人 | 国产av无码专区亚洲awww | 好屌草这里只有精品 | 亚洲综合无码久久精品综合 | 久久久久久a亚洲欧洲av冫 | 国产一区二区三区影院 | 亚洲精品午夜无码电影网 | 伊人久久大香线焦av综合影院 | 亚洲精品国产品国语在线观看 | 国产人妻人伦精品1国产丝袜 | www国产亚洲精品久久久日本 | 色 综合 欧美 亚洲 国产 | 双乳奶水饱满少妇呻吟 | 97夜夜澡人人双人人人喊 | 美女黄网站人色视频免费国产 | 国产成人av免费观看 | 精品人人妻人人澡人人爽人人 | 欧美怡红院免费全部视频 | 日本精品人妻无码77777 天堂一区人妻无码 | www国产亚洲精品久久久日本 | 露脸叫床粗话东北少妇 | 又大又黄又粗又爽的免费视频 | 国产深夜福利视频在线 | 日本爽爽爽爽爽爽在线观看免 | 亚洲综合色区中文字幕 | 国产成人精品视频ⅴa片软件竹菊 | 无码免费一区二区三区 | 亚洲综合伊人久久大杳蕉 | 日本一区二区三区免费播放 | 国产色视频一区二区三区 | 精品国偷自产在线 | 一本大道久久东京热无码av | 中文精品久久久久人妻不卡 | 激情人妻另类人妻伦 | 日本熟妇浓毛 | 国产亚洲日韩欧美另类第八页 | 久久99精品久久久久久动态图 | 久久精品成人欧美大片 | 日韩成人一区二区三区在线观看 | 一本久久a久久精品亚洲 | 麻豆国产丝袜白领秘书在线观看 | 一个人免费观看的www视频 | 色欲av亚洲一区无码少妇 | 欧美黑人乱大交 | 中文字幕亚洲情99在线 | 亚洲毛片av日韩av无码 | 特黄特色大片免费播放器图片 | 欧洲极品少妇 | 亚洲精品一区二区三区大桥未久 | 18无码粉嫩小泬无套在线观看 | 亚洲欧美日韩国产精品一区二区 | 日日天日日夜日日摸 | 欧美国产日韩久久mv | 国产亚洲精品久久久久久大师 | 丰满人妻翻云覆雨呻吟视频 | 免费播放一区二区三区 | 激情综合激情五月俺也去 | 男人扒开女人内裤强吻桶进去 | 在线亚洲高清揄拍自拍一品区 | 黑人巨大精品欧美一区二区 | 国内综合精品午夜久久资源 | 曰本女人与公拘交酡免费视频 | 亚洲码国产精品高潮在线 | 亚洲の无码国产の无码步美 | 秋霞成人午夜鲁丝一区二区三区 | 国产色在线 | 国产 | 国产精品亚洲а∨无码播放麻豆 | 乱码午夜-极国产极内射 | 99国产欧美久久久精品 | 成人欧美一区二区三区黑人 | 性欧美大战久久久久久久 | 少妇太爽了在线观看 | 国产精品久久久久久久9999 | 伊人久久大香线焦av综合影院 | 麻豆成人精品国产免费 | 天天做天天爱天天爽综合网 | 亚拍精品一区二区三区探花 | 狠狠色噜噜狠狠狠7777奇米 | 日韩成人一区二区三区在线观看 | 少妇的肉体aa片免费 | 久久精品国产亚洲精品 | av香港经典三级级 在线 | 免费国产黄网站在线观看 | 欧美猛少妇色xxxxx | 人人妻人人澡人人爽人人精品浪潮 | 欧美乱妇无乱码大黄a片 | 午夜福利不卡在线视频 | 日日碰狠狠躁久久躁蜜桃 | 国产舌乚八伦偷品w中 | 天天躁夜夜躁狠狠是什么心态 | 日韩av无码中文无码电影 | 成人女人看片免费视频放人 | 日韩人妻无码一区二区三区久久99 | 国产97在线 | 亚洲 | 久久精品人人做人人综合 | 国产精品国产自线拍免费软件 | 亚洲熟妇色xxxxx欧美老妇 | 国产精品久久久久久亚洲影视内衣 | 久久国产劲爆∧v内射 | 亚洲a无码综合a国产av中文 | 丰满少妇高潮惨叫视频 | 正在播放老肥熟妇露脸 | 一区二区三区高清视频一 | 成人精品一区二区三区中文字幕 | 一本加勒比波多野结衣 | 男人和女人高潮免费网站 | 天下第一社区视频www日本 | 少妇邻居内射在线 | 天天做天天爱天天爽综合网 | 六十路熟妇乱子伦 | 欧美成人高清在线播放 | 久久无码人妻影院 | 国产精品亚洲五月天高清 | 精品无码一区二区三区的天堂 | 鲁大师影院在线观看 | 国产精品久久久久久亚洲影视内衣 | 亚洲日韩乱码中文无码蜜桃臀网站 | 色爱情人网站 | 久久精品中文字幕大胸 | 黑人大群体交免费视频 | 四十如虎的丰满熟妇啪啪 | av人摸人人人澡人人超碰下载 | 色综合久久久无码网中文 | 中文字幕无码av波多野吉衣 | 国产精品理论片在线观看 | 精品久久久无码人妻字幂 | 国产无av码在线观看 | 久久综合给久久狠狠97色 | 影音先锋中文字幕无码 | 国产精品美女久久久久av爽李琼 | 国产免费久久精品国产传媒 | 欧美成人午夜精品久久久 | 亚洲日韩一区二区三区 | 天干天干啦夜天干天2017 | 女人和拘做爰正片视频 | www一区二区www免费 | 3d动漫精品啪啪一区二区中 | 蜜桃无码一区二区三区 | 色综合久久久久综合一本到桃花网 | 国产明星裸体无码xxxx视频 | 国产午夜福利亚洲第一 | 久久午夜无码鲁丝片秋霞 | 亚欧洲精品在线视频免费观看 | 波多野结衣av一区二区全免费观看 | 99在线 | 亚洲 | 女人色极品影院 | 欧美日韩视频无码一区二区三 | 久久久久久久久蜜桃 | 亚洲精品无码人妻无码 | 国产凸凹视频一区二区 | 人人爽人人爽人人片av亚洲 | 精品夜夜澡人妻无码av蜜桃 | 少妇人妻偷人精品无码视频 | 成人aaa片一区国产精品 | 国产偷自视频区视频 | 精品欧洲av无码一区二区三区 | 天天av天天av天天透 | 亚洲国产成人av在线观看 | 荫蒂被男人添的好舒服爽免费视频 | 综合人妻久久一区二区精品 | 一本久道高清无码视频 | 久久国产劲爆∧v内射 | 亚洲s色大片在线观看 | 久久婷婷五月综合色国产香蕉 | 欧美 亚洲 国产 另类 | 国产人妻精品一区二区三区不卡 | 日日夜夜撸啊撸 | 水蜜桃色314在线观看 | 国产精品久久久久无码av色戒 | 欧美第一黄网免费网站 | 乱中年女人伦av三区 | 成 人 免费观看网站 | 国产一区二区不卡老阿姨 | 精品国产一区二区三区av 性色 | 真人与拘做受免费视频一 | 青青青手机频在线观看 | 99精品视频在线观看免费 | 巨爆乳无码视频在线观看 | 人人妻人人澡人人爽精品欧美 | 久久久久国色av免费观看性色 | 精品无码一区二区三区爱欲 | 亚洲欧美精品aaaaaa片 | 精品国偷自产在线 | 牲欲强的熟妇农村老妇女 | 亚洲精品国产第一综合99久久 | 日韩欧美中文字幕在线三区 | 高清不卡一区二区三区 | 爆乳一区二区三区无码 | 精品一二三区久久aaa片 | 国产精品久久久午夜夜伦鲁鲁 | 欧美精品在线观看 | 精品人人妻人人澡人人爽人人 | 亚洲色欲久久久综合网东京热 | 久久精品99久久香蕉国产色戒 | 亚洲精品中文字幕乱码 | 久久久久免费看成人影片 | 国产激情无码一区二区 | aⅴ在线视频男人的天堂 | 一本色道久久综合狠狠躁 | 国产9 9在线 | 中文 | 亚洲日韩乱码中文无码蜜桃臀网站 | 免费无码的av片在线观看 | 午夜精品久久久久久久久 | 久久 国产 尿 小便 嘘嘘 | 无码人妻av免费一区二区三区 | 亚洲日韩av一区二区三区中文 | 国产精品二区一区二区aⅴ污介绍 | 黑人粗大猛烈进出高潮视频 | 无人区乱码一区二区三区 | 日韩精品无码一区二区中文字幕 | 久久亚洲中文字幕无码 | 久久伊人色av天堂九九小黄鸭 | 久久精品人妻少妇一区二区三区 | 男女爱爱好爽视频免费看 | 特级做a爰片毛片免费69 | 久久综合给合久久狠狠狠97色 | 成人精品视频一区二区三区尤物 | 全黄性性激高免费视频 | 亚洲人成无码网www | v一区无码内射国产 | 色婷婷久久一区二区三区麻豆 | 久热国产vs视频在线观看 | 水蜜桃色314在线观看 | 国产午夜视频在线观看 | 日日天日日夜日日摸 | 亚洲色大成网站www | 色窝窝无码一区二区三区色欲 | 内射爽无广熟女亚洲 | 免费视频欧美无人区码 | 日本爽爽爽爽爽爽在线观看免 | 日韩少妇白浆无码系列 | 18无码粉嫩小泬无套在线观看 | av人摸人人人澡人人超碰下载 | 色婷婷综合中文久久一本 | 在线观看国产一区二区三区 | 水蜜桃亚洲一二三四在线 | 中文精品无码中文字幕无码专区 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国内精品人妻无码久久久影院蜜桃 | 国产内射老熟女aaaa | 亚洲国产精品久久久久久 | 欧美日韩久久久精品a片 | 性欧美熟妇videofreesex | 少妇人妻大乳在线视频 | 精品久久综合1区2区3区激情 | 国产av人人夜夜澡人人爽麻豆 | 丝袜人妻一区二区三区 | 国产精品.xx视频.xxtv | 国产成人一区二区三区在线观看 | 又粗又大又硬毛片免费看 | 中文毛片无遮挡高清免费 | 在线а√天堂中文官网 | 国产内射老熟女aaaa | 国产一区二区不卡老阿姨 | 国产香蕉97碰碰久久人人 | 欧美日本免费一区二区三区 | 国产精品第一国产精品 | 精品国产青草久久久久福利 | 3d动漫精品啪啪一区二区中 | 国产三级久久久精品麻豆三级 | 色欲综合久久中文字幕网 | 久久 国产 尿 小便 嘘嘘 | 国内少妇偷人精品视频 | 中文字幕乱码中文乱码51精品 | 日韩亚洲欧美中文高清在线 | 奇米影视888欧美在线观看 | 久久亚洲a片com人成 | 天海翼激烈高潮到腰振不止 | 狠狠色色综合网站 | 成人精品视频一区二区三区尤物 | 亚洲va欧美va天堂v国产综合 | 丰满人妻翻云覆雨呻吟视频 | 狠狠色噜噜狠狠狠7777奇米 | 乱人伦人妻中文字幕无码 | 国产激情精品一区二区三区 | 国产成人一区二区三区别 | 人人妻人人澡人人爽精品欧美 | 成人免费视频视频在线观看 免费 | 亚洲欧美日韩成人高清在线一区 | 成人试看120秒体验区 |