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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Flink 运维与调优

發布時間:2024/1/8 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Flink 运维与调优 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉載-flink優化_黃瓜燉啤酒鴨的博客-CSDN博客

1.1 內存設置?

1.2 并行度設置?

1.2.1 最優并行度計算?

1.2.2 Source 端并行度的配置?

1.2.3 Transform端并行度的配置?

1.2.4 Sink 端并行度的配置?

1.3 RocksDB大狀態調優?

1.4 Checkpoint設置?

1.5 使用 Flink ParameterTool 讀取配置?

1.5.1 讀取運行參數?

1.5.2 讀取系統屬性?

1.5.3 讀取配置文件?

1.5.4 注冊全局參數?

1.6 壓測方式?

2 反壓處理?

2.1 反壓現象及定位?

2.1.1 利用 Flink Web UI 定位產生反壓的位置?

2.1.2 利用Metrics定位反壓位置?

2.2 反壓的原因及處理?

2.2.1 系統資源?

2.2.2 垃圾收集(GC)?

2.2.3 CPU/線程瓶頸?

2.2.4 線程競爭?

2.2.5 負載不平衡?

2.2.6 外部依賴?

3 數據傾斜?

3.1 判斷是否存在數據傾斜?

3.2 數據傾斜的解決?

3.2.1 keyBy 后的聚合操作存在數據傾斜?

3.2.2 keyBy 之前發生數據傾斜?

3.2.3 keyBy 后的窗口聚合操作存在數據傾斜?

4 KafkaSource調優?

4.1 動態發現分區?

4.2 從kafka數據源生成watermark?

4.3 設置空閑等待?

4.4 Kafka的offset消費策略?

5 FlinkSQL調優?

5.1 Group Aggregate優化?

5.1.1 開啟MiniBatch(提升吞吐)?

5.1.2 開啟LocalGlobal(解決常見數據熱點問題)?

5.1.3 開啟Split Distinct(解決COUNT DISTINCT熱點問題)?

5.1.4 改寫為AGG WITH FILTER語法(提升大量COUNT DISTINCT場景性能)?

5.2 TopN優化?

5.2.1 使用最優算法?

5.2.2 無排名優化(解決數據膨脹問題)?

5.2.3 增加TopN的Cache大小?

5.2.4 PartitionBy的字段中要有時間類字段?

5.2.5 優化后的SQL示例?

5.3 高效去重方案?

5.3.1 保留首行的去重策略(Deduplicate Keep FirstRow)?

5.3.2 保留末行的去重策略(Deduplicate Keep LastRow)?

5.4 高效的內置函數?

5.4.1 使用內置函數替換自定義函數?

5.4.2 LIKE操作注意事項?

5.4.3 慎用正則函數(REGEXP)?

5.5 指定時區?

5.6 設置參數總結?


  • 資源配置調優
  • Flink性能調優的第一步,就是為任務分配合適的資源,在一定范圍內,增加資源的分配與性能的提升是成正比的,實現了最優的資源配置后,在此基礎上再考慮進行后面論述的性能調優策略。

    提交方式主要是yarn-per-job,資源的分配在使用腳本提交Flink任務時進行指定。

    • 標準的Flink任務提交腳本(Generic CLI?模式)

    從1.11開始,增加了通用客戶端模式,參數使用-D <property=value>指定

    bin/flink run \

    -t?yarn-per-job \

    -d \

    -p 5 \ 指定并行度

    -Dyarn.application.queue=test \ 指定yarn隊列

    -Djobmanager.memory.process.size=1024mb \ 指定JM的總進程大小

    -Dtaskmanager.memory.process.size=1024mb \ 指定每個TM的總進程大小

    -Dtaskmanager.numberOfTaskSlots=2 \ 指定每個TM的slot數

    -c com.at.app.dwd.LogBaseApp \

    /opt/module/gmall-flink/gmall-realtime-1.0-SNAPSHOT-jar-with-dependencies.jar

    參數列表:

    Apache Flink 1.12 Documentation: Configuration


  • 內存設置
  • 生產資源配置:

    bin/flink run \

    -t yarn-per-job \

    -d \

    -p 5 \ 指定并行度

    -Dyarn.application.queue=test \ 指定yarn隊列

    -Djobmanager.memory.process.size=2048mb \ JM2~4G足夠

    -Dtaskmanager.memory.process.size=6144mb \ 單個TM2~8G足夠

    -Dtaskmanager.numberOfTaskSlots=2 \ 與容器核數1core:1slot或1core:2slot

    -c com.at.app.dwd.LogBaseApp \

    /opt/module/gmall-flink/gmall-realtime-1.0-SNAPSHOT-jar-with-dependencies.jar

    Flink是實時流處理,關鍵在于資源情況能不能抗住高峰時期每秒的數據量,通常用QPS/TPS來描述數據情況。

  • 并行度設置

  • 最優并行度計算
  • 開發完成后,先進行壓測。任務并行度給10以下,測試單個并行度的處理上限。然后 總QPS/單并行度的處理能力 = 并行度

    不能只從QPS去得出并行度,因為有些字段少、邏輯簡單的任務,單并行度一秒處理幾萬條數據。而有些數據字段多,處理邏輯復雜,單并行度一秒只能處理1000條數據。

    最好根據高峰期的QPS壓測,并行度*1.2倍,富余一些資源。


  • Source 端并行度的配置
  • 數據源端是 Kafka,Source的并行度設置為Kafka對應Topic的分區數。

    如果已經等于 Kafka 的分區數,消費速度仍跟不上數據生產速度,考慮下Kafka 要擴大分區,同時調大并行度等于分區數。

    Flink 的一個并行度可以處理一至多個分區的數據,如果并行度多于 Kafka 的分區數,那么就會造成有的并行度空閑,浪費資源。


    • Transform端并行度的配置
    • Keyby之前的算子

    一般不會做太重的操作,都是比如map、filter、flatmap等處理較快的算子,并行度可以和source保持一致。

    • Keyby之后的算子

    如果并發較大,建議設置并行度為 2 的整數次冪,例如:128、256、512;

    小并發任務的并行度不一定需要設置成 2 的整數次冪;

    大并發任務如果沒有 KeyBy,并行度也無需設置為 2 的整數次冪;


  • Sink 端并行度的配置
  • Sink 端是數據流向下游的地方,可以根據 Sink 端的數據量下游的服務抗壓能力進行評估。如果Sink端是Kafka,可以設為Kafka對應Topic的分區數。

    Sink 端的數據量小,比較常見的就是監控告警的場景,并行度可以設置的小一些。

    Source 端的數據量是最小的,拿到 Source 端流過來的數據后做了細粒度的拆分,數據量不斷的增加,到 Sink 端的數據量就非常大。那么在 Sink 到下游的存儲中間件的時候就需要提高并行度。

    另外 Sink 端要與下游的服務進行交互,并行度還得根據下游的服務抗壓能力來設置,如果在 Flink Sink 這端的數據量過大的話,且 Sink 處并行度也設置的很大,但下游的服務完全撐不住這么大的并發寫入,可能會造成下游服務直接被寫掛,所以最終還是要在 Sink 處的并行度做一定的權衡。

  • RocksDB大狀態調優
  • RocksDB 是基于 LSM Tree 實現的(類似HBase),寫數據都是先緩存到內存中,所以RocksDB 的寫請求效率比較高。RocksDB 使用內存結合磁盤的方式來存儲數據,每次獲取數據時,先從內存中 blockcache 中查找,如果內存中沒有再去磁盤中查詢。優化后差不多單并行度 TPS 5000 record/s,性能瓶頸主要在于 RocksDB 對磁盤的讀請求,所以當處理性能不夠時,僅需要橫向擴展并行度即可提高整個Job 的吞吐量。以下幾個調優參數:

    • 設置本地 RocksDB 多目錄

    在flink-conf.yaml 中配置:

    state.backend.rocksdb.localdir: /data1/flink/rocksdb,/data2/flink/rocksdb,/data3/flink/rocksdb

    注意:不要配置單塊磁盤的多個目錄,務必將目錄配置到多塊不同的磁盤上,讓多塊磁盤來分擔壓力。當設置多個 RocksDB 本地磁盤目錄時,Flink 會隨機選擇要使用的目錄,所以就可能存在三個并行度共用同一目錄的情況。如果服務器磁盤數較多,一般不會出現該情況,但是如果任務重啟后吞吐量較低,可以檢查是否發生了多個并行度共用同一塊磁盤的情況。

    當一個 TaskManager 包含 3 個 slot 時,那么單個服務器上的三個并行度都對磁盤造成頻繁讀寫,從而導致三個并行度的之間相互爭搶同一個磁盤 io,這樣務必導致三個并行度的吞吐量都會下降。設置多目錄實現三個并行度使用不同的硬盤從而減少資源競爭。

    如下所示是測試過程中磁盤的 IO 使用率,可以看出三個大狀態算子的并行度分別對應了三塊磁盤,這三塊磁盤的 IO 平均使用率都保持在 45% 左右,IO 最高使用率幾乎都是 100%,而其他磁盤的 IO 平均使用率相對低很多。由此可見使用 RocksDB 做為狀態后端且有大狀態的頻繁讀取時, 對磁盤IO性能消耗確實比較大。

    如下圖所示,其中兩個并行度共用了 sdb 磁盤,一個并行度使用 sdj磁盤。可以看到 sdb 磁盤的 IO 使用率已經達到了 91.6%,就會導致 sdb 磁盤對應的兩個并行度吞吐量大大降低,從而使得整個 Flink 任務吞吐量降低。如果每個服務器上有一兩塊 SSD,強烈建議將 RocksDB 的本地磁盤目錄配置到 SSD 的目錄下,從 HDD 改為 SSD 對于性能的提升可能比配置 10 個優化參數更有效

    • state.backend.incremental:開啟增量檢查點,默認false,改為true。
    • state.backend.rocksdb.predefined-options:SPINNING_DISK_OPTIMIZED_HIGH_MEM設置為機械硬盤+內存模式,有條件上SSD,指定為FLASH_SSD_OPTIMIZED
    • state.backend.rocksdb.block.cache-size: 整個 RocksDB 共享一個 block cache,讀數據時內存的 cache 大小,該參數越大讀數據時緩存命中率越高,默認大小為 8 MB,建議設置到 64 ~ 256 MB。
    • state.backend.rocksdb.thread.num: 用于后臺 flush 和合并 sst 文件的線程數,默認為 1,建議調大,機械硬盤用戶可以改為?4 等更大的值。
    • state.backend.rocksdb.writebuffer.size: RocksDB 中,每個 State 使用一個 Column Family,每個 Column Family 使用獨占的 write buffer,建議調大,例如:32M
    • state.backend.rocksdb.writebuffer.count: 每個 Column Family 對應的 writebuffer 數目,默認值是 2,對于機械磁盤來說,如果內存?夠大,可以調大到 5 左右
    • state.backend.rocksdb.writebuffer.number-to-merge: 將數據從 writebuffer 中 flush 到磁盤時,需要合并的 writebuffer 數量,默認值為 1,可以調成3
    • state.backend.local-recovery: 設置本地恢復,當 Flink 任務失敗時,可以基于本地的狀態信息進行恢復任務,可能不需要從 hdfs 拉取數據

    • Checkpoint設置

    一般我們的 Checkpoint 時間間隔可以設置為分鐘級別,例如 1 分鐘、3 分鐘,對于狀態很大的任務每次 Checkpoint 訪問 HDFS 比較耗時,可以設置為 5~10 分鐘一次Checkpoint,并且調大兩次 Checkpoint 之間的暫停間隔,例如設置兩次Checkpoint 之間至少暫停 4或8 分鐘。

    如果 Checkpoint 語義配置為 EXACTLY_ONCE,那么在 Checkpoint 過程中還會存在 barrier 對齊的過程,可以通過 Flink Web UI 的 Checkpoint 選項卡來查看 Checkpoint 過程中各階段的耗時情況,從而確定到底是哪個階段導致 Checkpoint 時間過長然后針對性的解決問題。

    RocksDB相關參數在1.3中已說明,可以在flink-conf.yaml指定,也可以在Job的代碼中調用API單獨指定,這里不再列出。

    ?// 使? RocksDBStateBackend 做為狀態后端,并開啟增量 Checkpoint

    ?RocksDBStateBackend rocksDBStateBackend = new RocksDBStateBackend("hdfs://hadoop1:8020/flink/checkpoints", true);

    ?env.setStateBackend(rocksDBStateBackend);

    ?// 開啟Checkpoint,間隔為 3 分鐘

    ?env.enableCheckpointing(TimeUnit.MINUTES.toMillis(3));

    ?// 配置 Checkpoint

    ?CheckpointConfig checkpointConf = env.getCheckpointConfig();

    ?checkpointConf.setCheckpointingMode(CheckpointingMode.EXACTLY_ONCE)

    ?// 最小間隔 4分鐘

    ?checkpointConf.setMinPauseBetweenCheckpoints(TimeUnit.MINUTES.toMillis(4))

    ?// 超時時間 10分鐘

    ?checkpointConf.setCheckpointTimeout(TimeUnit.MINUTES.toMillis(10));

    ?// 保存checkpoint

    ?checkpointConf.enableExternalizedCheckpoints(

    CheckpointConfig.ExternalizedCheckpointCleanup.RETAIN_ON_CANCELLATION);


  • 使用 Flink ParameterTool 讀取配置
  • 在實際開發中,有各種環境(開發、測試、預發、生產),作業也有很多的配置:算子的并行度配置、Kafka 數據源的配置(broker 地址、topic 名、group.id)、Checkpoint 是否開啟、狀態后端存儲路徑、數據庫地址、用戶名和密碼等各種各樣的配置,可能每個環境的這些配置對應的值都是不一樣的。

    如果你是直接在代碼??寫死的配置,每次換個環境去運行測試作業,都要重新去修改代碼中的配置,然后編譯打包,提交運行,這樣就要花費很多時間在這些重復的勞動力上了。在 Flink 中可以通過使用 ParameterTool 類讀取配置,它可以讀取環境變量、運行參數、配置文件。

    ParameterTool 是可序列化的,所以你可以將它當作參數進行傳遞給算子的自定義函數類。


  • 讀取運行參數
  • 我們可以在Flink的提交腳本添加運行參數,格式:

    • --參數名 參數值
    • -參數名 參數值

    在 Flink 程序中可以直接使用 ParameterTool.fromArgs(args) 獲取到所有的參數,也可以通過 parameterTool.get("username") 方法獲取某個參數對應的值。

    舉例:通過運行參數指定jobname

    bin/flink run \

    -t yarn-per-job \

    -d \

    -p 5 \ 指定并行度

    -Dyarn.application.queue=test \ 指定yarn隊列

    -Djobmanager.memory.process.size=1024mb \ 指定JM的總進程大小

    -Dtaskmanager.memory.process.size=1024mb \ 指定每個TM的總進程大小

    -Dtaskmanager.numberOfTaskSlots=2 \ 指定每個TM的slot數

    -c com.at.app.dwd.LogBaseApp \

    /opt/module/gmall-flink/gmall-realtime-1.0-SNAPSHOT-jar-with-dependencies.jar \

    --jobname dwd-LogBaseApp ?//參數名自己隨便起,代碼里對應上即可

    在代碼里獲取參數值:

    ????????ParameterTool parameterTool = ParameterTool.fromArgs(args);

    ????????String myJobname = parameterTool.get("jobname"); ?//參數名對應

    ????????env.execute(myJobname);

  • 讀取系統屬性
  • ParameterTool 還?持通過 ParameterTool.fromSystemProperties()?方法讀取系統屬性。做個打印:

    ParameterTool parameterTool = ParameterTool.fromSystemProperties();

    System.out.println(parameterTool.toMap().toString());

    可以得到全面的系統屬性,部分結果


  • 讀取配置文件
  • 可以使用ParameterTool.fromPropertiesFile("/application.properties") 讀取 properties 配置文件。可以將所有要配置的地方(比如并行度和一些 Kafka、MySQL 等配置)都寫成可配置的,然后其對應的 key 和 value 值都寫在配置文件中,最后通過 ParameterTool 去讀取配置文件獲取對應的值。

  • 注冊全局參數
  • 在 ExecutionConfig 中可以將 ParameterTool 注冊為全作業參數的參數,這樣就可以被 JobManager 的web 端以及用戶?定義函數中以配置值的形式訪問。

    StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment(); env.getConfig().setGlobalJobParameters(ParameterTool.fromArgs(args));

    可以不用將ParameterTool當作參數傳遞給算子的自定義函數,直接在用戶?定義的 Rich 函數中直接獲取到參數值了。

    env.addSource(new RichSourceFunction() {

    @Override

    public void run(SourceContext sourceContext) throws Exception {

    ?while (true) {

    ParameterTool parameterTool = (ParameterTool)getRuntimeContext().getExecutionConfig().getGlobalJobParameters();

    ???}

    ??}

    ??@Override

    ??public void cancel() {

    ??}

    })

  • 壓測方式
  • 壓測的方式很簡單,先在kafka中積壓數據,之后開啟Flink任務,出現反壓,就是處理瓶頸。相當于水庫先積水,一下子泄洪。數據可以是自己造的模擬數據,也可以是生產中的部分數據。


  • 反壓處理
  • 反壓(BackPressure)通常產生于這樣的場景:短時間的負載高峰導致系統接收數據的速率遠高于它處理數據的速率。許多日常問題都會導致反壓,例如,垃圾回收停頓可能會導致流入的數據快速堆積,或遇到大促、秒殺活動導致流量陡增。反壓如果不能得到正確的處理,可能會導致資源耗盡甚至系統崩潰。

    反壓機制是指系統能夠自己檢測到被阻塞的 Operator,然后自適應地降低源頭或上游數據的發送速率,從而維持整個系統的穩定。Flink 任務一般運行在多個節點上,數據從上游算子發送到下游算子需要網絡傳輸,若系統在反壓時想要降低數據源頭或上游算子數據的發送速率,那么肯定也需要網絡傳輸。所以下面先來了解一下 Flink 的網絡流控(Flink 對網絡數據流量的控制)機制。

  • 反壓現象及定位
  • Flink 的反壓太過于天然了,導致無法簡單地通過監控 BufferPool 的使用情況來判斷反壓狀態。Flink 通過對運行中的任務進行采樣來確定其反壓,如果一個 Task 因為反壓導致處理速度降低了,那么它肯定會卡在向 LocalBufferPool 申請內存塊上。那么該 Task 的 stack trace 應該是這樣:

    java.lang.Object.wait(Native Method)

    o.a.f.[...].LocalBufferPool.requestBuffer(LocalBufferPool.java:163) o.a.f.[...].LocalBufferPool.requestBufferBlocking(LocalBufferPool.java:133) [...]

    監控對正常的任務運行有一定影響,因此只有當 Web 頁面切換到 Job 的 BackPressure 頁面時,JobManager 才會對該 Job 觸發反壓監控。默認情況下,JobManager 會觸發 100 次 stack trace 采樣,每次間隔 50ms 來確定反壓。Web 界面看到的比率表示在內部方法調用中有多少 stack trace 被卡在LocalBufferPool.requestBufferBlocking(),例如: 0.01 表示在 100 個采樣中只有 1 個被卡在LocalBufferPool.requestBufferBlocking()。采樣得到的比例與反壓狀態的對應關系如下:

    • OK: 0 <= 比例 <= 0.10
    • LOW: 0.10 < 比例 <= 0.5
    • HIGH: 0.5 < 比例 <= 1

    Task 的狀態為 OK 表示沒有反壓,HIGH 表示這個 Task 被反壓。

  • 利用 Flink Web UI 定位產生反壓的位置
  • 在 Flink Web UI 中有 BackPressure 的頁面,通過該頁面可以查看任務中 subtask 的反壓狀態,如下兩圖所示,分別展示了狀態是 OK 和 HIGH 的場景。排查的時候,先把operator chain禁用,方便定位。

  • 利用Metrics定位反壓位置
  • 當某個 Task 吞吐量下降時,基于 Credit 的反壓機制,上游不會給該 Task 發送數據,所以該 Task 不會頻繁卡在向 Buffer Pool 去申請 Buffer。反壓監控實現原理就是監控 Task 是否卡在申請 buffer 這一步,所以遇到瓶頸的 Task 對應的反壓??必然會顯示 OK,即表示沒有受到反壓

    如果該 Task 吞吐量下降,造成該Task 上游的 Task 出現反壓時,必然會存在:該 Task 對應的 InputChannel 變滿,已經申請不到可用的Buffer 空間。如果該 Task 的 InputChannel 還能申請到可用 Buffer,那么上游就可以給該 Task 發送數據,上游 Task 也就不會被反壓了,所以說遇到瓶頸且導致上游 Task 受到反壓的 Task 對應的 InputChannel 必然是滿的(這?不考慮?絡遇到瓶頸的情況)。從這個思路出發,可以對該 Task 的 InputChannel 的使用情況進行監控,如果 InputChannel 使用率 100%,那么該 Task 就是我們要找的反壓源。Flink 1.9 及以上版本inPoolUsage 表示 inputFloatingBuffersUsage 和inputExclusiveBuffersUsage 的總和。

    反壓時,可以看到遇到瓶頸的該Task的inPoolUage為1

  • 反壓的原因及處理
  • 先檢查基本原因,然后再深入研究更復雜的原因,最后找出導致瓶頸的原因。下面列出從最基本到比較復雜的一些反壓潛在原因。

    注意:反壓可能是暫時的,可能是由于負載高峰、CheckPoint 或作業重啟引起的數據積壓而導致反壓。如果反壓是暫時的,應該忽略它。另外,請記住,斷斷續續的反壓會影響我們分析和解決問題。

  • 系統資源
  • 檢查涉及服務器基本資源的使用情況,如CPU、網絡或磁盤I/O,目前 Flink 任務使用最主要的還是內存和 CPU 資源,本地磁盤、依賴的外部存儲資源以及網卡資源一般都不會是瓶頸。如果某些資源被充分利用或大量使用,可以借助分析工具,分析性能瓶頸(JVM Profiler+ FlameGraph生成火焰圖)。

    如何生成火焰圖:如何生成 Flink 作業的交互式火焰圖? | zhisheng的博客

    如何讀懂火焰圖:如何讀懂火焰圖? - 知乎

    • 針對特定的資源調優Flink
    • 通過增加并行度或增加集群中的服務器數量來橫向擴展
    • 減少瓶頸算子上游的并行度,從而減少瓶頸算子接收的數據量(不建議,可能造成整個Job數據延遲增大)

    • 垃圾收集(GC)

    長時間GC暫停會導致性能問題。可以通過打印調試GC日志(通過-XX:+PrintGCDetails)或使用某些內存或 GC 分析器(GCViewer工具)來驗證是否處于這種情況。

    • 在Flink提交腳本中,設置JVM參數,打印GC日志:

    bin/flink run \

    -t?yarn-per-job \

    -d \

    -p 5 \ 指定并行度

    -Dyarn.application.queue=test \ 指定yarn隊列

    -Djobmanager.memory.process.size=1024mb \ 指定JM的總進程大小

    -Dtaskmanager.memory.process.size=1024mb \ 指定每個TM的總進程大小

    -Dtaskmanager.numberOfTaskSlots=2 \ 指定每個TM的slot數

    -Denv.java.opts="-XX:+PrintGCDetails -XX:+PrintGCDateStamps"

    -c com.at.app.dwd.LogBaseApp \

    /opt/module/gmall-flink/gmall-realtime-1.0-SNAPSHOT-jar-with-dependencies.jar

    • 下載GC日志的方式:

    因為是on yarn模式,運行的節點一個一個找比較麻煩。可以打開WebUI,選擇JobManager或者TaskManager,點擊Stdout,即可看到GC日志,點擊下載按鈕即可將GC日志通過HTTP的方式下載下來。

    • 分析GC日志:

    通過 GC 日志分析出單個 Flink Taskmanager 堆總大小、年輕代、老年代分配的內存空間、Full GC 后老年代剩余大小等,相關指標定義可以去 Github 具體查看。

    GCViewer地址:https://github.com/chewiebug/GCViewer

    擴展:最重要的指標是Full GC 后,老年代剩余大小這個指標,按照《Java 性能優化權威指南》這本書 Java 堆大小計算法則,設 Full GC 后老年代剩余大小空間為 M,那么堆的大小建議 3 ~ 4倍 M,新生代為 1 ~ 1.5 倍 M,老年代應為 2 ~ 3 倍 M。


  • CPU/線程瓶頸
  • 有時,一個或幾個線程導致 CPU 瓶頸,而整個機器的CPU使用率仍然相對較低,則可能無法看到 CPU 瓶頸。例如,48核的服務器上,單個 CPU 瓶頸的線程僅占用 2%的 CPU 使用率,就算單個線程發生了 CPU 瓶頸,我們也看不出來。可以考慮使用2.2.1提到的分析工具,它們可以顯示每個線程的 CPU 使用情況來識別熱線程。


  • 線程競爭
  • 與上?的 CPU/線程瓶頸問題類似,subtask 可能會因為共享資源上高負載線程的競爭而成為瓶頸。同樣,可以考慮使用2.2.1提到的分析工具,考慮在用戶代碼中查找同步開銷、鎖競爭,盡管避免在用戶代碼中添加同步。

  • 負載不平衡
  • 如果瓶頸是由數據傾斜引起的,可以嘗試通過將數據分區的 key 進行加鹽或通過實現本地預聚合來減輕數據傾斜的影響。(關于數據傾斜的詳細解決方案,會在下一章節詳細討論)

  • 外部依賴
  • 如果發現我們的 Source 端數據讀取性能比較低或者 Sink 端寫入性能較差,需要檢查第三方組件是否遇到瓶頸。例如,Kafka 集群是否需要擴容,Kafka 連接器是否并行度較低,HBase 的 rowkey 是否遇到熱點問題。關于第三方組件的性能問題,需要結合具體的組件來分析。


  • 數據傾斜

  • 判斷是否存在數據傾斜
  • 相同 Task 的多個 Subtask 中,個別Subtask 接收到的數據量明顯大于其他 Subtask 接收到的數據量,通過 Flink Web UI 可以精確地看到每個 Subtask 處理了多少數據,即可判斷出 Flink 任務是否存在數據傾斜。通常,數據傾斜也會引起反壓。

  • 數據傾斜的解決

  • keyBy 后的聚合操作存在數據傾斜
  • 使用LocalKeyBy的思想:在 keyBy 上游算子數據發送之前,首先在上游算子的本地

    對數據進行聚合后再發送到下游,使下游接收到的數據量大大減少,從而使得 keyBy 之后的聚合操作不再是任務的瓶頸。類似MapReduce 中 Combiner 的思想,但是這要求聚合操作必須是多條數據或者一批數據才能聚合,單條數據沒有辦法通過聚合來減少數據量。從Flink LocalKeyBy 實現原理來講,必然會存在一個積攢批次的過程,在上游算子中必須攢夠一定的數據量,對這些數據聚合后再發送到下游。

    注意:Flink是實時流處理,如果keyby之后的聚合操作存在數據傾斜,且沒有開窗口的情況下,簡單的認為使用兩階段聚合,是不能解決問題的。因為這個時候Flink是來一條處理一條,且向下游發送一條結果,對于原來keyby的維度(第二階段聚合)來講,數據量并沒有減少,且結果重復計算(非FlinkSQL,未使用回撤流),如下圖所示:

    • 實現方式:以計算PV為例,keyby之前,使用flatMap實現LocalKeyby

    class LocalKeyByFlatMap extends RichFlatMapFunction<String, Tuple2<String,

    ?//Checkpoint 時為了保證 Exactly Once,將 buffer 中的數據保存到該 ListState 中

    ?private ListState<Tuple2<String, Long>> localPvStatListState;

    ?//本地 buffer,存放 local 端緩存的 app 的 pv 信息

    ?private HashMap<String, Long> localPvStat;

    ?//緩存的數據量大小,即:緩存多少數據再向下游發送

    ?private int batchSize;

    ?//計數器,獲取當前批次接收的數據量

    ?private AtomicInteger currentSize;

    ?//構造器,批次大小傳參

    ?LocalKeyByFlatMap(int batchSize){

    ? this.batchSize = batchSize;

    ?}

    ?@Override

    ?public void flatMap(String in, Collector collector) throws Exception {

    ? // 將新來的數據添加到 buffer 中

    ? Long pv = localPvStat.getOrDefault(in, 0L);

    ? localPvStat.put(in, pv + 1);

    ? // 如果到達設定的批次,則將 buffer 中的數據發送到下游

    ? if(currentSize.incrementAndGet() >= batchSize){

    ? // 遍歷 Buffer 中數據,發送到下游

    ? for(Map.Entry<String, Long> appIdPv: localPvStat.entrySet()) {

    ? collector.collect(Tuple2.of(appIdPv.getKey(), appIdPv.getValue()

    ? }

    ? // Buffer 清空,計數器清零

    ? localPvStat.clear();

    ? currentSize.set(0);

    ? }

    ?}

    ?@Override

    ?public void snapshotState(FunctionSnapshotContext functionSnapshotConte

    ? // 將 buffer 中的數據保存到狀態中,來保證 Exactly Once

    ? localPvStatListState.clear();

    ? for(Map.Entry<String, Long> appIdPv: localPvStat.entrySet()) {

    ? localPvStatListState.add(Tuple2.of(appIdPv.getKey(), appIdPv.ge

    ? }

    ?}

    ?@Override

    ?public void initializeState(FunctionInitializationContext context) {

    ? // 從狀態中恢復 buffer 中的數據

    ? localPvStatListState = context.getOperatorStateStore().getListState

    ? new ListStateDescriptor<>("localPvStat",

    ? TypeInformation.of(new TypeHint<Tuple2<String, Long>>})));

    ? localPvStat = new HashMap();

    ? if(context.isRestored()) {

    ? // 從狀態中恢復數據到 localPvStat 中

    ? for(Tuple2<String, Long> appIdPv: localPvStatListState.get()){

    long pv = localPvStat.getOrDefault(appIdPv.f0, 0L);

    ? // 如果出現 pv != 0,說明改變了并行度,

    ? // ListState 中的數據會被均勻分發到新的 subtask中

    ? // 所以單個 subtask 恢復的狀態中可能包含兩個相同的 app 的數據

    ? localPvStat.put(appIdPv.f0, pv + appIdPv.f1);

    ? }

    ? // 從狀態恢復時,默認認為 buffer 中數據量達到了 batchSize,需要向下游發

    ? currentSize = new AtomicInteger(batchSize);

    ? } else {

    ? currentSize = new AtomicInteger(0);

    ? }

    ?}

    }


  • keyBy 之前發生數據傾斜
  • 如果 keyBy 之前就存在數據傾斜,上游算子的某些實例可能處理的數據較多,某些實例可能處理的數據較少,產生該情況可能是因為數據源的數據本身就不均勻,例如由于某些原因 Kafka 的 topic 中某些 partition 的數據量較大,某些 partition 的數據量較少。對于不存在 keyBy 的 Flink 任務也會出現該情況。

    這種情況,需要讓 Flink 任務強制進行shuffle。使用shuffle、rebalance 或 rescale算子即可將數據均勻分配,從而解決數據傾斜的問題。

  • keyBy 后的窗口聚合操作存在數據傾斜
  • 因為使用了窗口,變成了有界數據的處理(3.2.1已分析過),窗口默認是觸發時才會輸出一條結果發往下游,所以可以使用兩階段聚合的方式:

    實現思路:

    • 第一階段聚合:key拼接隨機數前綴或后綴,進行keyby、開窗、聚合

    注意:聚合完不再是WindowedStream,要獲取WindowEnd作為窗口標記作為第二階段分組依據,避免不同窗口的結果聚合到一起)

    • 第二階段聚合:去掉隨機數前綴或后綴,按照原來的key及windowEnd作keyby、聚合

  • KafkaSource調優

  • 動態發現分區
  • 當 FlinkKafkaConsumer 初始化時,每個 subtask 會訂閱一批 partition,但是當 Flink 任務運行過程中,如果被訂閱的 topic 創建了新的 partition,FlinkKafkaConsumer 如何實現動態發現新創建的 partition 并消費呢?

    在使用 FlinkKafkaConsumer 時,可以開啟 partition 的動態發現。通過 Properties指定參數開啟(單位是毫秒):

    FlinkKafkaConsumerBase.KEY_PARTITION_DISCOVERY_INTERVAL_MILLIS?

    該參數表示間隔多久檢測一次是否有新創建的 partition。默認值是Long的最小值,表示不開啟,大于0表示開啟。開啟時會啟動一個線程根據傳入的interval定期獲取Kafka最新的元數據,新 partition 對應的那一個 subtask 會自動發現并從earliest 位置開始消費,新創建的 partition 對其他 subtask 并不會產生影響。

    代碼如下所示:

    properties.setProperty(FlinkKafkaConsumerBase.KEY_PARTITION_DISCOVERY_INTERVAL_MILLIS, 30 * 1000 + "");

  • 從kafka數據源生成watermark
  • Kafka單分區內有序,多分區間無序。在這種情況下,可以使用 Flink 中可識別 Kafka 分區的 watermark 生成機制。使用此特性,將在 Kafka 消費端內部針對每個 Kafka 分區生成 watermark,并且不同分區 watermark 的合并方式與在數據流 shuffle 時的合并方式相同。

    在單分區內有序的情況下,使用時間戳單調遞增按分區生成的 watermark 將生成完美的全局 watermark。

    可以不使用?TimestampAssigner,直接用 Kafka 記錄自身的時間戳:

    StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();

    Properties properties = new Properties();

    properties.setProperty("bootstrap.servers", "hadoop1:9092,hadoop2:9092,hadoop3:9092");

    properties.setProperty("group.id", "fffffffffff");

    FlinkKafkaConsumer<String> kafkaSourceFunction = new FlinkKafkaConsumer<>(

    ????????????????"flinktest",

    ????????????????new SimpleStringSchema(),

    ????????????????properties

    ????????);

    kafkaSourceFunction.assignTimestampsAndWatermarks(

    ????????????????WatermarkStrategy

    ????????????????????????.forBoundedOutOfOrderness(Duration.ofMinutes(2))

    );

    env.addSource(kafkaSourceFunction)

  • 設置空閑等待
  • 如果數據源中的某一個分區/分片在一段時間內未發送事件數據,則意味著 WatermarkGenerator 也不會獲得任何新數據去生成 watermark。我們稱這類數據源為空閑輸入或空閑源。在這種情況下,當某些其他分區仍然發送事件數據的時候就會出現問題。比如Kafka的Topic中,由于某些原因,造成個別Partition一直沒有新的數據。由于下游算子 watermark 的計算方式是取所有不同的上游并行數據源 watermark 的最小值,則其 watermark 將不會發生變化,導致窗口、定時器等不會被觸發。

    為了解決這個問題,你可以使用 WatermarkStrategy 來檢測空閑輸入并將其標記為空閑狀態。

    StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();

    Properties properties = new Properties();

    properties.setProperty("bootstrap.servers", "hadoop1:9092,hadoop2:9092,hadoop3:9092");

    properties.setProperty("group.id", "fffffffffff");

    FlinkKafkaConsumer<String> kafkaSourceFunction = new FlinkKafkaConsumer<>(

    ????????????????"flinktest",

    ????????????????new SimpleStringSchema(),

    ????????????????properties

    ????????);

    kafkaSourceFunction.assignTimestampsAndWatermarks(

    ????????????????WatermarkStrategy

    ????????????????????????.forBoundedOutOfOrderness(Duration.ofMinutes(2))

    .withIdleness(Duration.ofMinutes(5))

    );

    env.addSource(kafkaSourceFunction)


  • Kafka的offset消費策略
  • FlinkKafkaConsumer可以調用以下API,注意與”auto.offset.reset”區分開

    • setStartFromGroupOffsets():默認消費策略,默認讀取上次保存的offset信息,如果是應用第一次啟動,讀取不到上次的offset信息,則會根據這個參數auto.offset.reset的值來進行消費數據。建議使用這個。
    • setStartFromEarliest():從最早的數據開始進行消費,忽略存儲的offset信息
    • setStartFromLatest():從最新的數據進行消費,忽略存儲的offset信息
    • setStartFromSpecificOffsets(Map):從指定位置進行消費
    • setStartFromTimestamp(long):從topic中指定的時間點開始消費,指定時間點之前的數據忽略
    • 當checkpoint機制開啟的時候,KafkaConsumer會定期把kafka的offset信息還有其他operator的狀態信息一塊保存起來。當job失敗重啟的時候,Flink會從最近一次的checkpoint中進行恢復數據,重新從保存的offset消費kafka中的數據(也就是說,上面幾種策略,只有第一次啟動的時候起作用)。
    • 為了能夠使用支持容錯的kafka Consumer,需要開啟checkpoint

  • FlinkSQL調優
  • FlinkSQL官網配置參數:

  • Group Aggregate優化

  • 開啟MiniBatch(提升吞吐)
  • MiniBatch是微批處理,原理是緩存一定的數據后再觸發處理,以減少對State的訪問,從而提升吞吐并減少數據的輸出量。MiniBatch主要依靠在每個Task上注冊的Timer線程來觸發微批,需要消耗一定的線程調度性能。

    • MiniBatch默認關閉,開啟方式如下:

    // 初始化table environment

    TableEnvironment tEnv = ...

    // 獲取 tableEnv的配置對象

    Configuration configuration = tEnv.getConfig().getConfiguration();

    // 設置參數:

    // 開啟miniBatch

    configuration.setString("table.exec.mini-batch.enabled", "true");

    // 批量輸出的間隔時間

    configuration.setString("table.exec.mini-batch.allow-latency", "5 s");

    // 防止OOM設置每個批次最多緩存數據的條數,可以設為2萬條

    configuration.setString("table.exec.mini-batch.size", "20000");

    • FlinkSQL參數配置列表:

    Apache Flink 1.12 Documentation: Configuration

    • 適用場景

    微批處理通過增加延遲換取高吞吐,如果有超低延遲的要求,不建議開啟微批處理。通常對于聚合的場景,微批處理可以顯著的提升系統性能,建議開啟。

    • 注意事項:

    1)目前,key-value 配置項僅被?Blink planner 支持。

    2)1.12之前的版本有bug,開啟miniBatch,不會清理過期狀態,也就是說如果設置狀態的TTL,無法清理過期狀態。1.12版本才修復這個問題。

    參考ISSUE:

  • 開啟LocalGlobal(解決常見數據熱點問題)
  • LocalGlobal優化將原先的Aggregate分成Local+Global兩階段聚合,即MapReduce模型中的Combine+Reduce處理模式。第一階段在上游節點本地攢一批數據進行聚合(localAgg),并輸出這次微批的增量值(Accumulator)。第二階段再將收到的Accumulator合并(Merge),得到最終的結果(GlobalAgg)。

    LocalGlobal本質上能夠靠LocalAgg的聚合篩除部分傾斜數據,從而降低GlobalAgg的熱點,提升性能。結合下圖理解LocalGlobal如何解決數據傾斜的問題。

    由上圖可知:

  • 未開啟LocalGlobal優化,由于流中的數據傾斜,Key為紅色的聚合算子實例需要處理更多的記錄,這就導致了熱點問題。
  • 開啟LocalGlobal優化后,先進行本地聚合,再進行全局聚合。可大大減少GlobalAgg的熱點,提高性能。
    • LocalGlobal開啟方式:

    1)LocalGlobal優化需要先開啟MiniBatch,依賴于MiniBatch的參數。

    2)table.optimizer.agg-phase-strategy: 聚合策略。默認AUTO,支持參數AUTO、TWO_PHASE(使用LocalGlobal兩階段聚合)、ONE_PHASE(僅使用Global一階段聚合)。

    // 初始化table environment

    TableEnvironment tEnv = ...

    // 獲取 tableEnv的配置對象

    Configuration configuration = tEnv.getConfig().getConfiguration();

    // 設置參數:

    // 開啟miniBatch

    configuration.setString("table.exec.mini-batch.enabled", "true");

    // 批量輸出的間隔時間

    configuration.setString("table.exec.mini-batch.allow-latency", "5 s");

    // 防止OOM設置每個批次最多緩存數據的條數,可以設為2萬條

    configuration.setString("table.exec.mini-batch.size", "20000");

    // 開啟LocalGlobal

    configuration.setString("table.optimizer.agg-phase-strategy", "TWO_PHASE");

    • 判斷是否生效

    觀察最終生成的拓撲圖的節點名字中是否包含GlobalGroupAggregate或LocalGroupAggregate。

    • 適用場景

    LocalGlobal適用于提升如SUM、COUNT、MAX、MIN和AVG等普通聚合的性能,以及解決這些場景下的數據熱點問題。

    • 注意事項:

    1)需要先開啟MiniBatch

    2)開啟LocalGlobal需要UDAF實現Merge方法。

  • 開啟Split Distinct(解決COUNT DISTINCT熱點問題)
  • LocalGlobal優化針對普通聚合(例如SUM、COUNT、MAX、MIN和AVG)有較好的效果,對于COUNT DISTINCT收效不明顯,因為COUNT DISTINCT在Local聚合時,對于DISTINCT KEY的去重率不高,導致在Global節點仍然存在熱點。

    之前,為了解決COUNT DISTINCT的熱點問題,通常需要手動改寫為兩層聚合(增加按Distinct Key取模的打散層)。

    從Flink1.9.0版本開始,提供了COUNT DISTINCT自動打散功能,不需要手動重寫。Split Distinct和LocalGlobal的原理對比參見下圖。

    舉例:統計一天的UV

    SELECT day, COUNT(DISTINCT user_id)

    FROM T

    GROUP BY day

    如果手動實現兩階段聚合:

    SELECT day, SUM(cnt)

    FROM (

    ????SELECT day, COUNT(DISTINCT user_id) as cnt

    ????FROM T

    ????GROUP BY day, MOD(HASH_CODE(user_id), 1024)

    )

    GROUP BY day

    第一層聚合: 將Distinct Key打散求COUNT DISTINCT。

    第二層聚合: 對打散去重后的數據進行SUM匯總。

    • Split Distinct開啟方式

    默認不開啟,使用參數顯式開啟:

  • table.optimizer.distinct-agg.split.enabled: true,默認false。
  • table.optimizer.distinct-agg.split.bucket-num: Split Distinct優化在第一層聚合中,被打散的bucket數目。默認1024。
  • // 初始化table environment

    TableEnvironment tEnv = ...

    // 獲取 tableEnv的配置對象

    Configuration configuration = tEnv.getConfig().getConfiguration();

    // 設置參數:

    // 開啟Split Distinct

    configuration.setString("table.optimizer.distinct-agg.split.enabled", "true");

    // 第一層打散的bucket數目

    configuration.setString("table.optimizer.distinct-agg.split.bucket-num", "1024");

    • 判斷是否生效

    觀察最終生成的拓撲圖的節點名中是否包含Expand節點,或者原來一層的聚合變成了兩層的聚合。

    • 適用場景

    使用COUNT DISTINCT,但無法滿足聚合節點性能要求。

    • 注意事項:

    1)目前不能在包含UDAF的Flink SQL中使用Split Distinct優化方法。

    2)拆分出來的兩個GROUP聚合還可參與LocalGlobal優化。

    3)從Flink1.9.0版本開始,提供了COUNT DISTINCT自動打散功能,不需要手動重寫(不用像上面的例子去手動實現)。


  • 改寫為AGG WITH FILTER語法(提升大量COUNT DISTINCT場景性能)
  • 在某些場景下,可能需要從不同維度來統計UV,如Android中的UV,iPhone中的UV,Web中的UV和總UV,這時,可能會使用如下CASE WHEN語法。

    SELECT

    ?day,

    ?COUNT(DISTINCT user_id) AS total_uv,

    ?COUNT(DISTINCT CASE WHEN flag IN ('android', 'iphone') THEN user_id ELSE NULL END) AS app_uv,

    ?COUNT(DISTINCT CASE WHEN flag IN ('wap', 'other') THEN user_id ELSE NULL END) AS web_uv

    FROM T

    GROUP BY day

    在這種情況下,建議使用FILTER語法, 目前的Flink SQL優化器可以識別同一唯一鍵上的不同FILTER參數。如,在上面的示例中,三個COUNT DISTINCT都作用在user_id列上。此時,經過優化器識別后,Flink可以只使用一個共享狀態實例,而不是三個狀態實例,可減少狀態的大小和對狀態的訪問。

    將上邊的CASE WHEN替換成FILTER后,如下所示:

    SELECT

    ?day,

    ?COUNT(DISTINCT user_id) AS total_uv,

    ?COUNT(DISTINCT user_id) FILTER (WHERE flag IN ('android', 'iphone')) AS app_uv,

    ?COUNT(DISTINCT user_id) FILTER (WHERE flag IN ('wap', 'other')) AS web_uv

    FROM T

    GROUP BY day


  • TopN優化

  • 使用最優算法
  • 當TopN的輸入是非更新流(例如Source),TopN只有一種算法AppendRank。當TopN的輸入是更新流時(例如經過了AGG/JOIN計算),TopN有2種算法,性能從高到低分別是:UpdateFastRank 和RetractRank。算法名字會顯示在拓撲圖的節點名字上。

    注意:apache社區版的Flink1.12目前還沒有UnaryUpdateRank,阿里云實時計算版Flink才有

    • UpdateFastRank :最優算法

    需要具備2個條件:

    1)輸入流有PK(Primary Key)信息,例如ORDER BY AVG。

    2)排序字段的更新是單調的,且單調方向與排序方向相反。例如,ORDER BY COUNT/COUNT_DISTINCT/SUM(正數)DESC

    如果要獲取到優化Plan,則您需要在使用ORDER BY SUM DESC時,添加SUM為正數的過濾條件。

    • AppendFast:結果只追加,不更新
    • RetractRank:普通算法,性能差

    不建議在生產環境使用該算法。請檢查輸入流是否存在PK信息,如果存在,則可進行UpdateFastRank優化。

    • 無排名優化(解決數據膨脹問題)
    • TopN語法:

    SELECT *

    FROM (

    ??SELECT *,

    ????ROW_NUMBER() OVER ([PARTITION BY col1[, col2..]]

    ????ORDER BY col1 [asc|desc][, col2 [asc|desc]...]) AS rownum

    ??FROM table_name)

    WHERE rownum <= N [AND conditions]

    • 數據膨脹問題:

    根據TopN的語法,rownum字段會作為結果表的主鍵字段之一寫入結果表。但是這可能導致數據膨脹的問題。例如,收到一條原排名9的更新數據,更新后排名上升到1,則從1到9的數據排名都發生變化了,需要將這些數據作為更新都寫入結果表。這樣就產生了數據膨脹,導致結果表因為收到了太多的數據而降低更新速度。

    • 使用方式

    TopN的輸出結果無需要顯示rownum值,僅需在最終前端顯式時進行1次排序,極大地減少輸入結果表的數據量。只需要在外層查詢中將rownum字段裁剪掉即可

    // 最外層的字段,不寫 rownum

    SELECT col1, col2, col3

    FROM (

    ?SELECT col1, col2, col3

    ???ROW_NUMBER() OVER ([PARTITION BY col1[, col2..]]

    ???ORDER BY col1 [asc|desc][, col2 [asc|desc]...]) AS rownum

    ?FROM table_name)

    WHERE rownum <= N [AND conditions]

    在無rownum的場景中,對于結果表主鍵的定義需要特別小心。如果定義有誤,會直接導致TopN結果的不正確。 無rownum場景中,主鍵應為TopN上游GROUP BY節點的KEY列表。


  • 增加TopN的Cache大小
  • TopN為了提升性能有一個State Cache層,Cache層能提升對State的訪問效率。TopN的Cache命中率的計算公式為。

    cache_hit = cache_size*parallelism/top_n/partition_key_num

    例如,Top100配置緩存10000條,并發50,當PatitionBy的key維度較大時,例如10萬級別時,Cache命中率只有10000*50/100/100000=5%,命中率會很低,導致大量的請求都會擊中State(磁盤),性能會大幅下降。因此當PartitionKey維度特別大時,可以適當加大TopN的CacheS ize,相對應的也建議適當加大TopN節點的Heap Memory。

    • 使用方式

    // 初始化table environment

    TableEnvironment tEnv = ...

    // 獲取 tableEnv的配置對象

    Configuration configuration = tEnv.getConfig().getConfiguration();

    // 設置參數:

    // 默認10000條,調整TopN cahce到20萬,那么理論命中率能達200000*50/100/100000 = 100%

    configuration.setString("table.exec.topn.cache-size", "200000");

    注意:目前源碼中標記為實驗項,官網中未列出該

  • PartitionBy的字段中要有時間類字段
  • 例如每天的排名,要帶上Day字段。否則TopN的結果到最后會由于State ttl有錯亂。

  • 優化后的SQL示例
  • insert

    ??into print_test

    SELECT

    ??cate_id,

    ??seller_id,

    ??stat_date,

    ??pay_ord_amt ?--不輸出rownum字段,能減小結果表的輸出量(無排名優化)

    FROM (

    ????SELECT

    ??????*,

    ??????ROW_NUMBER () OVER (

    ????????PARTITION BY cate_id,

    ????????stat_date ?--注意要有時間字段,否則state過期會導致數據錯亂(分區字段優化)

    ????????ORDER

    ??????????BY pay_ord_amt DESC ?--根據上游sum結果排序。排序字段的更新是單調的,且單調方向與排序方向相反(走最優算法)

    ??????) as rownum ?

    ????FROM (

    ????????SELECT

    ??????????cate_id,

    ??????????seller_id,

    ??????????stat_date,

    ??????????--重點。聲明Sum的參數都是正數,所以Sum的結果是單調遞增的,因此TopN能使用優化算法,只獲取前100個數據(走最優算法)

    ??????????sum (total_fee) filter (

    ????????????where

    ??????????????total_fee >= 0

    ??????????) as pay_ord_amt

    ????????FROM

    ??????????random_test

    ????????WHERE

    ??????????total_fee >= 0

    ????????GROUP

    ??????????BY cate_name,

    ??????????seller_id,

    ??????????stat_date

    ??????) a

    ????WHERE

    ??????rownum <= 100

    ??);

  • 高效去重方案
  • 由于SQL上沒有直接支持去重的語法,還要靈活的保留第一條或保留最后一條。因此我們使用了SQL的ROW_NUMBER OVER WINDOW功能來實現去重語法。去重本質上是一種特殊的TopN。

  • 保留首行的去重策略(Deduplicate Keep FirstRow)
  • 保留KEY下第一條出現的數據,之后出現該KEY下的數據會被丟棄掉。因為STATE中只存儲了KEY數據,所以性能較優,示例如下:

    SELECT *

    FROM (

    ??SELECT *,

    ????ROW_NUMBER() OVER (PARTITION BY b ORDER BY proctime) as rowNum

    ??FROM T

    )

    WHERE rowNum = 1

    以上示例是將T表按照b字段進行去重,并按照系統時間保留第一條數據。Proctime在這里是源表T中的一個具有Processing Time屬性的字段。如果按照系統時間去重,也可以將Proctime字段簡化PROCTIME()函數調用,可以省略Proctime字段的聲明。

  • 保留末行的去重策略(Deduplicate Keep LastRow)
  • 保留KEY下最后一條出現的數據。保留末行的去重策略性能略優于LAST_VALUE函數,示例如下:

    SELECT *

    FROM (

    ??SELECT *,

    ????ROW_NUMBER() OVER (PARTITION BY b, d ORDER BY rowtime DESC) as rowNum

    ??FROM T

    )

    WHERE rowNum = 1

    以上示例是將T表按照b和d字段進行去重,并按照業務時間保留最后一條數據。Rowtime在這里是源表T中的一個具有Event Time屬性的字段。

  • 高效的內置函數

  • 使用內置函數替換自定義函數
  • Flink的內置函數在持續的優化當中,請盡量使用內部函數替換自定義函數。使用內置函數好處:

    1)優化數據序列化和反序列化的耗時。

    2)新增直接對字節單位進行操作的功能。

    支持的系統內置函數:


    • LIKE操作注意事項
    • 如果需要進行StartWith操作,使用LIKE 'xxx%'。
    • 如果需要進行EndWith操作,使用LIKE '%xxx'。
    • 如果需要進行Contains操作,使用LIKE '%xxx%'。
    • 如果需要進行Equals操作,使用LIKE 'xxx',等價于str = 'xxx'。
    • 如果需要匹配 _ 字符,請注意要完成轉義LIKE '%seller/id%' ESCAPE '/'。_在SQL中屬于單字符通配符,能匹配任何字符。如果聲明為 LIKE '%seller_id%',則不單會匹配seller_id還會匹配seller#id、sellerxid或seller1id 等,導致結果錯誤。

    • 慎用正則函數(REGEXP)

    正則表達式是非常耗時的操作,對比加減乘除通常有百倍的性能開銷,而且正則表達式在某些極端情況下可能會進入無限循環,導致作業阻塞。建議使用LIKE。正則函數包括:

    • REGEXP
    • REGEXP_EXTRACT
    • REGEXP_REPLACE

    • 指定時區

    本地時區定義了當前會話時區id。當本地時區的時間戳進行轉換時使用。在內部,帶有本地時區的時間戳總是以UTC時區表示。但是,當轉換為不包含時區的數據類型時(例如TIMESTAMP, TIME或簡單的STRING),會話時區在轉換期間被使用。為了避免時區錯亂的問題,可以參數指定時區。

    // 初始化table environment

    TableEnvironment tEnv = ...

    // 獲取 tableEnv的配置對象

    Configuration configuration = tEnv.getConfig().getConfiguration();

    // 設置參數:

    // 指定時區

    configuration.setString("table.local-time-zone", "Asia/Shanghai");


  • 設置參數總結
  • 總結以上的調優參數,代碼如下:

    // 初始化table environment

    TableEnvironment tEnv = ...

    // 獲取 tableEnv的配置對象

    Configuration configuration = tEnv.getConfig().getConfiguration();

    // 設置參數:

    // 開啟miniBatch

    configuration.setString("table.exec.mini-batch.enabled", "true");

    // 批量輸出的間隔時間

    configuration.setString("table.exec.mini-batch.allow-latency", "5 s");

    // 防止OOM設置每個批次最多緩存數據的條數,可以設為2萬條

    configuration.setString("table.exec.mini-batch.size", "20000");

    // 開啟LocalGlobal

    configuration.setString("table.optimizer.agg-phase-strategy", "TWO_PHASE");

    // 開啟Split Distinct

    configuration.setString("table.optimizer.distinct-agg.split.enabled", "true");

    // 第一層打散的bucket數目

    configuration.setString("table.optimizer.distinct-agg.split.bucket-num", "1024");

    // TopN 的緩存條數

    configuration.setString("table.exec.topn.cache-size", "200000");

    // 指定時區

    configuration.setString("table.local-time-zone", "Asia/Shanghai");

    總結

    以上是生活随笔為你收集整理的Flink 运维与调优的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    天海翼激烈高潮到腰振不止 | 亚洲精品午夜无码电影网 | 蜜桃视频插满18在线观看 | 亚洲色无码一区二区三区 | 国产麻豆精品精东影业av网站 | 人妻aⅴ无码一区二区三区 | 亚洲第一网站男人都懂 | 国内精品人妻无码久久久影院蜜桃 | 日本护士xxxxhd少妇 | 国产成人av免费观看 | 高清不卡一区二区三区 | 精品国产成人一区二区三区 | 午夜肉伦伦影院 | 99久久人妻精品免费一区 | 激情亚洲一区国产精品 | 久久国产精品偷任你爽任你 | 影音先锋中文字幕无码 | 久久精品国产亚洲精品 | 国产亚洲精品久久久闺蜜 | 综合人妻久久一区二区精品 | 色窝窝无码一区二区三区色欲 | 国产色xx群视频射精 | 7777奇米四色成人眼影 | 日韩欧美成人免费观看 | 丝袜足控一区二区三区 | 国产熟妇另类久久久久 | 久久精品中文字幕大胸 | 色老头在线一区二区三区 | 国产亚av手机在线观看 | 日韩精品乱码av一区二区 | 久9re热视频这里只有精品 | 久久亚洲国产成人精品性色 | 精品国产一区二区三区四区在线看 | 中文字幕精品av一区二区五区 | 夜精品a片一区二区三区无码白浆 | 国产午夜无码视频在线观看 | aⅴ亚洲 日韩 色 图网站 播放 | 欧美xxxx黑人又粗又长 | 性色av无码免费一区二区三区 | 亚洲区小说区激情区图片区 | 亚洲aⅴ无码成人网站国产app | 2019nv天堂香蕉在线观看 | 亚洲欧美日韩成人高清在线一区 | 精品偷自拍另类在线观看 | 国产莉萝无码av在线播放 | v一区无码内射国产 | 波多野结衣一区二区三区av免费 | 又大又硬又爽免费视频 | 一区二区三区乱码在线 | 欧洲 | 国产精品沙发午睡系列 | 红桃av一区二区三区在线无码av | 黑人巨大精品欧美黑寡妇 | 乌克兰少妇xxxx做受 | 小泽玛莉亚一区二区视频在线 | 国产绳艺sm调教室论坛 | 天天摸天天碰天天添 | 欧美激情内射喷水高潮 | 久久精品国产亚洲精品 | 久久无码专区国产精品s | 久久无码人妻影院 | 国产精品二区一区二区aⅴ污介绍 | 亚洲日本va中文字幕 | 少妇高潮一区二区三区99 | 婷婷五月综合激情中文字幕 | 88国产精品欧美一区二区三区 | 国产一区二区三区影院 | 超碰97人人射妻 | 久精品国产欧美亚洲色aⅴ大片 | 精品久久久久久亚洲精品 | 少妇邻居内射在线 | 丰满少妇女裸体bbw | 天堂а√在线地址中文在线 | 国产亚洲美女精品久久久2020 | 女人和拘做爰正片视频 | 色诱久久久久综合网ywww | 欧美人与牲动交xxxx | 久久综合给久久狠狠97色 | 国产av无码专区亚洲a∨毛片 | 中文精品无码中文字幕无码专区 | 风流少妇按摩来高潮 | 国产在线精品一区二区高清不卡 | 男人和女人高潮免费网站 | 天天躁日日躁狠狠躁免费麻豆 | 久久精品无码一区二区三区 | 网友自拍区视频精品 | 国产成人无码av在线影院 | 一二三四在线观看免费视频 | 久久国产精品偷任你爽任你 | 两性色午夜免费视频 | 无码免费一区二区三区 | 成人无码精品一区二区三区 | 日日麻批免费40分钟无码 | 真人与拘做受免费视频一 | 最近中文2019字幕第二页 | 亚洲色欲久久久综合网东京热 | 日日噜噜噜噜夜夜爽亚洲精品 | 免费人成网站视频在线观看 | 中文字幕av无码一区二区三区电影 | 国产激情精品一区二区三区 | 亚洲理论电影在线观看 | 欧美大屁股xxxxhd黑色 | 国产精华av午夜在线观看 | 美女扒开屁股让男人桶 | 丰满少妇女裸体bbw | 牲欲强的熟妇农村老妇女 | 日产国产精品亚洲系列 | 无码人中文字幕 | 狠狠色色综合网站 | 国产sm调教视频在线观看 | 夜精品a片一区二区三区无码白浆 | 撕开奶罩揉吮奶头视频 | 亚洲精品综合一区二区三区在线 | 国产艳妇av在线观看果冻传媒 | 久久aⅴ免费观看 | 少妇愉情理伦片bd | 亚洲精品一区二区三区婷婷月 | 欧美35页视频在线观看 | 好爽又高潮了毛片免费下载 | 日本乱人伦片中文三区 | 男人的天堂av网站 | 国产成人无码av在线影院 | 国产精品va在线观看无码 | 精品熟女少妇av免费观看 | 奇米影视7777久久精品 | 人妻天天爽夜夜爽一区二区 | 一本大道久久东京热无码av | 一本大道久久东京热无码av | 久久精品人人做人人综合试看 | 亚洲国产欧美日韩精品一区二区三区 | 亚洲午夜福利在线观看 | 国产亚洲欧美日韩亚洲中文色 | 欧美老人巨大xxxx做受 | 免费看少妇作爱视频 | 男人的天堂2018无码 | 久久久久久国产精品无码下载 | 成人亚洲精品久久久久 | 国产精品亚洲а∨无码播放麻豆 | 四虎国产精品一区二区 | 免费人成在线观看网站 | 亚洲精品无码人妻无码 | 亚洲另类伦春色综合小说 | 东京热男人av天堂 | 国产精品毛多多水多 | 一个人看的www免费视频在线观看 | 在线播放免费人成毛片乱码 | 麻豆国产人妻欲求不满谁演的 | 自拍偷自拍亚洲精品被多人伦好爽 | 免费乱码人妻系列无码专区 | 成人无码精品1区2区3区免费看 | 亚洲a无码综合a国产av中文 | 搡女人真爽免费视频大全 | 国产办公室秘书无码精品99 | 国产精品沙发午睡系列 | 少妇无码一区二区二三区 | 水蜜桃色314在线观看 | 久久亚洲精品中文字幕无男同 | 久久国产精品二国产精品 | 国内少妇偷人精品视频免费 | 人妻插b视频一区二区三区 | 鲁大师影院在线观看 | 国产精品沙发午睡系列 | 精品乱码久久久久久久 | 日韩 欧美 动漫 国产 制服 | 人妻互换免费中文字幕 | 97夜夜澡人人爽人人喊中国片 | 国产麻豆精品一区二区三区v视界 | 风流少妇按摩来高潮 | 成人欧美一区二区三区黑人 | 成人三级无码视频在线观看 | 亚洲日韩av一区二区三区四区 | 成人精品一区二区三区中文字幕 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲日韩中文字幕在线播放 | 日本xxxx色视频在线观看免费 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲精品一区二区三区在线观看 | 男女性色大片免费网站 | 人人妻人人澡人人爽精品欧美 | 国产97色在线 | 免 | 日本xxxx色视频在线观看免费 | 久久精品国产一区二区三区 | 久久久久99精品成人片 | 婷婷六月久久综合丁香 | 四虎4hu永久免费 | 日韩成人一区二区三区在线观看 | 久久人人爽人人人人片 | 99久久婷婷国产综合精品青草免费 | 国产精品久久久久久久9999 | 亚洲精品久久久久久一区二区 | 无码人妻丰满熟妇区毛片18 | 成年美女黄网站色大免费全看 | 中文字幕无线码 | 精品国产一区av天美传媒 | 国产亲子乱弄免费视频 | 日本又色又爽又黄的a片18禁 | 国产激情一区二区三区 | 天堂久久天堂av色综合 | 67194成是人免费无码 | 中文字幕乱码人妻无码久久 | 成在人线av无码免观看麻豆 | 色欲综合久久中文字幕网 | 大地资源中文第3页 | 国产人妖乱国产精品人妖 | 最近免费中文字幕中文高清百度 | 亚洲精品久久久久久久久久久 | 色综合久久久无码网中文 | 亚洲欧美中文字幕5发布 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 东京一本一道一二三区 | 少妇高潮喷潮久久久影院 | 国产极品美女高潮无套在线观看 | 成人片黄网站色大片免费观看 | 夫妻免费无码v看片 | 狠狠躁日日躁夜夜躁2020 | 玩弄中年熟妇正在播放 | 丁香啪啪综合成人亚洲 | 国产在线精品一区二区高清不卡 | 性色欲情网站iwww九文堂 | 国产莉萝无码av在线播放 | 国产两女互慰高潮视频在线观看 | 国产精品a成v人在线播放 | 欧洲精品码一区二区三区免费看 | 无码毛片视频一区二区本码 | 日日干夜夜干 | 伊人久久婷婷五月综合97色 | 无码播放一区二区三区 | 丰满人妻被黑人猛烈进入 | 久久久久久九九精品久 | 欧美乱妇无乱码大黄a片 | 免费人成在线观看网站 | 亚洲色欲久久久综合网东京热 | 亚洲va欧美va天堂v国产综合 | 欧美国产日韩亚洲中文 | 久久综合网欧美色妞网 | 7777奇米四色成人眼影 | 久久国语露脸国产精品电影 | 欧美日本日韩 | 亚洲乱码国产乱码精品精 | 久久天天躁夜夜躁狠狠 | 久久精品99久久香蕉国产色戒 | 丰腴饱满的极品熟妇 | 水蜜桃av无码 | 丝袜 中出 制服 人妻 美腿 | 亚洲理论电影在线观看 | 无码av免费一区二区三区试看 | 成人欧美一区二区三区黑人免费 | 日本大香伊一区二区三区 | 伊人久久大香线焦av综合影院 | 成人精品视频一区二区三区尤物 | 日本www一道久久久免费榴莲 | 一本久道久久综合狠狠爱 | 国产精品a成v人在线播放 | 国产高潮视频在线观看 | 国产精品久久久 | 夜精品a片一区二区三区无码白浆 | 国产精品久久久av久久久 | 奇米影视888欧美在线观看 | 国产精品无码一区二区桃花视频 | 精品无码一区二区三区的天堂 | 久久久精品人妻久久影视 | 捆绑白丝粉色jk震动捧喷白浆 | 在教室伦流澡到高潮hnp视频 | 偷窥村妇洗澡毛毛多 | 国产午夜无码视频在线观看 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 久久99久久99精品中文字幕 | 啦啦啦www在线观看免费视频 | 国产在线aaa片一区二区99 | 亚洲人成网站免费播放 | 亚洲s码欧洲m码国产av | 国内丰满熟女出轨videos | 国产香蕉97碰碰久久人人 | 国产精品久久久久无码av色戒 | 蜜桃视频韩日免费播放 | 人妻体内射精一区二区三四 | 九九在线中文字幕无码 | 欧美国产日产一区二区 | 亚洲高清偷拍一区二区三区 | 在线观看欧美一区二区三区 | 国产精品二区一区二区aⅴ污介绍 | 福利一区二区三区视频在线观看 | 亚洲aⅴ无码成人网站国产app | 啦啦啦www在线观看免费视频 | 国精品人妻无码一区二区三区蜜柚 | 亚洲色www成人永久网址 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 全球成人中文在线 | 在线天堂新版最新版在线8 | 中文毛片无遮挡高清免费 | 精品国产一区二区三区四区在线看 | 欧美老妇交乱视频在线观看 | 精品国精品国产自在久国产87 | av在线亚洲欧洲日产一区二区 | 亚洲乱码日产精品bd | 国产97人人超碰caoprom | 欧美性猛交内射兽交老熟妇 | 美女毛片一区二区三区四区 | 精品欧美一区二区三区久久久 | 丝袜足控一区二区三区 | 午夜性刺激在线视频免费 | 3d动漫精品啪啪一区二区中 | 国精产品一区二区三区 | 亚洲人成网站免费播放 | 麻豆国产人妻欲求不满谁演的 | 国产在线精品一区二区三区直播 | 久久精品国产日本波多野结衣 | 成熟妇人a片免费看网站 | 亚洲熟女一区二区三区 | 久久久久亚洲精品中文字幕 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲综合另类小说色区 | 超碰97人人做人人爱少妇 | 精品人妻人人做人人爽夜夜爽 | 九九在线中文字幕无码 | 国产成人一区二区三区在线观看 | 18精品久久久无码午夜福利 | 天天拍夜夜添久久精品 | 一本久久a久久精品亚洲 | 小泽玛莉亚一区二区视频在线 | 天堂а√在线中文在线 | 欧美人与禽猛交狂配 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲人成网站色7799 | 成人一区二区免费视频 | 99久久99久久免费精品蜜桃 | 亚洲中文无码av永久不收费 | 蜜桃臀无码内射一区二区三区 | 国产97在线 | 亚洲 | 给我免费的视频在线观看 | 一二三四社区在线中文视频 | 自拍偷自拍亚洲精品10p | 亚洲国产精品久久久天堂 | 亚洲日韩一区二区 | 国产成人无码av一区二区 | 久久久精品人妻久久影视 | 国产真人无遮挡作爱免费视频 | √天堂中文官网8在线 | 国产精品久久久av久久久 | 最近中文2019字幕第二页 | 疯狂三人交性欧美 | 大地资源网第二页免费观看 | 国产亚洲视频中文字幕97精品 | 中文亚洲成a人片在线观看 | 国产午夜福利100集发布 | 日韩人妻系列无码专区 | 欧美激情内射喷水高潮 | 一个人看的www免费视频在线观看 | 国产精品免费大片 | 夫妻免费无码v看片 | 国产欧美亚洲精品a | 国产两女互慰高潮视频在线观看 | 扒开双腿吃奶呻吟做受视频 | 疯狂三人交性欧美 | 久久五月精品中文字幕 | 精品欧洲av无码一区二区三区 | 老熟女乱子伦 | 午夜精品久久久内射近拍高清 | 亚洲区欧美区综合区自拍区 | 性色欲网站人妻丰满中文久久不卡 | 久久天天躁狠狠躁夜夜免费观看 | 熟女少妇在线视频播放 | 国产另类ts人妖一区二区 | 四虎影视成人永久免费观看视频 | 99久久精品无码一区二区毛片 | 噜噜噜亚洲色成人网站 | 日日摸日日碰夜夜爽av | 国产精品美女久久久 | 国产电影无码午夜在线播放 | 亚洲成av人片在线观看无码不卡 | 久久人妻内射无码一区三区 | 久久视频在线观看精品 | 玩弄少妇高潮ⅹxxxyw | 日本乱偷人妻中文字幕 | 亚洲国精产品一二二线 | 国产精品免费大片 | 日本护士毛茸茸高潮 | 国产成人精品视频ⅴa片软件竹菊 | 2020久久香蕉国产线看观看 | 婷婷色婷婷开心五月四房播播 | 成 人 网 站国产免费观看 | 给我免费的视频在线观看 | 波多野结衣aⅴ在线 | 老熟女重囗味hdxx69 | 久久久中文字幕日本无吗 | 女人被爽到呻吟gif动态图视看 | 国产精品美女久久久网av | 中文字幕精品av一区二区五区 | 久久久久久久久888 | 永久免费观看美女裸体的网站 | 亚洲人成网站色7799 | 欧美国产日韩久久mv | 偷窥日本少妇撒尿chinese | 国产精品va在线播放 | 天天摸天天碰天天添 | 精品夜夜澡人妻无码av蜜桃 | 日本免费一区二区三区最新 | 色综合视频一区二区三区 | 精品久久久久久人妻无码中文字幕 | 少妇高潮一区二区三区99 | 亚洲色偷偷男人的天堂 | 欧美日韩精品 | 亚洲国产精华液网站w | 亚洲a无码综合a国产av中文 | 亚洲熟女一区二区三区 | 人妻aⅴ无码一区二区三区 | 精品国产av色一区二区深夜久久 | 欧美日韩视频无码一区二区三 | 日韩人妻少妇一区二区三区 | 兔费看少妇性l交大片免费 | 欧美性黑人极品hd | 色爱情人网站 | 扒开双腿吃奶呻吟做受视频 | 少妇高潮喷潮久久久影院 | 亚洲а∨天堂久久精品2021 | 久久久久久久久888 | 亚洲日本在线电影 | 人人妻人人澡人人爽人人精品 | 日韩精品无码一区二区中文字幕 | 精品久久久无码人妻字幂 | 99久久人妻精品免费一区 | 亚洲自偷精品视频自拍 | 久久久久久久人妻无码中文字幕爆 | 性欧美大战久久久久久久 | 亲嘴扒胸摸屁股激烈网站 | 国产一区二区不卡老阿姨 | 久久久国产一区二区三区 | 亚洲综合无码一区二区三区 | 久久久国产精品无码免费专区 | 中文字幕人妻无码一夲道 | 久久天天躁夜夜躁狠狠 | 成人无码精品1区2区3区免费看 | 亚洲国产欧美国产综合一区 | 精品无人区无码乱码毛片国产 | 色一情一乱一伦一视频免费看 | 中文字幕精品av一区二区五区 | 婷婷五月综合激情中文字幕 | 88国产精品欧美一区二区三区 | 国产精品人人爽人人做我的可爱 | 55夜色66夜色国产精品视频 | 欧美精品免费观看二区 | 国产人妖乱国产精品人妖 | 成人免费视频视频在线观看 免费 | 啦啦啦www在线观看免费视频 | 欧美真人作爱免费视频 | 国产成人午夜福利在线播放 | 欧美放荡的少妇 | 99精品国产综合久久久久五月天 | 久久精品国产一区二区三区 | 无码精品国产va在线观看dvd | 妺妺窝人体色www在线小说 | 欧美自拍另类欧美综合图片区 | 亚洲国产成人av在线观看 | 亚洲色大成网站www国产 | 亚洲gv猛男gv无码男同 | 成人免费视频视频在线观看 免费 | 在线观看免费人成视频 | 香蕉久久久久久av成人 | 一本久久a久久精品vr综合 | 熟妇女人妻丰满少妇中文字幕 | 久久久精品国产sm最大网站 | 特黄特色大片免费播放器图片 | 成人欧美一区二区三区黑人免费 | 人妻少妇精品无码专区动漫 | 久久综合狠狠综合久久综合88 | 亚洲区小说区激情区图片区 | 又大又紧又粉嫩18p少妇 | 欧美国产日韩亚洲中文 | 在线天堂新版最新版在线8 | 欧美兽交xxxx×视频 | 性欧美牲交在线视频 | 日欧一片内射va在线影院 | 国精产品一品二品国精品69xx | 国产黑色丝袜在线播放 | 中文字幕+乱码+中文字幕一区 | 最近免费中文字幕中文高清百度 | 午夜成人1000部免费视频 | 亚洲国产精品久久人人爱 | 亚洲精品美女久久久久久久 | 十八禁真人啪啪免费网站 | 97se亚洲精品一区 | 日本精品少妇一区二区三区 | av无码不卡在线观看免费 | 伊在人天堂亚洲香蕉精品区 | 欧美野外疯狂做受xxxx高潮 | 亚洲区小说区激情区图片区 | 精品亚洲成av人在线观看 | 午夜成人1000部免费视频 | 欧美一区二区三区视频在线观看 | 欧美xxxx黑人又粗又长 | 久久国产精品偷任你爽任你 | 国产av人人夜夜澡人人爽麻豆 | 日韩av无码一区二区三区不卡 | 午夜性刺激在线视频免费 | 欧洲熟妇精品视频 | 亚洲无人区午夜福利码高清完整版 | 一本大道久久东京热无码av | 国产精品无码一区二区桃花视频 | 亚洲人亚洲人成电影网站色 | 国产97在线 | 亚洲 | 无码人妻少妇伦在线电影 | 伊人久久大香线蕉av一区二区 | 国产精品爱久久久久久久 | 在线精品国产一区二区三区 | 又紧又大又爽精品一区二区 | 丰满妇女强制高潮18xxxx | 国产精品福利视频导航 | 人妻aⅴ无码一区二区三区 | 亚洲精品国产第一综合99久久 | 亚洲国产日韩a在线播放 | 亚洲中文字幕无码中文字在线 | 丰满少妇女裸体bbw | 一区二区三区乱码在线 | 欧洲 | 性生交片免费无码看人 | av人摸人人人澡人人超碰下载 | 国产精品怡红院永久免费 | 国产两女互慰高潮视频在线观看 | 露脸叫床粗话东北少妇 | 蜜桃臀无码内射一区二区三区 | 沈阳熟女露脸对白视频 | 国产无遮挡吃胸膜奶免费看 | 精品国偷自产在线 | 中文字幕人成乱码熟女app | 亚洲国产一区二区三区在线观看 | 在线 国产 欧美 亚洲 天堂 | 牲交欧美兽交欧美 | 丝袜 中出 制服 人妻 美腿 | 国产国产精品人在线视 | 人人妻人人澡人人爽人人精品 | 在线观看欧美一区二区三区 | 亚洲阿v天堂在线 | 国产亲子乱弄免费视频 | 精品日本一区二区三区在线观看 | 亚洲 另类 在线 欧美 制服 | 小sao货水好多真紧h无码视频 | 国产两女互慰高潮视频在线观看 | 大肉大捧一进一出视频出来呀 | 亚洲欧美精品aaaaaa片 | 老司机亚洲精品影院无码 | 亚洲精品国产品国语在线观看 | 青青青爽视频在线观看 | 亚洲一区二区三区国产精华液 | 中文亚洲成a人片在线观看 | 1000部夫妻午夜免费 | 国产精品igao视频网 | 欧美猛少妇色xxxxx | 国产成人精品一区二区在线小狼 | 纯爱无遮挡h肉动漫在线播放 | 国产成人精品三级麻豆 | 2020久久超碰国产精品最新 | 亚洲精品国产a久久久久久 | 妺妺窝人体色www婷婷 | 18黄暴禁片在线观看 | 装睡被陌生人摸出水好爽 | 国产一区二区三区四区五区加勒比 | 乱码av麻豆丝袜熟女系列 | 亚洲精品中文字幕久久久久 | 女人被男人躁得好爽免费视频 | 天天躁日日躁狠狠躁免费麻豆 | 免费观看激色视频网站 | 成人毛片一区二区 | 乱人伦人妻中文字幕无码 | 国产免费久久精品国产传媒 | 亚洲成色在线综合网站 | 欧美国产亚洲日韩在线二区 | 国产精品99久久精品爆乳 | 久热国产vs视频在线观看 | 日韩av无码中文无码电影 | 亚洲啪av永久无码精品放毛片 | 中文字幕乱码人妻无码久久 | 国产人妻人伦精品1国产丝袜 | 18精品久久久无码午夜福利 | 欧美黑人巨大xxxxx | 亚洲日韩一区二区三区 | aⅴ亚洲 日韩 色 图网站 播放 | 永久免费观看国产裸体美女 | 性生交片免费无码看人 | 亚洲精品久久久久久一区二区 | 欧美日韩在线亚洲综合国产人 | 成人三级无码视频在线观看 | 精品乱子伦一区二区三区 | 国产亚洲日韩欧美另类第八页 | 亚洲 激情 小说 另类 欧美 | 人妻尝试又大又粗久久 | 久9re热视频这里只有精品 | 少妇性荡欲午夜性开放视频剧场 | 日日橹狠狠爱欧美视频 | 人人妻人人澡人人爽人人精品浪潮 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲区小说区激情区图片区 | 蜜臀aⅴ国产精品久久久国产老师 | 澳门永久av免费网站 | 亚洲色www成人永久网址 | 日产精品99久久久久久 | 亚洲熟悉妇女xxx妇女av | 亚洲成色www久久网站 | 国产精品视频免费播放 | 亚洲综合无码一区二区三区 | 国产后入清纯学生妹 | 国产婷婷色一区二区三区在线 | 天天做天天爱天天爽综合网 | 在线а√天堂中文官网 | 欧美放荡的少妇 | 亚洲国产精品无码一区二区三区 | 色情久久久av熟女人妻网站 | 国产成人精品优优av | 窝窝午夜理论片影院 | 国内揄拍国内精品人妻 | aa片在线观看视频在线播放 | 色婷婷久久一区二区三区麻豆 | 国产超碰人人爽人人做人人添 | 成人无码视频在线观看网站 | 日本丰满熟妇videos | 国产亚洲精品久久久久久大师 | 在线天堂新版最新版在线8 | 久久综合网欧美色妞网 | 人人妻人人澡人人爽欧美一区九九 | 无码毛片视频一区二区本码 | 国产熟女一区二区三区四区五区 | 一本色道久久综合狠狠躁 | 丰满人妻翻云覆雨呻吟视频 | 国产精品办公室沙发 | 欧美成人高清在线播放 | 亚洲色无码一区二区三区 | 国产色在线 | 国产 | 男女性色大片免费网站 | 免费国产黄网站在线观看 | 草草网站影院白丝内射 | 国内精品人妻无码久久久影院 | 性史性农村dvd毛片 | 嫩b人妻精品一区二区三区 | 国产午夜视频在线观看 | 国产成人无码a区在线观看视频app | 学生妹亚洲一区二区 | 国产香蕉尹人综合在线观看 | 久久综合九色综合欧美狠狠 | 国产精品久久久久久久9999 | 亚洲国产精品无码一区二区三区 | 国精产品一品二品国精品69xx | 爆乳一区二区三区无码 | 色综合久久88色综合天天 | 亚洲一区二区三区四区 | 丁香花在线影院观看在线播放 | 国产成人无码a区在线观看视频app | 日韩精品无码一本二本三本色 | 未满成年国产在线观看 | 中文字幕人成乱码熟女app | 免费中文字幕日韩欧美 | 国产精品爱久久久久久久 | 国产成人精品无码播放 | 国内综合精品午夜久久资源 | 欧美一区二区三区 | 国产精品嫩草久久久久 | 丰满少妇女裸体bbw | 亚洲最大成人网站 | 丁香花在线影院观看在线播放 | 成人影院yy111111在线观看 | 国产成人精品一区二区在线小狼 | 97久久精品无码一区二区 | 在线精品亚洲一区二区 | 欧美怡红院免费全部视频 | 色欲综合久久中文字幕网 | 天堂亚洲2017在线观看 | 亚洲欧洲日本综合aⅴ在线 | 久久久久成人精品免费播放动漫 | 伦伦影院午夜理论片 | 无码福利日韩神码福利片 | 少女韩国电视剧在线观看完整 | 国产精品亚洲专区无码不卡 | 中文精品久久久久人妻不卡 | 国产精品亚洲综合色区韩国 | 色噜噜亚洲男人的天堂 | 国产深夜福利视频在线 | 中文字幕av无码一区二区三区电影 | 熟妇激情内射com | 一本加勒比波多野结衣 | 色诱久久久久综合网ywww | 四虎永久在线精品免费网址 | 久久综合香蕉国产蜜臀av | 亚洲欧美色中文字幕在线 | 蜜桃视频插满18在线观看 | 色情久久久av熟女人妻网站 | 亚洲国产精品久久久天堂 | 国产无av码在线观看 | 激情人妻另类人妻伦 | 日韩欧美群交p片內射中文 | 一本色道婷婷久久欧美 | 色欲人妻aaaaaaa无码 | 国产综合在线观看 | 成人精品一区二区三区中文字幕 | 午夜精品一区二区三区在线观看 | 亚洲熟悉妇女xxx妇女av | 久久99久久99精品中文字幕 | 一本色道久久综合亚洲精品不卡 | 未满小14洗澡无码视频网站 | 3d动漫精品啪啪一区二区中 | 欧美国产亚洲日韩在线二区 | 亚洲精品一区二区三区四区五区 | 十八禁真人啪啪免费网站 | 中国女人内谢69xxxxxa片 | 六月丁香婷婷色狠狠久久 | 久久亚洲日韩精品一区二区三区 | 久久视频在线观看精品 | 国产偷国产偷精品高清尤物 | 国语精品一区二区三区 | 99久久人妻精品免费一区 | 色欲人妻aaaaaaa无码 | 国产精品无码一区二区桃花视频 | 亚洲日韩中文字幕在线播放 | 97夜夜澡人人双人人人喊 | 狂野欧美性猛xxxx乱大交 | 国产人妻精品一区二区三区不卡 | 亚洲国产成人av在线观看 | 成人免费视频一区二区 | 久久伊人色av天堂九九小黄鸭 | 亚洲欧美日韩成人高清在线一区 | 夜先锋av资源网站 | 台湾无码一区二区 | 国产人妖乱国产精品人妖 | 久久综合狠狠综合久久综合88 | 99在线 | 亚洲 | 中文无码成人免费视频在线观看 | 图片区 小说区 区 亚洲五月 | 国内丰满熟女出轨videos | 97久久精品无码一区二区 | 免费观看的无遮挡av | 国内丰满熟女出轨videos | 狠狠cao日日穞夜夜穞av | 国产午夜亚洲精品不卡下载 | 亚洲精品久久久久久久久久久 | 国产免费久久久久久无码 | 成人欧美一区二区三区黑人免费 | 丁香啪啪综合成人亚洲 | 欧美日韩色另类综合 | 无码人妻精品一区二区三区不卡 | 67194成是人免费无码 | 捆绑白丝粉色jk震动捧喷白浆 | 99久久人妻精品免费二区 | 午夜时刻免费入口 | 天堂а√在线地址中文在线 | 黑人粗大猛烈进出高潮视频 | 国产xxx69麻豆国语对白 | 97se亚洲精品一区 | 人妻夜夜爽天天爽三区 | 小sao货水好多真紧h无码视频 | 国产农村乱对白刺激视频 | 欧美肥老太牲交大战 | 免费观看又污又黄的网站 | 亚洲中文字幕无码一久久区 | 18禁黄网站男男禁片免费观看 | 丰满妇女强制高潮18xxxx | 久久精品人妻少妇一区二区三区 | 国产av一区二区精品久久凹凸 | 在线a亚洲视频播放在线观看 | 午夜成人1000部免费视频 | 欧美日韩在线亚洲综合国产人 | 欧美人与禽猛交狂配 | 九九综合va免费看 | 亚洲日本va午夜在线电影 | 亚拍精品一区二区三区探花 | 最近的中文字幕在线看视频 | 波多野42部无码喷潮在线 | 欧美性生交xxxxx久久久 | 中文精品无码中文字幕无码专区 | 人妻天天爽夜夜爽一区二区 | 久久 国产 尿 小便 嘘嘘 | 人妻插b视频一区二区三区 | 亚洲小说春色综合另类 | 亚洲综合无码久久精品综合 | 成人无码视频免费播放 | 国产成人精品视频ⅴa片软件竹菊 | 无码一区二区三区在线观看 | 国产人妻精品一区二区三区不卡 | 中文字幕av日韩精品一区二区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 成人影院yy111111在线观看 | 88国产精品欧美一区二区三区 | 国产一区二区三区精品视频 | 无码国产乱人伦偷精品视频 | 领导边摸边吃奶边做爽在线观看 | 精品水蜜桃久久久久久久 | 国产一区二区三区日韩精品 | 久久成人a毛片免费观看网站 | 亚洲国产精品成人久久蜜臀 | 久久久久免费精品国产 | 亚洲欧美国产精品久久 | 久久亚洲日韩精品一区二区三区 | 无码精品人妻一区二区三区av | 性生交片免费无码看人 | 国产黑色丝袜在线播放 | 欧美日韩亚洲国产精品 | 精品无码国产一区二区三区av | 精品日本一区二区三区在线观看 | 性欧美熟妇videofreesex | 一本大道伊人av久久综合 | 人妻少妇被猛烈进入中文字幕 | 少妇性l交大片 | 久久综合九色综合97网 | 欧美放荡的少妇 | 国产精品无码成人午夜电影 | 成人女人看片免费视频放人 | 成人免费视频在线观看 | 少妇性俱乐部纵欲狂欢电影 | 国产特级毛片aaaaaa高潮流水 | 精品国产精品久久一区免费式 | 国产成人精品一区二区在线小狼 | 国产农村妇女高潮大叫 | 中文精品无码中文字幕无码专区 | 亚洲а∨天堂久久精品2021 | 国产成人无码专区 | 国产97色在线 | 免 | 乱码午夜-极国产极内射 | 暴力强奷在线播放无码 | 午夜精品一区二区三区在线观看 | 无码人妻精品一区二区三区不卡 | 97精品国产97久久久久久免费 | 97无码免费人妻超级碰碰夜夜 | 曰本女人与公拘交酡免费视频 | 欧美人妻一区二区三区 | 中文毛片无遮挡高清免费 | 人人妻人人澡人人爽人人精品 | 国产在线无码精品电影网 | 日本护士毛茸茸高潮 | 麻豆蜜桃av蜜臀av色欲av | 日本护士毛茸茸高潮 | 国产精品高潮呻吟av久久4虎 | 日韩av激情在线观看 | 精品亚洲成av人在线观看 | 日日天日日夜日日摸 | 大乳丰满人妻中文字幕日本 | 婷婷色婷婷开心五月四房播播 | 老熟女重囗味hdxx69 | 国产亚洲视频中文字幕97精品 | 无码国产乱人伦偷精品视频 | 久久成人a毛片免费观看网站 | 国产精品手机免费 | 亚洲の无码国产の无码步美 | 国产成人精品一区二区在线小狼 | 领导边摸边吃奶边做爽在线观看 | 少妇邻居内射在线 | 网友自拍区视频精品 | 在线а√天堂中文官网 | 美女黄网站人色视频免费国产 | 精品夜夜澡人妻无码av蜜桃 | 国产精品福利视频导航 | 日韩av无码中文无码电影 | 欧美激情一区二区三区成人 | 99re在线播放 | 99久久久无码国产aaa精品 | 欧洲vodafone精品性 | 亚洲成a人片在线观看日本 | 131美女爱做视频 | 骚片av蜜桃精品一区 | 99麻豆久久久国产精品免费 | 我要看www免费看插插视频 | 六十路熟妇乱子伦 | 国产成人综合色在线观看网站 | 成人性做爰aaa片免费看 | 99久久精品无码一区二区毛片 | 未满成年国产在线观看 | 欧美激情综合亚洲一二区 | 学生妹亚洲一区二区 | 捆绑白丝粉色jk震动捧喷白浆 | 国产精品亚洲lv粉色 | 天天拍夜夜添久久精品 | 国产成人午夜福利在线播放 | 又大又紧又粉嫩18p少妇 | 欧美人与动性行为视频 | 亚洲中文字幕乱码av波多ji | 国产黑色丝袜在线播放 | 欧美第一黄网免费网站 | 国产黑色丝袜在线播放 | 中文字幕av无码一区二区三区电影 | 又大又硬又黄的免费视频 | 国产成人无码午夜视频在线观看 | 美女扒开屁股让男人桶 | 欧美精品免费观看二区 | 国产精品亚洲专区无码不卡 | 麻豆人妻少妇精品无码专区 | 亚洲va欧美va天堂v国产综合 | 麻豆成人精品国产免费 | 亚洲中文字幕无码中文字在线 | 国产超碰人人爽人人做人人添 | 亚洲爆乳大丰满无码专区 | 国产舌乚八伦偷品w中 | 精品日本一区二区三区在线观看 | 亚洲中文字幕成人无码 | 国产精品久久国产三级国 | 成人无码视频在线观看网站 | 中文字幕无码av激情不卡 | 国产精品爱久久久久久久 | 久久精品国产一区二区三区 | 国产极品美女高潮无套在线观看 | 久久久亚洲欧洲日产国码αv | 国产情侣作爱视频免费观看 | 国产麻豆精品精东影业av网站 | 成人欧美一区二区三区 | 欧美丰满熟妇xxxx性ppx人交 | 国产情侣作爱视频免费观看 | 久久精品国产精品国产精品污 | 麻豆国产人妻欲求不满谁演的 | 18无码粉嫩小泬无套在线观看 | 18无码粉嫩小泬无套在线观看 | 图片小说视频一区二区 | 丝袜足控一区二区三区 | 人妻少妇被猛烈进入中文字幕 | 亚洲国产高清在线观看视频 | 真人与拘做受免费视频 | 无遮挡国产高潮视频免费观看 | 亚洲va中文字幕无码久久不卡 | 欧美激情一区二区三区成人 | 在线视频网站www色 | 亚洲最大成人网站 | 人妻夜夜爽天天爽三区 | 女人被男人躁得好爽免费视频 | 亚洲精品国产精品乱码视色 | 少女韩国电视剧在线观看完整 | 国产成人精品无码播放 | 日产国产精品亚洲系列 | 成人性做爰aaa片免费看不忠 | 东北女人啪啪对白 | 蜜桃视频插满18在线观看 | 欧美放荡的少妇 | 亚洲精品一区二区三区大桥未久 | 特大黑人娇小亚洲女 | 久精品国产欧美亚洲色aⅴ大片 | 樱花草在线播放免费中文 | 99riav国产精品视频 | 成人精品一区二区三区中文字幕 | 国产精品美女久久久网av | 午夜性刺激在线视频免费 | 亚洲国产精华液网站w | 天堂无码人妻精品一区二区三区 | 超碰97人人做人人爱少妇 | 久久久精品欧美一区二区免费 | 中文字幕无码免费久久9一区9 | 强奷人妻日本中文字幕 | 人妻中文无码久热丝袜 | 动漫av一区二区在线观看 | 亚洲呦女专区 | 又大又硬又黄的免费视频 | 午夜理论片yy44880影院 | 中文字幕+乱码+中文字幕一区 | 日日干夜夜干 | 无码中文字幕色专区 | 国产无遮挡又黄又爽免费视频 | 99久久久无码国产aaa精品 | 午夜福利不卡在线视频 | 欧美人与物videos另类 | 特级做a爰片毛片免费69 | 99久久无码一区人妻 | 亚洲日本在线电影 | 国产熟妇高潮叫床视频播放 | 老熟妇乱子伦牲交视频 | 97精品国产97久久久久久免费 | 一本色道久久综合亚洲精品不卡 | 午夜无码区在线观看 | 麻豆国产丝袜白领秘书在线观看 | 成人片黄网站色大片免费观看 | 精品国产国产综合精品 | 国产午夜亚洲精品不卡 | 少妇的肉体aa片免费 | 正在播放老肥熟妇露脸 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产深夜福利视频在线 | 国产黄在线观看免费观看不卡 | 日本熟妇人妻xxxxx人hd | 亚洲中文字幕无码中文字在线 | 大乳丰满人妻中文字幕日本 | 中文字幕乱码人妻无码久久 | 亚洲综合久久一区二区 | 一区二区三区乱码在线 | 欧洲 | 国产成人无码av在线影院 | 强伦人妻一区二区三区视频18 | 大地资源网第二页免费观看 | 欧美日韩色另类综合 | 在线看片无码永久免费视频 | 乌克兰少妇xxxx做受 | 成在人线av无码免费 | 97资源共享在线视频 | 久久综合狠狠综合久久综合88 | 日本一本二本三区免费 | 国产婷婷色一区二区三区在线 | 欧美 亚洲 国产 另类 | 东北女人啪啪对白 | 男人的天堂av网站 | 永久免费观看国产裸体美女 | 亚洲日本一区二区三区在线 | 国产精品办公室沙发 | 亚洲精品久久久久久久久久久 | 久久久中文字幕日本无吗 | 久久99久久99精品中文字幕 | 国精品人妻无码一区二区三区蜜柚 | 欧美色就是色 | 亚洲精品综合一区二区三区在线 | 少妇高潮一区二区三区99 | 精品欧美一区二区三区久久久 | 亚洲一区二区三区香蕉 | 久久人人爽人人爽人人片ⅴ | 国产亚洲人成在线播放 | 国精品人妻无码一区二区三区蜜柚 | 又大又黄又粗又爽的免费视频 | 国产精品第一区揄拍无码 | 日本va欧美va欧美va精品 | 精品人妻中文字幕有码在线 | 亚洲熟熟妇xxxx | 国产乱人偷精品人妻a片 | 最新国产乱人伦偷精品免费网站 | 小sao货水好多真紧h无码视频 | 国产xxx69麻豆国语对白 | 亚洲码国产精品高潮在线 | 国产精品久久久久9999小说 | 99精品视频在线观看免费 | 我要看www免费看插插视频 | 在教室伦流澡到高潮hnp视频 | 装睡被陌生人摸出水好爽 | 精品无码成人片一区二区98 | 男人的天堂av网站 | 熟妇人妻中文av无码 | 亚洲中文字幕av在天堂 | 国产亚洲视频中文字幕97精品 | 狂野欧美激情性xxxx | 2019nv天堂香蕉在线观看 | 久久久久亚洲精品男人的天堂 | 在线 国产 欧美 亚洲 天堂 | 1000部啪啪未满十八勿入下载 | 亚洲精品一区二区三区在线观看 | 久热国产vs视频在线观看 | 在线观看国产一区二区三区 | 亚洲中文字幕在线无码一区二区 | 久久综合久久自在自线精品自 | aⅴ在线视频男人的天堂 | 妺妺窝人体色www婷婷 | 又黄又爽又色的视频 | 动漫av一区二区在线观看 | 激情五月综合色婷婷一区二区 | av人摸人人人澡人人超碰下载 | 国产热a欧美热a在线视频 | 蜜臀av无码人妻精品 | 精品少妇爆乳无码av无码专区 | 精品无码av一区二区三区 | 午夜福利试看120秒体验区 | 国产精品二区一区二区aⅴ污介绍 | 蜜桃av抽搐高潮一区二区 | 美女毛片一区二区三区四区 | 久青草影院在线观看国产 | 美女张开腿让人桶 | 久久久久99精品国产片 | 一本久久伊人热热精品中文字幕 | 中国大陆精品视频xxxx | 天天综合网天天综合色 | 亚洲第一网站男人都懂 | 女人被男人躁得好爽免费视频 | 免费无码一区二区三区蜜桃大 | 在线播放免费人成毛片乱码 | 无码人妻av免费一区二区三区 | 成人三级无码视频在线观看 | 国产又爽又猛又粗的视频a片 | 色欲人妻aaaaaaa无码 | 国内少妇偷人精品视频 | 国产内射爽爽大片视频社区在线 | 国产精品美女久久久久av爽李琼 | www成人国产高清内射 | 精品国产麻豆免费人成网站 | 少妇久久久久久人妻无码 | 伊人久久大香线蕉av一区二区 | 人妻少妇被猛烈进入中文字幕 | 欧美性色19p | 国产亚洲精品久久久久久 | 国产av无码专区亚洲a∨毛片 | 久久zyz资源站无码中文动漫 | 成人动漫在线观看 | 日产精品高潮呻吟av久久 | 国产香蕉97碰碰久久人人 | 国产欧美精品一区二区三区 | 亚洲区欧美区综合区自拍区 | 清纯唯美经典一区二区 | 久久无码专区国产精品s | 老司机亚洲精品影院无码 | 99精品国产综合久久久久五月天 | 国产精品福利视频导航 | 999久久久国产精品消防器材 | 特黄特色大片免费播放器图片 | 国产网红无码精品视频 | 亚洲狠狠婷婷综合久久 | 久久综合九色综合欧美狠狠 | 性做久久久久久久久 | 99精品国产综合久久久久五月天 | 国产国产精品人在线视 | 国产成人无码av片在线观看不卡 | 无码av最新清无码专区吞精 | 国产熟妇高潮叫床视频播放 | 久久99精品国产.久久久久 | 亚洲综合无码久久精品综合 | 丁香花在线影院观看在线播放 | 麻豆精品国产精华精华液好用吗 | 又紧又大又爽精品一区二区 | 国产另类ts人妖一区二区 | 午夜成人1000部免费视频 | 亚洲色欲久久久综合网东京热 | 成人aaa片一区国产精品 | 夜夜影院未满十八勿进 | 麻豆国产97在线 | 欧洲 | 装睡被陌生人摸出水好爽 | 国产9 9在线 | 中文 | 2020久久香蕉国产线看观看 | 青青久在线视频免费观看 | 亚洲一区二区三区 | 亚洲人成网站在线播放942 | 丰满少妇高潮惨叫视频 | 久久99精品久久久久久动态图 | 中文字幕av日韩精品一区二区 | 国产明星裸体无码xxxx视频 | 377p欧洲日本亚洲大胆 | 亚洲熟妇色xxxxx欧美老妇y | 亚洲小说春色综合另类 | 精品偷拍一区二区三区在线看 | 东京热一精品无码av | 老熟妇乱子伦牲交视频 | 无码人妻av免费一区二区三区 | 久久国产劲爆∧v内射 | 欧美午夜特黄aaaaaa片 | 爽爽影院免费观看 | 国产精品福利视频导航 | 中国女人内谢69xxxxxa片 | 中文无码成人免费视频在线观看 | 人妻有码中文字幕在线 | 人人妻人人澡人人爽精品欧美 | 97se亚洲精品一区 | 国产亚洲精品久久久久久久久动漫 | 日韩无套无码精品 | 搡女人真爽免费视频大全 | 内射巨臀欧美在线视频 | 国产精华av午夜在线观看 | 国产后入清纯学生妹 | 呦交小u女精品视频 | www一区二区www免费 | 国产超级va在线观看视频 | 久久久久成人片免费观看蜜芽 | 久久人人爽人人人人片 | 亚洲精品成人av在线 | 亚洲 高清 成人 动漫 | 免费国产成人高清在线观看网站 | 欧美日韩一区二区三区自拍 | 国产精品久久久久久久影院 | 欧洲精品码一区二区三区免费看 | аⅴ资源天堂资源库在线 | 国产无遮挡又黄又爽免费视频 | 色婷婷久久一区二区三区麻豆 | 老司机亚洲精品影院无码 | 国产特级毛片aaaaaaa高清 | 鲁一鲁av2019在线 | 国产av一区二区精品久久凹凸 | 131美女爱做视频 | 丝袜美腿亚洲一区二区 | 国产偷自视频区视频 | 男女爱爱好爽视频免费看 | 牲交欧美兽交欧美 | 乱码午夜-极国产极内射 | 无码毛片视频一区二区本码 | 色五月五月丁香亚洲综合网 | 成人欧美一区二区三区黑人免费 | 无遮挡国产高潮视频免费观看 | 日韩欧美群交p片內射中文 | 少妇愉情理伦片bd | 亚洲呦女专区 | 国产特级毛片aaaaaa高潮流水 | 国产精品国产自线拍免费软件 | 国产欧美亚洲精品a | 少妇人妻偷人精品无码视频 | 国产在线无码精品电影网 | 亚洲中文字幕无码一久久区 | 98国产精品综合一区二区三区 | 欧美性猛交内射兽交老熟妇 | 国产精品理论片在线观看 | 18禁黄网站男男禁片免费观看 | yw尤物av无码国产在线观看 | 图片小说视频一区二区 | 国产精品久久久久无码av色戒 | 精品成在人线av无码免费看 | 亚洲啪av永久无码精品放毛片 | 国产国语老龄妇女a片 | 久久99精品久久久久久 | 精品欧洲av无码一区二区三区 | 乱中年女人伦av三区 | 日韩av无码一区二区三区 | 久久熟妇人妻午夜寂寞影院 | 精品日本一区二区三区在线观看 | 99久久久无码国产精品免费 | 两性色午夜免费视频 | 狠狠综合久久久久综合网 | 国产精品国产自线拍免费软件 | 丁香花在线影院观看在线播放 | 国内精品九九久久久精品 | 久久精品女人天堂av免费观看 | 亚洲国产一区二区三区在线观看 | 亚洲成a人片在线观看无码3d | 日本熟妇人妻xxxxx人hd | 国产一区二区三区精品视频 | 中文精品无码中文字幕无码专区 | 国产成人午夜福利在线播放 | 亚洲а∨天堂久久精品2021 | 日本精品高清一区二区 | 99精品国产综合久久久久五月天 | 久久久www成人免费毛片 | 亚洲无人区午夜福利码高清完整版 | 国产精品久久精品三级 | 亚洲精品一区三区三区在线观看 | 麻豆av传媒蜜桃天美传媒 | 国产亚洲精品久久久久久久 | 97色伦图片97综合影院 | 无码人妻出轨黑人中文字幕 | 无码人妻精品一区二区三区不卡 | 中文字幕久久久久人妻 | 18黄暴禁片在线观看 | 国产无套内射久久久国产 | 中文字幕无码人妻少妇免费 | 国产又爽又黄又刺激的视频 | 狠狠色色综合网站 | 亚洲成av人综合在线观看 | 日韩精品久久久肉伦网站 | 人妻天天爽夜夜爽一区二区 | 亚洲熟妇色xxxxx亚洲 | 色老头在线一区二区三区 | 曰本女人与公拘交酡免费视频 | 精品国产av色一区二区深夜久久 | 中国女人内谢69xxxx | 人妻尝试又大又粗久久 | 久久精品丝袜高跟鞋 | 亚洲国产欧美日韩精品一区二区三区 | 久久人人爽人人人人片 | 精品国偷自产在线视频 | 日欧一片内射va在线影院 | 国产97人人超碰caoprom | 亚洲天堂2017无码中文 | 福利一区二区三区视频在线观看 | 国产在线aaa片一区二区99 | 激情亚洲一区国产精品 | 国产麻豆精品精东影业av网站 | 欧美黑人巨大xxxxx | 中文字幕 亚洲精品 第1页 | 日韩 欧美 动漫 国产 制服 | 亚洲精品国偷拍自产在线麻豆 | 性色av无码免费一区二区三区 | 亚洲成色在线综合网站 | 青春草在线视频免费观看 | 67194成是人免费无码 | 狂野欧美性猛交免费视频 | 最新版天堂资源中文官网 | 理论片87福利理论电影 | 欧美激情综合亚洲一二区 | 久久精品国产大片免费观看 | √天堂中文官网8在线 | 狠狠色欧美亚洲狠狠色www | 精品久久久久久人妻无码中文字幕 | 少妇高潮喷潮久久久影院 | 亚洲国产精品毛片av不卡在线 | 久久这里只有精品视频9 | а√资源新版在线天堂 | 午夜福利试看120秒体验区 | 亚洲精品国产第一综合99久久 | 久久无码中文字幕免费影院蜜桃 | 亚洲国产精品无码久久久久高潮 | 秋霞成人午夜鲁丝一区二区三区 | 高潮毛片无遮挡高清免费视频 | 午夜成人1000部免费视频 | 亚洲小说春色综合另类 | 久久婷婷五月综合色国产香蕉 | 久久久久免费精品国产 | 国产免费久久久久久无码 | 性欧美牲交在线视频 | 日本爽爽爽爽爽爽在线观看免 | 亚洲中文字幕无码中字 | 国产精品对白交换视频 | 欧美乱妇无乱码大黄a片 | 国产69精品久久久久app下载 | 一本色道久久综合亚洲精品不卡 | 97夜夜澡人人爽人人喊中国片 | 中文字幕+乱码+中文字幕一区 | 亚洲日韩中文字幕在线播放 | 国产做国产爱免费视频 | 中文字幕人妻无码一夲道 | 中文毛片无遮挡高清免费 | 日日橹狠狠爱欧美视频 | 5858s亚洲色大成网站www | 午夜精品久久久久久久久 | 亚洲国产av美女网站 | 久久久久人妻一区精品色欧美 | 久久成人a毛片免费观看网站 | 乱人伦中文视频在线观看 | 国产人成高清在线视频99最全资源 | 国产精品国产自线拍免费软件 | 丰满人妻翻云覆雨呻吟视频 | 国产精品人人爽人人做我的可爱 | 熟女少妇人妻中文字幕 | 国产偷自视频区视频 | 天天综合网天天综合色 | 欧美日韩一区二区三区自拍 | 中文亚洲成a人片在线观看 | 东京一本一道一二三区 | 最新版天堂资源中文官网 | 日本xxxx色视频在线观看免费 | 99国产欧美久久久精品 | 天天躁夜夜躁狠狠是什么心态 | 99精品国产综合久久久久五月天 | 亚洲国产高清在线观看视频 | 国产特级毛片aaaaaaa高清 | 色综合久久久无码网中文 | 午夜精品久久久内射近拍高清 | 欧美一区二区三区视频在线观看 | 波多野结衣一区二区三区av免费 | 色婷婷av一区二区三区之红樱桃 | yw尤物av无码国产在线观看 | 日韩av无码中文无码电影 | 少妇高潮喷潮久久久影院 | 亚洲国产精品久久久天堂 | 国内少妇偷人精品视频免费 | 国产亚洲精品久久久久久国模美 | 国产农村乱对白刺激视频 | 国产热a欧美热a在线视频 | 久久综合九色综合97网 | 欧美喷潮久久久xxxxx | 国产精品亚洲lv粉色 | 日本饥渴人妻欲求不满 | 又大又硬又爽免费视频 | 国产农村乱对白刺激视频 | 乌克兰少妇性做爰 | 国产亚洲精品久久久久久久久动漫 | 国产亚洲人成a在线v网站 | 麻豆国产97在线 | 欧洲 | 又色又爽又黄的美女裸体网站 | а√资源新版在线天堂 | 55夜色66夜色国产精品视频 | 中文久久乱码一区二区 | 久久久久人妻一区精品色欧美 | a国产一区二区免费入口 | 日韩欧美中文字幕在线三区 | 亚洲狠狠婷婷综合久久 | 国内精品久久毛片一区二区 | 国产无遮挡又黄又爽免费视频 | 一区二区传媒有限公司 | 国产av无码专区亚洲a∨毛片 | 国产精品无码mv在线观看 | 丰腴饱满的极品熟妇 | 欧美日韩综合一区二区三区 | 激情国产av做激情国产爱 | 国产精品二区一区二区aⅴ污介绍 | 国产精品va在线播放 | 久久综合激激的五月天 | 亚洲爆乳大丰满无码专区 | 东京一本一道一二三区 | 色欲综合久久中文字幕网 | 蜜臀aⅴ国产精品久久久国产老师 | 成人毛片一区二区 | 人妻少妇被猛烈进入中文字幕 | 国产亚洲视频中文字幕97精品 | 国产亚洲日韩欧美另类第八页 | 亚洲精品成人av在线 | 捆绑白丝粉色jk震动捧喷白浆 | 久久国产36精品色熟妇 | 国产av人人夜夜澡人人爽麻豆 | 国产一区二区三区四区五区加勒比 | 亚洲人成无码网www | 伊人色综合久久天天小片 | 亚洲aⅴ无码成人网站国产app | 亚洲大尺度无码无码专区 | 国产成人无码av在线影院 | 男女下面进入的视频免费午夜 | 国色天香社区在线视频 | 亚洲精品一区三区三区在线观看 | 十八禁视频网站在线观看 | 国产无遮挡吃胸膜奶免费看 | 人妻少妇被猛烈进入中文字幕 | 大胆欧美熟妇xx | 亚洲人成影院在线无码按摩店 | 亚洲日本va中文字幕 | 成 人 网 站国产免费观看 | 无码av免费一区二区三区试看 | 亚洲人成人无码网www国产 | 少妇无套内谢久久久久 | 久久99热只有频精品8 | 久久 国产 尿 小便 嘘嘘 | 在线a亚洲视频播放在线观看 | 国产艳妇av在线观看果冻传媒 | 亚洲国产精品久久人人爱 | 日本精品人妻无码77777 天堂一区人妻无码 | 午夜福利一区二区三区在线观看 | 无码精品人妻一区二区三区av | 亚洲人交乣女bbw | 亚洲综合无码久久精品综合 | 亚洲成av人在线观看网址 | 亚洲精品综合一区二区三区在线 | 中文字幕无线码免费人妻 | 无码国产乱人伦偷精品视频 | 熟妇女人妻丰满少妇中文字幕 | 国产真实乱对白精彩久久 | 国产精品丝袜黑色高跟鞋 | 99国产精品白浆在线观看免费 | 亚洲阿v天堂在线 | 午夜精品一区二区三区的区别 | 国产精品鲁鲁鲁 | 午夜不卡av免费 一本久久a久久精品vr综合 | 爽爽影院免费观看 | 国产黄在线观看免费观看不卡 | 国产人妻精品午夜福利免费 | 成人精品天堂一区二区三区 | 久在线观看福利视频 | 久在线观看福利视频 | 免费播放一区二区三区 | 久久久亚洲欧洲日产国码αv | 亚洲精品午夜无码电影网 | 亚洲无人区午夜福利码高清完整版 | 未满成年国产在线观看 | 强开小婷嫩苞又嫩又紧视频 | 国产精品a成v人在线播放 | 日韩精品成人一区二区三区 | 在教室伦流澡到高潮hnp视频 | 成人精品视频一区二区 | 亚洲精品国偷拍自产在线观看蜜桃 | 无码人妻久久一区二区三区不卡 | 国产午夜福利亚洲第一 | 国产特级毛片aaaaaa高潮流水 | 日产国产精品亚洲系列 | 久久久久久av无码免费看大片 | 欧美人与善在线com | 乌克兰少妇性做爰 | 内射白嫩少妇超碰 | 高清不卡一区二区三区 | 精品少妇爆乳无码av无码专区 | 无码国内精品人妻少妇 | 色婷婷欧美在线播放内射 | 精品厕所偷拍各类美女tp嘘嘘 | 狠狠躁日日躁夜夜躁2020 | 7777奇米四色成人眼影 | 性欧美熟妇videofreesex | 狠狠综合久久久久综合网 | 国产亲子乱弄免费视频 | 国产激情无码一区二区 | 三级4级全黄60分钟 | 日本一卡2卡3卡四卡精品网站 | 东京无码熟妇人妻av在线网址 | 日韩亚洲欧美中文高清在线 | 樱花草在线播放免费中文 | 两性色午夜免费视频 | 亚洲精品中文字幕 | 亚洲色无码一区二区三区 | 激情亚洲一区国产精品 | 国产乱人无码伦av在线a | 成人片黄网站色大片免费观看 | 久久久久亚洲精品中文字幕 | 丝袜美腿亚洲一区二区 | 日本www一道久久久免费榴莲 | 无码一区二区三区在线观看 | 日韩欧美成人免费观看 | 色欲av亚洲一区无码少妇 | 乱人伦人妻中文字幕无码久久网 | 国模大胆一区二区三区 | 国产在线一区二区三区四区五区 | 亚洲国产精品一区二区第一页 | 国产熟妇另类久久久久 | 任你躁国产自任一区二区三区 | 国产性生交xxxxx无码 | 久久综合九色综合97网 | 99精品国产综合久久久久五月天 | 国产精品鲁鲁鲁 | 日日噜噜噜噜夜夜爽亚洲精品 | 亚洲天堂2017无码中文 | 亚洲毛片av日韩av无码 | 三级4级全黄60分钟 | 最近的中文字幕在线看视频 | 亚洲欧洲日本无在线码 | 国产人成高清在线视频99最全资源 | 4hu四虎永久在线观看 | 强奷人妻日本中文字幕 | 久久久精品人妻久久影视 | 国产香蕉尹人综合在线观看 | 国产乱码精品一品二品 | 97无码免费人妻超级碰碰夜夜 | 熟女俱乐部五十路六十路av | 日本精品少妇一区二区三区 | 欧洲精品码一区二区三区免费看 | 丰满护士巨好爽好大乳 | 亚洲午夜久久久影院 | 一区二区传媒有限公司 | 国产精品18久久久久久麻辣 | 国产极品视觉盛宴 | 九月婷婷人人澡人人添人人爽 | 国产精品久久久久无码av色戒 | 国产av剧情md精品麻豆 | 亚洲 激情 小说 另类 欧美 | 亚洲一区二区三区无码久久 | 日韩亚洲欧美中文高清在线 | 免费观看激色视频网站 | 丰腴饱满的极品熟妇 | 亚洲欧洲日本综合aⅴ在线 | 久久天天躁夜夜躁狠狠 | 国产一区二区三区日韩精品 | 狂野欧美性猛xxxx乱大交 | 日欧一片内射va在线影院 | 欧美日本精品一区二区三区 | 扒开双腿吃奶呻吟做受视频 | 波多野结衣av一区二区全免费观看 | 日本爽爽爽爽爽爽在线观看免 | 久青草影院在线观看国产 | 国产激情无码一区二区 | 国产成人综合色在线观看网站 | 久久国产36精品色熟妇 | 国产精品免费大片 | 亚洲精品中文字幕久久久久 | 人妻夜夜爽天天爽三区 | 亚洲七七久久桃花影院 | 国产高潮视频在线观看 | 国产网红无码精品视频 | 亚洲精品一区二区三区大桥未久 | 好男人www社区 | 亚洲中文字幕在线观看 | 永久黄网站色视频免费直播 | 内射老妇bbwx0c0ck | 欧美丰满老熟妇xxxxx性 | 十八禁真人啪啪免费网站 | 精品国产一区二区三区av 性色 | 人妻插b视频一区二区三区 | 精品乱码久久久久久久 | 亚洲精品无码国产 | 激情人妻另类人妻伦 | 亚洲男人av天堂午夜在 | 成人无码精品一区二区三区 | 夜夜躁日日躁狠狠久久av | 亚洲一区二区三区含羞草 | 少妇性荡欲午夜性开放视频剧场 | √天堂资源地址中文在线 | 性色av无码免费一区二区三区 | 国产精品欧美成人 | 国产亚洲视频中文字幕97精品 | 国产高清av在线播放 | 国产精品无码永久免费888 | 无码国产激情在线观看 | 成人影院yy111111在线观看 | 亚洲日韩中文字幕在线播放 | 国产精品丝袜黑色高跟鞋 | www国产亚洲精品久久久日本 | 亚洲精品鲁一鲁一区二区三区 | 精品水蜜桃久久久久久久 | 国产精品亚洲lv粉色 | а√资源新版在线天堂 | 无码国内精品人妻少妇 | 亚洲乱码国产乱码精品精 | 亚洲综合无码久久精品综合 | 中文久久乱码一区二区 | 极品尤物被啪到呻吟喷水 | 免费无码一区二区三区蜜桃大 | 色欲久久久天天天综合网精品 | 人人妻人人澡人人爽人人精品浪潮 | 色综合久久88色综合天天 | 亚洲国产精品一区二区第一页 | 乌克兰少妇xxxx做受 | 国内精品人妻无码久久久影院蜜桃 | 强伦人妻一区二区三区视频18 | 国产精品二区一区二区aⅴ污介绍 | 日本乱人伦片中文三区 | 国产精品人人爽人人做我的可爱 | 欧美丰满熟妇xxxx | 九月婷婷人人澡人人添人人爽 | 欧美精品一区二区精品久久 | 国产国产精品人在线视 | 丝袜人妻一区二区三区 | 婷婷综合久久中文字幕蜜桃三电影 | 2019nv天堂香蕉在线观看 | 久久久久久久人妻无码中文字幕爆 | 国产两女互慰高潮视频在线观看 | 中文字幕av无码一区二区三区电影 | 中文字幕+乱码+中文字幕一区 | 国产精华av午夜在线观看 | 亚洲欧美综合区丁香五月小说 | 水蜜桃亚洲一二三四在线 | 国产国产精品人在线视 | 久久久精品人妻久久影视 | 乱人伦人妻中文字幕无码 | 久久久久久a亚洲欧洲av冫 | 国産精品久久久久久久 | 国产在线精品一区二区三区直播 | 国内精品人妻无码久久久影院蜜桃 | 精品久久综合1区2区3区激情 | 无码人妻丰满熟妇区五十路百度 | 日日摸日日碰夜夜爽av | 色妞www精品免费视频 | 日韩精品无码免费一区二区三区 | 东京一本一道一二三区 | 荫蒂被男人添的好舒服爽免费视频 | 波多野42部无码喷潮在线 | 少妇厨房愉情理9仑片视频 | 国产一区二区三区影院 | 一二三四在线观看免费视频 | 无码午夜成人1000部免费视频 | 97人妻精品一区二区三区 | 国产美女极度色诱视频www | 人人妻人人澡人人爽精品欧美 | 乱码午夜-极国产极内射 | 成人免费视频在线观看 | 日韩精品无码一本二本三本色 | 亚洲精品一区二区三区四区五区 | 野外少妇愉情中文字幕 | 国产精品丝袜黑色高跟鞋 | 亚洲国产精品无码一区二区三区 | 亚洲综合另类小说色区 | 领导边摸边吃奶边做爽在线观看 | 国产真实伦对白全集 | 日日夜夜撸啊撸 | 夜先锋av资源网站 | 少妇高潮喷潮久久久影院 | 亚洲精品国产品国语在线观看 | 蜜臀aⅴ国产精品久久久国产老师 | 免费播放一区二区三区 | 成熟女人特级毛片www免费 | 国产精品第一区揄拍无码 | 99麻豆久久久国产精品免费 | 无码人妻av免费一区二区三区 | 成 人 网 站国产免费观看 | 18无码粉嫩小泬无套在线观看 | 国产成人久久精品流白浆 | 日本精品高清一区二区 | 无码国内精品人妻少妇 | 国产香蕉尹人视频在线 | 妺妺窝人体色www在线小说 | 女人和拘做爰正片视频 | 美女黄网站人色视频免费国产 | 欧美国产日韩亚洲中文 | 久久精品无码一区二区三区 | 国产成人综合在线女婷五月99播放 | 男女作爱免费网站 | 成人av无码一区二区三区 | 综合网日日天干夜夜久久 | 欧美第一黄网免费网站 | 免费乱码人妻系列无码专区 | 国产偷自视频区视频 | 国产农村乱对白刺激视频 | 国产精品久久久久无码av色戒 | 午夜丰满少妇性开放视频 | 国内精品人妻无码久久久影院蜜桃 | 日韩av无码一区二区三区不卡 | 亚洲s色大片在线观看 | 在线播放亚洲第一字幕 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲中文字幕乱码av波多ji | 大色综合色综合网站 | 老熟妇仑乱视频一区二区 | 麻豆av传媒蜜桃天美传媒 | 亚洲精品一区三区三区在线观看 | 国产成人无码一二三区视频 | 亚洲精品综合一区二区三区在线 | 亚洲精品欧美二区三区中文字幕 | 99精品国产综合久久久久五月天 | 又色又爽又黄的美女裸体网站 | 亚洲中文字幕乱码av波多ji | 国产成人精品优优av | 无码播放一区二区三区 | 国产成人一区二区三区别 | 狠狠cao日日穞夜夜穞av | 天天摸天天透天天添 | 青青青手机频在线观看 | 国产在线aaa片一区二区99 | 色一情一乱一伦一区二区三欧美 | 天天爽夜夜爽夜夜爽 | 久久人人97超碰a片精品 | 国内少妇偷人精品视频 | 国产色xx群视频射精 | 一本大道伊人av久久综合 | 无码精品人妻一区二区三区av | 无码吃奶揉捏奶头高潮视频 | 亚洲欧洲日本综合aⅴ在线 | 久久久久av无码免费网 | 少妇性俱乐部纵欲狂欢电影 | 久久国语露脸国产精品电影 | 熟妇人妻激情偷爽文 | 国产欧美亚洲精品a | 男人的天堂2018无码 | 国产麻豆精品精东影业av网站 |