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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

haddler处理队列 netty_Netty堆外内存泄漏排查,这一篇全讲清楚了

發布時間:2025/3/12 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 haddler处理队列 netty_Netty堆外内存泄漏排查,这一篇全讲清楚了 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

上篇文章介紹了Netty內存模型原理,由于Netty在使用不當會導致堆外內存泄漏,網上關于這方面的資料比較少,所以寫下這篇文章,專門介紹排查Netty堆外內存相關的知識點,診斷工具,以及排查思路提供參考

現象

堆外內存泄漏的現象主要是,進程占用的內存較高(Linux下可以用top命令查看),但Java堆內存占用并不高(jmap命令查看),常見的使用堆外內存除了Netty,還有基于java.nio下相關接口申請堆外內存,JNI調用等,下面側重介紹Netty堆外內存泄漏問題排查

堆外內存釋放底層實現

1 java.nio堆外內存釋放

Netty堆外內存是基于原生java.nio的DirectByteBuffer對象的基礎上實現的,所以有必要先了解下它的釋放原理

java.nio提供的DirectByteBuffer提供了sun.misc.Cleaner類的clean()方法,進行系統調用釋放堆外內存,觸發clean()方法的情況有2種

(1) 應用程序主動調用

ByteBuffer buf = ByteBuffer.allocateDirect(1);

((DirectBuffer) byteBuffer).cleaner().clean();

(2) 基于GC回收

Cleaner類繼承了java.lang.ref.Reference,GC線程會通過設置Reference的內部變量(pending變量為鏈表頭部節點,discovered變量為下一個鏈表節點),將可被回收的不可達的Reference對象以鏈表的方式組織起來

Reference的內部守護線程從鏈表的頭部(head)消費數據,如果消費到的Reference對象同時也是Cleaner類型,線程會調用clean()方法(Reference#tryHandlePending())

2 Netty noCleaner策略

介紹noCleaner策略之前,需要先理解帶有Cleaner對象的DirectByteBuffer在初始化時做了哪些事情:

只有在DirectByteBuffer(int cap)構造方法中才會初始化Cleaner對象,方法中檢查當前內存是否超過允許的最大堆外內存(可由-XX:MaxDirectMemorySize配置)

如果超出,則會先嘗試將不可達的Reference對象加入Reference鏈表中,依賴Reference的內部守護線程觸發可以被回收DirectByteBuffer關聯的Cleaner的run()方法

如果內存還是不足, 則執行 System.gc(),觸發full gc,來回收堆內存中的DirectByteBuffer對象來觸發堆外內存回收,如果還是超過限制,則拋出java.lang.OutOfMemoryError(代碼位于java.nio.Bits#reserveMemory()方法)

而Netty在4.1引入可以noCleaner策略:創建不帶Cleaner的DirectByteBuffer對象,這樣做的好處是繞開帶Cleaner的DirectByteBuffer執行構造方法和執行Cleaner的clean()方法中一些額外開銷,當堆外內存不夠的時候,不會觸發System.gc(),提高性能

hasCleaner的DirectByteBuffer和noCleaner的DirectByteBuffer主要區別如下:

構造器方式不同:

noCleaner對象:由反射調用 private DirectByteBuffer(long addr, int cap)創建

hasCleaner對象:由 new DirectByteBuffer(int cap)創建

釋放內存的方式不同

noCleaner對象:使用 UnSafe.freeMemory(address);

hasCleaner對象:使用 DirectByteBuffer 的 Cleaner 的 clean() 方法

note:Unsafe是位于sun.misc包下的一個類,可以提供內存操作、對象操作、線程調度等本地方法,這些方法在提升Java運行效率、增強Java語言底層資源操作能力方面起到了很大的作用,但不正確使用Unsafe類會使得程序出錯的概率變大,程序不再“安全”,因此官方不推薦使用,并可能在未來的jdk版本移除

Netty在啟動時需要判斷檢查當前環境、環境配置參數是否允許noCleaner策略(具體邏輯位于PlatformDependent的static代碼塊),例如運行在Android下時,是沒有Unsafe類的,不允許使用noCleaner策略,如果不允許,則使用hasCleaner策略

note:可以調用PlatformDependent.useDirectBufferNoCleaner()方法查看當前Netty程序是否使用noCleaner策略

讀到這里,也許有讀者會問,如果Netty基于hasCleaner策略,通過GC觸發Cleaner.clean(),自動回收堆外內存,是不是就可以不用考慮ByteBuf.release()方法的調用,不會內存泄漏?

當然不是,一方面原因是自動觸發不實時:需要ByteBuffer對象被GC線程回收才會觸發,如果ByteBuffer對象進入老年代后才變得可回收,則需要等到發送頻率較低老年代GC才會觸發

另一方面,Netty需要基于ByteBuf.release()方法執行其他操作,例如池化內存釋放回內存池,否則該對象會被內存池一直標記為已使用

ByteBuf.release()觸發機制

業界有一種誤解認為 Netty 框架分配的 ByteBuf,框架會自動釋放,業務不需要釋放;業務創建的 ByteBuf 則需要自己釋放,Netty 框架不會釋放

產生這種誤解是有原因的,Netty框架是會在一些場景調用ByteBuf.release()方法:

1 入站消息處理

當處理入站消息時,Netty會創建ByteBuf讀取channel上的消息,并觸發調用pipeline上的ChannelHandler處理,應用程序定義的使用ByteBuf的ChannelHandler需要負責release()

public void channelRead(ChannelHandlerContext ctx, Object msg) {

ByteBuf buf = (ByteBuf) msg;

try {

...

} finally {

buf.release();

}

}

如果該ByteBuf不由當前ChannelHandler處理,則傳遞給pipeline上下一個handler:

public void channelRead(ChannelHandlerContext ctx, Object msg) {

ByteBuf buf = (ByteBuf) msg;

...

ctx.fireChannelRead(buf);

}

常用的我們會通過繼承ChannelInboundHandlerAdapter定義入站消息處理的handler,這種情況下如果所有程序的hanler都沒有調用release()方法,該入站消息Netty最后并不會release(),會導致內存泄漏;

當在pipeline的handler處理中拋出異常之后,最后Netty框架是會捕捉該異常進行ByteBuf.release()的;

完整流程位于AbstractNioByteChannel.NioByteUnsafe#read(),下面抽取關鍵片段:

try {

do {

byteBuf = allocHandle.allocate(allocator);

allocHandle.lastBytesRead(doReadBytes(byteBuf));

// 入站消息已讀完

if (allocHandle.lastBytesRead() <= 0) {

// ...

break;

}

// 觸發pipline上handler進行處理

pipeline.fireChannelRead(byteBuf);

byteBuf = null;

} while (allocHandle.continueReading());

// ...

} catch (Throwable t) {

// 異常處理中包括調用 byteBuf.release()

handleReadException(pipeline, byteBuf, t, close, allocHandle);

}

不過,常用的還有通過繼承SimpleChannelInboundHandler定義入站消息處理,在該類會保證消息最終被release:

@Override

public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {

boolean release = true;

try {

// 該消息由當前handler處理

if (acceptInboundMessage(msg)) {

I imsg = (I) msg;

channelRead0(ctx, imsg);

} else {

// 不由當前handler處理,傳遞給pipeline上下一個handler

release = false;

ctx.fireChannelRead(msg);

}

} finally {

// 觸發release

if (autoRelease && release) {

ReferenceCountUtil.release(msg);

}

}

}

2 出站消息處理

不同于入站消息是由Netty框架自動創建的,出站消息通常由應用程序創建,然后調用基于channel的write()方法或writeAndFlush()方法,這些方法內部會負責調用傳入的byteBuf的release()方法

note: write()方法在netty-4.0.0.CR2前的版本存在問題,不會調用ByteBuf.release()

3 release()注意事項

(1) 引用計數

還有一種常見的誤解就是,只要調用了ByteBuf的release()方法,或者ReferenceCountUtil.release()方法,對象的內存就保證釋放了,其實不是

因為Netty的ByteBuf引用計數來管理ByteBuf對象的生命周期,ByteBuf繼承了ReferenceCounted接口,對外提供retain()和release()方法,用于增加或減少引用計數值,當調用release()方法時,內部計數值被減為0才會觸發內存回收動作

(2) derived ByteBuf

derived,派生的意思,在ByteBuf.duplicate(), ByteBuf.slice() 和 ByteBuf.order(ByteOrder) 等方法會創建出derived ByteBuf,創建出來的ByteBuf與原有ByteBuf是共享引用計數的,原有ByteBuf的release()方法調用,也會導致這些對象內存回收

相反ByteBuf.copy() 和 ByteBuf.readBytes(int)方法創建出來的對象并不是derived ByteBuf,這些對象與原有ByteBuf不是共享引用計數的,原有ByteBuf的release()方法調用不會導致這些對象內存回收

堆外內存大小控制參數

配置堆外內存大小的參數有-XX:MaxDirectMemorySize和-Dio.netty.maxDirectMemory,這2個參數有什么區別?

-XX:MaxDirectMemorySize

用于限制Netty中hasCleaner策略的DirectByteBuffer堆外內存的大小,默認值是JVM能從操作系統申請的最大內存,如果內存本身沒限制,則值為Long.MAX_VALUE個字節(默認值由Runtime.getRuntime().maxMemory()返回),代碼位于java.nio.Bits#reserveMemory()方法中

note:-XX:MaxDirectMemorySize無法限制Netty中noCleaner策略的DirectByteBuffer堆外內存的大小

-Dio.netty.maxDirectMemory

用于限制noCleaner策略下Netty的DirectByteBuffer分配的最大堆外內存的大小,如果該值為0,則使用hasCleaner策略,代碼位于PlatformDependent#incrementMemoryCounter()方法中

堆外內存監控

如何獲取堆外內存的使用情況?

1 代碼工具

(1) hasCleaner的DirectByteBuffer監控

對于hasCleaner策略的DirectByteBuffer,java.nio.Bits類是有記錄堆外內存的使用情況,但是該類是包級別的訪問權限,不能直接獲取,可以通過MXBean來獲取

note:MXBean,Java提供的一系列用于監控統計的特殊Bean,通過不同類型的MXBean可以獲取JVM進程的內存,線程、類加載信息等監控指標

List bufferPoolMXBeans = ManagementFactoryHelper.getBufferPoolMXBeans();

BufferPoolMXBean directBufferMXBean = bufferPoolMXBeans.get(0);

// hasCleaner的DirectBuffer的數量

long count = directBufferMXBean.getCount();

// hasCleaner的DirectBuffer的堆外內存占用大小,單位字節

long memoryUsed = directBufferMXBean.getMemoryUsed();

note: MappedByteBuffer:是基于FileChannelImpl.map進行進行mmap內存映射(零拷貝的一種實現)得到的另外一種堆外內存的ByteBuffer,可以通過ManagementFactoryHelper.getBufferPoolMXBeans().get(1)獲取到該堆外內存的監控指標

(2) noCleaner的DirectByteBuffer監控

Netty中noCleaner的DirectByteBuffer的監控比較簡單,直接通過PlatformDependent.usedDirectMemory()訪問即可

2 Netty自帶內存泄漏檢測工具

Netty也自帶了內存泄漏檢測工具,可用于檢測出ByteBuf對象被GC回收,但ByteBuf管理的內存沒有釋放的情況,但不適用ByteBuf對象還沒被GC回收內存泄漏的情況,例如任務隊列積壓

為了便于用戶發現內存泄露,Netty提供4個檢測級別:

disabled 完全關閉內存泄露檢測

simple 以約1%的抽樣率檢測是否泄露,默認級別

advanced 抽樣率同simple,但顯示詳細的泄露報告

paranoid 抽樣率為100%,顯示報告信息同advanced

使用方法是在命令行參數設置:

-Dio.netty.leakDetectionLevel=[檢測級別]

示例程序如下,設置檢測級別為paranoid :

// -Dio.netty.leakDetectionLevel=paranoid

public static void main(String[] args) {

for (int i = 0; i < 500000; ++i) {

ByteBuf byteBuf = UnpooledByteBufAllocator.DEFAULT.buffer(1024);

byteBuf = null;

}

System.gc();

}

可以看到控制臺輸出泄漏報告:

十二月 27, 2019 8:37:04 上午 io.netty.util.ResourceLeakDetector reportTracedLeak

嚴重: LEAK: ByteBuf.release() was not called before it's garbage-collected. See https://netty.io/wiki/reference-counted-objects.html for more information.

Recent access records:

Created at:

io.netty.buffer.UnpooledByteBufAllocator.newDirectBuffer(UnpooledByteBufAllocator.java:96)

io.netty.buffer.AbstractByteBufAllocator.directBuffer(AbstractByteBufAllocator.java:187)

io.netty.buffer.AbstractByteBufAllocator.directBuffer(AbstractByteBufAllocator.java:178)

io.netty.buffer.AbstractByteBufAllocator.buffer(AbstractByteBufAllocator.java:115)

org.caison.netty.demo.memory.BufferLeaksDemo.main(BufferLeaksDemo.java:15)

內存泄漏的原理是利用弱引用,弱引用(WeakReference)創建時需要指定引用隊列(refQueue),通過將ByteBuf對象用弱引用包裝起來(代碼入口位于AbstractByteBufAllocator#toLeakAwareBuffer()方法)

當發生GC時,如果GC線程檢測到ByteBuf對象只被弱引用對象關聯,會將該WeakReference加入refQueue;

當ByteBuf內存被正常釋放,會調用WeakReference的clear()方法解除對ByteBuf的引用,后續GC線程不會再將該WeakReference加入refQueue;

Netty在每次創建ByteBuf時,基于抽樣率,抽樣命中時會輪詢(poll)refQueue中的WeakReference對象,輪詢返回的非null的WeakReference關聯的ByteBuf即為泄漏的堆外內存(代碼入口位于ResourceLeakDetector#track()方法)

3 圖形化工具

在代碼獲取堆外內存的基礎上,通過自定義接入一些監控工具定時檢測獲取,繪制圖形即可,例如比較流行的Prometheus或者Zabbix

也可以通過jdk自帶的Visualvm獲取,需要安裝Buffer Pools插件,底層原理是訪問MXBean中的監控指標,只能獲取hasCleaner的DirectByteBuffer的使用情況

此外,對于JNI調用產生的堆外內存分配,可以使用google-perftools進行監控

堆外內存泄漏診斷

堆外內存泄漏的具體原因比較多,先介紹任務隊列堆積的監控,再介紹通用堆外內存泄漏診斷思路

1 任務隊列堆積

這里的任務隊列是值NioEventLoop中的QueuetaskQueue,提交到該任務隊列的場景有:

(1) 用戶自定義普通任務

ctx.channel().eventLoop().execute(runnable);

(2) 對channel進行寫入

channel.write(...)

channel.writeAndFlush(...)

(3) 用戶自定義定時任務

ctx.channel().eventLoop().schedule(runnable, 60, TimeUnit.SECONDS);

當隊列中積壓任務過多,導致消息不能對channel進行寫入然后進行釋放,會導致內存泄漏

public void channelActive(ChannelHandlerContext ctx) throws NoSuchFieldException, IllegalAccessException {

monitorPendingTaskCount(ctx);

monitorQueueFirstTask(ctx);

monitorOutboundBufSize(ctx);

}

/** 監控任務隊列堆積任務數,任務隊列中的任務包括io讀寫任務,業務程序提交任務 */

public void monitorPendingTaskCount(ChannelHandlerContext ctx) {

int totalPendingSize = 0;

for (EventExecutor eventExecutor : ctx.executor().parent()) {

SingleThreadEventExecutor executor = (SingleThreadEventExecutor) eventExecutor;

// 注意,Netty4.1.29以下版本本pendingTasks()方法存在bug,導致線程阻塞問題

// 參考 https://github.com/netty/netty/issues/8196

totalPendingSize += executor.pendingTasks();

}

System.out.println("任務隊列中總任務數 = " + totalPendingSize);

}

/** 監控各個堆積的任務隊列中第一個任務的類信息 */

public void monitorQueueFirstTask(ChannelHandlerContext ctx) throws NoSuchFieldException, IllegalAccessException {

Field singleThreadField = SingleThreadEventExecutor.class.getDeclaredField("taskQueue");

singleThreadField.setAccessible(true);

for (EventExecutor eventExecutor : ctx.executor().parent()) {

SingleThreadEventExecutor executor = (SingleThreadEventExecutor) eventExecutor;

Runnable task = ((Queue) singleThreadField.get(executor)).peek();

if (null != task) {

System.out.println("任務隊列中第一個任務信息:" + task.getClass().getName());

}

}

}

/** 監控出站消息的隊列積壓的byteBuf大小 */

public void monitorOutboundBufSize(ChannelHandlerContext ctx) {

long outBoundBufSize = ((NioSocketChannel) ctx.channel()).unsafe().outboundBuffer().totalPendingWriteBytes();

System.out.println("出站消息隊列中積壓的buf大小" + outBoundBufSize);

}

note: 上面程序至少需要基于Netty4.1.29版本才能使用,否則有性能問題

實際基于Netty進行業務開發,耗時的業務邏輯代碼應該如何處理?

先說結論,建議自定義一組新的業務線程池,將耗時業務提交業務線程池

Netty的worker線程(NioEventLoop),除了作為NIO線程處理連接數據讀取,執行pipeline上channelHandler邏輯,另外還有消費taskQueue中提交的任務,包括channel的write操作。

如果將耗時任務提交到taskQueue,也會影響NIO線程的處理還有taskQueue中的任務,因此建議在單獨的業務線程池進行隔離處理

2 通用診斷思路

Netty堆外內存泄漏的原因多種多樣,例如代碼漏了寫調用release();通過retain()增加了ByteBuf的引用計數值而在調用release()時引用計數值未清空;因為Exception導致未能release();ByteBuf引用對象提前被GC,而關聯的堆外內存未能回收等等,這里無法全部列舉,所以嘗試提供一套通用的診斷思路提供參考

首先,需要能復現問題,為了不影響線上服務的運行,盡量在測試環境或者本地環境進行模擬。但這些環境通常沒有線上那么大的并發量,可以通過壓測工具來模擬請求

對于有些無法模擬的場景,可以通過Linux流量復制工具將線上真實的流量復制到到測試環境,同時不影響線上的業務,類似工具有Gor、tcpreplay、tcpcopy等

能復現之后,接下來就要定位問題所在,先通過前面介紹的監控手段、日志信息試試能不能直接找到問題所在;

如果找不到,就需要定位出堆外內存泄漏的觸發條件,但有時應用程序比較龐大,對外提供的流量入口很多,無法逐一排查。

在非線上環境的話,可以將流量入口注釋掉,每次注釋掉一半,然后再運行檢查問題是否還存在,如果存在,繼續再注釋掉剩下的一半,通過這種二分法的策略通過幾次嘗試可以很快定位出問題觸發條件

定位出觸發條件之后,再檢查程序中在該觸發條件處理邏輯,如果該處理程序很復雜,無法直接看出來,還可以繼續注釋掉部分代碼,二分法排查,直到最后找出具體的問題代碼塊

整套思路的核心在于,問題復現、監控、排除法,也可以用于排查其他問題,例如堆內內存泄漏、CPU 100%,服務進程掛掉等

總結

整篇文章側重于介紹知識點和理論,缺少實戰環節,這里分享一些優質博客文章:

《netty 堆外內存泄露排查盛宴》 閃電俠手把手帶如何debug堆外內存泄漏

https://www.jianshu.com/p/4e96beb37935

總結

以上是生活随笔為你收集整理的haddler处理队列 netty_Netty堆外内存泄漏排查,这一篇全讲清楚了的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产成人精品国内自产拍免费看 | 日韩电影在线观看一区二区三区 | 黄色大片免费播放 | 欧美精品中文在线免费观看 | 国产麻豆精品一区 | a色视频| 国产999精品久久久影片官网 | 中国一级片在线观看 | 91丨九色丨首页 | 天天干,天天操 | 日韩一级成人av | 在线激情电影 | 国产精品视频99 | 久久久久夜色 | 亚洲免费在线观看视频 | 国产一区二区三区网站 | 天天爽人人爽 | 日本少妇视频 | 玖玖视频 | 久久高清免费视频 | 私人av | 亚洲一区视频在线播放 | 久久精品一区二区 | 亚洲另类视频在线观看 | 狠狠色噜噜狠狠 | 亚洲在线免费视频 | 精品免费在线视频 | 久久综合免费视频影院 | 亚洲精品美女 | 国产不卡视频 | 精品久久精品 | 国产精品久久久久久久婷婷 | 国产精品久久久久久久久久ktv | 高清不卡一区二区在线 | 日韩在线第一区 | 精品国产一区在线观看 | 国产视频精品视频 | 人人插人人费 | 国产免费黄视频在线观看 | 国产成人精品av | 久久一二三四 | 久久久久国产精品一区二区 | 国产69精品久久久久99尤 | 69av久久 | 亚洲国产精品一区二区尤物区 | 国产精品久久久777 成人手机在线视频 | 91精品国产福利在线观看 | 日韩精品中文字幕在线播放 | 亚洲日韩欧美视频 | 97成人在线观看视频 | 4hu视频 | 国产一区在线免费观看视频 | 国产成a人亚洲精v品在线观看 | 99久久精品国产一区 | 一区二区精品久久 | 国产日韩欧美自拍 | 成人午夜免费剧场 | 色综合亚洲精品激情狠狠 | 国产精品不卡在线观看 | 丁香在线观看完整电影视频 | 探花视频在线版播放免费观看 | 国产精品亚洲片在线播放 | 一区在线电影 | 91精品国产91久久久久久三级 | 国产 中文 日韩 欧美 | 免费在线观看一区二区三区 | 超碰97中文| 中文字幕二区在线观看 | 欧美日韩在线观看一区二区三区 | 亚洲成人资源网 | 9热精品| 五月天六月婷婷 | www黄免费 | av中文字幕日韩 | 亚洲一级二级三级 | 国产亚洲精品久久网站 | 日韩在线免费视频 | 婷婷网站天天婷婷网站 | 黄色国产在线 | 激情久久小说 | 亚洲国产电影在线观看 | 黄网站app在线观看免费视频 | 国产精品一区二区三区99 | aaaaaa毛片 | 久草精品免费 | 99热9| 狠狠躁夜夜a产精品视频 | 亚洲精品乱码久久久久久蜜桃动漫 | 国产精品 9999| 国产精品一区久久久久 | 99热999| 国产美女被啪进深处喷白浆视频 | 亚洲精品视频在线观看视频 | 国产色女| 欧美午夜视频在线 | 色www免费视频 | 中文字幕在线精品 | 国产高清视频免费 | 色在线中文字幕 | 日韩美女黄色片 | 激情婷婷色 | 91成人在线视频 | 蜜臀久久99精品久久久无需会员 | 久久久久久国产精品美女 | 国产一区二区午夜 | 天天鲁天天干天天射 | 欧美狠狠操 | 亚洲欧美日韩国产精品一区午夜 | av福利在线免费观看 | 日日草天天草 | 日韩大片在线免费观看 | 在线观看视频一区二区三区 | 在线观看不卡视频 | 久久久久一区二区三区四区 | 天天玩天天操天天射 | 亚洲成a人片在线观看网站口工 | 精品久久久久久综合 | 69av在线视频| av在线免费观看不卡 | 国产精品久久99综合免费观看尤物 | free,性欧美| 91日本在线播放 | 国产黄在线 | 又黄又爽又色无遮挡免费 | 一级黄色网址 | 国产精品毛片一区二区在线 | a级片久久久 | 狠狠躁18三区二区一区ai明星 | 五月导航 | 婷婷 中文字幕 | 国产女人免费看a级丨片 | 亚洲精品高清视频 | 99久久精品免费看国产四区 | 在线天堂中文www视软件 | 久久电影国产免费久久电影 | 91精品视频免费 | 日韩久久午夜一级啪啪 | 天天操 夜夜操 | 精品999在线 | 国产尤物一区二区三区 | 中文字幕网址 | 色福利网站| 中文字幕日韩高清 | 亚洲无吗av | 久久久久欠精品国产毛片国产毛生 | 九九在线视频 | 久草视频在线新免费 | 99国内精品 | 99爱这里只有精品 | 欧美大片mv免费 | 国产一级免费观看 | 久草在线最新 | 久久综合成人 | 91高清一区| 国产中文字幕在线免费观看 | 成年人免费看片 | 亚洲高清国产视频 | 蜜桃视频色 | 免费在线观看av片 | 成人一区影院 | 久久成视频 | 久久久久欧美精品999 | 国产特黄色片 | 久久久免费播放 | 91人人澡人人爽 | 亚洲精品影院在线观看 | 在线高清一区 | 午夜av免费在线观看 | 91九色视频在线 | 99免费在线| 西西人体4444www高清视频 | 国产精品igao视频网入口 | 午夜视频亚洲 | 精品在线观看一区二区三区 | av电影在线不卡 | 日韩av线观看 | www..com黄色片 | 国产精品视频不卡 | 免费看黄色小说的网站 | 99热网站| 成人免费xxxxxx视频 | 在线观看视频色 | 麻豆免费在线视频 | 波多野结衣在线视频一区 | 国产精品 美女 | 国产精品久久久久久久久久东京 | 久久久精品午夜 | 欧美日本国产在线观看 | 奇米网在线观看 | 免费久久视频 | 精品免费视频. | 超碰免费成人 | 国产剧情久久 | www免费网站在线观看 | 日韩动漫免费观看高清完整版在线观看 | 91午夜精品| 日韩有色| 欧美色888| 狠狠色丁香婷婷综合视频 | 黄色小说在线观看视频 | 国产丝袜制服在线 | www.伊人网| 亚洲人成在线观看 | 欧美三级在线播放 | 在线观看日韩视频 | 黄色免费网站 | 狠狠躁日日躁狂躁夜夜躁av | 激情大尺度视频 | 成人免费大片黄在线播放 | 亚洲理论在线观看 | 亚洲精品免费在线 | 国产小视频91 | 国产手机免费视频 | 午夜视频久久久 | 国产精品一区二区在线观看免费 | 久久国产欧美日韩精品 | 精品嫩模福利一区二区蜜臀 | 性色在线视频 | 一区在线观看 | 亚洲3级| 1024手机看片国产 | 97色免费视频 | 99热.com| 国产一级二级三级在线观看 | 亚洲六月丁香色婷婷综合久久 | 精品一区三区 | 久久久久久久久久久久久久av | 国产视频一区二区在线观看 | 精品国产欧美一区二区三区不卡 | 中文字幕中文字幕 | 午夜视频在线观看一区二区 | 免费精品久久久 | 欧美精品中文字幕亚洲专区 | 日本精品久久久久中文字幕 | 久久久激情视频 | 欧美激情综合五月色丁香 | 亚洲黑丝少妇 | 国产偷国产偷亚洲清高 | www.精选视频.com | 六月丁香在线视频 | 亚洲综合色视频 | 黄色av电影一级片 | 精品在线视频一区 | 精品国产一区二区三区久久 | 在线国产日本 | 欧美精品免费视频 | 中文字幕免费成人 | 亚洲精品一区二区久 | 免费成人在线观看视频 | 欧美精品久久 | 国产精品第一页在线观看 | 久久久毛片 | 免费福利小视频 | 国产中文| 欧美一级视频免费 | 国产成人精品999 | 婷婷综合视频 | 在线影院中文字幕 | av资源免费在线观看 | 亚洲va天堂va欧美ⅴa在线 | 精品在线视频一区 | 国产高清 不卡 | 亚洲精品在线电影 | 亚洲国产久 | 欧美色图亚洲图片 | 女人18毛片a级毛片一区二区 | 在线视频中文字幕一区 | 久久精品一区二区三区国产主播 | 亚洲美女视频在线 | 日韩中文字幕在线 | 免费在线色电影 | 特级西西人体444是什么意思 | 美女免费视频黄 | 日韩欧美一区二区三区在线观看 | 欧美日韩国产一区 | 国产高清视频色在线www | 亚洲精品一区二区久 | 精品国精品自拍自在线 | 国产精品一区二区av日韩在线 | 日韩精品免费在线 | 亚洲热久久 | 免费的国产精品 | 国产精品xxxx18a99 | 超碰在线1 | 久久首页 | 久久99视频| 69av免费视频 | 日韩av中文字幕在线免费观看 | 91网站观看| 黄色软件网站在线观看 | 999男人的天堂 | 又色又爽的网站 | 97视频免费在线看 | 狠狠干,狠狠操 | 欧美二区在线播放 | 天天操天天干天天 | 91免费在线 | 国产精品永久久久久久久久久 | 国产精品av免费 | 91在线小视频 | 亚洲精品乱码久久 | 国产一区视频在线观看免费 | 国产区 在线 | 欧美日韩视频在线播放 | 六月色丁 | av在线中文 | 美腿丝袜一区二区三区 | 香蕉影视 | 国产精品麻豆91 | 黄色亚洲免费 | 一区在线免费观看 | 久久公开视频 | 国产免码va在线观看免费 | 天天色天天操综合网 | 欧美精品久久久久久久久久久 | 欧美精品久久久久久久亚洲调教 | 一级性视频 | 国产精品成人一区二区 | 在线免费观看黄网站 | 丝袜少妇在线 | 国产成人精品三级 | 国产成人一区二 | 国产精品三级视频 | 三级视频片 | 欧美热久久 | 在线视频 国产 日韩 | 久久视频精品 | 在线中文日韩 | 综合亚洲视频 | 国产喷水在线 | 91麻豆产精品久久久久久 | 91禁在线看| 国产精品免费观看国产网曝瓜 | 中文字幕日本电影 | 日韩一区正在播放 | 97天堂 | 狠狠干电影| 天天操天天谢 | 99久热在线精品视频观看 | 成人作爱视频 | 香蕉久久久久 | 欧美日韩高清一区二区 | 91久久国产自产拍夜夜嗨 | 天天插天天操天天干 | 亚洲一区视频免费观看 | 亚洲精品字幕在线观看 | 91福利在线导航 | 九色视频网站 | 欧美日韩三级 | 新版资源中文在线观看 | www.天天色.com | 色婷婷国产 | 中文字幕一区二区三区在线视频 | 日韩av中文字幕在线免费观看 | 国产主播99 | 天天射狠狠干 | 午夜手机电影 | 天天射天天操天天 | 黄色大片国产 | 又色又爽又黄高潮的免费视频 | 黄色av免费 | 亚洲经典视频 | 精品欧美一区二区在线观看 | 国产精品久久久久久久久久了 | 国产 视频 久久 | 欧美一级淫片videoshd | 夜夜高潮夜夜爽国产伦精品 | 美女视频a美女大全免费下载蜜臀 | 欧美性视频网站 | 人人草在线视频 | 黄色高清视频在线观看 | 欧美性色综合 | 国产精品门事件 | 久久久麻豆视频 | 欧美日韩在线精品一区二区 | 国产精品手机看片 | 激情av网 | 九九久久久 | 国产中文字幕亚洲 | 99久久综合国产精品二区 | 黄色性av | 黄色tv视频 | 亚洲美女久久 | 男女免费视频观看 | 久久免费视频一区 | 天天干夜夜爱 | 91精品国产99久久久久久红楼 | 婷婷丁香国产 | 一区二区视频在线看 | 黄色免费观看视频 | 在线小视频国产 | 日b视频在线观看网址 | 激情伊人五月天久久综合 | 成人精品视频久久久久 | 最新国产中文字幕 | 国产精品观看 | 欧美综合在线视频 | 国产精品99久久久久久久久久久久 | 成人午夜影视 | 国产色道| 91精品国产成 | 亚洲国产成人久久综合 | 成人av电影在线观看 | www.夜夜操| 日韩在线 一区二区 | av在线之家电影网站 | 中文字幕免费一区二区 | 色在线视频网 | 国产一区二区高清 | 成人午夜电影网 | 天天插夜夜操 | 国产精品成人av在线 | 久久久精品国产一区二区三区 | 97精品国产91久久久久久 | 国产伦精品一区二区三区在线 | 国产亚洲人成网站在线观看 | 久久婷婷一区二区三区 | 色婷婷亚洲婷婷 | 嫩草av在线 | 国产精品18毛片一区二区 | 国产精品自产拍在线观看蜜 | 国产日产精品一区二区三区四区 | 中文av一区二区 | 九九热免费在线观看 | 在线观看国产一区二区 | 亚洲黄色在线观看 | 精品久久免费看 | 成年人黄色免费看 | 少妇做爰k8经典 | 久久成人视屏 | 久久久麻豆视频 | 亚洲h在线播放在线观看h | 视频在线亚洲 | 91av小视频 | 丁香色婷 | 国产精品麻豆免费版 | 97超碰在线久草超碰在线观看 | 国产视频1区2区3区 久久夜视频 | 91精品老司机久久一区啪 | 久久久69 | 国产福利91精品一区 | 久久毛片网 | 一区二区成人国产精品 | 日韩在线免费播放 | 日韩精品免费一区二区三区 | 国产亚洲日本 | 婷婷网站天天婷婷网站 | 日韩福利在线观看 | 91看片网址 | 1000部国产精品成人观看 | 国产精品第10页 | 久久精品毛片基地 | 欧美国产日韩在线视频 | 能在线观看的日韩av | 日日干夜夜干 | www.天天成人国产电影 | 91在线porny国产在线看 | 国产精品九九九 | 91成人在线视频观看 | 亚洲精品小区久久久久久 | 亚洲精品国产精品久久99 | 欧美精品一区二区三区四区在线 | 亚洲在线免费视频 | 久久久久一区 | 久草精品资源 | 又黄又爽又无遮挡免费的网站 | 久久五月天色综合 | www.色就是色| 日韩美女免费线视频 | 日本中文字幕在线播放 | 日韩av成人免费看 | 一级黄色av | 中文字幕视频在线播放 | 国产裸体视频bbbbb | 国产精品theporn | se视频网址| 日韩在线视频网站 | 在线日韩三级 | 少妇视频一区 | 天天操天天干天天 | 天天干夜夜干 | 在线观看视频你懂得 | 在线视频观看亚洲 | 久保带人| 日本中文字幕高清 | 国产精品美女视频网站 | 99国产成+人+综合+亚洲 欧美 | 亚洲黄色av一区 | 精品久久91 | 香蕉久久国产 | 国产精品一区二区电影 | 99精品国产福利在线观看免费 | av网站有哪些 | 日本在线中文 | 欧美巨乳波霸 | 色婷婷99| 国产精品日韩高清 | 久久999久久 | 亚洲永久精品在线 | 国产一级电影在线 | 在线免费观看涩涩 | 亚洲资源一区 | 草草草影院 | 欧美日韩天堂 | 国产精品美女在线观看 | 韩国在线一区二区 | 久久久久久福利 | 九九导航 | 国产在线一区观看 | 日韩黄在线观看 | 日韩a在线播放 | 免费v片| 国产视频资源在线观看 | 亚洲综合色丁香婷婷六月图片 | 久久视频在线免费观看 | 久久视频在线免费观看 | av中文字幕免费在线观看 | 国产专区精品视频 | 久久久精品网 | 国产精品亚洲片夜色在线 | 久久久久综合视频 | 天天爽夜夜爽人人爽一区二区 | 99c视频高清免费观看 | 日韩视频免费观看高清 | 亚洲日本在线视频观看 | 免费在线电影网址大全 | 成人免费在线网 | 色婷婷亚洲婷婷 | 97人人添人澡人人爽超碰动图 | 五月婷婷丁香综合 | 国产一级黄 | 911国产在线观看 | 亚洲精品色视频 | 久久人人做 | a级成人毛片 | 欧美激情精品久久久 | 国产传媒一区在线 | 日本黄色免费在线观看 | 国产又粗又长又硬免费视频 | 欧美精品九九99久久 | 亚洲成成品网站 | 人人爽人人搞 | 黄网站免费看 | 一区二区三区 亚洲 | 日日爽天天操 | 国产精品麻豆视频 | 成人一级影视 | 国产大尺度视频 | 久久精品男人的天堂 | 91精品视频免费看 | 在线黄色av| 99久久精品免费看国产免费软件 | 五月黄色 | 91视频在线自拍 | 欧美精品小视频 | 特级片免费看 | 综合久久网站 | 日韩精品一区二 | 丰满少妇在线观看 | 国产精品视频不卡 | 国产精品久久久久一区 | 久久久综合香蕉尹人综合网 | 国产专区精品 | av三区在线 | 天天综合网国产 | 一区二区三区在线看 | 久草a视频| 免费国产在线观看 | 99久久国产免费看 | 国产日产高清dvd碟片 | 午夜黄色影院 | 丝袜制服天堂 | 中文字幕a∨在线乱码免费看 | 亚洲伦理一区二区 | 亚洲精品av中文字幕在线在线 | 亚洲激情六月 | 亚洲精品9 | 精品亚洲免费 | 天天色天天 | 国产一区影院 | 99久久99久久精品免费 | 友田真希av| 亚洲欧美日韩国产一区二区三区 | 99视频+国产日韩欧美 | 免费看的黄色网 | 色欧美综合 | 麻豆传媒视频在线播放 | 在线一二三四区 | 国产一级精品视频 | 三级动态视频在线观看 | av电影免费在线 | 久久久精品二区 | 久久久久久久毛片 | 国产xx在线 | 国产精品资源在线观看 | 婷婷在线精品视频 | 天天爱天天操 | 国产日韩中文字幕 | 国产91精品看黄网站在线观看动漫 | 国产99久久99热这里精品5 | 激情婷婷综合网 | 国产成人精品av在线观 | 精品欧美日韩 | 99日韩精品 | 毛片区 | 国产小视频网站 | 九九视频精品在线 | 色婷婷视频在线观看 | 视频1区2区 | 中文字幕乱码视频 | 黄色在线观看免费 | 免费在线观看日韩视频 | 欧美在线a视频 | 在线观看视频福利 | 天天干天天射天天操 | 人人爽人人爽人人片av免 | 中文字幕av免费在线观看 | 日韩精品欧美一区 | 精品中文字幕在线观看 | 美女视频黄的免费的 | 国产小视频网站 | 香蕉视频在线免费看 | 五月婷婷在线视频观看 | av成人免费在线看 | 久久99精品久久久久久清纯直播 | 91在线日韩| 国产香蕉av | 久草在线欧美 | 色全色在线资源网 | 亚洲黄色小说网 | av中文字幕剧情 | 五月激情姐姐 | 在线观看午夜 | 久草在线视频在线观看 | 一区二区三区久久精品 | 免费av网站在线看 | 99视频| 97在线观看免费高清完整版在线观看 | 亚洲精品资源在线观看 | 五月天婷婷在线视频 | 国产精品aⅴ | 97色婷婷成人综合在线观看 | 国产 在线 高清 精品 | 最新日韩电影 | 国产一二三精品 | 亚洲成熟女人毛片在线 | 色综合激情网 | 婷婷色5月 | 黄色一级大片在线免费看产 | 国产亚洲视频在线 | 免费看国产视频 | 五月婷婷六月丁香在线观看 | 精品免费视频 | 91av免费观看 | 国内久久久久 | 国产高清区| 欧美日韩亚洲在线观看 | 97在线观看免费观看高清 | 日b视频在线观看网址 | 97视频免费观看2区 亚洲视屏 | 亚洲精品乱码白浆高清久久久久久 | 亚洲国产精品电影在线观看 | 又色又爽的网站 | 九九av | 99国产精品久久久久老师 | 青青草在久久免费久久免费 | 久久久久 免费视频 | 久久伊人八月婷婷综合激情 | 一本到视频在线观看 | 亚洲va欧美va | 麻豆视频大全 | 女人高潮特级毛片 | a级国产乱理伦片在线播放 久久久久国产精品一区 | www.久久精品视频 | 国产91精品欧美 | 在线免费观看视频 | 97碰在线视频 | 免费视频国产 | 久久电影国产免费久久电影 | 亚洲国产精品激情在线观看 | 欧美日韩国产精品一区二区 | 久久人人添人人爽添人人88v | 麻豆超碰 | 91麻豆精品久久久久久 | 国产成人性色生活片 | 亚洲精品在线观看网站 | 中文字幕在线中文 | 久草免费新视频 | 国产精品久久久久久五月尺 | 久久久久久久99 | 日日日日干 | 爱爱av在线 | 91最新中文字幕 | 国产综合片 | 国产精品毛片一区视频 | 在线 你懂 | 91热视频在线观看 | 91成人在线视频观看 | 91免费高清观看 | 国产精品日韩在线观看 | 久久久www免费电影网 | 日韩二区三区在线观看 | 久草在线欧美 | 国内精品久久久久久中文字幕 | 精品超碰 | 五月天综合色激情 | 久草免费在线视频 | 欧美日韩伦理一区 | 国产99色 | 日韩免费二区 | 天天操天天吃 | 日本精品视频在线 | 国产精品中文字幕在线观看 | 精选久久 | 免费在线观看日韩 | 亚洲午夜精品电影 | 就要干b| 免费看在线看www777 | 日日操狠狠干 | 久久午夜影院 | 五月婷在线播放 | 一区二区中文字幕在线播放 | 91插插插免费视频 | 一区免费观看 | 免费色视频网址 | 久久视频免费在线观看 | 在线视频精品播放 | 久久精品精品电影网 | 99视频在线精品免费观看2 | 亚洲色影爱久久精品 | 免费av网址在线观看 | 欧美视频二区 | 亚洲国产黄色片 | 天天爽天天摸 | 亚洲综合精品在线 | 91九色视频在线 | 精品福利网 | 国产麻豆精品久久 | 在线日韩中文 | 黄色福利视频网站 | 久久久久影视 | 中文字幕人成不卡一区 | 91片网 | 99精品视频免费观看视频 | 国产一区精品在线观看 | 国产一卡二卡四卡国 | 亚洲一级久久 | 丁香婷婷激情 | 免费看国产黄色 | 久久黄色影视 | 在线观看91视频 | 国产黄大片在线观看 | 91精品一区在线观看 | 丁香五香天综合情 | 久久狠狠干| 日韩在线免费视频 | 久久久国产高清 | 国产一级片观看 | 精品一区二区亚洲 | 最近中文字幕在线播放 | 精品影院一区二区久久久 | 女人18片毛片90分钟 | 欧美国产91 | 一区二区三区在线免费观看视频 | 国产一线天在线观看 | 婷婷六月丁香激情 | www操操操| 免费国产黄线在线观看视频 | 激情五月激情综合网 | 久久久久久综合网天天 | 久艹视频在线免费观看 | 97超碰总站 | 亚洲高清av | 国产美女免费视频 | 久久综合久久鬼 | 久久手机在线视频 | 成人黄在线 | 欧美性天天 | 狠狠狠干| 欧美视频不卡 | 国产亚洲精品xxoo | 免费三级av| 精品99999| 久久久久区 | 亚洲精品777| 欧美性视频网站 | 91免费高清视频 | 国产色婷婷 | 国产一区二区中文字幕 | 婷婷精品在线视频 | www色com | 91黄色在线视频 | 在线看片91 | 色99久久| 91.dizhi永久地址最新 | 夜夜骑天天操 | 在线观看欧美成人 | 天天操天 | 三级在线视频观看 | 欧美日本一区 | 国产精品孕妇 | 国产激情久久久 | 日韩精品短视频 | 国产精品99视频 | 808电影免费观看三年 | 正在播放久久 | 国产aaa大片 | 天堂在线视频中文网 | 欧美性成人 | 天天操天天谢 | 免费一级日韩欧美性大片 | 激情视频在线观看网址 | 草久久久久 | 麻豆国产精品永久免费视频 | 成人一级影视 | 国产青春久久久国产毛片 | 国产精品ssss在线亚洲 | 精品一区 在线 | 亚州中文av | 狠狠狠狠干| 超碰最新网址 | 欧美视频在线观看免费网址 | 色综合久久88 | 亚洲一级在线观看 | 国产精品观看在线亚洲人成网 | 亚洲自拍av在线 | av中文字幕在线观看网站 | 三级av在线播放 | 国产精品成人av久久 | 激情综合交| 日韩最新中文字幕 | 国产精品av电影 | 欧美xxxxx在线视频 | 久久激情精品 | 国产视频不卡一区 | 香蕉日日 | 成人免费大片黄在线播放 | 超碰97久久| 在线观看中文字幕一区 | 国产91精品一区二区 | 国产美腿白丝袜足在线av | 国产综合视频在线观看 | 日韩二三区 | 高清不卡毛片 | 亚洲精品日韩一区二区电影 | 91丨九色丨高潮 | 国产一区二区三区高清播放 | 亚洲精品色视频 | 国产精品麻豆99久久久久久 | 日韩一区在线免费观看 | 久久精品综合一区 | 91久色蝌蚪 | 久久99国产精品免费网站 | 正在播放国产精品 | 亚洲一区二区黄色 | 欧美另类交人妖 | 国产麻豆成人传媒免费观看 | 超碰97中文 | 国产精品久久人 | 国产高清在线a视频大全 | 丁香六月婷婷 | avove黑丝| 国产高清视频在线 | 福利一区二区 | 丰满少妇在线观看网站 | 中文字幕在线观看播放 | 国产视频一区在线 | 91av在线免费播放 | 狠狠色丁香久久婷婷综合丁香 | 欧美日韩视频网站 | 国产精品久久久久久久久久久久午 | 超碰在线最新网址 | 久久精品一区二区三 | 久久精品视频18 | 国产精品第2页 | 欧美一区,二区 | 日韩黄色免费 | 亚洲国内精品 | 久久久色| 成人九九视频 | 国产69久久久欧美一级 | 亚洲成a人片77777kkkk1在线观看 | 日日日操操| 五月婷婷色 | 久久成人国产精品免费软件 | 91免费观看国产 | 8090yy亚洲精品久久 | 狠狠地日 | 欧美一二三区在线观看 | 亚洲v欧美v国产v在线观看 | 国产精品 中文字幕 亚洲 欧美 | 精品国产1区二区 | 午夜在线看片 | 日韩午夜在线播放 | 国产精品原创 | 日韩在线观看视频中文字幕 | 视频国产在线观看18 | 午夜美女福利 | 五月天久久久久久 | 成人h动漫精品一区二 | 亚洲精品在线一区二区 | 欧美aa一级 | 日本中文字幕一二区观 | 欧美一二三四在线 | 你操综合 | 玖玖爱在线观看 | 亚洲精品国产精品国自 | 黄色一级大片在线免费看产 | 精品国产精品久久一区免费式 | 成人亚洲精品国产www | 精品国自产在线观看 | 伊人成人激情 | 日韩三级免费 | 国精产品一二三线999 | 99精品视频播放 | 91视频传媒 | 免费成人在线网站 | 2021国产精品视频 | 美女网站在线看 | 黄色一集片 | 久久久私人影院 | 极品中文字幕 | 92国产精品久久久久首页 | 国产伦理久久精品久久久久_ | 午夜精品久久久99热福利 | 九九热在线视频 | 国产日韩欧美在线观看 | 欧美日韩调教 | 丝袜美腿在线 | 黄色aaa毛片| 亚洲jizzjizz日本少妇 | 国产一级性生活视频 | 91av视频在线免费观看 | 欧美性色黄大片在线观看 | 久久精品视频2 | 国产精品激情在线观看 | 中文字幕在| 成人在线免费观看视视频 | 成人久久电影 | 在线视频日韩 | 久久这里只有精品视频首页 | 中文字幕中文字幕中文字幕 | 97成人资源站 | 久久97精品 | 人人爽人人射 | 天天操天天操天天操天天操天天操天天操 | 五月婷婷.com | 免费福利影院 | 亚洲五月综合 | 国内精品视频在线 | 国产主播大尺度精品福利免费 | 国产亚洲精品久久19p | 久久99这里只有精品 | 黄色com| 亚洲丝袜一区 | 在线高清| av网站大全免费 | 精品黄色在线观看 | 天天视频色版 | 日日爱网址 | 色无五月 | 最近中文字幕久久 | 久久久国产精品视频 | 国产一级精品绿帽视频 | av青草| 国产女人40精品一区毛片视频 | 久久免费视频网站 | 69国产成人综合久久精品欧美 | 狂野欧美激情性xxxx欧美 | av在线看网站 | 色综合婷婷久久 | 国产精品99久久久久的智能播放 | 日日操狠狠干 | 久久www免费人成看片高清 | 国产精品理论片在线观看 | 国产一级淫片在线观看 | 国产 日韩 欧美 在线 | 国产无套视频 | 制服丝袜在线 | 天天爱天天色 | 日本黄色免费播放 | 日韩欧美在线观看一区 | 亚洲永久精品国产 | 久爱精品在线 | 奇米影视在线99精品 | 婷婷九九| 久久精品亚洲精品国产欧美 | 国产精品久久久久永久免费看 | 91一区啪爱嗯打偷拍欧美 | 蜜臀久久99精品久久久无需会员 | 一本到视频在线观看 | 99精品国产99久久久久久福利 | 色婷av | 在线观看视频你懂得 | 99视频在线精品 | 精品久久久久久国产偷窥 | av成人免费网站 | 免费视频一二三 |