国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

對比Elasticsearch,使用Doris進行高效日志分析

數(shù)據(jù)庫 其他數(shù)據(jù)庫
基于SQL的分析引擎確保數(shù)據(jù)工程師和分析師能夠在短時間內(nèi)輕松掌握Apache Doris,并將其在SQL方面的經(jīng)驗應(yīng)用到這個OLAP引擎中。借助SQL的豐富功能,用戶可以執(zhí)行數(shù)據(jù)檢索、聚合、多表連接、子查詢、UDF、邏輯視圖和物化視圖,以滿足自身需求。

作為公司數(shù)據(jù)資產(chǎn)的重要組成部分,日志在系統(tǒng)的可觀察性、網(wǎng)絡(luò)安全和數(shù)據(jù)分析方面扮演著關(guān)鍵角色。日志記錄是故障排除的首選工具,也是提升系統(tǒng)安全性的重要參考。日志還是一個寶貴的數(shù)據(jù)源,通過對其進行分析,可以獲取指導(dǎo)業(yè)務(wù)增長的有價值信息。

日志是計算機系統(tǒng)中事件的順序記錄。一個理想的日志分析系統(tǒng)應(yīng)該是:

  • 具備無模式支持。 原始日志是非結(jié)構(gòu)化的自由文本,基本無法直接進行聚合和計算,因此,在將日志用于數(shù)據(jù)庫或數(shù)據(jù)倉庫進行分析之前,需要將其轉(zhuǎn)化為結(jié)構(gòu)化的表格形式(這個過程稱為“ETL”)。如果發(fā)生日志模式更改,需要在ETL流程和結(jié)構(gòu)化表中進行一系列復(fù)雜的調(diào)整。為了應(yīng)對此情況,可以使用半結(jié)構(gòu)化日志,主要采用JSON格式進行記錄。在這種格式的日志中,可以相對容易地添加或刪除字段,而日志存儲系統(tǒng)會相應(yīng)地調(diào)整其模式。
  • 低成本。 日志數(shù)據(jù)龐大且持續(xù)不斷生成。一個相當(dāng)大的公司每年會產(chǎn)生10~100 TB的日志數(shù)據(jù)。基于業(yè)務(wù)或合規(guī)要求,應(yīng)該保留半年或更長時間的日志。這意味著需要存儲以PB為單位的日志大小,成本相當(dāng)可觀。
  • 具備實時處理能力。 日志應(yīng)該實時寫入,否則工程師將無法及時捕捉故障排查和安全追蹤中的最新事件。此外,良好的日志系統(tǒng)應(yīng)該提供全文搜索功能,并能快速響應(yīng)交互式查詢。

1 基于Elasticsearch的日志分析解決方案

數(shù)據(jù)行業(yè)內(nèi)常用的日志處理解決方案是ELK技術(shù)棧:Elasticsearch、Logstash和Kibana。該流程可分為五個模塊:

  • 日志收集:Filebeat收集本地日志文件并將其寫入Kafka消息隊列。
  • 日志傳輸:Kafka消息隊列收集和緩存日志。
  • 日志轉(zhuǎn)換:Logstash過濾和轉(zhuǎn)換Kafka中的日志數(shù)據(jù)。
  • 日志存儲:Logstash以JSON格式將日志寫入Elasticsearch進行存儲。
  • 日志查詢:用戶通過Kibana可視化搜索日志或通過Elasticsearch DSL API發(fā)送查詢請求。

圖片圖片

ELK堆棧具有優(yōu)秀的實時處理能力,但也存在一些問題。

1.1 缺乏無模式支持

Elasticsearch中的索引映射定義了表的結(jié)構(gòu),包括字段名稱、數(shù)據(jù)類型以及是否啟用索引創(chuàng)建。

圖片圖片

Elasticsearch還擁有自動根據(jù)輸入的JSON數(shù)據(jù)添加字段到映射的動態(tài)映射機制。這提供了某種程度的無模式支持,但這還不夠,因為:

  • 動態(tài)映射在處理臟數(shù)據(jù)時經(jīng)常會創(chuàng)建過多的字段,從而中斷整個系統(tǒng)的運行。
  • 字段的數(shù)據(jù)類型是不可變的。為了確保兼容性,用戶通常將數(shù)據(jù)類型配置為"文本",但這會導(dǎo)致比二進制數(shù)據(jù)類型(如整數(shù))慢得多的查詢性能。
  • 字段的索引也是不可變的。用戶無法為特定字段添加或刪除索引,因此經(jīng)常為所有字段創(chuàng)建索引,以便在查詢中方便地進行數(shù)據(jù)過濾。但是太多的索引需要額外的存儲空間,并減慢數(shù)據(jù)攝入速度。

1.2 分析能力不足

Elasticsearch擁有獨特的領(lǐng)域特定語言(DSL),與大多數(shù)數(shù)據(jù)工程師和分析師熟悉的技術(shù)棧非常不同,所以存在陡峭的學(xué)習(xí)曲線。此外,Elasticsearch相對封閉的生態(tài)系統(tǒng),在與BI工具集成方面會遇到一些阻力。最重要的是,Elasticsearch僅支持單表分析,滯后于現(xiàn)代OLAP對多表連接、子查詢和視圖的需求。

圖片圖片

1.3 高成本和低穩(wěn)定性

Elasticsearch用戶一直在抱怨計算和存儲成本。根本原因在于Elasticsearch的工作方式。

  • 計算成本:在數(shù)據(jù)寫入過程中,Elasticsearch還執(zhí)行計算密集型操作,包括倒排索引的創(chuàng)建、分詞和倒排索引的排序。在這些情況下,數(shù)據(jù)以每個核心約2MB/s的速度寫入Elasticsearch。當(dāng)CPU資源緊張時,數(shù)據(jù)寫入需求往往會在高峰時段被拒絕,進一步導(dǎo)致更高的延遲。
  • 存儲成本:為了加快檢索速度,Elasticsearch存儲原始數(shù)據(jù)的正排索引、倒排索引和文檔值,消耗了更多的存儲空間。單個數(shù)據(jù)副本的壓縮比僅為1.5:1,而大多數(shù)日志解決方案的壓縮比為5:1。

隨著數(shù)據(jù)量和集群規(guī)模的增長,保持穩(wěn)定性會成為另一個問題:

  • 在數(shù)據(jù)寫入高峰期:集群在數(shù)據(jù)寫入高峰期容易超載。
  • 在查詢期間:由于所有查詢都在內(nèi)存中處理,大型查詢很容易導(dǎo)致JVM OOM(內(nèi)存溢出)。
  • 恢復(fù)緩慢:對于集群故障,Elasticsearch需要重新加載索引,這對資源消耗很大,因此恢復(fù)過程可能需要幾分鐘。這對于服務(wù)可用性的保證是一個挑戰(zhàn)。

2 更具成本效益的方案

在反思基于Elasticsearch的解決方案的優(yōu)點和局限性后,Apache Doris開發(fā)人員對Apache Doris進行了日志處理的優(yōu)化。

  • 增加寫入吞吐量: Elasticsearch的性能受到數(shù)據(jù)解析和倒排索引創(chuàng)建的限制,因此改進了Apache Doris在這些方面的性能:通過SIMD指令和CPU向量指令加快了數(shù)據(jù)解析和索引創(chuàng)建的速度;然后移除了在日志分析場景中不必要的數(shù)據(jù)結(jié)構(gòu),例如正排索引,以簡化索引創(chuàng)建過程。
  • 減少存儲成本: 移除了正排索引,這部分?jǐn)?shù)據(jù)占據(jù)了索引數(shù)據(jù)的30%。采用了列式存儲和ZSTD壓縮算法,從而實現(xiàn)了5:1到10:1的壓縮比。考慮到大部分歷史日志很少被訪問,引入了分層存儲來分離熱數(shù)據(jù)和冷數(shù)據(jù)。超過指定時間段的日志將被移動到存儲成本更低的對象存儲中。這可以將存儲成本降低約70%。

Elasticsearch的官方測試工具ES Rally進行的基準(zhǔn)測試顯示,Apache Doris在數(shù)據(jù)寫入方面比Elasticsearch快約5倍,在查詢方面快約2.3倍,并且僅消耗Elasticsearch使用存儲空間的1/5。在HTTP日志的測試數(shù)據(jù)集上,它實現(xiàn)了550 MB/s的寫入速度和10:1的壓縮比。

圖片圖片

下圖顯示了一個典型的基于Doris的日志處理系統(tǒng)的樣貌。它更加全面,從數(shù)據(jù)攝取、分析到應(yīng)用,都可以更靈活地使用:

  • 數(shù)據(jù)導(dǎo)入:Apache Doris支持多種日志數(shù)據(jù)的攝入方式。可以通過使用Logstash的HTTP輸出將日志推送到Doris,可以在將日志寫入Doris之前使用Flink預(yù)處理日志,或者可以通過常規(guī)加載和S3加載從Flink或?qū)ο蟠鎯χ屑虞d日志到Doris中。
  • 數(shù)據(jù)分析:可以把日志數(shù)據(jù)放入Doris,并在數(shù)據(jù)倉庫中進行跨日志和其他數(shù)據(jù)的聯(lián)接查詢。
  • 應(yīng)用:Apache Doris兼容MySQL協(xié)議,因此可以把各種數(shù)據(jù)分析工具和客戶端集成到Doris中,例如Grafana和Tableau。還可以通過JDBC和ODBC API將應(yīng)用程序連接到Doris。這里計劃構(gòu)建一個類似于Kibana的系統(tǒng)來可視化日志。

圖片圖片

此外,Apache Doris具有更好的無模式支持和更用戶友好的分析引擎。

2.1 原生支持半結(jié)構(gòu)化數(shù)據(jù)

首先,在數(shù)據(jù)類型上進行優(yōu)化。通過矢量化優(yōu)化了字符串搜索和正則表達式匹配的文本性能,性能提升了2~10倍。對于JSON字符串,Apache Doris將其解析并存儲為更緊湊和高效的二進制格式,可以加快查詢速度4倍。還為復(fù)雜數(shù)據(jù)添加了一種新的數(shù)據(jù)類型:Array Map。它可以將連接的字符串進行結(jié)構(gòu)化,以實現(xiàn)更高的壓縮率和更快的查詢速度。

其次,Apache Doris支持模式演化。這意味著可以根據(jù)業(yè)務(wù)變化調(diào)整模式。可以添加或刪除字段和索引,并更改字段的數(shù)據(jù)類型。

Apache Doris提供了輕量級的模式更改功能,因此開發(fā)人員可以在幾毫秒內(nèi)添加或刪除字段:

-- 添加列。結(jié)果會在毫秒級返回。
ALTER TABLE lineitem ADD COLUMN l_new_column INT;

還可以僅為目標(biāo)字段添加索引,以避免不必要的索引創(chuàng)建帶來的開銷。在添加索引后,默認情況下,系統(tǒng)將為所有增量數(shù)據(jù)生成索引,并且可以指定需要索引的歷史數(shù)據(jù)分區(qū)。

-- 添加倒排索引。Doris會為以后的所有新數(shù)據(jù)生成倒排索引。
ALTER TABLE table_name ADD INDEX index_name(column_name) USING INVERTED;

-- 為指定的歷史數(shù)據(jù)分區(qū)構(gòu)建索引。
BUILD INDEX index_name ON table_name PARTITIONS(partition_name1, partition_name2);

2.2 基于SQL的分析引擎

基于SQL的分析引擎確保數(shù)據(jù)工程師和分析師能夠在短時間內(nèi)輕松掌握Apache Doris,并將其在SQL方面的經(jīng)驗應(yīng)用到這個OLAP引擎中。借助SQL的豐富功能,用戶可以執(zhí)行數(shù)據(jù)檢索、聚合、多表連接、子查詢、UDF、邏輯視圖和物化視圖,以滿足自身需求。

Apache Doris具備MySQL兼容性,可以與大數(shù)據(jù)生態(tài)系統(tǒng)中的大多數(shù)GUI和BI工具集成,使用戶能夠?qū)崿F(xiàn)更復(fù)雜和多樣化的數(shù)據(jù)分析。

3 使用案例中的性能表現(xiàn)

一家游戲公司已經(jīng)從ELK技術(shù)棧轉(zhuǎn)向了Apache Doris解決方案。他們基于Doris的日志系統(tǒng)所需的存儲空間只有之前的1/6。

一家網(wǎng)絡(luò)安全公司利用Apache Doris中的倒排索引構(gòu)建了他們的日志分析系統(tǒng),支持每秒寫入30萬行數(shù)據(jù),僅使用以前所需的1/5服務(wù)器資源。

4 實踐指南

現(xiàn)在按照以下三個步驟來構(gòu)建一個基于Apache Doris的日志分析系統(tǒng)。

在開始之前,從官方網(wǎng)站下載Apache Doris 2.0或更新版本,并部署集群。

4.1 步驟1:創(chuàng)建表格

這是一個表格創(chuàng)建的示例。

對配置的解釋:

  • 將DATETIMEV2時間字段指定為鍵,以加快對最新N條日志記錄的查詢速度。
  • 為頻繁訪問的字段創(chuàng)建索引,并使用解析器參數(shù)指定需要進行全文搜索的字段。
  • "PARTITION BY RANGE"意味著根據(jù)時間字段將數(shù)據(jù)按范圍進行分區(qū),啟用動態(tài)分區(qū)以進行自動管理。
  • "DISTRIBUTED BY RANDOM BUCKETS AUTO"意味著將數(shù)據(jù)隨機分布到桶中,系統(tǒng)會根據(jù)集群大小和數(shù)據(jù)量自動決定桶的數(shù)量。
  • "log_policy_1day"和"log_s3"意味著將超過1天的日志移動到S3存儲。
CREATE DATABASE log_db;
USE log_db;

CREATE RESOURCE "log_s3"
PROPERTIES
(
   "type" = "s3",
   "s3.endpoint" = "your_endpoint_url",
   "s3.region" = "your_region",
   "s3.bucket" = "your_bucket",
   "s3.root.path" = "your_path",
   "s3.access_key" = "your_ak",
   "s3.secret_key" = "your_sk"
);

CREATE STORAGE POLICY log_policy_1day
PROPERTIES(
   "storage_resource" = "log_s3",
   "cooldown_ttl" = "86400"
);

CREATE TABLE log_table
(
 ``ts` DATETIMEV2,
 ``clientip` VARCHAR(20),
 ``request` TEXT,
 ``status` INT,
 ``size` INT,
 INDEX idx_size (`size`) USING INVERTED,
 INDEX idx_status (`status`) USING INVERTED,
 INDEX idx_clientip (`clientip`) USING INVERTED,
 INDEX idx_request (`request`) USING INVERTED PROPERTIES("parser" = "english")
)
ENGINE = OLAP
DUPLICATE KEY(`ts`)
PARTITION BY RANGE(`ts`) ()
DISTRIBUTED BY RANDOM BUCKETS AUTO
PROPERTIES (
"replication_num" = "1",
"storage_policy" = "log_policy_1day",
"deprecated_dynamic_schema" = "true",
"dynamic_partition.enable" = "true",
"dynamic_partition.time_unit" = "DAY",
"dynamic_partition.start" = "-3",
"dynamic_partition.end" = "7",
"dynamic_partition.prefix" = "p",
"dynamic_partition.buckets" = "AUTO",
"dynamic_partition.replication_num" = "1"
);

4.2 步驟2:導(dǎo)入日志

Apache Doris支持多種數(shù)據(jù)導(dǎo)入方法。對于實時日志,推薦以下三種方法:

  • 從Kafka消息隊列中拉取日志:Routine Load
  • Logstash:通過HTTP API將日志寫入Doris
  • 自定義編寫程序:通過HTTP API將日志寫入Doris

使用Kafka進行數(shù)據(jù)攝取

對于寫入Kafka消息隊列的JSON日志,創(chuàng)建常規(guī)加載(Routine Load),以便Doris從Kafka中拉取數(shù)據(jù)。以下是示例。property.* 配置為可選配置:

-- 準(zhǔn)備Kafka集群和主題("log_topic")

-- 創(chuàng)建常規(guī)加載,從Kafka的 log_topic 加載數(shù)據(jù)到 "log_table"
CREATE ROUTINE LOAD load_log_kafka ON log_db.log_table
COLUMNS(ts, clientip, request, status, size)
PROPERTIES (
   "max_batch_interval" = "10",
   "max_batch_rows" = "1000000",
   "max_batch_size" = "109715200",
   "strict_mode" = "false",
   "format" = "json"
)
FROM KAFKA (
   "kafka_broker_list" = "host:port",
   "kafka_topic" = "log_topic",
   "property.group.id" = "your_group_id",
   "property.security.protocol"="SASL_PLAINTEXT",     
   "property.sasl.mechanism"="GSSAPI",     
   "property.sasl.kerberos.service.name"="kafka",     
   "property.sasl.kerberos.keytab"="/path/to/xxx.keytab",     
   "property.sasl.kerberos.principal"="xxx@yyy.com"
);

可以通過SHOW ROUTINE LOAD命令查看常規(guī)加載的運行情況。

通過Logstash進行數(shù)據(jù)導(dǎo)入

配置Logstash的HTTP輸出,然后通過HTTP Stream Load將數(shù)據(jù)發(fā)送到Doris。

1) 在logstash.yml中指定批量大小和批量延遲,以提高數(shù)據(jù)寫入性能。

pipeline.batch.size: 100000
pipeline.batch.delay: 10000

2) 在日志收集配置文件testlog.conf中添加HTTP輸出,URL為Doris中的Stream Load地址。

  • 由于Logstash不支持HTTP重定向,應(yīng)該使用后端地址而不是FE地址。
  • 頭部中的授權(quán)是http basic auth,使用echo -n 'username:password' | base64進行計算。
  • 頭部中的load_to_single_tablet可以減少數(shù)據(jù)攝取中的小文件數(shù)量。
output {
  http {
      follow_redirects => true
      keepalive => false
      http_method => "put"
      url => "http://172.21.0.5:8640/api/logdb/logtable/_stream_load"
      headers => [
          "format", "json",
          "strip_outer_array", "true",
          "load_to_single_tablet", "true",
          "Authorization", "Basic cm9vdDo=",
          "Expect", "100-continue"
      ]
      format => "json_batch"
  }
}

通過自定義程序進行數(shù)據(jù)攝取

以下是通過HTTP Stream Load將數(shù)據(jù)攝取到Doris的示例。

注意:

  • 使用basic auth進行HTTP授權(quán),使用 echo -n 'username:password' | base64 進行計算。
  • http header "format:json":指定數(shù)據(jù)類型為JSON。
  • http header "read_json_by_line:true":每行都是一個JSON記錄。
  • http header "load_to_single_tablet:true":每次寫入一個分片(tablet)。
  • 對于數(shù)據(jù)寫入客戶端,建議批量大小為100MB~1GB。未來的版本將在服務(wù)器端啟用Group Commit,并減小客戶端的批量大小。
curl \
--location-trusted \
-u username:password \
-H "format:json" \
-H "read_json_by_line:true" \
-H "load_to_single_tablet:true" \
-T logfile.json \
http://fe_host:fe_http_port/api/log_db/log_table/_stream_load

4.3 步驟3:執(zhí)行查詢

Apache Doris支持標(biāo)準(zhǔn)SQL,因此可以通過MySQL客戶端或JDBC連接到Doris,然后執(zhí)行SQL查詢。

mysql -h fe_host -P fe_mysql_port -u root -Dlog_db

一些常見的日志分析查詢:

  • 檢查最新的10條記錄。
SELECT * FROM log_table ORDER BY ts DESC LIMIT 10;
  • 檢查Client IP為"8.8.8.8"的最新的10條記錄。
SELECT * FROM log_table WHERE clientip = '8.8.8.8' ORDER BY ts DESC LIMIT 10;
  • 檢索在"request"字段中包含"error"或"404"的最新的10條記錄。MATCH_ANY是Doris中的通過全文搜索來查找包含指定關(guān)鍵詞中任意一個的記錄。
SELECT * FROM log_table WHERE request MATCH_ANY 'error 404' ORDER BY ts DESC LIMIT 10;
  • 檢索在"request"字段中同時包含"image"和"faq"的最新的10條記錄。MATCH_ALL也是Doris中的全文搜索語法關(guān)鍵詞,表示查找同時包含所有指定關(guān)鍵詞的記錄。
SELECT * FROM log_table WHERE request MATCH_ALL 'image faq' ORDER BY ts DESC LIMIT 10;

5 總結(jié)

如果需要一種高效的日志分析解決方案,Apache Doris是非常友好的選擇,尤其適合那些具備SQL知識的讀者。相比ELK堆棧,使用Apache Doris可以獲得更好的無模式支持,實現(xiàn)更快的數(shù)據(jù)寫入和查詢,并且減少存儲負擔(dān)。


責(zé)任編輯:武曉燕 來源: Java學(xué)研大本營
相關(guān)推薦

2023-10-29 12:54:16

Doris數(shù)據(jù)倉庫

2024-08-06 09:54:20

2023-11-30 18:03:55

IDEA工具

2023-12-25 11:18:12

OpenTeleme應(yīng)用日志Loki

2024-06-05 08:14:26

SpringElasticsea人臉數(shù)據(jù)

2021-04-12 08:17:12

ElasticSear分詞中文

2024-08-06 09:40:21

2024-03-12 00:05:00

開發(fā)編程語言IDE

2023-10-10 07:24:59

SRE日志OnCall

2021-12-24 10:45:19

PandasLambda數(shù)據(jù)分析

2024-05-07 08:16:17

2024-11-15 13:15:36

2023-03-31 17:33:06

Oracle數(shù)據(jù)庫

2015-09-25 11:03:14

數(shù)據(jù)中心日志分析

2024-10-18 11:39:55

MySQL數(shù)據(jù)檢索

2025-02-24 09:30:00

日志系統(tǒng)系統(tǒng)開發(fā)

2021-08-09 15:00:36

SQL數(shù)據(jù)庫

2023-10-04 00:17:00

SQL數(shù)據(jù)庫

2024-02-04 00:00:00

Loki性能查詢

2024-03-25 14:22:07

大型語言模型GaLore
點贊
收藏

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

成人免费直播| videos性欧美另类高清| 粉嫩一区二区三区国产精品| 欧美成人激情| 欧美福利电影网| 国产在线视频综合| 成人51免费| 欧美视频在线观看免费| 久久久亚洲国产精品| 久久精品亚洲人成影院 | 欧美日韩另类图片| 日韩av网站电影| 97影院手机在线观看| 国产91富婆露脸刺激对白| 国产精品综合久久久| 日韩精品三级| 亚洲欧美激情精品一区二区| 操你啦视频在线| 亚洲精品欧美在线| 四虎国产精品成人免费4hu| 久久国产66| 国产高清一区视频| 在线看片不卡| 国产精品美女久久| 黑人久久a级毛片免费观看| 永久555www成人免费| 美女视频一区| 在线播放国产一区中文字幕剧情欧美 | 亚洲精品久久久久久久久久久| 成人在线免费视频| 91精品国产91久久综合桃花| porn视频在线观看| 欧美日韩久久不卡| 亚洲奶水xxxx哺乳期| 亚洲精品网址在线观看| 992tv国产精品成人影院| 日韩av中文字幕在线播放| av福利在线导航| 欧美大尺度激情区在线播放| 综合久久伊人| 亚洲自拍偷拍色图| 国产农村妇女精品一区二区| 91制片厂免费观看| av毛片久久久久**hd| 天天爽人人爽夜夜爽| 亚洲一二三区在线观看| 草草视频在线| 51ⅴ精品国产91久久久久久| 蜜乳av综合| 精品国产免费一区二区三区 | av在线免费一区| 亚洲成人激情在线| 午夜视频一区二区在线观看| 国产日韩欧美影视| 久久国产精品区| 99免费视频| 精品一区二区三区三区| 亚洲v天堂v手机在线| 天天人人精品| 一区二区三区四区激情| 手机av在线播放| 国产精品永久免费| youjizz久久| 性xxxx丰满孕妇xxxx另类| 日韩理论片久久| 乱亲女h秽乱长久久久| 久草热久草热线频97精品| 成人av手机在线观看| 香蕉视频在线免费| www日韩欧美| 日韩av高清在线观看| 夜色资源站国产www在线视频| 欧美大胆a视频| 成人黄色777网| 日韩av福利| 在线观看欧美一区| 欧美变态凌虐bdsm| 亚洲美洲欧洲综合国产一区| 成视人a免费观看视频| 久久久久久久久久久成人| 国产一区在线观看麻豆| av电影在线观看一区二区三区| 欧美中在线观看| 成人国产视频在线观看| 日韩av超清在线观看| 日韩一区国产在线观看| 91精品国产乱| 欧美中文日韩| 97视频精彩视频在线观看| 欧美激情伊人电影| 亚洲欧美自拍偷拍色图| 九一精品国产| 污视频网站免费看| 99视频免费观看蜜桃视频| 亚洲成人av在线电影| 在线精品亚洲| 国产精品剧情| 国产中文字幕乱人伦在线观看| 中文字幕亚洲欧美日韩在线不卡| 国产大片一区二区| 51精品国产| 高清免费观看在线| 国产伦理久久久| 精品精品欲导航| 国产视频在线观看一区二区三区| 国产精品久久久久久久| 亚洲s色大片| 国产天堂在线播放| 国产精品海角社区在线观看| 日韩视频免费直播| 91麻豆免费视频| 国产精品a级| 色8久久久久| 色影院视频在线| 在线观看一区二区三区三州| 97在线免费观看| 欧美午夜精品一区二区蜜桃| 久久网这里都是精品| 欧美女王vk| 日韩欧美精品一区二区三区| 午夜激情在线观看视频| 亚洲国产日韩美| 国产97在线观看| 日本中文字幕一区二区视频| 国产精品xxxav免费视频| 人成在线免费视频| 国产黄色一级电影| 男人j进女人j| 国产欧美日韩在线播放| 国产精品wwww| 日本欧美爱爱爱| 91精品国产99| 久久久久久久999| 中文国产亚洲喷潮| 亚洲男人av电影| 精品成人在线观看| 欧美色倩网站大全免费| 国产精品国产a| 久久久久久久综合| 久久久国产午夜精品| 久久亚洲精华国产精华液| 99re在线精品| 不卡区在线中文字幕| 精品一区二区三区免费| 国产精品综合一区二区三区| 丁香花在线电影小说观看| 中文字幕在线视频网| 91xxxxx| 男人操女人免费软件| 中文字幕久久一区| 国产乱子伦精品| 亚洲综合社区网| 国产一区红桃视频| 欧美成人综合一区| 色综合久久av| 尤物av无码色av无码| 国产91对白刺激露脸在线观看| 亚洲美女搞黄| 丁香六月激情婷婷| 99热免费在线| 欧美精品在欧美一区二区| 激情视频在线观看一区二区三区| 国产女人18毛片水18精品| 97香蕉久久超级碰碰高清版| 伊人久久久久久久久久| 日韩www在线| 欧美tk—视频vk| 欧美一区二区三区四区久久 | 国产激情偷乱视频一区二区三区| 国产揄拍国内精品对白| 日韩一区日韩二区| 欧美在线短视频| 日韩视频123| 国模精品系列视频| 97国产在线观看| 孩xxxx性bbbb欧美| 色噜噜狠狠色综合网| 激情视频国产| 偷拍视频一区二区三区| 欧美激情1区2区| 床上的激情91.| 一本久久综合亚洲鲁鲁五月天 | 久久久久福利视频| 色网址在线观看| 一区二区网站| 国产在线视视频有精品| 欧美性xxxx在线播放| 久久久久久久影院| 国产1区2区3区中文字幕| 九九九伊在人线综合| 综合色就爱涩涩涩综合婷婷| 久久精品国产99| 欧美三级电影网| 5566中文字幕一区二区| 午夜刺激在线| 天天操夜夜操国产精品| 亚洲午夜羞羞片| 国产自产女人91一区在线观看| 校园春色影音先锋| 欧美一区电影|