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

Docker 中的 .NET 異常了怎么抓 Dump

開發 前端
雖然Docker中的 .NET 程序占比較少,但把經驗總結出來還是很值得的,以后有人問怎么抓,可以把這篇文章直接丟過去啦!

一:背景

1. 講故事

有很多朋友跟我說,在 Windows 上看過你文章知道了怎么抓 Crash, CPU爆高,內存暴漲 等各種Dump,為什么你沒有寫在 Docker 中如何抓的相關文章呢?瞧不上嗎?

哈哈,在DUMP的分析旅程中,跑在 Docker 中的 .NET 占比真的不多,大概10個dump有 1-2 個是 docker 中的,市場決定了我的研究方向,為了彌補這一塊的空洞,決定寫一篇文章來分享下這三大異常下的捕獲吧。

二:Docker 下的三大異常捕獲

1. crash dump 捕獲

前不久我寫了一篇 Linux 上的 .NET 崩潰了怎么抓 Dump (https://www.cnblogs.com/huangxincheng/p/17440153.html) 的文章,使用了微軟推薦的環境變量方式,其實這在 Docker 中是一樣適用的。

為了讓 webapi 崩潰退出,我故意造一個棧溢出異常,參考代碼如下:

public class Program
    {
        public static void Main(string[] args)
        {
            var builder = WebApplication.CreateBuilder(args);
            builder.Services.AddAuthorization();
            var app = builder.Build();
            app.UseAuthorization();

            //1. crash
            Task.Factory.StartNew(() =>
            {
                Test("a");
            });

            app.Run();
        }

        public static string Test(string a)
        {
            return Test("a" + a.Length);
        }
    }

有了代碼之后,接下來寫一個 Dockerfile,主要就是把三個環境變量塞進去。

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS runtime
WORKDIR /app
COPY ./ ./

# 1. 使用中科大鏡像源
RUN sed -i 's/deb.debian.org/mirrors.ustc.edu.cn/g' /etc/apt/sources.list

ENV COMPlus_DbgMiniDumpType 4
ENV COMPlus_DbgMiniDumpName /dumps/%p-%e-%h-%t.dmp
ENV COMPlus_DbgEnableMiniDump 1

ENTRYPOINT ["dotnet", "AspNetWebApi.dll"]

這里有一個細節,為了能夠讓 Docker 中的 webapi 能夠訪問到,將 localhost 設置為 * ,修改 appsettings.json 如下:

{
  "urls": "http://*:5001",
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft.AspNetCore": "Warning"
    }
  },
  "AllowedHosts": "*"
}

有了這些基礎最后就是 docker build & docker run 啦。

[root@localhost data]# docker build -t aspnetapp .
[+] Building 0.3s (9/9) FINISHED                                                                         
 => [internal] load build definition from Dockerfile                                                0.0s
 => => transferring dockerfile: 447B                                                                0.0s
 => [internal] load .dockerignore                                                                   0.0s
 => => transferring context: 2B                                                                     0.0s
 => [internal] load metadata for mcr.microsoft.com/dotnet/aspnet:6.0                                0.3s
 => [1/4] FROM mcr.microsoft.com/dotnet/aspnet:6.0@sha256:a2a04325fdb2a871e964c89318921f82f6435b54  0.0s
 => [internal] load build context                                                                   0.0s
 => => transferring context: 860B                                                                   0.0s
 => CACHED [2/4] WORKDIR /app                                                                       0.0s
 => CACHED [3/4] COPY ./ ./                                                                         0.0s
 => CACHED [4/4] RUN sed -i 's/deb.debian.org/mirrors.ustc.edu.cn/g' /etc/apt/sources.list          0.0s
 => exporting to image                                                                              0.0s
 => => exporting layers                                                                             0.0s
 => => writing image sha256:be69203995c0e5423b2af913549e618d7ee8306fff3961118ff403b1359ae571        0.0s
 => => naming to docker.io/library/aspnetapp                                                        0.0s

[root@localhost data]# docker run -itd  -p 5001:5001 --privileged -v /data2:/dumps --name aspnetcore_sample aspnetapp
ca34c9274d998096f8562cbef3a43a7cbd9aa5ff2923e0f3e702b159e0b2f447

[root@localhost data]# docker ps -a
CONTAINER ID   IMAGE       COMMAND                  CREATED          STATUS                       PORTS     NAMES
ca34c9274d99   aspnetapp   "dotnet AspNetWebApi…"   20 seconds ago   Exited (139) 9 seconds ago             aspnetcore_sample

[root@localhost data]# docker logs ca34c9274d99
   ...
   at AspNetWebApi.Program.Test(System.String)
   at AspNetWebApi.Program.Test(System.String)
   at AspNetWebApi.Program.Test(System.String)
   at AspNetWebApi.Program.Test(System.String)
   at AspNetWebApi.Program+<>c.<Main>b__0_0()
   at System.Threading.Tasks.Task.InnerInvoke()
   at System.Threading.Tasks.Task+<>c.<.cctor>b__272_0(System.Object)
   at System.Threading.ExecutionContext.RunFromThreadPoolDispatchLoop(System.Threading.Thread, System.Threading.ExecutionContext, System.Threading.ContextCallback, System.Object)
   at System.Threading.Tasks.Task.ExecuteWithThreadLocal(System.Threading.Tasks.Task ByRef, System.Threading.Thread)
   at System.Threading.Tasks.Task.ExecuteEntryUnsafe(System.Threading.Thread)
   at System.Threading.ThreadPoolWorkQueue.Dispatch()
   at System.Threading.PortableThreadPool+WorkerThread.WorkerThreadStart()
   at System.Threading.Thread.StartCallback()

[createdump] Gathering state for process 1 dotnet
[createdump] Crashing thread 0017 signal 6 (0006)
[createdump] Writing full dump to file /dumps/1-dotnet-ca34c9274d99-1687746929.dmp
[createdump] Written 261320704 bytes (63799 pages) to core file
[createdump] Target process is alive
[createdump] Dump successfully written

[root@localhost data2]# cd /data2
[root@localhost data2]# ls -ln
total 255288
-rw-------. 1 0 0 261414912 Jun 26 10:35 1-dotnet-ca34c9274d99-1687746929.dmp

上面的腳本已經寫的非常清楚了,這里有幾個注意點提一下:

  • --privileged

一定要加上特殊權限,否則生成 dump 的時候會提示無權限。

  • -v /data2:/dumps

防止dump丟失,記得掛載到宿主機目錄 或者 共享容器 中。

2. 內存暴漲 dump 捕獲

要想對 docker 中的 .NET 程序內存 進行監控,我一直都是極力推薦 procdump,目前最新的是版本是 1.5, github官網地址:https://github.com/Sysinternals/ProcDump-for-Linux  鑒于現在訪問 github 太慢,大家可以把 procdump_1.5-16239_amd64.deb 下載到本地,為什么下載它,是因為容器中是 debain 系統。

圖片圖片

下載好了之后放到項目中,使用默認代碼骨架:

public class Program
    {
        public static void Main(string[] args)
        {
            var builder = WebApplication.CreateBuilder(args);
            builder.Services.AddAuthorization();
            var app = builder.Build();
            app.UseAuthorization();

            app.Run();
        }
    }

接下來就是寫 dockerfile 了,這里有一個細節,就是如何在 Docker 中開啟多進程,這里用 start.sh 腳本的方式開啟,參考代碼如下:

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS runtime
WORKDIR /app
COPY ./ ./

# 1. 使用中科大鏡像源
RUN sed -i 's/deb.debian.org/mirrors.ustc.edu.cn/g' /etc/apt/sources.list

# 2. 安裝 gdb & procdump
RUN apt-get update && apt-get install -y gdb
RUN dpkg -i procdump.deb

RUN echo "#!/bin/bash \n\
procdump -m 30 -w dotnet /dumps & \n\
dotnet \$1 \n\
" > ./start.sh

RUN chmod +x ./start.sh

ENTRYPOINT ["./start.sh", "AspNetWebApi.dll"]

有了這些設置后,接下來就是 publish 代碼用 docker 構建啦,為了方便演示,這里就用 前臺模式 開啟了哈。

[root@localhost data]# docker build -t aspnetapp .
[+] Building 11.5s (13/13) FINISHED              

[root@localhost data]# docker rm -f aspnetcore_sample
aspnetcore_sample
[root@localhost data]# docker run -it --rm  -p 5001:5001 --privileged -v /data2:/dumps --name aspnetcore_sample aspnetapp
ProcDump v1.5 - Sysinternals process dump utility
Copyright (C) 2023 Microsoft Corporation. All rights reserved. Licensed under the MIT license.
Mark Russinovich, Mario Hewardt, John Salem, Javid Habibi
Sysinternals - www.sysinternals.com

Monitors one or more processes and writes a core dump file when the processes exceeds the
specified criteria.

[02:57:34 - INFO]: Waiting for processes 'dotnet' to launch

[02:57:34 - INFO]: Press Ctrl-C to end monitoring without terminating the process(es).
Process Name:                           dotnet
CPU Threshold:                          n/a
Commit Threshold:                       >=30 MB
Thread Threshold:                       n/a
File Descriptor Threshold:              n/a
Signal:                                 n/a
Exception monitor                       Off
Polling Interval (ms):                  1000
Threshold (s):                          10
Number of Dumps:                        1
Output directory:                       /dumps
[02:57:34 - INFO]: Starting monitor for process dotnet (9)
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://[::]:5001
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
      Content root path: /app/
[02:57:35 - INFO]: Trigger: Commit usage:48MB on process ID: 9
[createdump] Gathering state for process 9 dotnet
[createdump] Writing full dump to file /dumps/dotnet_commit_2023-06-26_02:57:35.9
[createdump] Written 254459904 bytes (62124 pages) to core file
[createdump] Target process is alive
[createdump] Dump successfully written
[02:57:35 - INFO]: Core dump 0 generated: /dumps/dotnet_commit_2023-06-26_02:57:35.9
[02:57:36 - INFO]: Stopping monitors for process: dotnet (9)

[root@localhost data2]# ls -lh
total 243M
-rw-------. 1 root root 243M Jun 26 10:57 dotnet_commit_2023-06-26_02:57:35.9

從腳本信息看,當內存到了 48MB 的時候觸發的 dump 生成,也成功的進入了 /dumps 目錄中,太棒了。

3. cpu爆高 dump 捕獲

抓 cpu 爆高的dump最好的方式就是多抓幾個,比如說:當 CPU >20% 連續超過 5s 抓 2個dump,這種方式抓的dump很容易就能找到真兇,為了方便演示,讓兩個 cpu 直接打滿,參考代碼如下:

public static void Main(string[] args)
        {
            var builder = WebApplication.CreateBuilder(args);
            builder.Services.AddAuthorization();
            var app = builder.Build();
            app.UseAuthorization();

            //3. cpu
            app.MapGet("/cpu", (HttpContext httpContext) =>
            {
                Task.Factory.StartNew(() => { bool b = true; while (true) { b = !b; } });
                Task.Factory.StartNew(() => { bool b = true; while (true) { b = !b; } });

                return new WeatherForecast();
            });

            app.Run();
        }

接下來就是修改 dockerfile,因為我的虛擬機是 8 核心,如果兩個核心被打滿,那應該會占用大概 24% 的 cpu 利用率,所以腳本中就設置 20% 吧。

FROM mcr.microsoft.com/dotnet/aspnet:6.0 AS runtime
WORKDIR /app
COPY ./ ./

# 1. 使用中科大鏡像源
RUN sed -i 's/deb.debian.org/mirrors.ustc.edu.cn/g' /etc/apt/sources.list

# 2. 安裝 wget
RUN apt-get update && apt-get install -y gdb
RUN dpkg -i procdump.deb

RUN echo "#!/bin/bash \n\
procdump -c 20 -n 2 -s 5 -w dotnet /dumps & \n\
dotnet \$1 \n\
" > ./start.sh

RUN chmod +x ./start.sh

ENTRYPOINT ["./start.sh", "AspNetWebApi.dll"]

最后就是 docker 構建。

[root@localhost data]# docker build -t aspnetapp .
[+] Building 0.4s (13/13) FINISHED

[root@localhost data]# docker run -it --rm  -p 5001:5001 --privileged -v /data2:/dumps --name aspnetcore_sample aspnetapp

ProcDump v1.5 - Sysinternals process dump utility
Copyright (C) 2023 Microsoft Corporation. All rights reserved. Licensed under the MIT license.
Mark Russinovich, Mario Hewardt, John Salem, Javid Habibi
Sysinternals - www.sysinternals.com

Monitors one or more processes and writes a core dump file when the processes exceeds the
specified criteria.

[03:35:56 - INFO]: Waiting for processes 'dotnet' to launch

[03:35:56 - INFO]: Press Ctrl-C to end monitoring without terminating the process(es).
Process Name:                           dotnet
CPU Threshold:                          >= 20%
Commit Threshold:                       n/a
Thread Threshold:                       n/a
File Descriptor Threshold:              n/a
Signal:                                 n/a
Exception monitor                       Off
Polling Interval (ms):                  1000
Threshold (s):                          5
Number of Dumps:                        2
Output directory:                       /dumps
[03:35:56 - INFO]: Starting monitor for process dotnet (8)
info: Microsoft.Hosting.Lifetime[14]
      Now listening on: http://[::]:5001
info: Microsoft.Hosting.Lifetime[0]
      Application started. Press Ctrl+C to shut down.
info: Microsoft.Hosting.Lifetime[0]
      Hosting environment: Production
info: Microsoft.Hosting.Lifetime[0]
      Content root path: /app/

看輸出是正在監控,接下來我們訪問下網址:http://192.168.17.129:5001/cpu , 稍等片刻之后就會生成兩個dump 文件。

圖片圖片

三:總結

雖然Docker中的 .NET 程序占比較少,但把經驗總結出來還是很值得的,以后有人問怎么抓,可以把這篇文章直接丟過去啦!

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

2009-01-05 09:14:17

.NETcatch性能損失

2013-08-22 17:10:09

.Net異常處理

2014-08-01 10:18:16

.Netdump

2024-06-04 12:32:42

.NET開發內存泄漏

2010-09-06 08:43:13

.NET 4

2021-10-26 10:42:49

NET進程托管

2020-09-29 12:15:13

生死鎖MySQL

2010-01-05 09:26:13

.NET 4.0

2025-10-29 01:11:00

.NET系統windows

2023-08-28 10:54:09

容器Docker

2010-04-14 09:20:26

.NET多線程

2024-09-24 17:34:05

2009-12-22 15:51:18

ADO.NET代碼

2009-07-29 09:53:24

ASP.NET異常管理

2009-07-29 17:20:18

應用程序異常

2009-02-06 14:11:36

ASP.NET.NET全局異常處理

2010-01-06 16:45:42

.Net Framew

2021-06-06 13:07:06

.NETWindowsLinux

2021-06-05 23:41:47

NET異常 HttpClient

2025-08-06 03:22:00

點贊
收藏

51CTO技術棧公眾號

亚洲图片在线视频| 手机视频在线观看| 日韩欧美电影在线观看| 老司机午夜免费精品视频| 色午夜这里只有精品| 久久久精品视频国产| caoporn视频在线| 国产欧美日韩亚州综合 | 精品无人区卡一卡二卡三乱码免费卡| 久久艹在线视频| 亚洲精品中文字幕在线播放| 国产精品99久久久久久董美香 | 337p粉嫩大胆色噜噜噜噜亚洲| 国产精品www网站| 免费在线观看日韩| 成人羞羞视频播放网站| 亚洲高清一二三区| 日本高清久久久| 亚洲黄色免费av| 亚洲免费观看高清完整版在线观看熊| 久久精品第九区免费观看| 一区二区日韩在线观看| 国产一级一区二区| 伦理中文字幕亚洲| 色噜噜日韩精品欧美一区二区| 国产一区精品二区| 欧美性色aⅴ视频一区日韩精品| 黄网站色视频免费观看| av在线中文| 2020国产精品久久精品美国| 成人黄色片视频网站| 色婷婷久久综合中文久久蜜桃av| 亚洲日本成人| 欧美激情免费在线| 日本在线一级片| 久久综合成人| 伊人一区二区三区久久精品| 中文字幕一区二区三区人妻| 国产精品久久久久久久久久白浆| 91精品国产色综合久久不卡电影| 亚洲视频在线观看一区二区三区| 三妻四妾的电影电视剧在线观看| 亚洲一区二区三区在线| 欧美aaa在线观看| 91网页在线观看| 久久精品一级爱片| 蜜桃av久久久亚洲精品| 无码精品黑人一区二区三区 | √天堂8在线网| 国产精品美女久久久久久久网站| 欧美日韩在线观看一区二区三区| 午夜激情在线视频| www.色精品| 国产精品一区二区三区四区五区| www.日韩在线观看| 国产精品99精品久久免费| 91在线观看免费观看| 亚洲视屏在线观看| 看国产成人h片视频| 国产日韩欧美电影在线观看| 中文字幕自拍偷拍| 麻豆专区一区二区三区四区五区| 国产精品日韩电影| 在线观看日韩一区二区| 精品在线一区二区三区| 国产色婷婷国产综合在线理论片a| 国产精品第6页| 久久精品国产亚洲高清剧情介绍 | 中文字幕一区二区三| 亚洲一区二区高清视频| 九义人在线观看完整免费版电视剧| 国产精品久久久久桃色tv| 亚洲欧美精品在线观看| 国产在线高清视频| 亚洲国产人成综合网站| 国产h视频在线播放| 在线免费看h| 欧美专区日韩专区| 一区二区三区四区毛片| 亚洲va欧美va人人爽成人影院| 欧美tk丨vk视频| 日本黄色动态图| 久久99国产精品视频| 一道本无吗dⅴd在线播放一区| 999精品久久久| 欧美a级片网站| 91国内免费在线视频| 中文字幕在线观看视频免费| 久久99精品一区二区三区三区| 亚洲一区二区三区四区视频 | 成人豆花视频| 亚洲国产成人av在线| 老牛影视av老牛影视av| 久久亚洲成人| 久久久久久久久国产精品| 欧美国产成人精品一区二区三区| 美女视频黄免费的久久| 99r国产精品视频| 久久久久久久影视| 亚洲精品国产一区二区精华液| 大陆极品少妇内射aaaaaa| av影视在线看| 欧美日韩日日摸| a级一a一级在线观看| 日韩欧美午夜| 午夜精品99久久免费| 这里只有精品6| 不卡电影免费在线播放一区| 一区二区三区欧美在线| 毛片在线网站| 欧美一级午夜免费电影| 日韩人妻无码精品综合区| 中文字幕午夜精品一区二区三区 | 亚洲精品国产精品国自产网站按摩| 国产高清久久久久| 性欧美videosex高清少妇| 大香伊人久久| 91精品国产综合久久福利软件| 亚洲精品乱码久久久久久久久久久久| 亚洲午夜精品一区 二区 三区| 欧洲永久精品大片ww免费漫画| 国产色片在线观看| 日本一区二区三区在线观看| 热99这里只有精品| 精品久久久久久久久久岛国gif| 亚洲欧美一区二区三区四区 | av成人激情| 亚洲综合一区二区不卡| 91亚洲欧美| 在线观看一区日韩| 成年人网站免费在线观看| 欧美另类综合| 91精品啪aⅴ在线观看国产| 久青草国产在线| 欧美午夜丰满在线18影院| 丰满熟女人妻一区二区三区| 伊人青青综合网| 91精品久久久久久久久中文字幕| 国产三级电影在线| 一本久道中文字幕精品亚洲嫩| 国产精品九九视频| 在线观看一区| 国产精品一区二区在线观看| 色婷婷av在线| 日韩精品中文字幕一区二区三区 | 久久久久久久久久码影片| 九色91在线| 精品少妇一区二区三区| 免费在线观看黄视频| 国产成人精品一区二 | 久久福利精品| 欧美另类一区| 日韩免费福利视频| 国产亚洲精品久久久久久777| 欧美精品一二三四区| 91视频com| 国产av无码专区亚洲精品| 午夜精品福利影院| 清纯唯美日韩制服另类| 国产中文在线视频| 色婷婷综合中文久久一本| 88久久精品无码一区二区毛片| 久久精选视频| 亚洲精品乱码久久久久久蜜桃91| 国产精品4hu.www| 最近中文字幕2019免费| 国产精品国产精品国产专区| 最新久久zyz资源站| 超碰中文字幕在线观看| 欧美精品一卡| 久久久久久久久久久久久久久久av| 波多视频一区| 日韩在线视频导航| www.麻豆av| 欧美午夜久久久| 9.1片黄在线观看| 国产精品资源在线观看| 97视频久久久| 深爱激情综合| 91最新国产视频| 草美女在线观看| 亚洲色图校园春色| 国产一区二区三区三州| 亚洲愉拍自拍另类高清精品| 不卡一区二区在线观看| 免费在线欧美视频| 黄色特一级视频| 自拍偷拍欧美一区| 91久久国产精品91久久性色| 国产啊啊啊视频在线观看| 亚洲乱码国产乱码精品精| 一区二区国产欧美| 亚洲成人第一页| 中文字幕有码在线播放| 精品综合久久久久久8888| 国产成人永久免费视频| 精品欧美久久| 成人自拍偷拍| 精品久久在线| 88xx成人精品| 黄色在线免费| 日韩精品久久久久久久玫瑰园| 中文字幕在线观看1| 亚洲国产va精品久久久不卡综合| 中文字幕欧美激情极品| 成人精品小蝌蚪| 亚洲免费看av| 亚洲在线电影| 波多野结衣 作品| 成人一二三区| 蜜桃久久精品乱码一区二区| 视频精品二区| 国产在线拍揄自揄视频不卡99| 天堂√中文最新版在线| 美女福利精品视频| h网站在线免费观看| 日韩成人av在线播放| 99国产精品久久久久99打野战| 色综合久久88色综合天天免费| 黄色一级视频免费观看| 国产精品嫩草99a| www.久久国产| 不卡一区在线观看| 在线成人免费av| 久久国产综合精品| av丝袜天堂网| 男人的天堂成人在线| 国产肉体ⅹxxx137大胆| 色男人天堂综合再现| 日本精品一区二区三区视频| 女同一区二区三区| 成人免费视频观看视频| 国产精品毛片无码| 成人免费视频网| 国产精品伦一区二区| 国产成人av在线播放| xx欧美视频| 青青草99啪国产免费| 国产高清自产拍av在线| 欧美高清视频一区二区| a级网站在线播放| 久久亚洲精品毛片| 老司机免费在线视频| 日韩中文字幕免费| 免费黄色在线观看| 色偷偷噜噜噜亚洲男人的天堂| 91caoporn在线| 色999日韩欧美国产| 在线观看免费网站黄| 色噜噜久久综合伊人一本| 日本三级视频在线播放| 北条麻妃一区二区三区中文字幕| 91短视频版在线观看www免费| 日韩中文字幕在线视频| 毛片激情在线观看| 欧美xxxx做受欧美| 美洲精品一卡2卡三卡4卡四卡| 久久99视频免费| 岛国在线视频网站| 日韩女优人人人人射在线视频| 日韩成人亚洲| 成人免费视频a| 盗摄牛牛av影视一区二区| 加勒比在线一区二区三区观看| 首页亚洲中字| 亚洲v欧美v另类v综合v日韩v| 久久在线免费| a级黄色小视频| 久久精品女人| 91丨九色丨蝌蚪| 懂色av一区二区三区免费看| 亚洲欧美日本一区| 国产欧美精品一区二区色综合 | 亚洲欧洲日韩| 可以看毛片的网址| 丝袜亚洲另类丝袜在线| mm131国产精品| 丁香婷婷综合激情五月色| 日本免费福利视频| 国产精品国产三级国产aⅴ无密码| 欧美又粗又大又长| 懂色aⅴ精品一区二区三区蜜月| 国产污视频网站| 欧美精品v国产精品v日韩精品 | 夜夜精品视频一区二区| 特级做a爱片免费69| 欧美中文字幕不卡| a毛片在线免费观看| 日韩电影网在线| 97电影在线看视频| 欧美美女15p| 人人鲁人人莫人人爱精品| 国产伦精品一区二区三区精品视频| 国产精品蜜月aⅴ在线| 国产一区视频观看| 成人高清电影网站| 美女扒开大腿让男人桶| 午夜在线观看免费一区| 自拍偷拍一区二区三区四区| www.成人在线| 91狠狠综合久久久| 午夜欧美视频在线观看| 这里只有精品6| 亚洲精品国产电影| 日本视频在线播放| 欧美又大又粗又长| www一区二区三区| 久中文字幕一区| 国产精品麻豆久久| 久久久999视频| 国产成人精品三级| 国产熟妇久久777777| 亚洲乱码国产乱码精品精的特点| 成人av网站在线播放| 日韩欧美国产综合在线一区二区三区| 性猛交xxxx乱大交孕妇印度| 最近2019中文字幕大全第二页 | 久久久久久久久亚洲精品| www日韩欧美| 欧美特大特白屁股xxxx| 国产伦精品一区二区三区四区视频 | 91在线观看免费| 国产精品一区二区av日韩在线| 无码人妻精品一区二区蜜桃百度| 视频一区二区中文字幕| 亚洲蜜桃精久久久久久久久久久久| 国产精品九色蝌蚪自拍| 欧美 日韩 精品| 亚洲女人天堂色在线7777| 色www永久免费视频首页在线 | 欧美激情 国产精品| 国产精品羞羞答答xxdd| 免费一级suv好看的国产网站| 欧美日韩国产精品一区二区不卡中文| 亚洲爱情岛论坛永久| 日韩在线激情视频| 色偷偷色偷偷色偷偷在线视频| 99在线热播| 欧美 日韩 国产一区二区在线视频| 色噜噜狠狠一区二区| 国产午夜一区二区三区| 国产无遮挡又黄又爽| 亚洲高清色综合| 牛牛在线精品视频| 91影视免费在线观看| 久久精品一区二区不卡| 亚洲这里只有精品| 中文字幕日韩一区| 中文字幕一二区| 亚洲激情在线视频| 黄色软件视频在线观看| 国产99午夜精品一区二区三区| 欧美三区不卡| 无套白嫩进入乌克兰美女| 国产精品传媒视频| 国产免费黄色网址| 另类美女黄大片| 136福利精品导航| 岛国大片在线播放| 99久久久久久| 无码人妻熟妇av又粗又大| 亚洲欧美三级在线| 国外成人福利视频| 中文字幕日韩精品久久| 激情丁香综合五月| 精品深夜av无码一区二区老年| 精品国精品国产尤物美女| 免费看男女www网站入口在线| 久久精品国产理论片免费| 亚洲高清免费| 泷泽萝拉在线播放| 欧洲亚洲国产日韩| 国精产品一区| 国产乱子伦精品| 国产精品婷婷| 粉嫩av蜜桃av蜜臀av| 欧美在线小视频| 制服丝袜中文字幕在线| 国产在线精品一区二区三区| 日本成人中文字幕在线视频| 久久久久人妻一区精品色| 91麻豆精品国产自产在线观看一区| 久草在线资源站资源站| 久久亚洲国产精品日日av夜夜| 麻豆精品新av中文字幕| av成人免费网站| 欧美成人a在线| 欧美日韩五码| 国产又大又长又粗又黄| 91性感美女视频| 中文字幕日本人妻久久久免费| 日韩在线免费高清视频| 日韩欧美一级| 黄色片久久久久| 亚洲精品中文在线| 午夜18视频在线观看| 91精品视频在线看| 欧美涩涩视频| 老鸭窝一区二区| 日韩视频一区在线观看|