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

支撐百萬級并發(fā),Netty如何實現(xiàn)高性能內(nèi)存管理

存儲 存儲軟件
通過學(xué)習其中的實現(xiàn)原理、算法、并發(fā)設(shè)計,有利于我們寫出更優(yōu)雅、更高性能的代碼;當使用Netty時碰到內(nèi)存方面的問題時,也可以更高效定位排查出來。

 Netty作為一款高性能網(wǎng)絡(luò)應(yīng)用程序框架,實現(xiàn)了一套高性能內(nèi)存管理機制。

通過學(xué)習其中的實現(xiàn)原理、算法、并發(fā)設(shè)計,有利于我們寫出更優(yōu)雅、更高性能的代碼;當使用Netty時碰到內(nèi)存方面的問題時,也可以更高效定位排查出來。

[[287314]]

本文基于Netty4.1.43.Final介紹其中的內(nèi)存管理機制

ByteBuf分類

Netty使用ByteBuf對象作為數(shù)據(jù)容器,進行I/O讀寫操作,Netty的內(nèi)存管理也是圍繞著ByteBuf對象高效地分配和釋放

當討論ByteBuf對象管理,主要從以下方面進行分類:

  • Pooled 和 Unpooled

Unpooled,非池化內(nèi)存每次分配時直接調(diào)用系統(tǒng) API 向操作系統(tǒng)申請ByteBuf需要的同樣大小內(nèi)存,用完后通過系統(tǒng)調(diào)用進行釋放Pooled,池化內(nèi)存分配時基于預(yù)分配的一整塊大內(nèi)存,取其中的部分封裝成ByteBuf提供使用,用完后回收到內(nèi)存池中。

tips: Netty4默認使用Pooled的方式,可通過參數(shù)-Dio.netty.allocator.type=unpooled或pooled進行設(shè)置

  • Heap 和 Direct

Heap,指ByteBuf關(guān)聯(lián)的內(nèi)存JVM堆內(nèi)分配,分配的內(nèi)存受GC 管理

Direct,指ByteBuf關(guān)聯(lián)的內(nèi)存在JVM堆外分配,分配的內(nèi)存不受GC管理,需要通過系統(tǒng)調(diào)用實現(xiàn)申請和釋放,底層基于Java NIO的DirectByteBuffer對象

note: 使用堆外內(nèi)存的優(yōu)勢在于,Java進行I/O操作時,需要傳入數(shù)據(jù)所在緩沖區(qū)起始地址和長度,由于GC的存在,對象在堆中的位置往往會發(fā)生移動,導(dǎo)致對象地址變化,系統(tǒng)調(diào)用出錯。為避免這種情況,當基于堆內(nèi)存進行I/O系統(tǒng)調(diào)用時,需要將內(nèi)存拷貝到堆外,而直接基于堆外內(nèi)存進行I/O操作的話,可以節(jié)省該拷貝成本

池化(Pooled)對象管理

非池化對象(Unpooled),使用和釋放對象僅需要調(diào)用底層接口實現(xiàn),池化對象實現(xiàn)則復(fù)雜得多,可以帶著以下問題進行研究:

  • 內(nèi)存池管理算法是如何實現(xiàn)高效內(nèi)存分配釋放,減少內(nèi)存碎片
  • 高負載下內(nèi)存池不斷申請/釋放,如何實現(xiàn)彈性伸縮
  • 內(nèi)存池作為全局數(shù)據(jù),在多線程環(huán)境下如何減少鎖競爭

1 算法設(shè)計

1.1 整體原理

Netty先向系統(tǒng)申請一整塊連續(xù)內(nèi)存,稱為chunk,默認大小chunkSize = 16Mb,通過PoolChunk對象包裝。為了更細粒度的管理,Netty將chunk進一步拆分為page,默認每個chunk包含2048個page(pageSize = 8Kb)

不同大小池化內(nèi)存對象的分配策略不同,下面首先介紹申請內(nèi)存大小在(pageSize/2, chunkSize]區(qū)間范圍內(nèi)的池化對象的分配原理,其他大對象和小對象的分配原理后面再介紹。在同一個chunk中,Netty將page按照不同粒度進行多層分組管理:

  • 第1層,分組大小size = 1*pageSize,一共有2048個組
  • 第2層,分組大小size = 2*pageSize,一共有1024個組
  • 第3層,分組大小size = 4*pageSize,一共有512個組

...

當請求分配內(nèi)存時,將請求分配的內(nèi)存數(shù)向上取值到最接近的分組大小,在該分組大小的相應(yīng)層級中從左至右尋找空閑分組例如請求分配內(nèi)存對象為1.5 pageSize,向上取值到分組大小2 pageSize,在該層分組中找到完全空閑的一組內(nèi)存進行分配,如下圖:

當分組大小2 pageSize的內(nèi)存分配出去后,為了方便下次內(nèi)存分配,分組被標記為全部已使用(圖中紅色標記),向上更粗粒度的內(nèi)存分組被標記為部分已使用*(圖中黃色標記)

1.2 算法結(jié)構(gòu)

Netty基于平衡樹實現(xiàn)上面提到的不同粒度的多層分組管理。

當需要創(chuàng)建一個給定大小的ByteBuf,算法需要在PoolChunk中大小為chunkSize的內(nèi)存中,找到第一個能夠容納申請分配內(nèi)存的位置。

為了方便快速查找chunk中能容納請求內(nèi)存的位置,算法構(gòu)建一個基于byte數(shù)組(memoryMap)存儲的完全平衡樹,該平衡樹的多個層級深度,就是前面介紹的按照不同粒度對chunk進行多層分組:

樹的深度depth從0開始計算,各層節(jié)點數(shù),每個節(jié)點對應(yīng)的內(nèi)存大小如下:

  1. depth = 0, 1 node,nodeSize = chunkSizedepth = 1, 2 nodes,nodeSize = chunkSize/2...depth = d, 2^d nodes, nodeSize = chunkSize/(2^d)...depth = maxOrder, 2^maxOrder nodes, nodeSize = chunkSize/2^{maxOrder} = pageSize 

樹的最大深度為maxOrder(最大階,默認值11),通過這棵樹,算法在chunk中的查找就可以轉(zhuǎn)換為:

當申請分配大小為chunkSize/2^k的內(nèi)存,在平衡樹高度為k的層級中,從左到右搜索第一個空閑節(jié)點

數(shù)組的使用域從index = 1開始,將平衡樹按照層次順序依次存儲在數(shù)組中,depth = n的第1個節(jié)點保存在memoryMap[2^n] 中,第2個節(jié)點保存在memoryMap[2^n+1]中,以此類推。

可以根據(jù)memoryMap[id]的值得出節(jié)點的使用情況,memoryMap[id]值越大,剩余的可用內(nèi)存越少

  • memoryMap[id] = depth_of_id:**id節(jié)點空閑**, 初始狀態(tài),depth_of_id的值代表id節(jié)點在樹中的深度
  • memoryMap[id] = maxOrder + 1:**id節(jié)點全部已使用**,節(jié)點內(nèi)存已完全分配,沒有一個子節(jié)點空閑
  • depthofid < memoryMap[id] < maxOrder + 1:**id節(jié)點部分已使用**,memoryMap[id] 的值 x,代表**id的子節(jié)點中,第一個空閑節(jié)點位于深度x,在深度[depth_of_id, x)的范圍內(nèi)沒有任何空閑節(jié)點**

1.3 申請/釋放內(nèi)存

當申請分配內(nèi)存,會首先將請求分配的內(nèi)存大小歸一化(向上取值),通過PoolArena#normalizeCapacity()方法,取最近的2的冪的值​,例如8000byte歸一化為8192byte( chunkSize/2^11 ),8193byte歸一化為16384byte(chunkSize/2^10)

處理內(nèi)存申請的算法在PoolChunk#allocateRun方法中,當分配已歸一化處理后大小為chunkSize/2^d的內(nèi)存,即需要在depth = d的層級中找到第一塊空閑內(nèi)存,算法從根節(jié)點開始遍歷 (根節(jié)點depth = 0, id = 1),具體步驟如下:

  • 步驟1 判斷是否當前節(jié)點值memoryMap[id] > d

如果是,則無法從該chunk分配內(nèi)存,查找結(jié)束

  • 步驟2 判斷是否節(jié)點值memoryMap[id] == d,且depth_of_id == h

如果是,當前節(jié)點是depth = d的空閑內(nèi)存,查找結(jié)束,更新當前節(jié)點值為memoryMap[id] = max_order + 1,代表節(jié)點已使用,并遍歷當前節(jié)點的所有祖先節(jié)點,更新節(jié)點值為各自的左右子節(jié)點值的最小值;如果否,執(zhí)行步驟3

  • 步驟3 判斷是否當前節(jié)點值memoryMap[id] <= d,且depth_of_id < h

如果是,則空閑節(jié)點在當前節(jié)點的子節(jié)點中,則先判斷左子節(jié)點memoryMap[2 * id] <=d(判斷左子節(jié)點是否可分配),如果成立,則當前節(jié)點更新為左子節(jié)點,否則更新為右子節(jié)點,然后重復(fù)步驟2

參考示例如下圖,申請分配了chunkSize/2的內(nèi)存

 note:圖中雖然index = 2的子節(jié)點memoryMap[id] = depth_of_id,但實際上節(jié)點內(nèi)存已分配,因為算法是從上往下開始遍歷,所以在實際處理中,節(jié)點分配內(nèi)存后僅更新祖先節(jié)點的值,并沒有更新子節(jié)點的值。

釋放內(nèi)存時,根據(jù)申請內(nèi)存返回的id,將 memoryMap[id]更新為depth_of_id,同時設(shè)置id節(jié)點的祖先節(jié)點值為各自左右節(jié)點的最小值

1.4 巨型對象內(nèi)存管理

對于申請分配大小超過chunkSize的巨型對象(huge),Netty采用的是非池化管理策略,在每次請求分配內(nèi)存時單獨創(chuàng)建特殊的非池化PoolChunk對象進行管理,內(nèi)部memoryMap為null,當對象內(nèi)存釋放時整個Chunk內(nèi)存釋放,相應(yīng)內(nèi)存申請邏輯在PoolArena#allocateHuge()方法中,釋放邏輯在PoolArena#destroyChunk()方法中。

1.5 小對象內(nèi)存管理

當請求對象的大小reqCapacity <= 496,歸一化計算后方式是向上取最近的16的倍數(shù),例如15規(guī)整為15、40規(guī)整為48、490規(guī)整為496,規(guī)整后的大小(normalizedCapacity)小于pageSize的小對象可分為2類:微型對象(tiny):規(guī)整后為16的整倍數(shù),如16、32、48、...、496,一共31種規(guī)格小型對象(small):規(guī)整后為2的冪的,有512、1024、2048、4096,一共4種規(guī)格。

這些小對象直接分配一個page會造成浪費,在page中進行平衡樹的標記又額外消耗更多空間,因此Netty的實現(xiàn)是:先PoolChunk中申請空閑page,同一個page分為相同大小規(guī)格的小內(nèi)存進行存儲。

這些page用PoolSubpage對象進行封裝,PoolSubpage內(nèi)部有記錄內(nèi)存規(guī)格大小(elemSize)、可用內(nèi)存數(shù)量(numAvail)和各個小內(nèi)存的使用情況,通過long[]類型的bitmap相應(yīng)bit值0或1,來記錄內(nèi)存是否已使用。

note:應(yīng)該有讀者注意到,Netty申請池化內(nèi)存進行歸一化處理后的值更大了,例如1025byte會歸一化為2048byte,8193byte歸一化為16384byte,這樣是不是造成了一些浪費?可以理解為是一種取舍,通過歸一化處理,使池化內(nèi)存分配大小規(guī)格化,大大方便內(nèi)存申請和內(nèi)存、內(nèi)存復(fù)用,提高效率。

2 彈性伸縮

前面的算法原理部分介紹了Netty如何實現(xiàn)內(nèi)存塊的申請和釋放,單個chunk比較容量有限,如何管理多個chunk,構(gòu)建成能夠彈性伸縮內(nèi)存池?

2.1 PoolChunk管理

為了解決單個PoolChunk容量有限的問題,Netty將多個PoolChunk組成鏈表一起管理,然后用PoolChunkList對象持有鏈表的head

將所有PoolChunk組成一個鏈表的話,進行遍歷查找管理效率較低,因此Netty設(shè)計了PoolArena對象(arena中文是舞臺、場所),實現(xiàn)對多個PoolChunkList、PoolSubpage的管理,線程安全控制、對外提供內(nèi)存分配、釋放的服務(wù)。

PoolArena內(nèi)部持有6個PoolChunkList,各個PoolChunkList持有的PoolChunk的使用率區(qū)間不同:

  1. // 容納使用率 (0,25%) 的PoolChunkprivate final PoolChunkList<T> qInit;// [1%,50%) private final PoolChunkList<T> q000;// [25%, 75%) private final PoolChunkList<T> q025;// [50%, 100%) private final PoolChunkList<T> q050;// [75%, 100%) private final PoolChunkList<T> q075;// 100% private final PoolChunkList<T> q100; 

 6個PoolChunkList對象組成雙向鏈表,當PoolChunk內(nèi)存分配、釋放,導(dǎo)致使用率變化,需要判斷PoolChunk是否超過所在PoolChunkList的限定使用率范圍,如果超出了,需要沿著6個PoolChunkList的雙向鏈表找到新的合適PoolChunkList,成為新的head;同樣的,當新建PoolChunk并分配完內(nèi)存,該PoolChunk也需要按照上面邏輯放入合適的PoolChunkList中。

分配歸一化內(nèi)存normCapacity(大小范圍在[pageSize, chunkSize]) 具體處理如下:

  • 按順序依次訪問q050、q025、q000、qInit、q075,遍歷PoolChunkList內(nèi)PoolChunk鏈表判斷是否有PoolChunk能分配內(nèi)存
  • 如果上面5個PoolChunkList有任意一個PoolChunk內(nèi)存分配成功,PoolChunk使用率發(fā)生變更,重新檢查并放入合適的PoolChunkList中,結(jié)束
  • 否則新建一個PoolChunk,分配內(nèi)存,放入合適的PoolChunkList中(PoolChunkList擴容)

note:可以看到分配內(nèi)存依次優(yōu)先在q050 -> q025 -> q000 -> qInit -> q075的PoolChunkList的內(nèi)分配,這樣做的好處是,使分配后各個區(qū)間內(nèi)存使用率更多處于[75,100)的區(qū)間范圍內(nèi),提高PoolChunk內(nèi)存使用率的同時也兼顧效率,減少在PoolChunkList中PoolChunk的遍歷。

當PoolChunk內(nèi)存釋放,同樣PoolChunk使用率發(fā)生變更,重新檢查并放入合適的PoolChunkList中,如果釋放后PoolChunk內(nèi)存使用率為0,則從PoolChunkList中移除,釋放掉這部分空間,避免在高峰的時候申請過內(nèi)存一直緩存在池中(PoolChunkList縮容)。

 PoolChunkList的額定使用率區(qū)間存在交叉,這樣設(shè)計是因為如果基于一個臨界值的話,當PoolChunk內(nèi)存申請釋放后的內(nèi)存使用率在臨界值上下徘徊的話,會導(dǎo)致在PoolChunkList鏈表前后來回移動

2.2 PoolSubpage管理

PoolArena內(nèi)部持有2個PoolSubpage數(shù)組,分別存儲tiny和small規(guī)格類型的PoolSubpage:

  1. // 數(shù)組長度32,實際使用域從index = 1開始,對應(yīng)31種tiny規(guī)格PoolSubpageprivate final PoolSubpage<T>[] tinySubpagePools;// 數(shù)組長度4,對應(yīng)4種small規(guī)格PoolSubpageprivate final PoolSubpage<T>[] smallSubpagePools; 

相同規(guī)格大小(elemSize)的PoolSubpage組成鏈表,不同規(guī)格的PoolSubpage鏈表的head則分別保存在tinySubpagePools 或者 smallSubpagePools數(shù)組中,如下圖:

 當需要分配小內(nèi)存對象到PoolSubpage中時,根據(jù)歸一化后的大小,計算出需要訪問的PoolSubpage鏈表在tinySubpagePools和smallSubpagePools數(shù)組的下標,訪問鏈表中的PoolSubpage的申請內(nèi)存分配,如果訪問到的PoolSubpage鏈表節(jié)點數(shù)為0,則創(chuàng)建新的PoolSubpage分配內(nèi)存然后加入鏈表。

PoolSubpage鏈表存儲的PoolSubpage都是已分配部分內(nèi)存,當內(nèi)存全部分配完或者內(nèi)存全部釋放完的PoolSubpage會移出鏈表,減少不必要的鏈表節(jié)點;當PoolSubpage內(nèi)存全部分配完后再釋放部分內(nèi)存,會重新將加入鏈表。

PoolArean內(nèi)存池彈性伸縮可用下圖總結(jié):

 3 并發(fā)設(shè)計

內(nèi)存分配釋放不可避免地會遇到多線程并發(fā)場景,無論是PoolChunk的平衡樹標記或者PoolSubpage的bitmap標記都是多線程不安全,如何在線程安全的前提下盡量提升并發(fā)性能?

首先,為了減少線程間的競爭,Netty會提前創(chuàng)建多個PoolArena(默認生成數(shù)量 = 2 * CPU核心數(shù)),當線程首次請求池化內(nèi)存分配,會找被最少線程持有的PoolArena,并保存線程局部變量PoolThreadCache中,實現(xiàn)線程與PoolArena的關(guān)聯(lián)綁定(PoolThreadLocalCache#initialValue()方法)。

note:Java自帶的ThreadLocal實現(xiàn)線程局部變量的原理是:基于Thread的ThreadLocalMap類型成員變量,該變量中map的key為ThreadLocal,value-為需要自定義的線程局部變量值。調(diào)用ThreadLocal#get()方法時,會通過Thread.currentThread()獲取當前線程訪問Thread的ThreadLocalMap中的值。

Netty設(shè)計了ThreadLocal的更高性能替代類:FastThreadLocal,需要配套繼承Thread的類FastThreadLocalThread一起使用,基本原理是將原來Thead的基于ThreadLocalMap存儲局部變量,擴展為能更快速訪問的數(shù)組進行存儲(Object[] indexedVariables),每個FastThreadLocal內(nèi)部維護了一個全局原子自增的int類型的數(shù)組index。

此外,Netty還設(shè)計了緩存機制提升并發(fā)性能:當請求對象內(nèi)存釋放,PoolArena并沒有馬上釋放,而是先嘗試將該內(nèi)存關(guān)聯(lián)的PoolChunk和chunk中的偏移位置(handler變量)等信息存入PoolThreadLocalCache中的固定大小緩存隊列中(如果緩存隊列滿了則馬上釋放內(nèi)存);當請求內(nèi)存分配,PoolArena會優(yōu)先訪問PoolThreadLocalCache的緩存隊列中是否有緩存內(nèi)存可用,如果有,則直接分配,提高分配效率。

總結(jié)

Netty池化內(nèi)存管理的設(shè)計借鑒了Facebook的jemalloc,同時也與Linux內(nèi)存分配算法Buddy算法和Slab算法也有相似之處,很多分布式系統(tǒng)、框架的設(shè)計都可以在操作系統(tǒng)的設(shè)計中找到原型,學(xué)習底層原理是很有價值的。

參考

《scalable memory allocation using jemalloc —— Facebook》https://engineering.fb.com/core-data/scalable-memory-allocation-using-jemalloc/

《Netty入門與實戰(zhàn):仿寫微信 IM 即時通訊系統(tǒng)》https://juejin.im/book/5b4bc28bf265da0f60130116?referrer=598ff735f265da3e1c0f9643

 

責任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2024-12-26 09:15:28

2022-09-09 08:41:43

Netty服務(wù)端驅(qū)動

2021-05-24 10:55:05

Netty單機并發(fā)

2024-12-04 13:52:30

2011-08-23 17:12:22

MySQL支撐百萬級流

2025-11-14 00:25:00

微服務(wù)架構(gòu)并發(fā)

2025-05-26 02:11:00

2019-02-27 09:46:05

數(shù)據(jù)庫架構(gòu)并發(fā)

2025-02-10 08:20:09

2025-08-05 09:20:20

2025-10-27 05:11:00

2011-04-07 09:25:25

內(nèi)存Java

2011-04-25 14:06:23

java

2017-01-09 16:06:19

2020-11-10 07:46:09

服務(wù)器高并發(fā)高性能

2023-02-20 15:27:30

開發(fā)JavaScript內(nèi)存管理

2025-05-12 00:00:00

2021-07-27 16:01:29

高并發(fā)定時器高性能

2025-09-30 02:11:00

2019-09-23 08:46:04

零拷貝 CPU內(nèi)存
點贊
收藏

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

杨幂一区欧美专区| 欧美在线视频一区二区| 老女人性生活视频| 欧美a级在线观看| 国产精品伦一区二区三级视频| 国产在线观看一区二区三区| 久久精品视频国产| jizzjizz欧美69巨大| 欧美久久久久久蜜桃| 国产精品69久久久| av资源在线观看免费高清| 国产精品系列在线播放| 国产91亚洲精品| 久久黄色免费视频| 青草国产精品| 精品国产乱码久久久久久浪潮| 人人爽人人av| 91九色在线看| 综合av第一页| 秋霞久久久久久一区二区| 国产麻豆一精品一男同| 丝袜亚洲精品中文字幕一区| 色综合久久精品亚洲国产| 日本精品在线观看视频| 久久香蕉网站| 日韩一级完整毛片| 污版视频在线观看| 国产免费不卡| 午夜精品免费在线| 欧美少妇一区二区三区| www日韩tube| 91亚洲大成网污www| 91在线在线观看| 91精东传媒理伦片在线观看| 久久性天堂网| 91av视频在线观看| 亚洲精品在线观看av| 久久精品影视| 精品国偷自产在线视频99| 91网站免费视频| 西野翔中文久久精品国产| 五月综合久久| 国产精品欧美经典| 蜜桃视频在线观看成人| 少妇高潮久久久| 国产精品一二三区在线| 91免费视频网站| 最近中文字幕在线观看视频| 久久一二三四| 国产精品国产三级国产专播精品人| 国内免费精品视频| 亚洲精选91| 91国产一区在线| 日产亚洲一区二区三区| 亚洲国产影院| 91chinesevideo永久地址| 亚洲欧美在线观看视频| 亚洲激情不卡| 欧美亚洲日本网站| 在线永久看片免费的视频| 久久aⅴ乱码一区二区三区| 日本一区二区不卡| 69xxxx国产| 美国欧美日韩国产在线播放| 国产精品一区二区女厕厕| 在线观看黄色网| 久久er精品视频| 97人人干人人| 无码精品在线观看| 久久久国产精品麻豆| 日韩高清三级| 黄色小网站在线观看| 亚洲女人小视频在线观看| 人妻无码一区二区三区四区| 国产嫩草在线视频| 日韩欧美在线观看| 男女视频在线看| 九九99久久精品在免费线bt| 亚洲爱爱爱爱爱| 久久丫精品忘忧草西安产品| 欧美一区电影| 欧美疯狂做受xxxx高潮| 国产视频91在线| 日本欧美一区二区| 亚洲综合中文字幕在线观看| 天堂中文网在线| 国产人伦精品一区二区| 欧美一级免费在线观看| 欧美xxxx性xxxxx高清| 欧美视频在线观看免费| 成 人 黄 色 小说网站 s色| 777久久精品| 国产亚洲欧美aaaa| 老女人性淫交视频| 免费视频一区二区三区在线观看| 国产欧美韩国高清| 成人免费视频国产| 欧美激情综合五月色丁香| 国产高清不卡无码视频| 色黄视频在线观看| 日韩一区二区精品在线观看| 欧美熟妇一区二区| 午夜亚洲福利| 国产成人精品免高潮在线观看| 99产精品成人啪免费网站| 26uuu精品一区二区在线观看| 中日韩在线视频| 亚洲欧洲高清| 日韩欧美精品三级| 欧美福利第一页| 99亚洲一区二区| 91在线视频精品| 国产高清视频免费最新在线| 亚洲成人一区二区在线观看| 日韩爱爱小视频| 精品中文一区| 97视频免费观看| 99国产精品久久久久99打野战| 国产喂奶挤奶一区二区三区 | 美女毛片一区二区三区四区最新中文字幕亚洲| 亚洲欧洲在线视频| 99视频在线看| 高清不卡在线观看av| 一个色的综合| 欧美精品高清| 日韩精品视频在线播放| a级片在线观看免费| 六月丁香综合在线视频| 日韩电影在线播放| 亚洲高清黄色| 国产视频久久久久久久| 日韩激情在线播放| 国产成人自拍在线| 三年中文高清在线观看第6集| 肉色欧美久久久久久久免费看| 亚洲第一页自拍| 在线免费观看毛片| 国产99久久久精品| 喜爱夜蒲2在线| 欧美1区2区3| 久久国产精品99国产精| 国产精品国产精品国产专区| 国产精品欧美久久久久一区二区 | 国产精品第二十页| 丁香天五香天堂综合| 久久久久久久久久伊人| 欧美一级大片在线视频| 久久网福利资源网站| 国产免费黄色网址| 亚洲视频 欧洲视频| 亚洲精品在线视频播放| 午夜欧美视频| 国产精品高清一区二区三区| 暖暖在线中文免费日本| 亚洲精品电影网| 日产精品久久久| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 性做久久久久久久| 亚洲一区二区四区蜜桃| 性色av蜜臀av浪潮av老女人| 在线亚洲欧美| 欧洲精品码一区二区三区免费看| 亚洲mmav| 久久中文精品视频| 亚洲精品国产suv一区| 精品国产老师黑色丝袜高跟鞋| 日韩人妻一区二区三区| 日本少妇一区二区| 国产一级黄色录像片| 国产一区二区三区亚洲| 国产91色在线| 国产在线观看av| 亚洲精品一区二区三区蜜桃下载 | 午夜亚洲精品| 婷婷久久青草热一区二区| 北岛玲精品视频在线观看| 欧美激情久久久久久| 欧美一区二区少妇| 欧美日本一区二区在线观看| 亚洲色婷婷一区二区三区| www.性欧美| 成人黄色一区二区| 女同性一区二区三区人了人一 | 精品国产美女| 91精品久久久久久久久久久久久| 日本小视频在线免费观看| 日韩精品在线播放| 国产女人18毛片18精品| 午夜精品一区二区三区电影天堂 | 久久久久久久穴| 玖玖玖国产精品| 亚洲色图都市激情| 亚洲人成网77777色在线播放| 成人在线国产精品| 国模私拍一区二区国模曼安| 色狠狠久久aa北条麻妃| 人妻与黑人一区二区三区| 欧美三级视频在线观看| 国产无遮挡免费视频| 国产精品入口麻豆九色| 欧美在线一级片| 国精品**一区二区三区在线蜜桃| 亚洲熟妇国产熟妇肥婆| 亚洲成人精选| 日本亚洲欧洲精品| 国产精品网在线观看| 91精品免费看| 精品网站在线| 午夜精品久久久久久久99热| 国产美女福利在线| 亚洲欧美日本精品| 高h放荡受浪受bl| 91精品国产高清一区二区三区| 中文字幕激情小说| 亚洲一区电影777| 国产传媒免费在线观看| 久久精品亚洲乱码伦伦中文| 手机在线成人av| 国产不卡一区视频| 欧美激情第一区| 蜜臀av在线播放一区二区三区| 丰满爆乳一区二区三区| 国产一区二区三区自拍| 色乱码一区二区三区熟女| 奇米亚洲欧美| 久热国产精品视频一区二区三区| aaa国产精品| 97人人模人人爽人人喊38tv| av在线播放一区二区| 国产精品一区二区久久精品| 电影天堂国产精品| 国产成人综合精品| 激情都市亚洲| 欧美最猛性xxxxx免费| caoprom在线| 午夜精品久久久久久久久久久久 | 久热av在线| 亚洲男人天堂古典| 欧美美女色图| 亚洲欧美日韩中文视频| 日本免费一区二区三区最新| 日韩精品极品在线观看| 五月婷婷深深爱| 亚洲精品在线看| 欧美女同网站| 一本色道久久88综合亚洲精品ⅰ| 男人的天堂在线视频| 亚洲欧美一区二区三区在线| 你懂的免费在线观看视频网站| 日韩大陆欧美高清视频区| 男人天堂手机在线观看| 亚洲国产精品中文| 欧美孕妇性xxxⅹ精品hd| 亚洲一级黄色av| 91精彩视频在线播放| 久久精彩免费视频| 综合久久2o19| 韩国欧美亚洲国产| av高清不卡| 国产精品午夜一区二区欲梦| 青青草国产一区二区三区| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美a在线观看| 国产精品青青草| 亚洲区小说区| 尤物一区二区三区| 欧美久久久久| 日韩视频第二页| 蜜桃视频一区二区| 永久看看免费大片| 波多野结衣中文字幕一区二区三区| 免费a在线观看播放| 国产亚洲污的网站| 无码人妻精品中文字幕| 亚洲国产精品欧美一二99| 一级免费在线观看| 91国偷自产一区二区使用方法| 一级片在线免费观看视频| 精品欧美一区二区三区精品久久| 香蕉视频网站在线| 少妇av一区二区三区| 中文在线手机av| 日本亚洲欧洲色α| 欧美日韩中出| 日韩女优中文字幕| 欧美1区2区3区| 丰满少妇在线观看| 国产不卡一区视频| 亚洲欧美日韩第一页| 亚洲永久免费视频| 中文字幕日日夜夜| 亚洲国产精品999| 五月天婷婷在线视频| 亚洲91精品在线观看| 国产成人午夜性a一级毛片| 国产高清精品一区二区| 久久国产成人精品| 玩弄中年熟妇正在播放| 精品一区二区三区视频在线观看| fc2成人免费视频| 中文字幕在线不卡国产视频| 国产情侣自拍av| 日韩欧美黄色影院| 成人在线播放视频| 91成人免费观看网站| 国产精品中文| 亚洲精品成人a8198a| 在线亚洲国产精品网站| 亚洲妇女无套内射精| 国产精品理论在线观看| 久久久精品免费看| 日韩欧美高清dvd碟片| 丝袜美腿美女被狂躁在线观看| 88国产精品欧美一区二区三区| 日韩高清一区| 欧美性视频在线播放| 久久婷婷影院| avtt香蕉久久| 亚洲一区二三区| 国产国语亲子伦亲子| 中文字幕日韩综合av| 欧美大胆成人| 久久综合入口| 国产视频一区三区| 亚洲青青久久| 欧美性黄网官网| 99免费在线视频| 夜夜嗨av色一区二区不卡| 草草视频在线| 福利视频一区二区三区| 中国成人一区| 日韩 国产 一区| 中文字幕色av一区二区三区| 无码任你躁久久久久久久| 日韩av网站在线| 超碰在线视屏| 激情小说综合网| 禁久久精品乱码| 国产大学生视频| 亚洲成人激情综合网| 丰满岳乱妇国产精品一区| 欧美精品电影免费在线观看| 日韩中文字幕一区二区高清99| 中文字幕av久久| 国产一区二区导航在线播放| 一级黄色录像视频| 精品剧情v国产在线观看在线| 新版中文在线官网| 成人欧美一区二区三区黑人免费| 好吊日精品视频| 欧美日韩一区二区三区四区五区六区| 亚洲一区二区三区自拍| 日韩在线观看视频一区| 91福利视频网| 国产精品美女久久久久久不卡| 国产自偷自偷免费一区| 国产精品沙发午睡系列990531| 影音先锋国产资源| 超碰97人人做人人爱少妇| 一区二区日韩| 3d动漫一区二区三区| 2021久久国产精品不只是精品| 日韩综合在线观看| www亚洲欧美| julia中文字幕一区二区99在线| 欧美不卡在线播放| 久久品道一品道久久精品| 亚洲在线观看av| 色综合导航网站| 美日韩中文字幕| 免费一区二区三区在线观看| 亚洲欧洲综合另类| 特黄aaaaaaaaa真人毛片| 日本精品视频在线播放| 欧美激情欧美| 在线xxxxx| 日本韩国欧美三级| 国产福利在线播放麻豆| 国产一区二区无遮挡| 奇米四色…亚洲| 国产一二三四在线| 亚洲新声在线观看| 日本超碰一区二区| 亚洲成熟丰满熟妇高潮xxxxx| 中文字幕一区二区三区蜜月| 国 产 黄 色 大 片| 国产精品旅馆在线| 亚洲一本视频| 日韩一区二区三区四区视频| 精品少妇一区二区三区视频免付费| 欧美日韩视频网站| 四虎4hu永久免费入口| 久久久久国产精品人| a毛片在线免费观看| 日本午夜在线亚洲.国产| 狠狠入ady亚洲精品| 欧美午夜激情影院| 亚洲国产精彩中文乱码av在线播放| 欧美成人毛片| 黄色高清无遮挡|