日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

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

编程问答

Flink+Iceberg搭建实时数据湖实战

發(fā)布時間:2024/3/12 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Flink+Iceberg搭建实时数据湖实战 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

點擊上方藍色字體,選擇“設為星標”

回復"面試"獲取更多驚喜

全網最全大數據面試提升手冊!

第一部分:Iceberg 核心功能原理剖析 :

Apache Iceberg

摘自官網:

Apache?Iceberg?is?an?open?table?format?for?huge?analytic?datasets.

可以看到 Founders 對 Iceberg 的定位是面向海量數據分析場景的高效存儲格式。海量數據分析的場景,類比于 Hive 是 Hdfs 的封裝一樣,本質上解決的還是數倉場景的痛點問題。

Iceberg 在最開始,也確實是在數倉場景朝著更快更好用的 format 目標不斷演進,比如支持 schema 變更,文件粒度的 Filter 優(yōu)化等,但隨著和流式計算 Flink 引擎的生態(tài)打通,Delete/Update/Merge 語義的出現,場景就會變得多樣化起來。

背景

過去業(yè)界更多是使用 Hive/Spark on HDFS 作為離線數據倉庫的載體,在越來越趨于實時化和快速迭代的場景中,逐漸暴露出以下缺點:

  • 不支持 Row-Level-Update,對于更新的操作需要 overwrite 整張 Hive 表,成本極高

  • 不支持讀寫分離,用戶的讀取操作會被另一個用戶的寫入操作所影響(尤其是流式讀取的場景)

  • 不支持版本回滾和快照,需要保存大量歷史數據

  • 不支持增量讀取,每次掃描全表或分區(qū)所有數據

  • 性能低,只能裁剪到 Hive Partition 粒度

  • 不支持 Schema 變更

  • .....

基本概念

如上圖所示,iceberg 將 hdfs 上的文件進行了 snapshot、manifest list、manifest、data files 的分層。

  • Snapshot:用戶的每次 commit(每次寫入的 spark job) 會產生一個新的 snapshot

  • Manifest List:維護當前 snapshot 中所有的 manifest

  • Manifest:維護當前 Manifest 下所有的 data files

  • Data File:存儲數據的文件,后續(xù) Iceberg 引入了 Delete File,用于存儲要刪除的數據,文件結構上也是與 Data File 處在同一層

  • 核心功能剖析
    Time Travel 和增量讀取

    Time Travel 指的是用戶可以任意讀取歷史時刻的相關數據,以 Spark 的代碼為例:

    //?time?travel?to?October?26,?1986?at?01:21:00 spark.read.option("as-of-timestamp",?"499162860000").format("iceberg").load("path/to/table")

    上述代碼即是在讀取 timestamp=499162860000 時,該 Iceberg 表的數據,那么底層原理是什么樣子的呢?

    從「基本概念」中的文件結構可以看到,用戶每次新的寫入都會產生一個 snapshot,那么 Iceberg 只需要存儲用戶每次 commit 產生的 metadata,比如時間戳等信息,就能找到對應時刻的 snapshot,并且解析出 Data Files。

    增量讀取也同理,通過 start 和 end 的時間戳取到時間范圍內的 snapshot,并讀取所有的 Data Files 作為原始數據。

    Fast Scan & Data Filtering

    上面提到 Hive 的查詢性能低下,其中一個原因是數據計算時,只能下推到 Partition 層面,粒度太粗。而 Iceberg 在細粒度的 Plan 上做了一系列的優(yōu)化,當一個 Query 進入 Iceberg 后:

  • 根據 timestamp 找到對應的 snapshot(默認最新)

  • 根據 Query 的 Partition 信息從指定 snapshot 中過濾出符合條件的 manifest 文件集合

  • 從 manifest 文件集合中取出所有的 Data Files 對象(只包含元信息)

  • 根據 Data File 的若干個屬性,進行更細粒度的數據過濾,包括 column-level value counts, null counts, lower bounds, and upper bounds 等

  • Delete 實現

    為了上線 Row-Level Update 的功能,Iceberg 提供了 Delete 的實現,通過 Delete + Insert 我們可以達到 Update 的目的。在引入 Delete 實現時,引入了兩個概念:

    • Delete File:用于存儲刪除的數據(分為 position delete 和 equality delete)

    • Sequence Number:是 Data File 和 Delete File 的共有屬性之一,主要用于區(qū)分 Insert 和 Delete 的先后順序,否則會出現數據一致性的問題

    position & equality delete

    Iceberg 引入了 equality_ids 概念,用戶建表時可以指定 Table 的 equality_ids 來標識未來 Delete 操作對應的 Key,比如 GDPR 場景,我們需要根據 user_id 來隨機刪除用戶的相關數據,就可以把 equality_ids 設置為 user_id。

    兩種 Delete 操作對應不同的 Delete File,其存儲字段也不同:

    • position delete:包括三列,file_path(要刪除的數據所在的 Data File)、pos(行數)、row(數據)

    • equality delete:包括 equality_ids 中的字段

    顯而易見,存儲 Delete File 的目的是將來讀取數據時,進行實時的 Join,而 position delete 在 Join 時能精準定位到文件,并且只需要行號的比較,肯定是更加高效的。所以在 Delete 操作寫入時,Iceberg 會將正在寫入的數據文件信息存儲到內存中,來保證將 DELETE 操作盡量走 position delete 的鏈路。示意圖如下所示:

    按照時間順序,依次寫入三條 INSERT 和 DELETE 數據,假設 Iceberg Writer 在寫入 a1 和 b1 的 INSERT 數據后,就關閉并新開啟了一個文件,那么此時寫入的記錄 c1 和對應的行號會被記錄在內存中。此時 Writer 接收到 user_id=c1 的數據后,便能直接從內存中找到 user_id=c1 的數據是在 fileA 中的第一行,此時寫下一個 Position Delete File;而 user_id=a1 的 DELETE 數據,由于文件已經關閉,內存中沒有記錄其信息,所以寫下一個 Equality Delete File。

    Sequence Number

    引入 DELETE 操作后,如果在讀取時進行合并,則涉及到一個問題,如果用戶對同一個 equality_id 的數據進行插入、刪除、再插入,那么讀取時該如何保證把第一次插入的數據給刪掉,讀取第二次插入的數據?

    這里的處理方式是將 Data File 和 Delete File 放在一起按寫入順序編號,在讀取時,DELETE 只對小于當前 Sequence Number 的 Data File 生效。如果遇到相同記錄的并發(fā)寫入的時候怎么辦?這里就要利用 Iceberg 自身的事務機制了,Iceberg Writer 在寫入前會檢查相關 meta 以及 Sequence Number,如果寫入后不符合預期則會采取樂觀鎖的形式進行重試。

    Schema Evolution

    Iceberg 的 schema evolution 是其特色之一,支持以下操作:

    • 增加字段

    • 刪除字段

    • 重命名字段

    • 修改字段

    • 改變字段順序

    關于 schema 的變更也依賴上面文件結構,由于每次寫入時,都會產生 snapshot -> manifest -> data file 的層級,同樣,讀取時也會從 snapshot 開始讀取并路由到對應的底層 data file。所以 Iceberg 只需要每次寫入時在 manifest 中記錄下 schema 的情況,并在讀取時進行對應的轉換即可。

    第二部分:Flink+Iceberg環(huán)境搭建:

    1. Flink SQL Client配置Iceberg

    Flink集群需要使用Scala 2.12版本的

  • 將Iceberg的依賴包下載放到Flink集群所有服務器的lib目錄下,然后重啟Flink

  • [root@flink1?~]#?wget?-P?/root/flink-1.14.3/lib?https://repo.maven.apache.org/maven2/org/apache/iceberg/iceberg-flink-runtime-1.14/0.13.0/iceberg-flink-runtime-1.14-0.13.0.jar [root@flink1?~]# [root@flink1?~]#?scp?/root/flink-1.14.3/lib/iceberg-flink-runtime-1.14-0.13.0.jar?root@flink2:/root/flink-1.14.3/lib iceberg-flink-runtime-1.14-0.13.0.jar????????????????????????????????????????????????????????????????????????????????????????????????????100%???23MB??42.9MB/s???00:00???? [root@flink1?~]#?scp?/root/flink-1.14.3/lib/iceberg-flink-runtime-1.14-0.13.0.jar?root@flink3:/root/flink-1.14.3/lib iceberg-flink-runtime-1.14-0.13.0.jar????????????????????????????????????????????????????????????????????????????????????????????????????100%???23MB??35.4MB/s???00:00???? [root@flink1?~]#

    Iceberg默認支持Hadoop Catalog。如果需要使用Hive Catalog,需要將flink-sql-connector-hive-3.1.2_2.12-1.14.3.jar放到Flink集群所有服務器的lib目錄下,然后重啟Flink

  • 然后啟動SQL Client就可以了

  • 2.Java/Scala pom.xml配置

    添加如下依賴

    <dependency><groupId>org.apache.iceberg</groupId><artifactId>iceberg-flink</artifactId><version>0.13.0</version><scope>provided</scope></dependency>
    3.Catalog
    3.1 Hive Catalog

    注意:測試的時候,從Hive中查詢表數據,查詢不到。但是從Trino查詢可以查詢到數據

    使用Hive的metastore保存元數據,HDFS保存數據庫表的數據

    Flink?SQL>?create?catalog?hive_catalog?with( >?'type'='iceberg', >?'catalog-type'='hive', >?'property-version'='1', >?'cache-enabled'='true', >?'uri'='thrift://hive1:9083', >?'client'='5', >?'warehouse'='hdfs://nnha/user/hive/warehouse', >?'hive-conf-dir'='/root/flink-1.14.3/hive_conf' >?); [INFO]?Execute?statement?succeed.Flink?SQL>
    • property-version: 為了向后兼容,以防property格式改變。當前設置為1即可

    • cache-enabled: 是否開啟catalog緩存,默認開啟

    • clients: 在hive metastore中,hive_catalog供客戶端訪問的連接池大小,默認是2

    • warehouse: 是Flink集群所在的HDFS路徑, hive_catalog下的數據庫表存放數據的位置

    • hive-conf-dir: hive集群的配置目錄。只能是Flink集群的本地路徑,從hive-site.xml解析出來的HDFS路徑,是Flink集群所在HDFS路徑

    • warehouse的優(yōu)先級比hive-conf-dir的優(yōu)先級高

    • 如果Hive中已經存在要創(chuàng)建的數據庫,則創(chuàng)建的表path會位于Hive的warehouse下

    3.2 HDFS Catalog

    用HDFS保存元數據和數據庫表的數據。warehouse是Flink集群所在的HDFS路徑

    Flink?SQL>?create?catalog?hadoop_catalog?with?( >?'type'='iceberg', >?'catalog-type'='hadoop', >?'property-version'='1', >?'cache-enabled'='true', >?'warehouse'='hdfs://nnha/user/iceberg/warehouse' >?); [INFO]?Execute?statement?succeed.Flink?SQL>

    通過配置conf/sql-cli-defaults.yaml實現永久catalog。但測試的時候并未生效

    [root@flink1?~]#?cat?/root/flink-1.14.3/conf/sql-cli-defaults.yaml? catalogs:-?name:?hadoop_catalogtype:?icebergcatalog-type:?hadoopproperty-version:?1cache-enabled:?truewarehouse:?hdfs://nnha/user/iceberg/warehouse[root@flink1?~]# [root@flink1?~]#?chown?501:games?/root/flink-1.14.3/conf/sql-cli-defaults.yaml

    下面我們重點以Hadoop Catalog為例,進行測試講解

    4.數據庫和表相關DDL命令
    4.1 創(chuàng)建數據庫

    Catalog下面默認都有一個default數據庫

    Flink?SQL>?create?database?hadoop_catalog.iceberg_db; [INFO]?Execute?statement?succeed.Flink?SQL>?use?hadoop_catalog.iceberg_db; [INFO]?Execute?statement?succeed.Flink?SQL>
    • 會在HDFS目錄上創(chuàng)建iceberg_db子目錄

    • 如果刪除數據庫,會刪除HDFS上的iceberg_db子目錄

    4.2 創(chuàng)建表(不支持primary key等)
    Flink?SQL>?create?table?hadoop_catalog.iceberg_db.my_user?( >?user_id?bigint?comment?'用戶ID', >?user_name?string, >?birthday?date, >?country?string >?)?comment?'用戶表'? >?partitioned?by?(birthday,?country)?with?( >?'write.format.default'='parquet', >?'write.parquet.compression-codec'='gzip' >?); [INFO]?Execute?statement?succeed.Flink?SQL>
    • 目前表不支持計算列、primay key, Watermark

    • 不支持計算分區(qū)。但是iceberg支持計算分區(qū)

    • 因為Iceberg支持primary key。設置屬性'format-version' = '2'和'write.upsert.enabled' = 'true',同時表添加primary key,也是可以支持upsert的。可以實現insert、update、delete的功能

    • 創(chuàng)建表生成的文件信息如下:

    [root@flink1?~]#? [root@flink1?~]#?hadoop?fs?-ls?hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata Found?2?items -rw-r--r--???1?root?supergroup???????2115?2022-02-13?22:01?hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/v1.metadata.json -rw-r--r--???1?root?supergroup??????????1?2022-02-13?22:01?hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/version-hint.text [root@flink1?~]#

    查看v1.metadata.json,可以看到"current-snapshot-id" : -1

    Flink?SQL>?create?table?hadoop_catalog.iceberg_db.my_user_copy? >?like?hadoop_catalog.iceberg_db.my_user; [INFO]?Execute?statement?succeed.Flink?SQL>
    • 復制的表擁有相同的表結構、分區(qū)、表屬性

    4.3 修改表

    修改表屬性

    Flink?SQL>?alter?table?hadoop_catalog.iceberg_db.my_user_copy? >?set( >?'write.format.default'='avro', >?'write.avro.compression-codec'='gzip' >?); [INFO]?Execute?statement?succeed.Flink?SQL>
    • 目前Flink只支持修改iceberg的表屬性

    重命名表

    Flink?SQL>?alter?table?hadoop_catalog.iceberg_db.my_user_copy? >?rename?to?hadoop_catalog.iceberg_db.my_user_copy_new; [ERROR]?Could?not?execute?SQL?statement.?Reason: java.lang.UnsupportedOperationException:?Cannot?rename?Hadoop?tablesFlink?SQL>
    • Hadoop Catalog中的表不支持重命名表

    4.4 刪除表
    Flink?SQL>?drop?table?hadoop_catalog.iceberg_db.my_user_copy; [INFO]?Execute?statement?succeed.Flink?SQL>

    會刪除HDFS上的my_user_copy子目錄

    5.插入數據到表
    5.1 insert into
  • insert into … values …

  • insert into … select …

  • Flink?SQL>?insert?into?hadoop_catalog.iceberg_db.my_user( >?user_id,?user_name,?birthday,?country >?)?values(1,?'zhang_san',?date?'2022-02-01',?'china'),? >?(2,?'li_si',?date?'2022-02-02',?'japan'); [INFO]?Submitting?SQL?update?statement?to?the?cluster... [INFO]?SQL?update?statement?has?been?successfully?submitted?to?the?cluster: Job?ID:?f1aa8bee0be5bda8b166cc361e113268Flink?SQL> Flink?SQL>?insert?into?hadoop_catalog.iceberg_db.my_user?select?(user_id?+?1),?user_name,?birthday,?country?from?hadoop_catalog.iceberg_db.my_user; [INFO]?Submitting?SQL?update?statement?to?the?cluster... [INFO]?SQL?update?statement?has?been?successfully?submitted?to?the?cluster: Job?ID:?c408e324ca3861b39176c6bd15770acaFlink?SQL>

    HDFS目錄結果如下

    hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/data/birthday=2022-02-01/country=china/00000-0-4ef3835f-b18b-4c48-b47a-85af1771a10a-00001.parquet hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/data/birthday=2022-02-01/country=china/00000-0-6e66c02b-cb09-4fd0-b669-15aa7f5194e4-00001.parquet hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/data/birthday=2022-02-02/country=japan/00000-0-4ef3835f-b18b-4c48-b47a-85af1771a10a-00002.parquet hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/data/birthday=2022-02-02/country=japan/00000-0-6e66c02b-cb09-4fd0-b669-15aa7f5194e4-00002.parquet
    5.2 insert overwrite(只有Batch模式支持,且overwrite粒度為partition)

    只支持Flink Batch模式,不支持Streaming模式

    insert overwrite替換多個整個分區(qū),而不是一行數據。如果不是分區(qū)表,則替換的是整個表,如下所示:

    Flink?SQL>?set?'execution.runtime-mode'?=?'batch'; [INFO]?Session?property?has?been?set.Flink?SQL> Flink?SQL>?insert?overwrite?hadoop_catalog.iceberg_db.my_user?values?(4,?'wang_wu',?date?'2022-02-02',?'japan'); [INFO]?Submitting?SQL?update?statement?to?the?cluster... [INFO]?SQL?update?statement?has?been?successfully?submitted?to?the?cluster: Job?ID:?63cf6c27060ec9ebdce75b785cc3fa3aFlink?SQL>?set?'sql-client.execution.result-mode'?=?'tableau'; [INFO]?Session?property?has?been?set.Flink?SQL>?select?*?from?hadoop_catalog.iceberg_db.my_user; +---------+-----------+------------+---------+ |?user_id?|?user_name?|???birthday?|?country?| +---------+-----------+------------+---------+ |???????1?|?zhang_san?|?2022-02-01?|???china?| |???????4?|???wang_wu?|?2022-02-02?|???japan?| |???????2?|?zhang_san?|?2022-02-01?|???china?| +---------+-----------+------------+---------+ 3?rows?in?set

    birthday=2022-02-02/country=japan分區(qū)下的數據如下,insert overwrite也是新增一個文件

    birthday=2022-02-02/country=japan/00000-0-1d0ff907-60a7-4062-93a3-9b443626e383-00001.parquet birthday=2022-02-02/country=japan/00000-0-4ef3835f-b18b-4c48-b47a-85af1771a10a-00002.parquet birthday=2022-02-02/country=japan/00000-0-6e66c02b-cb09-4fd0-b669-15aa7f5194e

    insert ovewrite … partition替換指定分區(qū)

    Flink?SQL>?insert?overwrite?hadoop_catalog.iceberg_db.my_user?partition?(birthday?=?'2022-02-02',?country?=?'japan')?select?5,?'zhao_liu'; [INFO]?Submitting?SQL?update?statement?to?the?cluster... [INFO]?SQL?update?statement?has?been?successfully?submitted?to?the?cluster: Job?ID:?97e9ba4131028c53461e739b34108ae0Flink?SQL>?select?*?from?hadoop_catalog.iceberg_db.my_user; +---------+-----------+------------+---------+ |?user_id?|?user_name?|???birthday?|?country?| +---------+-----------+------------+---------+ |???????1?|?zhang_san?|?2022-02-01?|???china?| |???????5?|??zhao_liu?|?2022-02-02?|???japan?| |???????2?|?zhang_san?|?2022-02-01?|???china?| +---------+-----------+------------+---------+ 3?rows?in?setFlink?SQL>
    6.查詢數據

    Batch模式

    Flink?SQL>?select?*?from?hadoop_catalog.iceberg_db.my_user; +---------+-----------+------------+---------+ |?user_id?|?user_name?|???birthday?|?country?| +---------+-----------+------------+---------+ |???????1?|?zhang_san?|?2022-02-01?|???china?| |???????5?|??zhao_liu?|?2022-02-02?|???japan?| |???????2?|?zhang_san?|?2022-02-01?|???china?| +---------+-----------+------------+---------+ 3?rows?in?setFlink?SQL>

    streaming模式

    查看最新的snapshot-id

    [root@flink1?conf]#?hadoop?fs?-cat?hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/version-hint.text 5

    我們前面創(chuàng)建表 + 兩次insert + 兩次insert overwrite,所以最新的版本號為5。然后我們查看該版本號對于的metadata json文件

    [root@flink1?~]#?hadoop?fs?-cat?hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/v5.metadata.json {"format-version"?:?1,"table-uuid"?:?"84a5e90d-7ae9-4dfd-aeab-c74f07447513","location"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user","last-updated-ms"?:?1644761481488,"last-column-id"?:?4,"schema"?:?{"type"?:?"struct","schema-id"?:?0,"fields"?:?[?{"id"?:?1,"name"?:?"user_id","required"?:?false,"type"?:?"long"},?{"id"?:?2,"name"?:?"user_name","required"?:?false,"type"?:?"string"},?{"id"?:?3,"name"?:?"birthday","required"?:?false,"type"?:?"date"},?{"id"?:?4,"name"?:?"country","required"?:?false,"type"?:?"string"}?]},"current-schema-id"?:?0,"schemas"?:?[?{"type"?:?"struct","schema-id"?:?0,"fields"?:?[?{"id"?:?1,"name"?:?"user_id","required"?:?false,"type"?:?"long"},?{"id"?:?2,"name"?:?"user_name","required"?:?false,"type"?:?"string"},?{"id"?:?3,"name"?:?"birthday","required"?:?false,"type"?:?"date"},?{"id"?:?4,"name"?:?"country","required"?:?false,"type"?:?"string"}?]}?],"partition-spec"?:?[?{"name"?:?"birthday","transform"?:?"identity","source-id"?:?3,"field-id"?:?1000},?{"name"?:?"country","transform"?:?"identity","source-id"?:?4,"field-id"?:?1001}?],"default-spec-id"?:?0,"partition-specs"?:?[?{"spec-id"?:?0,"fields"?:?[?{"name"?:?"birthday","transform"?:?"identity","source-id"?:?3,"field-id"?:?1000},?{"name"?:?"country","transform"?:?"identity","source-id"?:?4,"field-id"?:?1001}?]}?],"last-partition-id"?:?1001,"default-sort-order-id"?:?0,"sort-orders"?:?[?{"order-id"?:?0,"fields"?:?[?]}?],"properties"?:?{"write.format.default"?:?"parquet","write.parquet.compression-codec"?:?"gzip"},"current-snapshot-id"?:?138573494821828246,"snapshots"?:?[?{"snapshot-id"?:?8012517928892530314,"timestamp-ms"?:?1644761130111,"summary"?:?{"operation"?:?"append","flink.job-id"?:?"8f228ae49d34aafb4b2887db3149e3f6","flink.max-committed-checkpoint-id"?:?"9223372036854775807","added-data-files"?:?"2","added-records"?:?"2","added-files-size"?:?"2487","changed-partition-count"?:?"2","total-records"?:?"2","total-files-size"?:?"2487","total-data-files"?:?"2","total-delete-files"?:?"0","total-position-deletes"?:?"0","total-equality-deletes"?:?"0"},"manifest-list"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/snap-8012517928892530314-1-5c33451b-48ab-4ce5-be7a-2c2d2dc9e11d.avro","schema-id"?:?0},?{"snapshot-id"?:?453371561664052237,"parent-snapshot-id"?:?8012517928892530314,"timestamp-ms"?:?1644761150082,"summary"?:?{"operation"?:?"append","flink.job-id"?:?"813b7a17c21ddd003e1a210b1366e0c5","flink.max-committed-checkpoint-id"?:?"9223372036854775807","added-data-files"?:?"2","added-records"?:?"2","added-files-size"?:?"2487","changed-partition-count"?:?"2","total-records"?:?"4","total-files-size"?:?"4974","total-data-files"?:?"4","total-delete-files"?:?"0","total-position-deletes"?:?"0","total-equality-deletes"?:?"0"},"manifest-list"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/snap-453371561664052237-1-bc0e56ec-9f78-4956-8412-4d8ca70ccc19.avro","schema-id"?:?0},?{"snapshot-id"?:?6410282459040239217,"parent-snapshot-id"?:?453371561664052237,"timestamp-ms"?:?1644761403566,"summary"?:?{"operation"?:?"overwrite","replace-partitions"?:?"true","flink.job-id"?:?"f7085f68e5ff73c1c8aa1f4f59996068","flink.max-committed-checkpoint-id"?:?"9223372036854775807","added-data-files"?:?"1","deleted-data-files"?:?"2","added-records"?:?"1","deleted-records"?:?"2","added-files-size"?:?"1244","removed-files-size"?:?"2459","changed-partition-count"?:?"1","total-records"?:?"3","total-files-size"?:?"3759","total-data-files"?:?"3","total-delete-files"?:?"0","total-position-deletes"?:?"0","total-equality-deletes"?:?"0"},"manifest-list"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/snap-6410282459040239217-1-2b20c57e-5428-4483-9f7b-928b980dd50d.avro","schema-id"?:?0},?{"snapshot-id"?:?138573494821828246,"parent-snapshot-id"?:?6410282459040239217,"timestamp-ms"?:?1644761481488,"summary"?:?{"operation"?:?"overwrite","replace-partitions"?:?"true","flink.job-id"?:?"d434d6d4f658d61732d7e9a0a85279fc","flink.max-committed-checkpoint-id"?:?"9223372036854775807","added-data-files"?:?"1","deleted-data-files"?:?"1","added-records"?:?"1","deleted-records"?:?"1","added-files-size"?:?"1251","removed-files-size"?:?"1244","changed-partition-count"?:?"1","total-records"?:?"3","total-files-size"?:?"3766","total-data-files"?:?"3","total-delete-files"?:?"0","total-position-deletes"?:?"0","total-equality-deletes"?:?"0"},"manifest-list"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/snap-138573494821828246-1-b243b39e-7122-4571-b6fa-c902241e36a8.avro","schema-id"?:?0}?],"snapshot-log"?:?[?{"timestamp-ms"?:?1644761130111,"snapshot-id"?:?8012517928892530314},?{"timestamp-ms"?:?1644761150082,"snapshot-id"?:?453371561664052237},?{"timestamp-ms"?:?1644761403566,"snapshot-id"?:?6410282459040239217},?{"timestamp-ms"?:?1644761481488,"snapshot-id"?:?138573494821828246}?],"metadata-log"?:?[?{"timestamp-ms"?:?1644760911017,"metadata-file"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/v1.metadata.json"},?{"timestamp-ms"?:?1644761130111,"metadata-file"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/v2.metadata.json"},?{"timestamp-ms"?:?1644761150082,"metadata-file"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/v3.metadata.json"},?{"timestamp-ms"?:?1644761403566,"metadata-file"?:?"hdfs://nnha/user/iceberg/warehouse/iceberg_db/my_user/metadata/v4.metadata.json"}?] }[root@flink1?~]#

    可以看到 "current-snapshot-id" : 138573494821828246,,表示當前的snapshot-id

    Flink?SQL>?set?'execution.runtime-mode'?=?'streaming'; [INFO]?Session?property?has?been?set.Flink?SQL> Flink?SQL>?select?*?from?hadoop_catalog.iceberg_db.my_user? >?/*+?options( >?'streaming'='true',? >?'monitor-interval'='5s' >?)*/?; +----+----------------------+--------------------------------+------------+--------------------------------+ |?op?|??????????????user_id?|??????????????????????user_name?|???birthday?|????????????????????????country?| +----+----------------------+--------------------------------+------------+--------------------------------+ |?+I?|????????????????????5?|???????????????????????zhao_liu?|?2022-02-02?|??????????????????????????japan?| |?+I?|????????????????????2?|??????????????????????zhang_san?|?2022-02-01?|??????????????????????????china?| |?+I?|????????????????????1?|??????????????????????zhang_san?|?2022-02-01?|??????????????????????????china?|

    可以看到最新snapshot對應的數據

    Flink?SQL>?select?*?from?hadoop_catalog.iceberg_db.my_user? >?/*+?options( >?'streaming'='true',? >?'monitor-interval'='5s', >?'start-snapshot-id'='138573494821828246' >?)*/?; +----+----------------------+--------------------------------+------------+--------------------------------+ |?op?|??????????????user_id?|??????????????????????user_name?|???birthday?|????????????????????????country?| +----+----------------------+--------------------------------+------------+--------------------------------+

    這里只能指定最后一個insert overwrite操作的snapshot id,及其后面的snapshot id,否則后臺會報異常,且程序一直處于restarting的狀態(tài):

    java.lang.UnsupportedOperationException:?Found?overwrite?operation,?cannot?support?incremental?data?in?snapshots?(8012517928892530314,?138573494821828246]

    在本示例中snapshot id: 138573494821828246,是最后一個snapshot id,同時也是最后一個insert overwrite操作的snapshot id。如果再insert兩條數據,則只能看到增量的數據

    Flink?SQL>?insert?into?hadoop_catalog.iceberg_db.my_user( >?user_id,?user_name,?birthday,?country >?)?values(6,?'zhang_san',?date?'2022-02-01',?'china'); [INFO]?Submitting?SQL?update?statement?to?the?cluster... [INFO]?SQL?update?statement?has?been?successfully?submitted?to?the?cluster: Job?ID:?8eb279e61aed66304d78ad027eaf8d30Flink?SQL>?insert?into?hadoop_catalog.iceberg_db.my_user( >?user_id,?user_name,?birthday,?country >?)?values(7,?'zhang_san',?date?'2022-02-01',?'china'); [INFO]?Submitting?SQL?update?statement?to?the?cluster... [INFO]?SQL?update?statement?has?been?successfully?submitted?to?the?cluster: Job?ID:?70a050e455d188d0d3f3adc2ba367fb6Flink?SQL>?select?*?from?hadoop_catalog.iceberg_db.my_user? >?/*+?options( >?'streaming'='true',? >?'monitor-interval'='30s', >?'start-snapshot-id'='138573494821828246' >?)*/?; +----+----------------------+--------------------------------+------------+--------------------------------+ |?op?|??????????????user_id?|??????????????????????user_name?|???birthday?|????????????????????????country?| +----+----------------------+--------------------------------+------------+--------------------------------+ |?+I?|????????????????????6?|??????????????????????zhang_san?|?2022-02-01?|??????????????????????????china?| |?+I?|????????????????????7?|??????????????????????zhang_san?|?2022-02-01?|??????????????????????????china?|
    • streaming模式支持讀取增量snapshot數據

    • 如果不指定start-snapshot-id,則先讀取當前snapshot全量數據,再讀取增量數據。如果指定start-snapshot-id,讀取該snapshot-id之后的增量數據,即不讀取該snapshot-id的數據

    • monitor-interval:表示監(jiān)控新提交的數據文件的時間間隔,默認1s

    如果這個文章對你有幫助,不要忘記?「在看」?「點贊」?「收藏」?三連啊喂!

    2022年全網首發(fā)|大數據專家級技能模型與學習指南(勝天半子篇)

    互聯網最壞的時代可能真的來了

    我在B站讀大學,大數據專業(yè)

    我們在學習Flink的時候,到底在學習什么?

    193篇文章暴揍Flink,這個合集你需要關注一下

    Flink生產環(huán)境TOP難題與優(yōu)化,阿里巴巴藏經閣YYDS

    Flink CDC我吃定了耶穌也留不住他!| Flink CDC線上問題小盤點

    我們在學習Spark的時候,到底在學習什么?

    在所有Spark模塊中,我愿稱SparkSQL為最強!

    硬剛Hive | 4萬字基礎調優(yōu)面試小總結

    數據治理方法論和實踐小百科全書

    標簽體系下的用戶畫像建設小指南

    4萬字長文 | ClickHouse基礎&實踐&調優(yōu)全視角解析

    【面試&個人成長】2021年過半,社招和校招的經驗之談

    大數據方向另一個十年開啟 |《硬剛系列》第一版完結

    我寫過的關于成長/面試/職場進階的文章

    當我們在學習Hive的時候在學習什么?「硬剛Hive續(xù)集」

    總結

    以上是生活随笔為你收集整理的Flink+Iceberg搭建实时数据湖实战的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    成人在线免费观看网站 | 国产精品大尺度 | 98福利在线| 欧美韩日在线 | 国产性天天综合网 | 探花视频在线版播放免费观看 | 国产精品久久久久久久久费观看 | 国产成人精品电影久久久 | 久久久久日本精品一区二区三区 | 久久久精品欧美 | 国产99久久 | 亚洲第一区在线播放 | 夜色成人网 | 缴情综合网五月天 | 人人添人人澡人人澡人人人爽 | 久久99精品国产一区二区三区 | 免费中文字幕视频 | 美女久久一区 | 精品美女久久久久 | 麻豆av一区二区三区在线观看 | 亚洲精品视频网址 | 99久久精品国产网站 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 国产久草在线 | 国产高清视频免费在线观看 | 精品一区精品二区 | 丰满少妇在线观看资源站 | 亚洲国产三级在线观看 | 欧美日韩视频在线观看一区二区 | 一级黄色片在线免费观看 | 青青五月天 | 久久国产一区 | 色婷婷亚洲综合 | 久久国内精品视频 | 久久激情视频网 | 国产精品美女在线 | 日韩精品一区二区三区不卡 | 日本成址在线观看 | 欧美亚洲三级 | 超碰在线中文字幕 | 麻豆视频入口 | 成人wwwxxx视频 | 91网在线看| 欧美精品一区二区性色 | 免费视频99 | 成人在线一区二区 | 综合色站 | 99精品在线免费在线观看 | 婷婷国产视频 | 在线中文字幕一区二区 | 成人av手机在线 | 色婷婷www | 国产小视频91 | 婷婷六月网 | 3d黄动漫免费看 | 成年人在线免费看片 | 国产精品99爱 | 国产美女免费观看 | 免费观看www7722午夜电影 | 国产精品午夜在线观看 | 国产成人精品一区一区一区 | 欧美精品资源 | 日韩免费二区 | 国产日韩欧美中文 | 欧美亚洲成人免费 | 在线免费观看黄网站 | 日韩精品中文字幕在线播放 | 国产黄色片一级三级 | 韩国精品在线 | 麻豆精品国产传媒 | 五月婷婷在线视频观看 | 四虎国产视频 | 日韩二级毛片 | 亚洲在线观看av | av大片免费在线观看 | 欧美日韩亚洲在线观看 | 亚洲日本精品视频 | 一区二区中文字幕在线播放 | 激情导航| 黄色成人免费电影 | 91超级碰 | 久久亚洲专区 | 夜夜骑日日操 | 久久情网| 国产精品久久久视频 | 视频一区二区三区视频 | 91福利国产在线观看 | 992tv在线观看网站 | 久久精品99久久久久久 | 久久久久久久综合色一本 | 国产精品一区二区果冻传媒 | 亚洲精品乱码久久久久久蜜桃91 | 麻豆成人在线观看 | 国产亚洲aⅴaaaaaa毛片 | 久草.com| 日韩欧美国产精品 | 国产一级淫片在线观看 | 99精品国产成人一区二区 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 国产午夜不卡 | 麻花天美星空视频 | 欧美日韩不卡在线 | 国产视频手机在线 | 91新人在线观看 | 久久精品艹 | 九色琪琪久久综合网天天 | 亚洲欧美日韩精品久久奇米一区 | 国产在线超碰 | 久久免费国产电影 | 国产亚洲精品日韩在线tv黄 | 日韩二区三区在线 | av在线播放不卡 | 久草在线视频网 | 精品国产一二区 | 黄网站污| 91福利专区| 日韩.com | 国产精品久久久久久久久久不蜜月 | 精品国产综合区久久久久久 | 日韩电影在线一区 | 天天爽天天碰狠狠添 | 成人av网站在线观看 | 欧美日在线观看 | 日韩欧美高清一区二区三区 | 免费在线观看日韩 | 久久综合九色综合欧美就去吻 | 射射射av| 免费毛片一区二区三区久久久 | 91探花系列在线播放 | 中文字幕在线一区观看 | 欧美一级日韩免费不卡 | 在线91av | 亚洲三级毛片 | 国产黄色片免费在线观看 | 99国产精品一区二区 | 欧美久久久一区二区三区 | 国产一级免费视频 | 日韩久久精品 | 视频精品一区二区三区 | 黄色1级毛片 | av在线一级 | 日韩精品五月天 | 久久精品一区二 | 97超碰在线资源 | 成人毛片100免费观看 | 国产专区视频 | 精品久久久久久久久久久院品网 | 91资源在线观看 | 激情久久久久久久久久久久久久久久 | 999久久国精品免费观看网站 | 最近更新好看的中文字幕 | 亚洲精品成人在线 | 日韩在线观看视频网站 | 亚洲精品综合欧美二区变态 | 久久免费视频7 | 欧美一区二视频在线免费观看 | 亚洲国产精品视频在线观看 | 免费久久网| 香蕉视频亚洲 | 天堂网在线视频 | 午夜精品成人一区二区三区 | 亚洲 成人 一区 | 一区二区影视 | 男女免费视频观看 | 91一区二区三区久久久久国产乱 | 国产乱码精品一区二区蜜臀 | 五月婷婷视频在线观看 | 久久精品这里都是精品 | www.色的 | 久草免费在线观看 | 91久久精品一区二区三区 | 超碰在线日本 | 日韩精品一区二区免费视频 | 精品久久一区二区三区 | 这里只有精彩视频 | 久久免费看 | 正在播放一区 | 国产在线不卡一区 | 亚洲婷婷综合色高清在线 | 日韩在线欧美在线 | 91亚洲精品久久久中文字幕 | 亚洲午夜av | 国产精品久久久久久久免费大片 | 亚洲性少妇性猛交wwww乱大交 | 国产精品婷婷午夜在线观看 | 日韩精品一区二区三区不卡 | 99久久精品视频免费 | 欧美激情视频在线观看免费 | www久久精品 | 欧美日韩三级在线观看 | 亚洲,国产成人av | 中文av资源站 | 99国产视频 | 欧美日韩国产在线精品 | 中文字幕在线专区 | av电影中文 | 操操爽 | 在线观看91av | 亚洲国产免费看 | 激情视频二区 | 中文资源在线观看 | 热久久这里只有精品 | 国产在线一区二区 | 在线免费国产 | 精品国产电影一区二区 | 中国一级特黄毛片大片久久 | 欧美日韩精品在线观看视频 | av网站播放 | 国产精品二区在线 | 午夜国产福利在线 | 亚洲一区网 | 久久综合9988久久爱 | 欧美日韩精品在线观看视频 | 香蕉视频网站在线观看 | 精精国产xxxx视频在线播放 | 波多野结衣视频一区二区 | 久久视频这里有久久精品视频11 | 精品99在线观看 | 亚洲欧洲精品一区二区精品久久久 | 色狠狠综合天天综合综合 | 久久久亚洲精品 | 久精品在线 | 欧美性生交大片免网 | 欧美国产亚洲精品久久久8v | 一区三区视频在线观看 | 亚洲日本va午夜在线影院 | 欧美亚洲国产精品久久高清浪潮 | 色婷婷亚洲婷婷 | 久久国产精品色av免费看 | 国产资源精品在线观看 | 日本3级在线观看 | 欧美激情视频免费看 | 日韩一区二区三区不卡 | 2021国产精品 | a视频在线播放 | 91中文视频| a√国产免费a | 黄色av成人在线观看 | 欧美一区三区四区 | 精品久久久久久久久久久院品网 | 91视频久久久久久 | 色婷久久 | 免费电影一区二区三区 | 免费在线一区二区三区 | 中文字幕亚洲精品在线观看 | av网站播放 | 日韩免费av在线 | 国产精品婷婷 | 久久婷婷色综合 | 婷婷综合影院 | 毛片美女网站 | 久久九九影视网 | 亚洲成人网在线 | 日韩精品一区二区三区中文字幕 | 在线91视频| 国模一二三区 | 六月丁香在线观看 | 狠狠色丁香婷婷综合久久片 | 亚洲精品理论 | 99热国产在线中文 | 国产高清久久 | 黄色av一区二区 | 亚洲免费观看视频 | 黄色aa久久 | 女人高潮一级片 | 国产99久久久国产精品 | 国产伦精品一区二区三区免费 | 国产美女精品视频免费观看 | 99久久精品免费看国产四区 | 99久高清在线观看视频99精品热在线观看视频 | 欧美日韩3p | 九九视频在线播放 | 在线影院av | 亚洲网久久 | 奇米网网址 | av免费电影在线 | 激情综合网五月激情 | 国产美女精彩久久 | 日韩欧美大片免费观看 | 欧美日韩精品在线观看 | 亚洲一区欧美激情 | 中文永久免费观看 | 日韩视频一 | 美女免费黄网站 | av在线永久免费观看 | 欧美亚洲三级 | 毛片网站免费 | 久久精品国产亚洲a | 欧美a级在线播放 | 在线观看一级片 | 国产色在线视频 | 国产在线观看你懂得 | 爱爱av网| 久久精品亚洲一区二区三区观看模式 | 天天操天天吃 | 日韩成人精品在线观看 | 五月天久久久久久 | 91视频在线免费 | 精品国产1区2区3区 国产欧美精品在线观看 | 国产精品福利一区 | 亚洲国内精品在线 | 天天操天天射天天爽 | 久久精品99精品国产香蕉 | 伊人色综合网 | 99精品欧美一区二区三区 | 亚洲少妇天堂 | 97精品国自产拍在线观看 | 欧美精品亚洲二区 | 日韩在线视频在线观看 | 久久综合九色 | 国产婷婷一区二区 | 在线免费视频你懂的 | 亚洲人片在线观看 | 欧美国产日韩久久 | 欧美大片大全 | 国产视频资源 | 国产精品一区二区久久精品爱微奶 | 中文字幕视频观看 | 香蕉久草 | 欧美激情综合五月色丁香 | 99视频免费播放 | 精品一区二区三区香蕉蜜桃 | 一区二区三区在线视频观看58 | 色综合天天视频在线观看 | 97超碰总站 | 日韩不卡高清视频 | 视频一区二区视频 | 欧美污网站| 欧美日韩69| 人人狠 | 最新黄色av网址 | 狠狠干夜夜爽 | 一二三区在线 | 欧美国产日韩一区二区三区 | 狠狠色丁香九九婷婷综合五月 | 国产亚洲免费的视频看 | av片中文字幕 | av线上看| 麻豆94tv免费版 | 中文字字幕在线 | 亚洲视频 在线观看 | 国产资源在线免费观看 | 日韩电影精品 | 欧美精品久久久久久久久免 | av日韩av | 日韩欧美在线高清 | 国产精品久久一卡二卡 | 六月丁香综合 | 99在线视频网站 | av网站有哪些 | 日韩高清免费电影 | 免费精品 | 综合色综合色 | 中文字幕av全部资源www中文字幕在线观看 | 欧美日韩免费一区二区三区 | 97av在线 | 欧美极品少妇xxxx | 91网免费看 | 右手影院亚洲欧美 | 久久国产精品99久久人人澡 | 在线电影日韩 | 亚洲狠狠婷婷综合久久久 | 久久曰视频 | 免费高清在线观看成人 | 久久久久久久久艹 | 久久久国产在线视频 | 天堂成人在线 | 狠狠色狠狠色合久久伊人 | zzijzzij亚洲日本少妇熟睡 | 日本午夜免费福利视频 | 中文视频在线 | 日韩高清成人 | 天天做天天射 | 在线免费黄色av | ww视频在线观看 | 91人人澡人人爽 | 国产精品视频内 | 国产一区网址 | 中文字幕a∨在线乱码免费看 | 最新av网址在线观看 | 亚洲精品观看 | 91av电影 | 成人av网站在线播放 | 一区二区三区在线免费播放 | 天天操夜夜干 | 久久99精品国产麻豆宅宅 | 精品国产1区二区 | 99精品免费久久久久久久久 | 九九色网| 草久热 | 婷婷色网站 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 91成人黄色| 天天综合网入口 | 欧美精品久久久久 | 精品a级片 | 亚洲精品视频第一页 | 婷婷中文在线 | 久久精品视频一 | 国产精品久久久 | 精品a在线 | 精品亚洲一区二区三区 | 人人干人人干人人干 | 亚洲精品人人 | 瑞典xxxx性hd极品 | 日韩成人精品一区二区三区 | 在线黄av | 国产精品国产三级国产 | 激情综合狠狠 | a黄色| av先锋影音少妇 | 色婷婷www| av免费在线网站 | 超碰在线中文字幕 | 久日精品| 色婷婷激婷婷情综天天 | 欧美激情精品久久久久久免费印度 | 免费观看版 | 欧美精品午夜 | 欧美精品一区二区蜜臀亚洲 | 91黄色在线看 | 特黄特黄的视频 | 日韩中文在线视频 | 不卡的av| 国产精品21区| 国产精品一区在线观看你懂的 | 大荫蒂欧美视频另类xxxx | wwwwwww色| 伊人狠狠色 | 国产资源免费 | 亚洲成人精品av | 日韩欧美综合在线视频 | 中文字幕永久免费 | 国产精品国产三级国产专区53 | 人人插人人爱 | 在线视频一区观看 | 日韩精品一区二区在线视频 | 亚洲视频电影在线 | 午夜精品一区二区三区在线视频 | 天天摸日日操 | 国产成人av在线影院 | 黄色一级在线视频 | 少妇bbw搡bbbb搡bbbb | 日本系列中文字幕 | 午夜精品一区二区三区在线观看 | 成人中文字幕av | 高清不卡毛片 | 日日爽天天爽 | 国产乱视频 | 一区二区三区视频网站 | 久久综合狠狠综合 | 国产亚洲精品久 | a级成人毛片 | 亚洲欧美日韩一区二区三区在线观看 | 国产精品一区二区62 | 久久99视频免费观看 | 成人97视频一区二区 | 亚洲精品视频在线看 | 99在线观看视频网站 | 天天操操操操操 | 日韩高清精品一区二区 | 日韩欧美专区 | 久久五月天色综合 | 制服丝袜一区二区 | 国产伦理久久精品久久久久_ | 久久久久久国产精品免费 | 在线看一区二区 | 免费黄色在线 | 久草91视频| 自拍超碰在线 | 在线免费观看视频 | 久久久久久久亚洲精品 | av电影一区 | 成人精品一区二区三区电影免费 | 丁香影院在线 | 国产69久久久 | 日本激情动作片免费看 | 久久精品国产一区二区 | 麻豆国产在线视频 | 在线免费视频你懂的 | 在线免费黄色 | 三级小视频在线观看 | 国产精品18久久久久久vr | 国产不卡在线视频 | 日韩精品一区二区三区电影 | 国产亚洲精品精品精品 | 国产成人精品999在线观看 | 中文资源在线官网 | 午夜精品福利一区二区 | 二区三区毛片 | 69国产盗摄一区二区三区五区 | 国产精品免费久久久久影院仙踪林 | 久久男人免费视频 | 午夜久久福利视频 | 一本一道久久a久久综合蜜桃 | 伊人开心激情 | 国产精品99精品 | 久久久99精品免费观看乱色 | 天天插天天狠 | 美女视频是黄的免费观看 | 国产香蕉视频在线观看 | 四虎在线影视 | 三级av在线免费观看 | 成人久久久久久久久久 | 中文字幕美女免费在线 | 麻豆精品国产传媒 | 亚洲一级在线观看 | 激情丁香 | 国产黄色精品网站 | 波多野结衣精品视频 | 日本大片免费观看在线 | 99综合视频 | 夜夜天天干 | 久草视频在线新免费 | 午夜aaaa| 免费黄a | 亚洲精品网页 | 国产在线观看中文字幕 | 天天干夜夜干 | 国产无套精品久久久久久 | www.国产在线 | 亚州黄色一级 | 久久成人在线视频 | 成人av在线资源 | 91精品伦理| 国产精品美女免费 | 日韩夜夜爽 | 九九热免费在线视频 | 久久久精品一区二区三区 | 国产成人黄色 | 88av色| 国产精品国产亚洲精品看不卡15 | 免费网站在线观看人 | 中文字幕在线免费观看 | 波多野结衣在线中文字幕 | 在线免费视频 你懂得 | 成人毛片在线视频 | 色婷婷视频 | 九九国产视频 | 五月激情婷婷丁香 | 国产一区国产二区在线观看 | 日韩a在线观看 | 日日操操操 | 国产精品免费人成网站 | 久久综合久久鬼 | 91日韩在线播放 | www.人人草 | 日本性xxx | 五月天激情在线 | 四季av综合网站 | 久久曰视频 | 国产第一页福利影院 | 国产精品第一 | www国产精品com | 日本福利视频在线 | 亚洲区色 | 成年人免费观看在线视频 | 一区二区中文字幕在线 | 久久精品国产亚洲精品 | 综合五月婷婷 | 国产精品va视频 | 日韩欧美国产免费播放 | 国产又粗又猛又爽 | 懂色av一区二区三区蜜臀 | 日韩h在线观看 | 亚洲理论视频 | 综合黄色网 | 在线免费观看视频一区 | 国产精品99精品久久免费 | 国产精品久久久久久久久久久久午夜片 | 蜜臀精品久久久久久蜜臀 | 国产美女视频免费 | 久久久91精品国产一区二区三区 | 国产r级在线观看 | 黄色一级大片在线免费看产 | 成人av日韩| 欧美激情综合五月色丁香小说 | 一级α片免费看 | 91在线麻豆| 91久久国产自产拍夜夜嗨 | 欧美日韩有码 | 激情五月在线视频 | 日韩女同av | 五月婷婷在线视频观看 | 日韩久久电影 | 超碰在线成人 | 久久精品综合网 | 激情视频一区二区三区 | 五月婷婷激情六月 | www夜夜| 激情五月综合 | 国产97免费 | 国产日韩精品一区二区在线观看播放 | 成人在线你懂得 | 色噜噜狠狠狠狠色综合久不 | 亚洲精品男人的天堂 | 久久全国免费视频 | 高清精品在线 | 午夜丁香视频在线观看 | 九九免费精品 | 在线涩涩| 丁香视频全集免费观看 | 欧美一区二区三区在线观看 | 91在线精品播放 | 国产精品久久久久久久久久久久午 | 91av短视频 | 国产专区视频在线观看 | 久久在线免费视频 | 成片免费观看视频大全 | 日韩大片在线观看 | 日韩精品在线免费观看 | 又爽又黄又无遮挡网站动态图 | 亚洲国产精品资源 | 在线观看国产永久免费视频 | 九热精品| 波多野结衣动态图 | 中文字幕不卡在线88 | 国产一级免费在线观看 | 在线观看中文字幕网站 | 中文字幕一区三区 | 一区二区伦理电影 | 精品产品国产在线不卡 | 午夜视频在线观看一区二区三区 | 日韩免费电影 | av免费成人 | 在线观看亚洲精品 | 国内久久精品视频 | 精品免费国产一区二区三区四区 | 天天拍天天爽 | 国产综合精品一区二区三区 | 天天搞天天干 | 欧产日产国产69 | 国产黄色精品视频 | 久久亚洲欧美日韩精品专区 | 免费观看黄色12片一级视频 | 草久电影 | 免费在线观看视频一区 | www.国产高清 | 成人在线免费av | 天堂在线免费视频 | 91av在线视频免费观看 | 免费高清在线观看电视网站 | 一级做a爱片性色毛片www | 久久久久久美女 | 日韩高清无线码2023 | 九九交易行官网 | 国产精品观看 | 久久精品系列 | 亚洲 欧美 日韩 综合 | 最新影院| 日韩乱色精品一区二区 | 中文字幕精品在线 | 日韩免费视频线观看 | 久久国产一区二区 | 久久综合九色综合欧美狠狠 | 狠狠操狠狠干2017 | 亚洲欧美国产日韩在线观看 | 天天看天天干天天操 | 在线网址你懂得 | 亚洲国产精品人久久电影 | 久久97久久 | 久久在线 | 99热9| 亚洲视频免费在线看 | 亚洲精品视频国产 | 亚洲h在线播放在线观看h | 色视频成人在线观看免 | 日本乱码在线 | 欧美视屏一区二区 | 曰本三级在线 | 国产精品伦一区二区三区视频 | 美女国产 | 久久精品视频99 | 国产精品初高中精品久久 | 久久久综合九色合综国产精品 | 国产一在线精品一区在线观看 | 日韩免费观看一区二区 | 在线观看91精品视频 | 国产又黄又爽无遮挡 | 2023年中文无字幕文字 | 日韩精品电影在线播放 | 免费黄色av电影 | 久久国产精品一区二区三区四区 | 亚洲 欧美 另类人妖 | 久草免费在线 | 成人资源在线播放 | 国产精品一区二区在线观看 | 精品999在线观看 | 在线有码中文字幕 | 色就色,综合激情 | 一区二区三区在线观看免费 | 中文字幕91在线 | 九草视频在线观看 | 一区免费观看 | 国产色视频123区 | 久久精品小视频 | 国产福利91精品一区 | 亚洲激情影院 | 国产精品成久久久久 | 久久黄色影院 | 日韩系列| 黄色片网站 | 精品中文字幕在线观看 | 91人人视频在线观看 | 国产无区一区二区三麻豆 | 超碰在线cao | 国产精品午夜在线观看 | 一本—道久久a久久精品蜜桃 | 久久午夜精品影院一区 | 亚洲老妇xxxxxx| 在线免费观看国产视频 | 国产国语在线 | 日韩精品一区二区三区在线播放 | 色免费在线| 久久99久久99精品免观看粉嫩 | 日日碰狠狠添天天爽超碰97久久 | 国产精品99页 | 丝袜美腿在线 | 中文字幕视频播放 | 免费黄色一区 | 国产精品免费视频久久久 | 男女啪啪视屏 | 久草精品免费 | 在线看岛国av | 免费三及片| 亚洲精品激情 | 国产短视频在线播放 | 午夜av免费看| 国产一级片毛片 | 亚洲午夜久久久综合37日本 | 亚洲乱亚洲乱亚洲 | 中文在线免费观看 | 美女免费视频观看网站 | 四虎影视国产精品免费久久 | 在线观看欧美成人 | 激情欧美一区二区三区 | 日韩av影视在线观看 | 丁香六月天婷婷 | 免费观看的黄色片 | av怡红院| 999精品| 99久久免费看 | 国产精品密入口果冻 | 国产一级电影 | 亚洲精品国产欧美在线观看 | 九九热精品视频在线观看 | 又紧又大又爽精品一区二区 | 东方av在 | 视频在线亚洲 | 99视频偷窥在线精品国自产拍 | 免费观看第二部31集 | 久久久久久高清 | 国产精品 中文字幕 亚洲 欧美 | 高清不卡毛片 | 天天透天天插 | 久久99国产综合精品 | 欧美精品天堂 | 日韩av一区二区三区四区 | 久久成人18免费网站 | 亚洲午夜不卡 | 国产夫妻av在线 | 久久久一本精品99久久精品 | 日本精品一区二区 | 久久无码av一区二区三区电影网 | 欧美少妇的秘密 | 亚洲欧美成人网 | 欧美精品久久久久久久 | 女人18片毛片90分钟 | 天天色中文 | 国内外成人在线视频 | 91视频最新网址 | 国产精品久久久久久久午夜 | 成人在线视频你懂的 | 免费观看性生活大片 | 国产 日韩 在线 亚洲 字幕 中文 | 成年人在线观看网站 | 国语麻豆| 久章操 | 国产精品久久一 | 色综合久久久久久中文网 | 综合久久五月天 | 9999精品视频 | 国产精品免费观看久久 | 久久激情五月丁香伊人 | 99久久精品免费看国产一区二区三区 | 久久久精品国产一区二区电影四季 | 欧美在线观看小视频 | 国产精品毛片一区二区 | 在线激情网 | 精品视频123区在线观看 | 欧美激情视频一区二区三区免费 | 国产亚洲精品日韩在线tv黄 | 国产亚洲欧美一区 | 亚洲国产经典视频 | 一区二区av| 久久理论电影网 | 久久高清视频免费 | 日日夜日日干 | 亚洲精品国产综合99久久夜夜嗨 | 欧美精品久久久久久久久老牛影院 | 欧美日韩大片在线观看 | 亚洲第一中文字幕 | 久久成人免费 | 国产v在线观看 | 国产在线高清精品 | 在线观看涩涩 | 91av在线免费视频 | 久久久视屏 | 日韩字幕在线 | 天天操婷婷 | 成人久久久久 | 99久高清在线观看视频99精品热在线观看视频 | 中文字幕乱在线伦视频中文字幕乱码在线 | 亚洲成人第一区 | 欧美a性 | 最新日本中文字幕 | 成年人黄色免费视频 | 国产日产精品久久久久快鸭 | 啪啪av在线 | 成人av在线电影 | 91欧美日韩国产 | www.黄色在线 | 国内精品久久久久 | 波多野结衣小视频 | 99久久精品无免国产免费 | 香蕉视频国产在线 | 成人免费观看网址 | 亚洲一二区精品 | 在线亚洲精品 | 国产精品av一区二区 | 亚洲激情中文 | 日韩精品久久中文字幕 | 免费看毛片在线 | 手机色在线 | 久久精品三 | 成人夜晚看av | 又黄又刺激又爽的视频 | 在线观看的a站 | 亚洲综合色激情五月 | 日韩www在线 | 成人中文字幕在线观看 | 日韩国产欧美视频 | 黄色a视频 | 亚洲精品午夜国产va久久成人 | 国产手机精品视频 | 久一久久 | 精品国产一区二区三区在线 | 日本二区三区在线 | 91精品国产欧美一区二区成人 | 国产精品婷婷午夜在线观看 | 国产剧情在线一区 | 在线免费av网站 | 麻豆传媒视频在线 | 国产精品一区在线 | 国产69精品久久久久99 | 天天操夜夜摸 | 亚洲精品午夜国产va久久成人 | 麻豆免费视频网站 | 91精品国产高清自在线观看 | 91精品导航| 一区二区三区免费在线观看视频 | 久久久国产精品一区二区中文 | 亚洲国产精品推荐 | 97成人免费 | 色噜噜狠狠色综合中国 | 99久热精品 | 国产精品嫩草影院123 | av导航福利 | 热久久国产 | 国产精品久久久久aaaa | 国产成人精品亚洲 | av3级在线| 国产精品一二 | 91av视频在线播放 | 91av小视频| 婷婷午夜激情 | 亚洲国产精品推荐 | 欧美色图亚洲图片 | 五月婷婷黄色网 | 日韩乱码中文字幕 | 00av视频| 91国内产香蕉 | 日韩在线观看不卡 | 99在线观看 | 国产精品 亚洲精品 | 激情网第四色 | 九九热中文字幕 | 日韩久久精品一区二区三区下载 | 亚洲精品动漫成人3d无尽在线 | 福利久久久| 国产精品成人品 | 欧美日韩精品在线免费观看 | 九九一级片 | 国产在线色 | 玖玖爱免费视频 | 日韩成人看片 | 成年人免费在线观看网站 | 日本高清xxxx | 精品毛片一区二区免费看 | 成人av在线观 | 国产毛片久久久 | 亚洲精品在线免费观看视频 | 美女久久一区 | 婷婷深爱 | 亚洲天堂网在线播放 | 在线观看免费av网 | 91日韩在线专区 | 成人一级电影在线观看 | 97国产在线播放 | 免费福利在线播放 | 91香蕉国产在线观看软件 | 成人资源网 | 狠狠色免费 | 国模一二三区 | 欧美激情在线网站 | 日韩,中文字幕 | 国产涩涩在线观看 | 国产一及片 | 国产成人不卡 | 国产18精品乱码免费看 | 欧美日韩久久不卡 | 日日夜夜天天干 | 成 人 黄 色 片 在线播放 | 超碰精品在线观看 | 国产精品视频99 | av黄色亚洲 | 成人一级在线观看 | 久色小说 | 久碰视频在线观看 | 日本午夜免费福利视频 | 亚洲日韩中文字幕 | 亚洲国产中文在线观看 | 国产精品一区二 | 天天操天天射天天插 | 亚洲欧美国产精品18p | 国产一级淫片在线观看 | 午夜av在线免费 | av中文字幕亚洲 | 国产亚洲精品久久久久久电影 | 国产精品久久二区 | 免费在线黄 | 91精品亚洲影视在线观看 | 伊人婷婷久久 | 久草视频精品 | 色综合久久天天 | 久久久国产毛片 | 国内视频在线 | 懂色av一区二区三区蜜臀 | 日韩在线观看av | 日韩av影视 | 伊人精品在线 | 亚洲一一在线 | 亚洲永久在线 | 国产在线观看你懂的 | 蜜臀av性久久久久av蜜臀妖精 | 久久精品国产精品 | 91麻豆精品国产自产在线游戏 | 久久免费福利视频 | 久影院| 国产成人精品一区二区三区在线观看 | 亚洲成aⅴ人片久久青草影院 | 中文在线资源 | 免费在线观看黄色网 | 色婷在线 | 五月婷婷激情六月 | 亚洲精品综合欧美二区变态 | 国产中文字幕免费 | 97免费在线观看视频 | 97人人艹 | 丁香六月久久综合狠狠色 | 欧美大码xxxx | 午夜精品一区二区三区免费视频 | 人人爱人人舔 | 亚洲精品久久视频 | 国产一二三四在线视频 | 色资源二区在线视频 | www.色五月.com| 99se视频在线观看 | 狠狠躁18三区二区一区ai明星 | 中文字幕网址 | 久草在线视频网 | 91在线视频观看免费 | 不卡中文字幕在线 | 国产成人久久精品亚洲 | 综合伊人久久 | 一区免费视频 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 手机看片 | 精品视频123区在线观看 | 成人国产亚洲 | 久久久影院一区二区三区 | 日日干日日色 | 不卡国产在线 | 久久免费观看少妇a级毛片 久久久久成人免费 | 人人干网| 91精品国产网站 | 久久亚洲私人国产精品va | 99久久精品免费看国产一区二区三区 |