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

沒想到,錯誤的單例寫法,讓 RabbitMQ 大量超時導致程序掛死!

開發 前端
既然無響應了,那必然是程序的大量線程被主動或者被動的掛起,朋友也很及時的從程序上抽了一管血下來,接下來就上 windbg 一起探究下到底發生了什么?

[[438682]]

一、背景

1. 講故事

10月份星球里的一位老朋友找到我,說他們公司的程序在一個網紅直播帶貨下給弄得無響應了,無響應期間有大量的 RabbitMQ 超時,尋求如何找到根源,聊天截圖我就不發了。

既然無響應了,那必然是程序的大量線程被主動或者被動的掛起,朋友也很及時的從程序上抽了一管血下來,接下來就上 windbg 一起探究下到底發生了什么?

二、Windbg 分析

1. 線程們都怎么了

要想看所有線程,還是老命令 !t 。

  1. 0:000> !t 
  2. ThreadCount:      5221 
  3. UnstartedThread:  0 
  4. BackgroundThread: 5199 
  5. PendingThread:    0 
  6. DeadThread:       21 
  7. Hosted Runtime:   no 
  8.                                                                                                             Lock   
  9.  DBG   ID     OSID ThreadOBJ           State GC Mode     GC Alloc Context                  Domain           Count Apt Exception 
  10.   20    1     74e4 00000276CB778180  202a020 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 MTA  
  11.   31    2     42cc 00000276CB6CA830    2b220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 MTA (Finalizer)  
  12.   32    3     2b40 00000276CB85D1B0  102a220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 MTA (Threadpool Worker)  
  13.    2    6     bccc 00000276CBA5D2F0    20220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 Ukn  
  14.   33    9     7224 00000276CBA5C0C0  3029220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 MTA (Threadpool Worker) System.IO.IOException 00000279ccc56cd0 
  15.    9   23     29e0 0000027BD86FD180    20220 Preemptive  0000000000000000:0000000000000000 00000276cb77c9d0 -00001 Ukn  
  16. ... 

從簡要信息看,當前有 5000+ 的線程,太牛了,一般一臺機器的所有進程的線程加起來也沒這么多。。。不過我目前看到最多的是 1w + 的線程 ??????, 就是那種不用線程池,直接用 Thread 造成的一種線程垃圾。

可以看到線程列表中的 9號線程 拋了托管異常,接下來看看是個啥錯誤, 使用 !wpe 00000279ccc56cd0 命令。

  1. 0:000> !wpe 00000279ccc56cd0 
  2. Address: 00000279ccc56cd0 
  3. Exception Type: System.IO.IOException 
  4. Message: Unable to read data from the transport connection: 遠程主機強迫關閉了一個現有的連接。. 
  5. Inner Exception: 00000279ccc56b20 System.Net.Sockets.SocketException 遠程主機強迫關閉了一個現有的連接。 
  6. Stack: 
  7. SP               IP               Function 
  8. 000000791b88c970 00007ffd844a1b31 System.Net.Sockets.NetworkStream.Read(Byte[], Int32, Int32) 
  9. 000000791b88ee80 00007ffd849e6f8a System.IO.BufferedStream.ReadByteSlow() 
  10. 000000791b88eeb0 00007ffd8312950a RabbitMQ.Client.Impl.InboundFrame.ReadFrom(System.IO.Stream, Byte[]) 
  11. 000000791b88ef40 00007ffd849e6d7d RabbitMQ.Client.Framing.Impl.Connection.MainLoopIteration() 
  12. 000000791b88efa0 00007ffd8312832f RabbitMQ.Client.Framing.Impl.Connection.MainLoop() 
  13.  
  14. HResult: 80131620 

從堆棧信息來看,程序做了一個遠程訪問 RabbitMQ,結果 tcp 連接被對方關閉了,貌似和朋友說的有大量 RabbitMQ 超時有關。

接下來就是查看各個線程棧,研究下此時這些線程都在干什么,使用 ~*e !clrstack 命令,通過仔細研讀線程棧,我發現有大量的方法卡在 xxx.RabbitMq.RabbitMqConnection.GetInstance 方法處。

  1.         Child SP               IP Call Site 
  2. 0000008B8A9ED6A8 00007ffdf5246594 [HelperMethodFrame_1OBJ: 0000008b8a9ed6a8] System.Threading.Monitor.ReliableEnter(System.Object, Boolean ByRef) 
  3. 0000008B8A9ED800 00007ffd84a6a4a9 xxx.RabbitMq.RabbitMqConnection.GetInstance(Microsoft.Extensions.Options.IOptions`1<xxx.RabbitMq.RabbitMqConfig>, Microsoft.Extensions.Logging.ILogger`1<System.Object>) 
  4. 0000008B8A9ED860 00007ffd84a6a317 xxx.RabbitMq.RabbitMqProducer..ctor(Microsoft.Extensions.Options.IOptionsSnapshot`1<xxx.RabbitMq.RabbitMqConfig>, Microsoft.Extensions.Logging.ILogger`1<xxx.RabbitMq.RabbitMqProducer>) 
  5. 0000008B8A9ED8A0 00007ffd8334817b DynamicClass.ResolveService(ILEmitResolverBuilderRuntimeContext, Microsoft.Extensions.DependencyInjection.ServiceLookup.ServiceProviderEngineScope) 
  6. 0000008B8A9ED930 00007ffd83347d76 DynamicClass.ResolveService(ILEmitResolverBuilderRuntimeContext, Microsoft.Extensions.DependencyInjection.ServiceLookup.ServiceProviderEngineScope) 
  7. 0000008B8A9EDE90 00007ffd844f3cb3 Microsoft.Extensions.DependencyInjection.ActivatorUtilities.GetService(System.IServiceProvider, System.Type, System.Type, Boolean) [/_/src/libraries/Common/src/Extensions/ActivatorUtilities/ActivatorUtilities.cs @ 173] 
  8. DynamicClass.lambda_method196(System.Runtime.CompilerServices.Closure, System.IServiceProvider, System.Object[]) 
  9. 0000008B8A9EDF20 00007ffd84a0fc9c Microsoft.AspNetCore.Mvc.Controllers.ControllerFactoryProvider+c__DisplayClass5_0.g__CreateController|0(Microsoft.AspNetCore.Mvc.ControllerContext) 
  10. 0000008B8A9EDF70 00007ffd8452ce7f Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.Next(State ByRef, Scope ByRef, System.Object ByRef, Boolean ByRef) [/_/src/Mvc/Mvc.Core/src/Infrastructure/ControllerActionInvoker.cs @ 285] 
  11. 0000008B8A9EE030 00007ffd84a0fac8 Microsoft.AspNetCore.Mvc.Infrastructure.ControllerActionInvoker.InvokeInnerFilterAsync() [/_/src/Mvc/Mvc.Core/src/Infrastructure/ControllerActionInvoker.cs @ 490] 
  12. 0000008B8A9EE0B0 00007ffd845346cd Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Next(State ByRef, Scope ByRef, System.Object ByRef, Boolean ByRef) [/_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs @ 883] 
  13. 0000008B8A9EE240 00007ffd84a0f9ad Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeNextExceptionFilterAsync() [/_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs @ 1024] 
  14. 0000008B8A9EE2C0 00007ffd84534272 Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Next(State ByRef, Scope ByRef, System.Object ByRef, Boolean ByRef) [/_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs @ 883] 
  15. 0000008B8A9EE450 00007ffd84a0f850 Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeNextResourceFilter() [/_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs @ 976] 
  16. ... 

從調用棧信息看,源頭是一個http請求,然后在 GetInstance 下的 lock 處被凍結,這就激發了我很大的好奇心,接下來根據 IP 導出源碼看看。

  1. public sealed class RabbitMqConnection 
  2.     public static RabbitMqConnection GetInstance(IOptions<RabbitMqConfig> options, ILogger<dynamic> logger) 
  3.     { 
  4.         if (_uniqueInstance == null || _uniqueInstance.Connection == null || !_uniqueInstance.Connection.IsOpen) 
  5.         { 
  6.             lock (_objLock) 
  7.             { 
  8.                 if (_uniqueInstance == null || _uniqueInstance.Connection == null || !_uniqueInstance.Connection.IsOpen) 
  9.                 { 
  10.                     _uniqueInstance = new RabbitMqConnection(options.Value, logger); 
  11.                 } 
  12.             } 
  13.         } 
  14.         return _uniqueInstance; 
  15.     } 
  16.  
  17.  private RabbitMqConnection(RabbitMqConfig config, ILogger<dynamic> logger) 
  18.  { 
  19.   Policy.Handle<SocketException>().Or<BrokerUnreachableException>().WaitAndRetry(6, (int retryAttempt) => TimeSpan.FromSeconds(1.0), delegate (Exception ex, TimeSpan timeint retryCount, Context content) 
  20.   { 
  21.    if (6 == retryCount) 
  22.    { 
  23.     throw ex; 
  24.    } 
  25.    _logger.LogError(ex, $"{retryCount}:{ex.Message}"); 
  26.   }) 
  27.    .Execute(delegate 
  28.    { 
  29.     Connection = factory.CreateConnection(); 
  30.    }); 
  31.  } 

從代碼邏輯看,朋友用了 雙檢鎖 來給 RabbitMQ 實例做單例化,如果實例創建失敗還會有 6 次 1s 的嘗試,這種寫法乍一看沒什么問題。

2. 單例寫法真的沒問題嗎

如果單例寫法沒問題的話,為什么有大量的線程卡在 lock 處呢?既然是 單例 那肯定是 rabbitmq 第一次被實例化后,后人直接乘涼就好了哈,帶著這個疑問再次檢查 雙檢索 寫法,尼瑪,在判斷單例的時候居然做了 _uniqueInstance.Connection.IsOpen 判斷,大家知道這意味著什么嗎?

這意味著,一旦 rabbitmq 在某個時刻掛掉了,單例條件就被破防了,無數的線程排隊來做 RabbimtMQ 的實例化,要知道這都是些不實例出來不罷休的勇士,繼而導致程序掛死...??????

3. 驗證我的想法

既然從源碼中推出了這個代碼缺陷,但口說無憑,我得拿出證據,要想驗證很簡單,到托管堆尋找 RabbitMqConnection 實例,看下此時它的 IsOpen 是不是 false 即可, 通過 ILSpy 查看源碼發現它是用 CloseReason==null 來判斷的。

接下來看看 CloseReason 不為空即可。

  1. 0:000> !dumpheap -type RabbitMqConnection 
  2.          Address               MT     Size 
  3. 00000277cbd7aa68 00007ffd831f1570       32   
  4. 00000277ccb13068 00007ffd831f1570       32    
  5.  
  6. 0:000> !DumpObj /d 00000277cbd7b858 
  7. Name:        RabbitMQ.Client.Framing.Impl.AutorecoveringConnection 
  8. MethodTable: 00007ffd83235db0 
  9. EEClass:     00007ffd83242898 
  10. Size:        200(0xc8) bytes 
  11. File:        G:\xxx\RabbitMQ.Client.dll 
  12. Fields: 
  13.               MT    Field   Offset                 Type VT     Attr            Value Name 
  14. 00007ffd82397238  4000180       bc       System.Boolean  1 instance                0 _disposed 
  15. 00007ffd82390c68  4000181        8        System.Object  0 instance 00000277cbd7b920 _eventLock 
  16. 00007ffd831fc230  4000182       10 ...g.Impl.Connection  0 instance 00000277cbd7d5f8 _delegate 
  17.  
  18. 0:000> !DumpObj /d 00000277cbd7d5f8 
  19. Name:        RabbitMQ.Client.Framing.Impl.Connection 
  20. MethodTable: 00007ffd831fc230 
  21. EEClass:     00007ffd8322cd70 
  22. Size:        232(0xe8) bytes 
  23. File:        G:\xxx\RabbitMQ.Client.dll 
  24. Fields: 
  25.               MT    Field   Offset                 Type VT     Attr            Value Name 
  26. 00007ffd82397238  4000198       b8       System.Boolean  1 instance                0 _disposed 
  27. 00007ffd82390c68  4000199        8        System.Object  0 instance 00000277cbd7d6e0 _eventLock 
  28. 00007ffd82d93d00  400019a       10 ...ualResetEventSlim  0 instance 00000277cbd7d6f8 _appContinuation 
  29. 00007ffd83276028  400019b       18 ...ShutdownEventArgs  0 instance 00000279ccc56e28 _closeReason 
  30.  
  31. 0:000> !do 00000277ccb13068 
  32. Name:        xxx.RabbitMq.RabbitMqConnection 
  33. MethodTable: 00007ffd831f1570 
  34. EEClass:     00007ffd831eb920 
  35. Size:        32(0x20) bytes 
  36. File:        G:\xxx\xxx.dll 
  37. Fields: 
  38.               MT    Field   Offset                 Type VT     Attr            Value Name 
  39. 00007ffd831f13f8  400001f        8 ...Private.CoreLib]]  0 instance 00000278cbe4c2a0 _logger 
  40. 00007ffd831f2ab0  4000020       10 ...lient.IConnection  0 instance 0000000000000000 <Connection>k__BackingField 
  41. 00007ffd831f1570  400001d        8 ...abbitMqConnection  0   static 00000277cbd7aa68 _uniqueInstance 
  42. 00007ffd82390c68  400001e       10        System.Object  0   static 00000277cbd7aa50 _objLock 

從輸出信息中可以很清楚的看到當前托管堆有兩個 RabbitMqConnection 對象,其中一個果然是失敗了(_closeReason=00000279ccc56e28),還有一個正在努力的new k__BackingField=0000000000000000, 這也就驗證了假設。

4. 后續

有了這些信息,和朋友做了下溝通,建議再優化一下 IsOpen=false 時的異常處理邏輯,比如 return 或者 throw new,或者干脆不要用懶檢測, 千萬不要硬著來。

至于造成 RabbitMQ 不響應的一系列誘因,朋友通過參考的開源項目,發現將別人的 AddSingleton 改成了 AddScoped。

這也就造成了每一次Http請求都要試探性的判斷單例邏輯, 別人的解法是一旦上層單例化了,下層就不會再次處理了,也就不會走 IsOpen 邏輯。

三、總結

造成本次程序卡死的事故,主要有兩點:

  • RabbitMQ 生成單例化中的 IsOpen 判斷問題,建議改用自動重連屬性 AutomaticRecoveryEnabled 和 TopologyRecoveryEnabled,或者用靜態構造函數替代雙檢鎖。 
  • 過多的 http 請求對單例邏輯的試探,按照朋友的改發將 Scoped 改成 Singleton 來規避。

本文轉載自微信公眾號「一線碼農聊技術」,可以通過以下二維碼關注。轉載本文請聯系一線碼農聊技術公眾號。

 

責任編輯:武曉燕 來源: 一線碼農聊技術
相關推薦

2019-03-08 10:08:41

網絡程序猿代碼

2018-01-26 23:23:23

JDBC MySQL數據庫

2021-01-27 18:13:35

日志nginx信息

2017-12-26 15:41:26

2022-07-05 13:56:21

模式Spring注入

2018-05-02 09:38:02

程序員代碼互聯網

2022-03-21 08:55:53

RocketMQ客戶端過濾機制

2012-12-28 13:47:36

Raspberry PGeek

2017-02-09 17:00:00

iOSSwiftKVC

2022-01-05 17:13:28

監控HTTPS網站

2020-08-14 08:19:25

Shell命令行數據

2021-11-29 05:37:24

Windows Def操作系統微軟

2009-04-28 07:48:29

蓋茨打工基金會

2018-10-22 15:29:50

2020-12-31 06:12:38

Siri Windows電腦

2022-11-02 07:46:31

GoFrameGcache緩存

2023-09-07 06:48:38

Intel顯卡AMD

2023-05-26 07:25:46

微服務架構Dubbo

2021-02-21 17:14:27

程序員技能開發者

2023-09-08 06:39:33

NVIDIA顯卡行業
點贊
收藏

51CTO技術棧公眾號

久久国产视频播放| 免费看91视频| 黄色的网站在线观看| 国产成人精品免费在线| 4p变态网欧美系列| 国产又黄又粗又猛又爽的| 日韩精品一区二区三区中文在线| 午夜精品123| 一本一本久久a久久精品综合妖精| 午夜免费福利视频| 日韩专区中文字幕一区二区| 欧美人交a欧美精品| 中文字幕一二三四区| 欧洲精品99毛片免费高清观看| 欧美日韩国产麻豆| 中文字幕在线乱| 九色视频在线观看免费播放| 国产精品一区二区免费不卡| 国产成人免费av电影| 国产在线观看免费av| 91久久高清国语自产拍| 亚洲欧美国产视频| 国产精品入口麻豆| 久久久久久亚洲精品美女| 在线中文字幕不卡| 97国产精东麻豆人妻电影| 51xtv成人影院| 亚洲国产精品成人综合| 欧美激情一区二区三区在线视频| 国产99久久九九精品无码免费| 视频一区二区三区中文字幕| 91精品国产91久久久久久最新| 麻豆一区产品精品蜜桃的特点| 日韩在线不卡| 在线午夜精品自拍| 中文字幕伦理片| 亚洲伊人春色| 精品在线观看国产| 中文字幕在线播放视频| 国产伦精品一区二区三区免费优势| 日韩一区国产二区欧美三区| www.成年人| 日韩毛片免费看| 欧美日韩免费一区二区三区| av视屏在线播放| 1区2区3区在线| 亚洲成人黄色影院| 大陆av在线播放| 国产精品186在线观看在线播放| 亚洲天堂网中文字| 国产免费色视频| 国产在线观看91| 亚洲美女精品一区| 免费看日本黄色| 成人三级小说| 红桃视频成人在线观看| a√天堂在线观看| 一区二区乱码| 色偷偷久久一区二区三区| 欧美激情精品久久久久久小说| 欧美成人精品三级网站| 在线视频欧美精品| 亚洲精品久久久中文字幕| 色综合久久久| 日韩欧美国产综合在线一区二区三区| 亚洲 自拍 另类 欧美 丝袜| 超碰在线亚洲| 日韩精品视频在线播放| japanese中文字幕| 欧美第一精品| 色综合导航网站| 国产一级理论片| 裸体素人女欧美日韩| 国产精品露脸av在线| 一区二区久久精品66国产精品 | 欧美综合激情网| aaa在线视频| 久久99精品网久久| 不卡视频一区二区三区| 亚洲av成人无码久久精品老人 | 亚洲一区第一页| 五月激情四射婷婷| 亚洲欧美综合| 青草成人免费视频| 国产绿帽刺激高潮对白| 成人短视频下载| 婷婷久久伊人| 日本电影在线观看| 一本一本大道香蕉久在线精品| 自拍偷拍21p| 亚洲一区电影| 一区二区在线视频播放| 青青草偷拍视频| 香蕉视频成人在线观看| 91精品中文在线| 四虎影视在线观看2413| ...av二区三区久久精品| 青青艹视频在线| av在线国产精品| 亚洲欧美成人一区二区在线电影| 登山的目的在线| 国产精品日本| 69174成人网| 国产精品影院在线| 亚洲福利视频三区| 色噜噜狠狠永久免费| 里番精品3d一二三区| 久久国内精品一国内精品| 日韩男人的天堂| 国内精品自线一区二区三区视频| 欧美精品一区三区在线观看| 综合久久2o19| 欧美中文字幕一区| 在线观看国产网站| 午夜久久福利| 国产日韩亚洲欧美| 美丽的姑娘在线观看免费动漫| 亚洲少妇中出一区| 午夜免费一区二区| 奇米影视777在线欧美电影观看 | 色资源二区在线视频| 欧美电影影音先锋| 久久精品三级视频| 香蕉国产精品偷在线观看不卡| 动漫精品视频| 老司机在线视频二区| 在线观看视频91| 黄色性生活一级片| 一本色道久久精品| av免费精品一区二区三区| 免费网站成人| 欧美日韩小视频| 国产毛片欧美毛片久久久| 亚洲综合精品| 精品一区二区三区自拍图片区| 亚洲按摩av| 欧美一级欧美三级在线观看| 国精产品一区一区| 免费一级欧美片在线观看| 精品国产乱码久久久久久108| 欧美6一10sex性hd| 精品日韩99亚洲| 久久久久久久久久网站| 国产精品综合二区| 欧美 亚洲 视频| 成人看片爽爽爽| 午夜精品视频在线| 亚洲欧美自偷自拍| 日韩欧美成人精品| av中文字幕免费观看| 午夜亚洲视频| 品久久久久久久久久96高清| 免费观看成人性生生活片| 亚洲人成电影网| 婷婷激情五月综合| 国产精品区一区二区三| 在线能看的av网站| 伊人青青综合网| 岛国一区二区三区高清视频| 久久男人天堂| 一区二区欧美亚洲| 91精东传媒理伦片在线观看| 亚洲精品视频在线看| 人妻精品久久久久中文字幕69| 欧美日韩国产高清| 精品乱码一区| 一区在线影院| 久久在线免费视频| 亚洲欧美另类视频| 狠狠色狠色综合曰曰| 永久免费av无码网站性色av| 韩国午夜理伦三级不卡影院| 免费在线黄网站| 精品一区在线| 成人性生交大片免费看视频直播| 七七成人影院| 亚洲最新视频在线| a天堂视频在线| 午夜久久久久久电影| 极品久久久久久久| 国产成人免费视| 男女av免费观看| 香蕉国产精品| 久久久久久国产精品mv| 日日夜夜精品| 国产69精品99久久久久久宅男| 免费黄色在线视频网站| 91麻豆精品国产91久久久更新时间 | 亚洲三级免费观看| 欧美 变态 另类 人妖| 六月婷婷色综合| 霍思燕三级露全乳照| 日韩精品不卡一区二区| 国产精品乱码视频| 久久亚洲精品中文字幕| 国内揄拍国内精品少妇国语| 在线播放毛片| 日韩精品视频观看| 精品人妻无码一区二区色欲产成人| 欧美日韩中文在线观看| 91高清免费观看| 久久精品一级爱片| 亚洲一二三四五| 久久99国产精品免费网站| 免费无遮挡无码永久视频| 天天揉久久久久亚洲精品| 欧美国产一区二区在线| 日韩精品三级| 国产一区二区色| 成人美女黄网站| 欧美激情欧美激情| 免费黄色在线| 怡红院精品视频| 香蕉久久国产av一区二区| 欧美一级免费大片| 亚洲一区在线观| 日韩欧美亚洲综合| 日韩网红少妇无码视频香港| 一区二区三区四区乱视频| 手机免费观看av| 久久欧美一区二区| 你懂得在线视频| 丁香婷婷综合网| 九九九九九国产| 欧美aⅴ一区二区三区视频| 久久久免费视频网站| 伊人久久久大香线蕉综合直播| 99re8这里只有精品| 欧美3p在线观看| 亚洲国产激情一区二区三区| 精品久久久久久久久久久aⅴ| 精品欧美国产一区二区三区不卡| 成年永久一区二区三区免费视频| 国产精品看片资源| 91在线成人| 国产精品自产拍在线观| av激情成人网| 国产精品福利小视频| 亚洲成人不卡| 国产精品第七影院| 精品欧美日韩精品| 国产精品高清在线观看| 日本美女久久| 国产美女直播视频一区| 素人一区二区三区| 国产欧美中文字幕| 国产 日韩 欧美| 91在线观看免费网站| 日韩第一区第二区| 国产伦精品一区二区三区视频孕妇 | 国产福利电影一区二区三区| 中文字幕在线视频一区二区| 国产激情精品久久久第一区二区| 亚洲成人av免费观看| 国产成人午夜视频| 国产又黄又粗又猛又爽的视频| 99re成人在线| 免费一级做a爰片久久毛片潮| 一区二区视频观看| 国产成人在线视频网址| 欧美一级片在线免费观看| 粉嫩在线一区二区三区视频| 中文字幕在线视频播放| 久久久久久久久久看片| 懂色av蜜桃av| 亚洲精品你懂的| 欧美精品久久久久性色| 亚洲va韩国va欧美va| 国产九色在线播放九色| 欧美在线免费播放| 国产又爽又黄免费软件| 亚洲第一黄色网| 精品电影在线| 久久影院中文字幕| 92久久精品| 国产精品热视频| 一区二区三区在线资源| 鲁鲁狠狠狠7777一区二区| 日韩电影在线视频| 香港三级日本三级a视频| 久久不射网站| 三区视频在线观看| av动漫一区二区| 人与嘼交av免费| 亚洲一区二区五区| 在线免费观看av网址| 91精品久久久久久久99蜜桃 | 麻豆一区二区三区在线观看| 影音先锋久久久| 孩娇小videos精品| 成人高清免费观看| 日韩在线一卡二卡| 疯狂做受xxxx欧美肥白少妇| 亚洲综合精品视频| 亚洲激情在线观看视频免费| 日本精品在线| 欧洲s码亚洲m码精品一区| 韩国三级大全久久网站| 欧美一区视久久| 国产中文一区| 99re6在线观看| 久久综合色天天久久综合图片| 青花影视在线观看免费高清| 狠狠躁18三区二区一区| 精品国产av 无码一区二区三区| 亚洲另类xxxx| 98色花堂精品视频在线观看| 成人av色在线观看| 美女毛片一区二区三区四区| 欧美亚洲色图视频| 国产一区二区在线观看视频| 国产亚洲色婷婷久久99精品91| 日韩码欧中文字| 中文字幕一区二区人妻视频| 亚洲国产另类久久精品| av免费在线免费| 国产精品一区二区三区在线播放| 亚洲视频分类| 青青草国产精品视频| 国产精品资源站在线| 久久成人小视频| 欧美色综合网站| 国产毛片av在线| 日本高清+成人网在线观看| 国内精品免费| 国产精品久久..4399| 国产91富婆露脸刺激对白 | 亚洲成a人片在线观看中文| 国产三级按摩推拿按摩| 在线观看亚洲视频| 澳门av一区二区三区| 欧美黑人3p| 爽好多水快深点欧美视频| xxxx黄色片| 欧美日韩性生活视频| 天天干视频在线观看| 久久久免费精品| 国产精品色呦| 精品少妇在线视频| 91视频精品在这里| 国产精品一区二区三区四| 亚洲成人久久久| 成人在线免费观看黄色| 超碰97在线资源| 亚洲视屏一区| 欧产日产国产精品98| 亚洲h精品动漫在线观看| 熟妇高潮一区二区高潮| 欧美亚洲视频一区二区| 校花撩起jk露出白色内裤国产精品 | av电影在线不卡| 欧美午夜精品一区二区蜜桃| 91精品专区| 91中文字幕在线| 欧美日韩在线大尺度| 久久免费精品国产| 婷婷开心久久网| 蜜桃视频在线播放| 国产免费一区二区三区香蕉精| 久久久久国产精品| 善良的小姨在线| 亚洲国产精品久久一线不卡| 亚州精品国产精品乱码不99按摩| 日本免费一区二区三区视频观看| 国产永久精品大片wwwapp| 亚洲美女性囗交| 亚洲一区二区三区自拍| 无码精品在线观看| 国产精品久久久久91| 久久精品亚洲人成影院| 国产乱国产乱老熟300部视频| 欧美日韩免费一区| 福利成人在线观看| 91探花福利精品国产自产在线| 亚洲视频一区| 一级在线观看视频| 日韩情涩欧美日韩视频| 亚洲小少妇裸体bbw| 伊人色综合影院| 成人手机电影网| 无码人妻精品一区二区三区蜜桃91 | 精品视频免费看| 欧美xxxx黑人又粗又长| 欧美亚洲一级二级| 国产高清无密码一区二区三区| 亚洲 欧美 成人| 久久国产天堂福利天堂| 亚洲理论电影| 欧美精品色视频| 日韩欧美国产网站| 在线观看中文字幕的网站| 欧美动漫一区二区| 国产精品伊人色| 波多野结衣二区三区| 欧美韩日一区二区| 99久久www免费| av女人的天堂| 亚洲精品一区二区三区精华液| 99只有精品| 黄色影院一级片|