国产精品毛片久久久久久久 I 欧美操穴 I 欧美成人一级 I 黄网址在线观看 I 美女激情网站 I 久久网av I 超污网站在线观看 I 曰本无码人妻丰满熟妇啪啪 I 国产欧美大片 I 天天草夜夜操 I 干美女少妇 I 日韩美女激情 I 亚洲女同在线 I 老司机激情影院 I 精品国产亚洲一区二区麻豆 I 亚洲天堂五码 I 亚洲产国偷v产偷v自拍涩爱 I 欧洲午夜精品 I 乱人伦精品 I 国产精品欧美一级免费 I 91精品论坛 I 日本视频专区 I 久久理论电影网 I 精品国产亚洲第一区二区三区 I 久久av在线看 I 亚洲综合精品四区 I 久久久国产乱子伦精品 I 午夜人妻久久久久久久久

首頁 智能 > 正文

Docker 中的 .NET 異常了怎么抓 Dump|當前獨家

一:背景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 runtimeWORKDIR /appCOPY ./ ./# 1. 使用中科大鏡像源RUN sed -i "s/deb.debian.org/mirrors.ustc.edu.cn/g" /etc/apt/sources.listENV COMPlus_DbgMiniDumpType 4ENV COMPlus_DbgMiniDumpName /dumps/%p-%e-%h-%t.dmpENV COMPlus_DbgEnableMiniDump 1ENTRYPOINT ["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 aspnetappca34c9274d998096f8562cbef3a43a7cbd9aa5ff2923e0f3e702b159e0b2f447[root@localhost data]# docker ps -aCONTAINER ID   IMAGE       COMMAND                  CREATED          STATUS                       PORTS     NAMESca34c9274d99   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.
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 -lntotal 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 runtimeWORKDIR /appCOPY ./ ./# 1. 使用中科大鏡像源RUN sed -i "s/deb.debian.org/mirrors.ustc.edu.cn/g" /etc/apt/sources.list# 2. 安裝 gdb & procdumpRUN apt-get update && apt-get install -y gdbRUN dpkg -i procdump.debRUN echo "#!/bin/bash \n\procdump -m 30 -w dotnet /dumps & \n\dotnet \$1 \n\" > ./start.shRUN chmod +x ./start.shENTRYPOINT ["./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_sampleaspnetcore_sample[root@localhost data]# docker run -it --rm  -p 5001:5001 --privileged -v /data2:/dumps --name aspnetcore_sample aspnetappProcDump v1.5 - Sysinternals process dump utilityCopyright (C) 2023 Microsoft Corporation. All rights reserved. Licensed under the MIT license.Mark Russinovich, Mario Hewardt, John Salem, Javid HabibiSysinternals - www.sysinternals.comMonitors one or more processes and writes a core dump file when the processes exceeds thespecified 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:                           dotnetCPU Threshold:                          n/aCommit Threshold:                       >=30 MBThread Threshold:                       n/aFile Descriptor Threshold:              n/aSignal:                                 n/aException monitor                       OffPolling Interval (ms):                  1000Threshold (s):                          10Number of Dumps:                        1Output directory:                       /dumps[02:57:34 - INFO]: Starting monitor for process dotnet (9)info: Microsoft.Hosting.Lifetime[14]      Now listening on: http://[::]:5001info: Microsoft.Hosting.Lifetime[0]      Application started. Press Ctrl+C to shut down.info: Microsoft.Hosting.Lifetime[0]      Hosting environment: Productioninfo: 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 -lhtotal 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 runtimeWORKDIR /appCOPY ./ ./# 1. 使用中科大鏡像源RUN sed -i "s/deb.debian.org/mirrors.ustc.edu.cn/g" /etc/apt/sources.list# 2. 安裝 wgetRUN apt-get update && apt-get install -y gdbRUN dpkg -i procdump.debRUN echo "#!/bin/bash \n\procdump -c 20 -n 2 -s 5 -w dotnet /dumps & \n\dotnet \$1 \n\" > ./start.shRUN chmod +x ./start.shENTRYPOINT ["./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 aspnetappProcDump v1.5 - Sysinternals process dump utilityCopyright (C) 2023 Microsoft Corporation. All rights reserved. Licensed under the MIT license.Mark Russinovich, Mario Hewardt, John Salem, Javid HabibiSysinternals - www.sysinternals.comMonitors one or more processes and writes a core dump file when the processes exceeds thespecified 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:                           dotnetCPU Threshold:                          >= 20%Commit Threshold:                       n/aThread Threshold:                       n/aFile Descriptor Threshold:              n/aSignal:                                 n/aException monitor                       OffPolling Interval (ms):                  1000Threshold (s):                          5Number of Dumps:                        2Output directory:                       /dumps[03:35:56 - INFO]: Starting monitor for process dotnet (8)info: Microsoft.Hosting.Lifetime[14]      Now listening on: http://[::]:5001info: Microsoft.Hosting.Lifetime[0]      Application started. Press Ctrl+C to shut down.info: Microsoft.Hosting.Lifetime[0]      Hosting environment: Productioninfo: Microsoft.Hosting.Lifetime[0]      Content root path: /app/

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

三:總結

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

關鍵詞:

最近更新

關于本站 管理團隊 版權申明 網站地圖 聯系合作 招聘信息

Copyright © 2005-2023 創投網 - m.zhigu.net.cn All rights reserved
聯系我們:39 60 29 14 2@qq.com
皖ICP備2022009963號-3

主站蜘蛛池模板: 日韩精品无码视频一区二区蜜桃 | 久久久久国产精品人妻aⅴ院 | 黄色一级片在线看 | 亚洲涩网 | 男生操女生逼网站 | 在线亚洲中文精品第1页 | 国产免费丝袜调教视频免费的 | 人成在线免费视频 | 欧美另类交人妖 | 久久精品在线观看 | 国产黑色丝袜视频在线观看网红 | 波多野结衣喷水最猛几部 | 欧美在线专区 | 欧美日本激情 | 国产亚洲日韩在线a不卡 | 久久艹网站| 久久精品成人一区二区三区蜜臀 | 性色av无码免费一区二区三区 | 国产欧美小视频 | 天堂在/线中文在线资源 官网 | 国产a大片免费 | 曰欧一片内射vα在线影院 午夜影院激情av | 国产l精品国产亚洲区在线观看 | 国产成人一区二区三区在线观看 | 日韩不卡 | 国产精品久久精品三级 | 无码熟妇人妻av在线影片 | 精品国产三级在线观看 | 久久婷婷五月综合色一区二区 | 日韩欧美一区二区在线观看视频 | 成人av在线播放网站 | 国产又粗又猛的视频 | 国产欧美激情日韩成人三区 | 永久免费的啪啪网站免费观看 | 校园 春色 欧美 另类 小说 | 四虎影视久久久免费观看 | 男人的机机桶女人的机机 | 成人在线免费播放 | 97成人免费 | 国产又色又爽又黄刺激在线视频 | www.98av| 大ji巴好深好爽又大又粗视频 | 国产女主播一区二区三区 | a√天堂在线 | 老司机久久99久久精品播放免费 | 99有精品 | 国产精品兄妹在线观看麻豆 | 成人亚洲a片v一区二区三区蜜臀 | 激情六月综合 | 国产aa大片 | 日本熟妇毛耸耸xxxxxx | 台湾黄三级高清在线观看播放 | 伊人成色综合人夜夜久久 | 体内谢xxxxx视少妇频 | 午夜精品一区二区国产 | 亚洲综合中文字幕无线码 | 九九热精品视频在线观看 | 91大神精品| 美妇颤抖双乳呻吟求欢视频 | 主站蜘蛛池模板: 蛛词}| 国产精品久久久久久亚洲影视公司 | 日韩青青草 | 丝袜 亚洲 另类 欧美 变态 | 国产中文字二暮区 | www成人在线 | 欧美精品 日韩 | 国产十八禁啪啦拍无遮拦视频 | 天堂av2024 | 日韩欧美视频免费观看 | 亚洲女欲精品久久久久久久18 | 伊人久久大香线蕉综合av | 无遮挡无码h纯肉动漫在线观看 | 高清孕妇性孕交hd xx | 美女脱免费看网站女同 | 黄瓜影院污 | 又大又硬又黄又刺激的免费视频 | 广东少妇大战黑人34厘米视频 | 制服肉丝袜亚洲中文字幕 | 日韩欧美在线免费 | 在线观看特色大片免费视频 | 天天躁日日躁很很很躁 | 伊在人亚洲香蕉精品区麻豆 | 国模私拍一区二区三区 | 人妻被按摩师玩弄到潮喷 | 久热精品视频在线观看 | 国产精品hdvideosex4k | 亚洲一区二区无码偷拍 | 欧美高清69hd | 成人午夜精品视频 | 网友自拍露脸国语对白 | 日日摸夜夜添夜夜无码区 | 国产原创av在线 | 国产乱码1卡二卡3卡四卡5 | 亚洲色无码播放亚洲成av | 日韩人妻无码一本二本三本 | 少妇吹潮| 在线无码视频观看草草视频 | 欧洲成人在线 | 久久99精品久久久久久牛牛影视 | 亚洲一线二线三线久久久 | 中日躁夜夜躁 | 人妻熟女一区二区aⅴ | 大肉大捧一进一出好爽动态图 | 久章草视频| 深夜做爰性大片108式 | 在线观看国产丝袜控网站 | 漂亮人妻洗澡被公强 日日躁 | 五月天婷婷社区 | 女人被狂躁c到高潮喷水一区二区 | 国内精品久久久久久久日韩 | 亚洲天堂v | 欧美小视频在线观看 | 草草网站影院白丝内射 | 亚洲97视频 | 国产成人无码免费视频79 | 免费av播放| 日本又紧又色又嫩又爽的视频 | 亚洲福利影视 | 国产色网址 | 主站蜘蛛池模板: 蛛词}| 亚洲卡一卡二新区入口将开 | 日韩激情无码不卡码 | 亚洲欧美成人片在线观看 | 日日躁夜夜躁白天躁晚上躁91 | 日本丰满妇人成熟免费中文字幕 | 福利视频自拍 | 日本无遮羞打屁股网站视频 | 久久女同互慰一区二区三区 | 无码人妻在线一区二区三区免费 | 久久久久北条麻妃免费看 | 国产高颜值大学生情侣酒店 | 毛片大全真人在线 | 毛片91 | 激情影院内射美女 | 亚洲成a∧人片在线播放黑人 | 熟女少妇精品一区二区 | 国产无套喷白浆在线播放 | 美女免费毛片 | 欧美激情视频网 | 国产无遮挡又爽又刺激的视频老师 | 日本一二三区在线视频 | 日本一道在线 | 国产做爰全过程免费视频 | 国产成人无码手机在线观看 | 国产边摸边吃奶叫床视频 | 巨熟乳波霸若妻在线播放 | 五月天婷婷亚洲 | 亚洲综合另类小说色区一 | 91精品无人区麻豆乱码1区2区介绍 | 精品国精品自拍自在线 | 性xxxx视频播放免费 | 日本高潮69ⅹxxx视频 | 欧美在线aa| 成人一级毛片 | 国产美女www | 亚洲欧洲视频在线观看 | 色婷婷激情一区二区三区 | 超碰97人人模人人爽人人喊 | 亚洲熟妇少妇任你躁在线观看 | 亚洲精品一区二三区 | www.婷婷.com | 美女裸体色黄污视频网站 | 欧美精品久久久久久久免费软件 | 97热视频 | 99热亚洲色精品国产88 | 精品国产91洋老外米糕 | 色射色| 成人禁片又硬又粗太爽了 | 国产重口老太和小伙乱 | 少妇做爰α片免费视频网站 | 欧美色图第二页 | 成人免费看黄 | 国产麻传媒精品国产av | 亚洲免费观看视频 | 激情五月av久久久久久久 | 一区二区视频网 | 理论片毛片 | 又湿又黄裸乳漫画无遮挡网站 | 福利姬液液酱喷水 | 主站蜘蛛池模板: 蛛词}| 久草热8精品视频在线观看 免费无码黄动漫在线观看 国产精品xxx在线观看www | 午夜福利理论片高清在线观看 | 久久精品国产久精国产爱 | 免费看一级 | 亚洲香蕉久久 | 阳茎伸入女人阳道视频 | 亚洲一区免费看 | 在线播放免费人成毛片试看 | 六月丁香婷婷网 | 九九在线中文字幕无码 | 激情文学在线 | 巴西性猛交xxxx免费看久久久 | 九九热只有精品 | 极品白嫩高潮呻吟喷水av | 欧美一级黄色视屏 | 亚洲成av人片久久 | 日本欧美久久久 | 日韩内射美女人妻一区二区三区 | 交做爰xxxⅹ性爽 | 日日躁狠狠躁夜夜躁av中文字幕 | 精品欧美激情精品一区 | 国产成人精品日本亚洲18 | 亚洲一区二区三区高清av | 这里只有精品网 | 狠狠色伊人亚洲综合网站色 | 免费看黄色毛片 | 97精品人人妻人人 | 久久精品国产亚洲a片高清不卡 | 免费一级淫片红桃视频 | 亚洲女人的天堂 | 精品国产一区二区三区久久久狼 | 国产盗摄av | 国产精品揄拍一区二区 | 久草观看| 天天影院色 | 日日摸夜夜夜夜夜添 | 久久久精品99 | 成人无码av一区二区 | 国产精品色一区二区三区 | 盗摄精品av一区二区三区 | 被窝影院午夜无码国产 | 日韩精品一区在线 | 777精品视频 | 香蕉视频网站 | 九九热思思 | 青青青国产在线视频 | 国产又粗又硬又大爽黄老大爷视频 | 精品国产小视频在线观看 | 四虎影院色 | 在线亚洲综合 | 无人区国产成人久久三区 | 国产偷久久一级精品60部 | 色屁屁草草影院ccyycom | 偷窥国产亚洲免费视频 | 国产又粗又硬又猛的毛片视频 | 亚洲图片视频在线观看 | 日韩午夜一区 | 成人无码www免费视频 | 亚洲人成色77777在线观看大战 | 主站蜘蛛池模板: 蛛词}| 欧美成人a天堂片在线观看 成人免费视频国产 | 99激情| 免费国产a| 狠狠躁夜夜躁人人爽天天bl | 中国凸偷窥xxxx自由视频 | 国产片一区二区三区 | 含羞草传媒mv免费观看视频 | 欧美激情综合五月色丁香 | 午夜影院免费在线观看 | 久久97超碰色中文字幕 | 亚洲国产欧美日韩精品一区二区三区 | 国产91av在线 | 午夜黄色福利 | 国产又粗又猛又爽视频上高潮 | 亚洲日韩成人无码不卡网站 | 免费人成在线观看网站播放 | 神马久久网 | 国产第三页 | 日a在线 | 国产精品精东影业 | 青青草免费在线观看视频 | 久久精品免视看国产成人 | 国产超碰av人人做人人爽 | 日产中文字暮在线理论 | 欧美精品一区二区视频在线观看 | 日韩成人无码片av网站 | 婷婷夜色潮精品综合在线 | 那里有黄色网址 | 亚洲精品第一国产综合境外资源 | 九九九九九九精品 | 特黄特黄的视频 | 一个人看的www日本高清视频 | 精品少妇v888av| 丁香色欲久久久久久综合网 | 欧美日韩在线视频一区二区 | 久久99精品久久久久久无毒不卡8 | 伊人丁香 | 亚洲天堂免费视频 | 日本一二区视频 | 高清自拍亚洲精品二区 | 色婷婷丁香| 亚洲精品第一国产综合精品 | 国产公开免费人成视频 | 亚洲国产一区二区三区四区电影网 | 日韩性插 | 影音先锋中文字幕在线视频 | 豆花视频18 成人入口 | 成人免费午夜无码视频在线播放 | 无码精品人妻一区二区三区中 | 成人一级视频在线观看 | 欧美熟妇xxxxx欧美老妇不卡 | 国产精品一区二区 尿失禁 国产精品内射视频免费 | 久久网中文字幕日韩精品专区四季 | 能直接看的av | 免费在线观看网址 | 国产区福利 | 精精国产xxxx视频在线野外 | 欧美日韩精品久久免费 | 性做爰高清视频在线观看视频 |