精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

ZGC關鍵技術分析

開發
ZGC是如何設計怎么達到這個目標的呢?本文將從ZGC算法的關鍵特性入手,通過分析ZGC周期處理過程來理解這些特性,探索ZGC設計思想。

一、引言

垃圾回收對于Javaer來說是一個繞不開的話題,工作中涉及到的調優工作也經常圍繞垃圾回收器展開。面對不同的業務場景沒有一個統一的垃圾回收器能保證可GC性能。因此對程序員來說不僅要會編寫業務代碼,同時也要卷一下JVM底層原理和調優知識。這種局面可能因為ZGC的出現而發生改變,新一代回收器ZGC幾乎不需要調優的情況下GC停頓時間可以降低到亞秒級。

Oracle從JDK11開始正式引入ZGC,ZGC設計三大目標:

  • 支持TB級內存 (8M~4TB) 。
  • 停頓時間控制在10ms之內 (生產環境實際觀測在微秒級) ,停頓不會隨著堆的大小,或者活躍對象的大小而增加。
  • 對程序吞吐量影響小于15%。

ZGC是如何設計怎么達到這個目標的呢?本文將從ZGC算法的關鍵特性入手,通過分析ZGC周期處理過程來理解這些特性,探索ZGC設計思想。

二、ZGC術語

非分代:將對內存劃分為新生代和老年代 (G1已經邏輯分代) ,ZGC取消分代設計,每個GC周期都將標記整個堆中的所有活動對象。

頁面:ZGC將堆空間分解成一塊塊區域,這些區域叫做頁面,ZGC通過頁面來回收內存。

并發性:GC和線程和業務線程同時運行ZGC的高度并發設計,幾乎所有GC工作、標記和堆碎片整理都是和業務線程 (mutators) 同時運行的,只包含了短暫的STW同步暫停。

并行:多個線程進行GC線程同時工作,加快回收速度。

標記-復制算法:標記-復制算法主要包括以下3個過程。

  • 標記階段,即從GC Roots集合開始,分析對象可達性,標記出活躍對象。

圖1:可達性分析后對象的引用狀態

  • 對象轉移階段,即把活躍對象復制到新的內存地址上。
  • 重定位階段,因為轉移導致對象的地址發生了變化,在重定位階段,所有指向對象舊地址的指針都要調整到對象新的地址上。

標記-復制算法的最大優勢就是防止堆內存碎片化的出現,復制的過程就可以對堆內存進行整理。ZGC、CMS和G1都是采用了標記-復制算法,但是不同的實現導致了很大的性能差異。

三、ZGC性能數據

ZGC設計致力于提供幾毫秒的最大暫停時間,同時保證吞吐量不受影響。下面是SPECjbb2015針對OpenJDK中的不同收集器運行的性能測試數據。在128G堆內存下,無論是延遲還是吞吐量上面ZGC的性能表現都高于其他收集器。

圖2:SPECjbb2015GC性能評分

圖3: SPECjbb2015GC延遲比較

四、ZGC關鍵特性

ZGC的周期是高度并發的,并發性越高意味著GC工作時對業務線程的影響越小,SPECjbb2015的性能報告可以看出ZGC在延遲上比G1低10倍以上,ZGC的工作周期只有三個階段是STW的,其他階段完全并發。這得益于ZGC在堆視圖并發一致性設計上的改進。我們都清楚在并發的場景下需要協調各個線程對共享資源達成一致性,常用的手段就是對資源加鎖,而在垃圾回收器下的思路也是類似,如果GC線程工作是需要鎖定對象資源進行處理,業務線程則需要全部暫停,這就產生了STW (Stop The Word) 。以往的垃圾回收器都是讓GC線程和業務線程就堆中對象地址達成一致,對象在發生轉移時業務線程是不能訪問的 (因為對象的地址發生了變化) ,無論G1還是CMS對象在進行復制時都是需要STW。ZGC使用到的著色指針(Colored Pointer)和讀屏障(Load Barrier)技術,可以讓所有線程在并發的條件下就指針的顏色 (狀態) 達成一致,而不是對象地址。因此,ZGC可以并發的復制對象,這大大的降低了GC的停頓時間。我們先對著色指針和讀屏障有個初步的理解,然后在通過ZGC回收周期來看這2項技術的具體運用。

著色指針(Colored Pointer)

在指針中嵌入元數據(使用地址中的高階位來實現),這種通過在指針存儲元數據的技術就叫做著色指針 (Colored Pointer) 。ZGC中指針始終是64位結構,由元位(指針的顏色)和地址位組成。地址位數決定了理論上支持的最大堆大小,ZGC使用42位存儲地址也就意味著ZGC最大支持4TB堆內存。如圖所示,低42位是地址位,中間4位是元位,高18位未使用。四個元位是Finalized ( F )、Remapped ( R )、Marked1 ( M1 ) 和Marked0 ( M0 )。

圖4: 64位地址使用示意圖

ZGC中將指定上的標記通過顏色來表示,顏色可以是“good” (地址有效) 或“bad” (地址可能無效) 。指針的顏色由其元位的狀態決定:F、R、M1和M0。“good”是R、M1、M0元位中的一個被設置,另外三個未設置,比如0100、0010和 0001屬于“good”顏色。通過在指針上的顏色就能區分出對象狀態,不用額外做內存訪問,這使得ZGC在標記和轉移階段會更快。

通過設置地址元位的狀態,可以形成不同地址視圖,ZGC同一物理堆內存被映射到虛擬地址空間三次,從而產生同一物理內存的三個“視圖”,GC活動的不同時期會只存在一個活躍視圖,根據垃圾回收的周期ZGC通過切換不同視圖標來記出對象的顏色。

下圖是虛擬地址的空間劃分:

圖5:虛擬地址空間劃分和多視圖映射

[0~4TB) 對應Java堆;

[4TB ~ 8TB) 稱為M0地址空間;

[8TB ~ 12TB) 稱為M1地址空間;

[12TB ~ 16TB) 預留未使用;

[16TB ~ 20TB) 稱為Remapped空間。

ZGC是不分代的,這意味著垃圾回收是需要掃描整個堆空間,地址視圖將整個Java堆分成多個部分,并為每個部分分配一個虛擬內存段。在垃圾回收時,ZGC只需要掃描其中一個虛擬內存段,并將其作為當前視圖映射到實際的內存位置。同時,ZGC會將其他虛擬內存段映射到虛擬地址上,這些內存段不會被收集器掃描。

讀屏障(Load Barrier)

ZGC 通過利用讀屏障而不是寫入屏障,與HotSpot JVM中以前的GC (CMS,G1等) 算法顯著不同。讀屏障解決了并發轉移時對象指針更新問題:在轉移期間,如果移動對象而不用更新引用對象的傳入指針(移動的對象可能被堆中的任何其他對象所引用),就會產生懸空指針 (已經被釋放的內存空間或者無效的內存地址,訪問懸空指針會出現問題) 。通過讀屏障技術能夠捕獲此類懸空指針對象,并觸發代碼,更新對象的新位置,從而“修復”懸空指針。為了跟蹤對象如何移動,以便在加載時固定懸空指針,ZGC中使用轉發表 (forwarding tables ) 來將重定位前(舊)地址映射到重定位后(新)地址。無論是業務線程作為使用者訪問對象,還是GC線程遍歷堆中的所有活動對象(在標記期間)都有可能會觸發讀屏障。

ZGC讀屏障如何實現呢?舉個例子,代碼 var x = obj.field。x是一個位于堆棧上的局部變量,field是一個位于堆上的指針。業務線程在操作堆對象時觸發讀屏障。讀屏障的執行路徑有快 (fast path) 和慢 (slow path) 兩種,如果正在加載的指針有效狀態 (good color) ,則采用加載屏障的快速路徑,否則,采用慢速路徑。快速路徑實際上是空的,而慢速路徑包含計算有效狀態指針的邏輯:檢查對象是否已經(或即將)重新定位,如果是,則查找或生成新的地址。讀屏障除了能讓觸發讀屏障的線程讀取到最新地址,同時還具有自我修復指針(self-healed)的功能,這意味著讀屏障會修改指針的狀態,以便后續其他線程訪問時能執行快速路徑。無論采用哪條路徑,都會返回正確狀態的地址。下面用偽代碼表示ZGC在執行讀屏障時的大體邏輯:

/**
slot 是值線程棧中的局部變量,也就是屏障要操作的目標對象
*/
unintptr_t barrier(unintptr_t *slot,unintptr_t addr){
    //快速路徑,fast path
    if(is_good_or_null(addr))return addr;
    //慢速路徑,slow path
    good_addr = process(addr);
    //自我修復
    self_heal(slot,addr,good_addr);
    return good_addr;
}
/*
自我修復,將指針恢復到正常狀態
*/
void self_heal(unintptr_t *slot,unintptr_t old_addr,unintptr_t new_addr){
    if(new_addr == 0)return;
    while(true){
        if(CAS(slot,&old_addr,new_addr)
        return;
        if(is_good_or_null(old_addr))
        return;
    }
}

ZGC的讀屏障可能被GC線程和業務線程觸發,并且只會在訪問堆內對象時觸發,訪問的對象位于GC Roots時不會觸發,這也是掃描GC Roots時需要STW的原因。

下面是一個簡化的示例代碼,展示了讀屏障的觸發時機。

Object o = obj.FieldA   // 從堆中讀取引用,需要加入屏障
<Load barrier>
Object p = o  // 無需加入屏障,因為不是從堆中讀取引用
o.dosomething() // 無需加入屏障,因為不是從堆中讀取引用
int i =  obj.FieldB  //無需加入屏障,因為不是對象引用

五、ZGC執行周期

如下圖 所示,ZGC 周期由三個 STW 暫停和四個并發階段組成:標記/重新映射( M/R )、并發引用處理( RP )、并發轉移準備( EC ) 和并發轉移( RE )。為了讀者能快速理解,下面對ZGC執行過程進行了大量簡化。

圖6:ZGC周期表示

初始標記(STW1)

ZGC 初始標記執行包含三個主要任務。

  • 地址視圖被設置成M0 (或M1) ,M0還是M1根據前一周期交替設置的。
  • 重新分配新的頁面給業務線程創建對象,ZGC只會處理當前周期之前分配的頁面。
  • 初始標記只會存活的根對象被標記為M0 (M1) ,并被加入標記棧進行并發標記。

GC周期中地址視圖窗口

圖7:ZGC周期中狀態窗口劃分


并發標記(M/R)

并發標記的任務有2個:

第一,并發標記線程從待標記的對象列表出發,根據對象引用關系圖遍歷對象的成員變量,遞歸進行標記。

第二,計算,并更新關聯頁面的活躍度信息。活動信息是頁面上的活動字節數,用于選擇將要回收的頁面,這些對象將作為堆碎片整理的一部分進行重新定位。

下面偽代碼是并發標記的主要過程:

while(obj in mark_stack){
    //標記存活對象,當且僅當該對象未被標記并且當前線程成功標記該對象時才返回true
    success = mark_obj(obj);
    if(success){
        for(e in obj->ref_fields()){
            MarkBarrier(slot_of_e,e);
        }
    }
}
//GC線程調用
//EC是待回收頁面的集合
void MarkBarrier(uintptr_t *slot,unintptr_t addr){
    if(is_null(addr))return;
    //判斷是否在待回收集合內
    if(is_pointing_into(addr,EC)){
        //地址重映射到當前GC視圖
        good_addr = remap(addr);
    } else {
        good_addr = good_color(addr);
    }
    //訪問的對象添加到標記棧
    mark_stack->add(good_addr);
    self_heal(slot,addr,good_addr);
}


//讀屏障前面有介紹過,由業務線程調用
void LoadBarrier(uintptr_t *slot,unintptr_t addr){
    if(is_null(addr))return;
    if(is_pointing_into(addr,EC)){
        good_addr = remap(addr);
    } else {
        good_addr = good_color(addr);
    }
    mark_stack->add(good_addr);
    self_heal(slot,addr,good_addr);
    return good_addr;
}

再標記階段(STW2)

再標記階段的主要任務有3個:

  • 執行修復任務,指線程運行C2編譯的代碼,在進入再標記階段時可能發生漏標。
  • 結束標記,并發標記后業務線程本地標記棧可能存在待標記的對象,執行本步驟的目的就是對這些待標記對象進行標記。
  • 執行部分非強根并行標記。

并發轉移準備(EC)

并發轉移準備任務:

  • 篩選所有可以被回收的頁面
  • 選擇垃圾比較多的頁面作為頁面轉移集

初始轉移(STW3)

初始轉移主要以下過程:

  • 調整地址視圖:將地址視圖從M0或者M1調整為Remapped,說明進入真正的轉移,此后所有分配的對象視圖都是Remapped。
  • 重定位TLAB:因為地址視圖調整,所以要調整TLAB中地址的視圖。
  • 開始轉移:從根集合出發,遍歷根對象的直接引用的對象,對這些對象進行轉移。

初始轉移是STW的,其處理時間和GC Roots的數量成正比,一般情況耗時非常短。

并發轉移(RE)

初始轉移完成了GC Roots對象重定位,在并發轉移階段將對前面步驟確定的轉移集 (EC) ,對轉移集的每一頁執行轉移。

并發轉移的過程可以抽象成如下偽代碼過程:

//GC線程主循環遍歷EC的頁面,將個將EC集頁面中對象進行轉移
for (page in EC){
    for(obj in page){
        relocate(obj);
    }
}
//該方法GC和業務線程都有可能執行,如果是業務線程訪問對象會先進行轉移在進行操作
unintptr_t relocate(unintptr_t obj) {
    //獲取對象的地址轉發表
    ft = forwarding_tables_get(obj);
    if (ft->exist(obj)){
        return ft->get(obj);
    }
    new_obj = copy(obj);
    //CAS寫對象轉發表數據
    if(ft->insert(obj,new_obj)){
        return new_obj;
    }
    //CAS發生競爭,寫轉發表失敗,釋放分配的內存
    dealloc(new_obj)
    return ft->get(obj);
}

轉發表的作用是存儲對轉移后舊地址到新地址的映射,轉發表的數據存儲在頁面中,轉移完成的頁面即可被回收掉。

并發轉移完成之后整個ZGC周期完成。

六、ZGC算法演示

為了說明ZGC算法,下圖演示了示例中的所有階段。

圖8:ZGC算法演示

圖8(1)顯示了堆的初始狀態,應用啟動后ZGC完成了初始化。

在圖8(2)中,選擇M0作為全局標記,并且所有根指針都被標記成M0。然后,所有根都被推送到標記堆棧,該標記堆棧在并發標記 (M/R) 期間由GC線程消耗。

如圖8(3)所示,圖中用合適的顏色繪制對象本身,以表明它們已被標記,即使指針有狀態。

在圖8(4) 中,選擇存活對象最少的頁面(中間的頁面)作為轉移候選集 (EC) 。

隨后,在圖8(5)中,全局標記被設置為Remmaped,并且所有根指針都已更新Remmaped。如果根指向EC,則相應的對象將被重新定位,并且根指針更新為新地址。

在圖8(6)中,EC中的對象被轉移,并且地址記錄被逐出頁面中轉發表上,用于新舊地址轉換。當并發轉移階段結束時,當前GC周期也會結束。當前周期內整個EC都會被回收。這里可能有個疑問,對象的舊地址還沒有更新,頁面如果被回收了如何還能訪問對象呢?原因是回收的是頁面中對象存儲空間,轉發表不會被回收,如果此時業務線程訪問這些對象,會觸發讀屏障的慢路徑位,失效指針會被修復。對于沒有訪問到的失效指針,直到下一個GC并發標記 (M/R) 階段才會被修復。

在圖8(7)中,下一個GC循環開始,M1被選擇為全局狀態(M0 和 M1 之間交替使用)。

在圖8(8)中,并發標記階段 (M/R) 通過查詢轉發表失效的指標被映射到新位置。

最后,在圖8(9)中,上一周期EC頁面的轉發表被回收,為即將到來的并發轉移 (RE) 階段做準備。

七、總結

ZGC是一個十分復雜的JVM子系統,沒辦法通過一篇文章把所有的細節描述清楚。本文詳細探討了ZGC的著色指針和讀屏障關鍵技術,他們也是ZGC中創新點,最后通過一個示例對ZGC算法過程做了一個簡化版的演示。通過對ZGC這種復雜系統的學習,讓我也體會到分析復雜系統時沒必要一開始就過多的糾結實現細節,可以先從關鍵流程入手再層層深入。

ZGC的高并發設計造就了它的高性能,背后要歸功于著色指針和讀屏障運用,當然除了這2項還有其他精妙的設計比如:內存模型,并發模型,預測算法等這里不展開,讀者可以參考其他文章。了解ZGC的基本原理可以幫助優化應用程序的性能,為應用調優做些知識儲備。最后,ZGC有卓越的性能和穩定性表現,我們在選擇GC選型時可以優先考慮使用ZGC。

參考內容:

[1]彭成寒:《新一代垃圾回收器ZGC設計與實現》.機械工業出版社, 2019.

[2]https://tech.meituan.com/2020/08/06/new-zgc-practice-in-meituan.html

[3]https://www.baeldung.com/jvm-zgc-garbage-collector

[4]https://openjdk.org/projects/zgc/

[5]https://www.jfokus.se/jfokus18/preso/ZGC--Low-Latency-GC-for-OpenJDK.pdf

責任編輯:龐桂玉 來源: 得物技術
相關推薦

2018-01-03 00:38:20

大數據Hadoop分布式文件系統

2016-10-28 13:12:41

2025-02-17 09:00:00

DeepSeek人工智能AI

2015-09-11 13:54:51

大數據關鍵技術

2011-03-21 15:29:46

2021-05-17 14:57:22

NFV虛擬化數據

2022-04-15 15:03:42

云計算容器Linux

2018-07-18 14:59:43

車聯網互聯網通信

2018-07-17 05:48:34

車聯網互聯網物聯網

2009-12-22 15:22:45

IP路由器技術

2024-09-09 13:55:35

2021-04-08 10:45:37

大數據技術安全

2019-01-09 13:20:51

2018-06-14 09:38:53

Linux多核編程

2019-10-30 15:35:08

虛擬化云計算封裝

2024-04-08 11:52:08

PromQL技術監控

2017-07-12 13:49:45

微服務架構數據共享

2018-03-27 09:10:52

AI

2018-05-20 15:43:50

2023-04-04 10:33:07

自動駕駛
點贊
收藏

51CTO技術棧公眾號

美日韩免费视频| 久久成人精品一区二区三区| 99久久国产宗和精品1上映 | 日韩欧美第一区| 国产1区2区3区中文字幕| 色欲av永久无码精品无码蜜桃| 国产精品日韩久久久| 亚洲天堂影视av| 午夜精品中文字幕| 国产理论电影在线| 久久精品人人做人人爽97| 国产欧美精品日韩精品| 深夜福利影院在线观看| 青草久久视频| 欧美婷婷六月丁香综合色| 天天干天天色天天爽| 无码国产精品一区二区色情男同| 日韩和欧美一区二区| 欧美精品生活片| 天天躁日日躁aaaxxⅹ| 超碰国产精品一区二页| 精品国产91久久久久久| 最近中文字幕免费mv| 日韩欧美在线番号| 国产精品18久久久久久久久久久久| 91高清视频免费观看| 麻豆天美蜜桃91| 蜜桃一区二区三区| 精品少妇一区二区三区在线视频| 亚洲欧美另类动漫| 在线观看av免费| 日本一区二区在线不卡| 国产免费一区| 亚洲天堂中文网| 一区二区三区高清视频在线观看| 久久精品免费电影| 中文字幕免费高清| 国产精品x8x8一区二区| 777精品伊人久久久久大香线蕉| 香港三级韩国三级日本三级| 麻豆tv免费在线观看| 国产欧美精品一区二区色综合| 亚洲最大成人免费视频| 日本视频www色| 国产日韩欧美一区二区三区在线观看 | 在线视频综合导航| www.射射射| 最新av在线播放| 中文字幕在线不卡一区二区三区| 乱一区二区三区在线播放| 亚洲免费成人在线| 国产精品99久久久久久久女警| 国产精品人成电影在线观看| 亚洲天堂男人av| 亚洲主播在线| 7777kkkk成人观看| 五月婷婷亚洲综合| 国产欧美短视频| 国内外成人免费激情在线视频网站 | 欧美深深色噜噜狠狠yyy| 色一情一乱一乱一区91av| 国产69精品一区二区亚洲孕妇 | 日本精品一区二区三区在线观看视频| 欧洲一区二区av| 国产黄色特级片| 欧美gay视频| 一本到三区不卡视频| 欧美日韩激情视频在线观看| 成av人片在线观看www| 亚洲成人福利片| 妞干网在线观看视频| 99re6在线精品视频免费播放| 亚洲一区二区三区在线看| 草草草视频在线观看| 福利写真视频网站在线| 午夜精品久久久久久久久久久| 日韩国产成人无码av毛片| 手机在线免费av| 亚洲一区二区三区中文字幕在线| 精品无码国模私拍视频| 深夜福利视频一区二区| 一本到不卡免费一区二区| 国产又黄又猛又粗又爽的视频| 国产精品.xx视频.xxtv| 69堂精品视频| 白丝校花扒腿让我c| 国产欧美啪啪| 亚洲欧洲日韩国产| 免费黄色激情视频| 欧美日韩亚洲一区二区三区在线| 欧美精品成人在线| youjizz在线视频| 久久最新视频| 成人欧美一区二区三区在线 | 中文字幕欧美激情极品| 欧美成人激情| 欧美国产高跟鞋裸体秀xxxhd| 亚洲一区二区91| 久久久久久婷| 日本韩国欧美国产| 一道本视频在线观看| 欧美电影院免费观看| 亚洲国产精品免费| 午夜影院黄色片| 欧美暴力喷水在线| 欧美专区中文字幕| www青青草原| 亚洲精品社区| 国产精品无av码在线观看| 国产黄色av网站| 久久夜色精品国产欧美乱极品| 手机成人在线| 国产精品电影| 欧美精品v国产精品v日韩精品| 亚洲午夜久久久久久久久| 久操成人av| 美女福利精品视频| 亚洲欧美综合自拍| 国产精品一二一区| 视频一区视频二区视频| 2020国产在线| 欧美精品三级日韩久久| 自拍视频一区二区| 999在线精品| 亚洲天堂色网站| 九九热视频精品| 青草国产精品久久久久久| 国产女主播一区二区| 欧美边添边摸边做边爱免费| 黑人巨大精品欧美一区二区一视频 | 九色在线免费| 亚洲成人免费电影| 久久黄色一级视频| 日韩在线二区| 日本一区二区在线播放| 日本久久一级片| 伊人一区二区三区| 国产永久免费网站| 欧美裸体在线版观看完整版| 午夜精品久久久久久久99热| 国产手机精品视频| 国产精品久久国产精麻豆99网站| 国产在线青青草| 91精品日本| 欧美老妇交乱视频| 国产视频在线观看免费| 亚洲色图在线视频| 羞羞的视频在线| 欧美偷拍自拍| 国产精品99久久久久久久久久久久| 日本精品久久久久| 亚洲午夜激情网页| 亚洲AV成人精品| 欧美99在线视频观看| 成人亚洲综合色就1024| 淫片在线观看| 欧美日韩国产精选| 中文字幕91视频| 麻豆精品在线播放| 一区二区高清视频| 在线不卡一区| 久久久精品视频在线观看| 国产又粗又猛又爽又黄的视频一| 中文在线一区二区| 999在线观看| 婷婷综合网站| 亚洲va欧美va国产综合久久| 成人在线网址| 欧美tickling网站挠脚心| 国产无套内射又大又猛又粗又爽| 成人av在线一区二区三区| 国产二级片在线观看| 羞羞答答一区二区| 国产精品久久久久久av福利软件| 国模吧精品人体gogo| 欧美性大战久久久久久久蜜臀| 日本美女bbw| 久久成人免费网站| 久久久久久久香蕉| 日韩精品免费一区二区三区竹菊| 欧美亚洲午夜视频在线观看| 天天射,天天干| 日韩欧美精品在线观看| 黄色免费一级视频| 国产伦精品一区二区三区免费迷| 精品无码一区二区三区爱欲| 香蕉久久精品| 91亚洲va在线va天堂va国| 欧美一区二区三区成人片在线| 亚洲成人资源在线| 最近中文字幕在线mv视频在线| 美女在线观看视频一区二区| 麻豆映画在线观看| 欧美成人专区| 国产精品中文久久久久久久| 欧美xxxx视频| 亚洲天堂久久av| 国产丰满美女做爰| 欧美性色19p| 亚洲综合视频网站| 99精品国产视频| 亚洲国产高清av| 亚洲一级影院| 亚洲精品成人自拍| 五月天国产在线| 亚洲天堂网站在线观看视频| 国产黄a三级三级看三级| 色婷婷综合久久久中文一区二区| 精品一区二区在线观看视频| 国产成人亚洲综合a∨猫咪| 日韩 欧美 高清| 欧美精品日韩| 视频一区视频二区视频三区高| 国产精品tv| 91精品国产自产在线老师啪| 欧美freesex黑人又粗又大| 日韩中文在线视频| 艳母动漫在线看| 欧美一区二区三区在线观看| 色屁屁影院www国产高清麻豆| 亚洲女同女同女同女同女同69| 9.1成人看片免费版| 国产成人精品www牛牛影视| 我要看一级黄色大片| 一本色道久久综合| 日韩精品免费一区| 国产精品88久久久久久| 日韩免费中文专区| 免费日韩一区二区三区| 99re在线观看| 国产精品久久久久久吹潮| 欧美制服第一页| a√中文在线观看| 久热在线中文字幕色999舞| 国产爆初菊在线观看免费视频网站| 精品国产乱码久久久久久浪潮 | 成人欧美一区二区三区在线| 天堂久久午夜av| 国产91成人在在线播放| segui88久久综合| 精品自在线视频| 国产精品剧情一区二区在线观看| 中文字幕精品av| 黄色在线免费观看大全| 精品丝袜一区二区三区| 图片区 小说区 区 亚洲五月| 精品日韩一区二区| www.国产欧美| 日韩一区二区三区观看| 国产片在线播放| 91精品国产色综合久久不卡电影 | 内射无码专区久久亚洲| 日韩免费看网站| 国产成人精品无码高潮| 日韩欧美综合一区| 亚洲成人精品女人久久久| 欧美一级在线视频| www.av在线.com| 日韩女优制服丝袜电影| 精品人妻一区二区三区浪潮在线| 日韩免费观看高清完整版 | 五月天色婷婷丁香| 亚洲三级电影全部在线观看高清| 国产激情无码一区二区三区| 亚洲丝袜制服诱惑| 欧美日韩一级大片| 亚洲国产日韩一级| av大片免费在线观看| 欧美日韩在线观看视频| 无码人妻精品一区二区三区蜜桃91| 在线视频综合导航| 亚洲专区在线播放| 日韩午夜在线观看视频| 少妇人妻一区二区| 亚洲精品影视在线观看| 91涩漫在线观看| 久热在线中文字幕色999舞| 黑人精品视频| 欧美一级大片视频| 久久99国产精品二区高清软件| 91久久久久久久久久| 成人福利一区| 欧美日韩在线不卡一区| 日韩在线二区| 日本五级黄色片| 久久天堂成人| 欧美又黄又嫩大片a级| 成人免费视频免费观看| 国产精品扒开腿做爽爽| 18欧美乱大交hd1984| 国产无码精品视频| 欧美日韩一区二区三区在线看| 国产肥老妇视频| 日韩精品在线免费观看视频| 在线观看的av| 欧美精品videos| 国产在视频一区二区三区吞精| 91传媒视频免费| 国产最新精品| 99三级在线| 蜜桃一区二区三区| wwwwww欧美| 日日噜噜夜夜狠狠视频欧美人 | 欧美极品一区二区| 色综合狠狠操| bt天堂新版中文在线地址| 日韩成人精品在线| 成人啪啪18免费游戏链接| 日本一区二区三区dvd视频在线| 久久中文免费视频| 色婷婷亚洲综合| www.av日韩| 中文字幕日韩视频| 三级在线观看视频| 91久热免费在线视频| 免费成人av| 国产aaa免费视频| 精品一区二区三区免费播放 | 久久精品五月天| 精品少妇一区二区三区免费观看| 福利视频在线导航| 国内精品视频在线| 国产午夜久久av| 天堂va久久久噜噜噜久久va| 夜夜嗨av一区二区三区网站四季av| 成人日韩在线视频| 国产午夜精品美女毛片视频| 日韩字幕在线观看| 精品日韩欧美在线| 黄网站视频在线观看| 国产精品狠色婷| 尤物tv在线精品| heyzo亚洲| 粉嫩嫩av羞羞动漫久久久| 男人在线观看视频| 欧美影片第一页| 免费在线黄色电影| 2019av中文字幕| 欧美巨大xxxx| 欧美久久在线观看| 国产成人在线免费| 精品一区在线观看视频| 欧美福利视频导航| 午夜视频在线观看免费视频| 日本高清不卡在线| 亚洲色图丝袜| 99色精品视频| 久久综合色综合88| 日韩中文字幕在线观看视频| 亚洲第一区第一页| 98色花堂精品视频在线观看 | 欧美男同视频网| 精品一区二区中文字幕| 99精品视频在线免费观看| 偷偷操不一样的久久| 国产婷婷97碰碰久久人人蜜臀| 漫画在线观看av| 久久伦理网站| 日一区二区三区| 国产午夜精品久久久久久久久| 欧美专区亚洲专区| 91caoporm在线视频| 国产在线观看不卡| 一区二区三区毛片免费| 一级黄色免费毛片| 亚洲一区二区三区四区在线观看 | 精品无人区一区二区三区竹菊| 99精品99| 久久久久久亚洲中文字幕无码| 91福利国产成人精品照片| 在线国产情侣| 97超级在线观看免费高清完整版电视剧| 欧美在线网站| 中文字幕乱码一区| 欧美性猛交xxxx免费看漫画 | 国精品产品一区| 特色特色大片在线| 99久久免费国产| 久久久久精彩视频| 久久影视电视剧免费网站| 97青娱国产盛宴精品视频| 91猫先生在线| 亚洲国产成人私人影院tom| 国产剧情精品在线| 性欧美亚洲xxxx乳在线观看| 欧美禁忌电影| 手机免费看av网站| 天天色天天爱天天射综合| аⅴ资源新版在线天堂| 51精品国产人成在线观看| 国产精品夜夜夜| 永久免费看片视频教学| 亚洲成人性视频| 美女色狠狠久久| 91免费国产精品| 欧美国产精品久久| 深爱激情五月婷婷| 91日本在线视频| 久久久久欧美精品| 欧美人妻精品一区二区免费看|