在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

什么是數據傾斜?數據傾斜發生時的現象?

OSC開源社區 ? 來源:京東零售技術 ? 2023-04-20 10:09 ? 次閱讀

一、數據傾斜的基本概念

01 什么是數據傾斜?

用最通俗易懂的話來說,數據傾斜無非就是大量的相同key被partition分配到一個分區里,造成了'一個人累死,其他人閑死'的情況,這種情況是我們不能接受的,這也違背了并行計算的初衷,首先一個節點要承受著巨大的壓力,而其他節點計算完畢后要一直等待這個忙碌的節點,也拖累了整體的計算時間,可以說效率是十分低下的。

02? 數據傾斜發生時的現象?

(1)絕大多數task執行得都非???,但個別task執行的極慢。

(2)原本能正常執行的Spark作業,某天突然爆出OOM(內存溢出)異常。觀察異常棧,是我們寫的業務代碼造成的。

03 通用的常規解決方案

(1)增加jvm內存,這適用于第一種情況(唯一值非常少,極少數值有非常多的記錄值(唯一值少于幾千)),這種情況下,往往只能通過硬件的手段來進行調優,增加jvm內存可以顯著的提高運行效率。

(2)增加reduce的個數,這適用于第二種情況(唯一值比較多,這個字段的某些值有遠遠多于其他值的記錄數,但是它的占比也小于百分之一或千分之一),我們知道,這種情況下,最容易造成的結果就是大量相同key被partition到一個分區,從而一個reduce執行了大量的工作,而如果我們增加了reduce的個數,這種情況相對來說會減輕很多,畢竟計算的節點多了,就算工作量還是不均勻的,那也要小很多。

(3)自定義分區,這需要用戶自己繼承partition類,指定分區策略,這種方式效果比較顯著。

(4)重新設計key,有一種方案是在map階段時給key加上一個隨機數,有了隨機數的key就不會被大量的分配到同一節點(小幾率),待到reduce后再把隨機數去掉即可。

(5)使用combinner合并,combinner是在map階段,reduce之前的一個中間階段,在這個階段可以選擇性的把大量的相同key數據先進行一個合并,可以看做是local reduce,然后再交給reduce來處理,這樣做的好。

04 通用定位發生數據傾斜的代碼

(1)數據傾斜只會發生在shuffle中,下面是常用的可能會觸發shuffle操作的算子:distinct、groupByKey、reduceByKey、aggregateByKey、join、cogroup、repartition等。出現數據傾斜時,可能就是代碼中使用了這些算子的原因。

(2)通過觀察spark UI,定位數據傾斜發生在第幾個stage中,如果是用yarn-client模式提交,那么本地是可以直接看到log的,可以在log中找到當前運行到了第幾個stage;如果用yarn-cluster模式提交,可以通過Spark Web UI 來查看當前運行到了第幾個stage。此外,無論是使用了yarn-client模式還是yarn-cluster模式,我們都可以在Spark Web UI 上深入看一下當前這個stage各個task分配的數據量,從而進一步確定是不是task分配的數據不均勻導致了數據傾斜。

二、 Hive數據傾斜

1、Hive的執行是分階段的,map處理數據量的差異取決于上一個stage的reduce輸出,所以如何將數據均勻的分配到各個reduce中,就是解決數據傾斜的根本所在。

2 、造成數據傾斜的原因

1)、key分布不均勻

2)、業務數據本身的特性

3)、建表時考慮不周

4)、某些SQL語句本身就有數據傾斜

3 、數據傾斜的表現:

數據傾斜出現在SQL算子中包含join/group by/等聚合操作時,大量的相同KEY被分配到少量的reduce去處理。導致絕大多數TASK執行得都非???,但個別TASK執行的極慢,原本能正常執行的作業,某天突然爆出OOM(內存溢出)異常。任務進度長時間維持在99%(或100%)。任務監控頁面,發現只有少量(1個或幾個)reduce子任務未完成。因為其處理的數據量和其他reduce差異過大。單一reduce的記錄數與平均記錄數差異過大,通??赡苓_到3倍甚至更多。 最長時長遠大于平均時長。可以查看具體job的reducer counter計數器協助定位。

4、數據傾斜的解決方案:

1)參數調節:

hive.map.aggr=true(是否在Map端進行聚合,默認為true),這個設置可以將頂層的聚合操作放在Map階段執行,從而減輕清洗階段數據傳輸和Reduce階段的執行時間,提升總體性能
Set hive.groupby.skewindata=true(hive自動進行負載均衡)

2)SQL語句調節

a、如何Join: 關于驅動表的選取,選用join key分布最均勻的表作為驅動表。 做好列裁剪和filter操作,以達到兩表做join的時候,數據量相對變小的效果,避免笛卡爾積。 Hive中進行表的關聯查詢時,盡可能將較大的表放在Join之后。

b、大小表Join,開啟mapjoin

mapjoin的原理: MapJoin 會把小表全部讀入內存中,在map階段直接拿另外一個表的數據和內存中表數據做匹配,由于在map是進行了join操作,省去了reduce 階段,運行的效率就會高很多。參與連接的小表的行數,以不超過2萬條為宜,大小不超過25M。

設置參數

set hive.auto.convert.join=true;
hive.mapjoin.smalltable.filesize=25000000( 即25M)
?手動指定

-- a 表是大表,數據量是百萬級別

-- b 表是小表,數據量在百級別,mapjion括號中的b就是指定哪張表為小表
select
/*+mapjoin(b)*/
a.field1asfield1,
b.field2asfield2,
b.field3asfield3
fromaleftjoinb
on a.field1 = b.field1; 
c、大表Join大表:

null值不參與連接,簡單舉例
select field1,field2,field3…
fromlogaleftjoinuserbona.useridisnotnullanda.userid=b.userid
unionselectfield1,field2,field3fromlogwhereuseridisnull;

將熱點key打散,但是需要注意,盡量不要在join時,對關聯key使用rand()函數。因為在hive中當遇到map失敗重算時,就會出現數據重復(數據丟失)的問題,spark引擎使用rand容易導致task失敗重新計算的時候偶發不一致的問題??梢允褂胢d5加密唯一維度值的方式替代rand(), 比如: md5(concat(coalesce(sku_id, 0), '_', coalesce(dim_store_num, 0), '_', coalesce(store_id, 0), '_',coalesce(delv_center_id, 0))),其中concat的字段是表的唯一粒度;也可以使用hash。

d、count distinct大量相同特殊值,使用sum...group by代替count(distinct ) 例如

selecta,count(distinctb)fromtgroupbya 
可以寫成selecta,sum(1)from(selecta,bfromtgroupbya,b)groupbya;
select count (distinct key) from  a 
可以寫成 Select  sum(1) from (Select  key  from  a   group by  key)  t
特殊情況特殊處理:在業務邏輯優化效果的不大情況下,有些時候是可以將傾斜的數據單獨拿出來處理。最后union回去

e、 不管是join還是groupby 請先在內層先進行數據過濾,建議只保留需要的key值

f、 取最大最小值盡量使用min/max;不要采用row_number

g、 不要直接select * ;在內層做好數據過濾

h、 盡量使用sort by替換order by

i、 明確數據源,有上層匯總的就不要使用基礎fdm或明細表

J、join避免多對多關聯

在join鏈接查詢時,確認是否存在多對多的關聯,起碼保證有一個表的結果集的關聯字段不重復。

5、典型的業務場景舉例

(1)空值產生的數據傾斜

場景:如日志中,常會有信息丟失的問題,比如日志中的 user_id,如果取其中的 user_id 和 用戶表中的user_id 關聯,會碰到數據傾斜的問題。

解決方法1: user_id為空的不參與關聯
select * from log a
join users b
on a.user_id is not null
and a.user_id = b.user_idunion allselect * from log a
where a.user_id is null;
(2)不同數據類型關聯產生數據傾斜

場景:用戶表中user_id字段為int,log表中user_id字段既有string類型也有int類型。當按照user_id進行兩個表的Join操作時,默認的Hash操作會按int型的id來進行分配,這樣會導致所有string類型id的記錄都分配到一個Reducer中。

解決方法:把數字類型轉換成字符串類型
select * from users a
left outer join logs b
on a.usr_id = cast(b.user_id as string)
(3)小表不小不大,怎么用 map join 解決傾斜問題

使用 map join 解決小表(記錄數少)關聯大表的數據傾斜問題,這個方法使用的頻率非常高,但如果小表很大,大到map join會出現bug或異常,這時就需要特別的處理 。
select * from log a
left outer join users b
on a.user_id = b.user_id;
users 表有 600w+ 的記錄,把 users 分發到所有的 map 上也是個不小的開銷,而且 map join 不支持這么大的小表。如果用普通的 join,又會碰到數據傾斜的問題。 解決方法:
select /*+mapjoin(x)*/* from log a
left outer join (
select /*+mapjoin(c)*/d.*
from ( select distinct user_id from log ) c
join users d
on c.user_id = d.user_id
) x
on a.user_id = b.user_id;
log里user_id有上百萬個,這就又回到原來map join問題。所幸,每日的會員uv不會太多,有交易的會員不會太多,有點擊的會員不會太多,有傭金的會員不會太多等等。所以這個方法能解決很多場景下的數據傾斜問題。

(4)業務邏輯突發熱key的處理(真實線上問題) 業務場景舉例:

流量數據多個設備號對應了一個安裝id,突發某幾個安裝id數量級特別大。在歸一環節中,按照安裝id進行分發reduce,再進行處理,異常熱key會造成單一節點處理數據量大,由于數據傾斜從而導致任務卡死的情況。

解決方案:基于小時任務,提前設置一個異常范圍,把異常安裝id和對應的aid撈出來,寫到維表里面。按照歸一邏輯,優先使用aid值作為歸一結果,所以在歸一任務中,讀取異常值,隨機分發到reduce中,并將aid賦值給歸一字段,這樣就避免了熱點處理。

總結:

1、對于join,在判斷小表不大于1G的情況下,使用map join


2、對于group by或distinct,設定 hive.groupby.skewindata=true


3、盡量使用上述的SQL語句調節進行優化


6、數據傾斜的監控預防

(1)測試的時候需要關注數據分布,針對不同日期、關鍵指標、重點key、枚舉值等

(2)增加數據質量監控,數據計算的每層任務增加數據質量監控。

(3)L0任務,大數據平臺需要有健康度巡檢,對資源、參數配置,數據傾斜、穩定性等做任務健康度打分,從而發現數據傾斜的趨勢,及早檢查任務

、spark數據傾斜

Spark優化數據傾斜的思路,join方式從SMJ方式改成BMJ的方式,但是只適合大小表的情況。優化思路一般是: 改join方式,開啟spark自適應框架,優化sql。

1、開啟sparksql的數據傾斜時的自適應關聯優化

spark.shuffle.statistics.verbose=true 
打開后MapStatus會采集每個partition條數的信息,用于傾斜處理。

2 、Sortmergejoin 改成 BroadcastHashJoin。調大BroadcastHashJoin的閾值。

在某些場景下可以把SortMergeJoin轉化成BroadcastHashJoin而避免shuffle產生的數據傾斜。 增加參數:
spark.sql.autoBroadcastJoinThreshold=524288000
將BHJ的閾值提高到500M

3、優化sql同hive

4、傾斜KEY查找

需要結合實際業務代碼,查找到引起Shuffle的算子,并按照以下兩種方式查找大KEY。?

方式一:通過SQL抽樣傾斜KEY

適用場景:如果數據量比較小的情況下,通過SQL的方式驗證比較便捷 。

操作步驟:

1、針對KEY進行數量統計

2、按照數量從大到小進行排序

3、直接取 limit N 即可?

方式二:通過sample抽樣傾斜KEY

適用場景:如果數據量很大,可以通過抽樣進行抽取大KEY。能否抽取到大KEY一般和抽取數據比例有關系。

操作步驟:

1、對KEY賦值為1,便于下一步進行計數

2、對KEY進行累計

3、對KEY和VALUE交換

4、針對KEY按照字典進行倒排

5、將KEY和VAlUE位置交換,還原到真實的

6、從已排序的RDD中,直接取前N條

數據傾斜一般由Shuffle時數據不均勻導致,一般有三類算子會產生Shuffle:Aggregation (groupBy)、Join、Window。 01 Aggregation

建議打散key進行二次聚合:采用對 非constant值、與key無關 的列進行hash取模,不要使用rand類函數。

以DataFrame API示例:

dataframe
.groupBy(col("key"),pmod(hash(col("some_col")),100)).agg(max("value").as("partial_max"))
.groupBy(col("key")).agg(max("partial_max").as("max"))
02? Window

目前支持該模式下的傾斜window,(僅支持3.0)

select (... row_number() over(partition by ... order by ...) as rn)
wherern[==|<=|<]?k?and?other?conditionsspark.sql.rankLimit.enabled=true?(目前支持基于row_number的topK計算邏輯)
03? Shuffled Join

Spark 2.4開啟參數

spark.sql.adaptive.enabled=true
spark.shuffle.statistics.verbose=true
spark.sql.adaptive.skewedJoin.enabled=true
spark.sql.adaptive.allowAdditionalShuffle=true
如果不能處理,建議用戶自行定位熱點數據進行處理 Spark 3.0
spark.sql.adaptive.enabled=true
spark.sql.adaptive.skewJoin.enabled=true
spark.sql.adaptive.skewJoin.enhance.enabled=true (通用傾斜算法,可處理更多場景)
spark.sql.adaptive.forceOptimizeSkewedJoin=true(允許插入額外shuffle,可處理更多場景)

其他參數:

spark.sql.adaptive.skewJoin.skewedPartitionThresholdInBytes (默認為256MB,分區大小超過該閾值才可被識別為傾斜分區,如果希望調整的傾斜分區小于該閾值,可以酌情調?。?

spark.sql.adaptive.skewJoin.skewedPartitionFactor (默認為5,分區大小超過中位數Xfactor才可被識別為傾斜分區,一般不需要調整)? spark.sql.adaptive.skewJoin.enhance.maxJoins (默認5,通用傾斜算法中,如果shuffled join超過此閾值則不處理,一般不需要調整)? spark.sql.adaptive.skewJoin.enhance.maxSplitsPerPartition (默認1000,通用傾斜算法中,盡量使得每個傾斜分區的劃分不超過該閾值,一般不需要調整)?

04 數據膨脹(Join)

spark.sql.adaptive.skewJoin.inflation.enabled=true(默認false,由于采樣計算會導致性能回歸,正常任務不要開啟)
spark.sql.adaptive.skewJoin.inflation.factor=50(默認為100,預估的分區輸出大小超過中位數Xfactor才可被識別為膨脹分區,由于預估算法存在誤差,一般不要低于50)
spark.sql.adaptive.shuffle.sampleSizePerPartition=500(默認100,每個Task中的采樣數,基于該采樣數據預估Join之后的分區大小,如果Task數量不大,可以酌情調大)
05 傾斜key檢測(Join)

由于Join語義限制,對于A left join skewed B之類的場景,無法對B進行劃分處理,否則會導致數據正確性問題,這也是Spark項目所面臨的難題。如果開啟以上功能依然不能處理數據傾斜,可以通過開啟傾斜key檢測功能來定位是哪些key導致了傾斜或膨脹,繼而進行過濾等處理。

spark.sql.adaptive.shuffle.detectSkewness=true(默認false,由于采樣計算會導致性能回歸,正常任務不要開啟)
其他參數:
spark.sql.adaptive.shuffle.sampleSizePerPartition=100(默認100,每個Task中的采樣數,如果Task數量不大,可以酌情調大)






審核編輯機:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 計數器
    +關注

    關注

    32

    文章

    2259

    瀏覽量

    94841
  • SQL
    SQL
    +關注

    關注

    1

    文章

    772

    瀏覽量

    44201
  • RDD
    RDD
    +關注

    關注

    0

    文章

    7

    瀏覽量

    7986
  • JVM
    JVM
    +關注

    關注

    0

    文章

    158

    瀏覽量

    12249

原文標題:淺談離線數據傾斜

文章出處:【微信號:OSC開源社區,微信公眾號:OSC開源社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    輸電線電桿安全守護者:傾斜監測裝置如何保障電網穩定運行

    TLKS-PMG-QX電桿傾斜監測裝置的核心在于雙軸傾角傳感器,其能精確測量桿塔在縱向與橫向的傾斜角度。傳感器持續采集數據,并通過高性能通信模塊(支持3G、4G、光纖、WiFi等多種傳輸方式)實時
    的頭像 發表于 11-26 17:38 ?189次閱讀
    輸電線電桿安全守護者:<b class='flag-5'>傾斜</b>監測裝置如何保障電網穩定運行

    輸電線路桿塔傾斜在線監測裝置,桿塔傾斜預警大師

    很多人還不知道桿塔傾斜有怎樣的危害以及桿塔傾斜是什么?桿塔傾斜是指輸電線路的桿塔在垂直方向上偏離了正常位置,出現一定角度或位移的現象。 產生原因 1、桿塔基礎是確保桿塔穩定的關鍵。水土
    的頭像 發表于 11-20 18:05 ?246次閱讀

    北斗輸電線路桿塔傾斜在線監測裝置 高精度差分定位 雙天線

    鐵塔出現傾斜、變形、倒塌等危及鐵塔或周邊環境及人員財產安全的事件發生,為桿塔的后期維護檢修提供大數據支撐,輔助運維人員進行科學決策。
    的頭像 發表于 11-08 10:55 ?210次閱讀

    PLR-30M-G傾斜開關常閉型接線圖

    基于常見傾斜開關常閉型的通用描述。在實際應用中,應根據具體品牌和型號的傾斜開關說明書進行接線操作。
    的頭像 發表于 11-05 18:19 ?292次閱讀

    電桿傾斜監測裝置 桿塔傾斜監測裝置 支持數據實時讀取 精確預警

    TLKS-PMG-QX電桿傾斜監測裝置的核心組件是雙軸傾角傳感器,該傳感器能夠精確測量桿塔在縱向和橫向兩個方向的傾斜角度。傳感器持續進行數據采集,并將這些數據實時傳輸至監測主機。監測主
    的頭像 發表于 11-05 11:05 ?299次閱讀
    電桿<b class='flag-5'>傾斜</b>監測裝置 桿塔<b class='flag-5'>傾斜</b>監測裝置 支持<b class='flag-5'>數據</b>實時讀取 精確預警

    傾斜開關的精度如何判斷MY-QT20

    判斷傾斜開關的精度需要綜合考慮多個方面,包括使用測試儀器進行測試、觀察外觀和接線情況、檢查指示燈和工作狀態以及考慮環境因素等。通過這些方法,可以更有效地評估傾斜開關的精度和性能。
    的頭像 發表于 10-28 14:32 ?171次閱讀

    傾斜傳感器的種類與選擇技巧

    2024-07-17 傾斜傳感器,又稱傾角傳感器或傾斜計,是一種測量物體相對于重力場的傾斜角度的設備。這些傳感器在各種應用中都有廣泛的使用,包括工業自動化、航空航天、樓宇、汽車和消費類電子產品等領域
    的頭像 發表于 10-02 17:10 ?648次閱讀
    <b class='flag-5'>傾斜</b>傳感器的種類與選擇技巧

    三軸高精度監測!這款無線傾斜儀,讓建筑更安全~

    YD-223WA3A無線傾斜儀是我司自主研發生產的一款低功耗、小體積且高性能的無線三軸傾斜儀。
    的頭像 發表于 08-21 15:28 ?656次閱讀
    三軸高精度監測!這款無線<b class='flag-5'>傾斜</b>儀,讓建筑更安全~

    傾斜光柵的魯棒性優化

    直接納入優化過程,例如參數變化分析儀。該工具結合了同一系統的多次迭代,在優化過程中實現了評價函數的表示和自動計算,如平均效率。在這個用例中,我們通過稍微改變填充因子來優化傾斜光柵來演示這個特性。 仿真
    發表于 08-12 18:38

    傾斜傳感器:工作原理與廣泛應用

    來源:天天IC 編輯:感知芯視界 Link 在科技日新月異的今天,傳感器技術作為連接物理世界與數字世界的橋梁,正以前所未有的速度推動著各行各業的進步。其中,傾斜傳感器作為一種能夠精準感知物體傾斜
    的頭像 發表于 08-02 09:58 ?852次閱讀

    北斗桿塔傾斜在線監測裝置:智能守護電網安全的新利器

    鐵塔在電力輸電線路與通信網絡的覆蓋中起到了重要作用。但是絡,由于一些自然災害(如雨雪、大風等)以及煤礦開采、工程施工、人為破壞等,塔體傾斜的情況時有發生。塔體傾斜經常會造成輸電線路和通信網絡中斷
    的頭像 發表于 06-28 15:54 ?492次閱讀
    北斗桿塔<b class='flag-5'>傾斜</b>在線監測裝置:智能守護電網安全的新利器

    輸電線路桿塔傾斜在線監測裝置功能,案例 桿塔傾斜的影響因素及鐵塔傾斜監測預警系統的應用

    輸電線路桿塔傾斜是由于基礎不平或地基不穩下沉引起桿塔中心偏離鉛垂位置的現象。這種現象不僅會影響輸電線路的安全和穩定運行,還可能導致線路故障,甚至造成停電事故。桿塔傾斜會加大桿塔的受力,
    的頭像 發表于 05-23 09:20 ?452次閱讀
    輸電線路桿塔<b class='flag-5'>傾斜</b>在線監測裝置功能,案例 桿塔<b class='flag-5'>傾斜</b>的影響因素及鐵塔<b class='flag-5'>傾斜</b>監測預警系統的應用

    輸電線路桿塔傾斜在線監測裝置 桿塔傾斜計算監測 桿塔沉降位移監測

    鐵塔出現傾斜現象,由于采空區地表出現沉降時,導致輸電線路桿身和塔身出現受力彎曲和桿塔傾斜問題同時,桿塔存在不平衡問題,嚴重情況下,導致輸電線路出現跳閘和倒桿斷線問題。 第二,在正常的情況下,鐵塔兩側導線張力,
    的頭像 發表于 05-08 10:27 ?555次閱讀
    輸電線路桿塔<b class='flag-5'>傾斜</b>在線監測裝置  桿塔<b class='flag-5'>傾斜</b>計算監測 桿塔沉降位移監測

    線路上發生桿塔傾斜或沉降的原因以及解決方案

    1、概述當前電力行業發展速度較快,電力企業在實際發展過程中,架空送電線路塔桿與輸電線路正常運行具有重要作用和意義。但如果架空送電線路桿塔出現嚴重的傾斜問題,對輸電線路安全運行造成重大影響,嚴重情況
    的頭像 發表于 02-28 16:35 ?1363次閱讀
    線路上<b class='flag-5'>發生</b>桿塔<b class='flag-5'>傾斜</b>或沉降的原因以及解決方案

    遠程傾斜位移監測儀使用說明書

    產品概述遠程傾斜位移監測儀具有體積小、精度高、安裝方便、功能完備等優勢,可對被測物進行實時的監測,兼具自動化、云模式、高精度。能根據對設備自身的X、Y、Z三個方向的姿態傾斜狀況進行實時監測,測量出
    發表于 01-30 09:06 ?0次下載
    主站蜘蛛池模板: 嫩草影院国产| 久久综合狠狠综合狠狠| 伊人久久大杳蕉综合大象| 久久中出| 在线网站你懂| 亚洲电影一区二区三区| 上课被同桌摸下面做羞羞 | 日日射天天射| 免费又爽又黄的禁片1000部| 久久天天躁狠狠躁夜夜呲| 国产大毛片| 狠狠干人人干| 男女性生动态免费视频| 一级毛片视屏| 日韩一区二区三区在线| 六月婷婷在线视频| 高清色| 天天免费| free chinese 国产精品| 椎名空中文字幕一区二区| 美女被强插| 色香蕉色香蕉在线视频| 六月婷婷网视频在线观看| 丁香啪啪天堂激情婷婷| 天天干天天做天天射| 国产伦精品一区二区三区| 亚洲无卡| 四虎永久在线精品| 精品国产污网站在线观看15| 在线免费看黄的网站| 乱色伦图片区| 亚洲一二三四| 色综合网址| 国产高清一区二区| 日韩一级片免费| 国产精品久久久久久久9999| 优优色综合| 尻老逼| 色图插插插| 色偷偷亚洲天堂| 三级视频在线|