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

前端監(jiān)控之性能與異常

開(kāi)發(fā) 前端
通過(guò)簡(jiǎn)單的js代碼,即可實(shí)現(xiàn)對(duì)頁(yè)面性能與異常的監(jiān)控與數(shù)據(jù)上報(bào),后續(xù)還需要相應(yīng)具體的平臺(tái)匯總,及相應(yīng)的業(yè)務(wù)所需數(shù)據(jù)(如PV、UV等)的計(jì)算,才能真正實(shí)現(xiàn)對(duì)產(chǎn)品的頁(yè)面數(shù)據(jù)呈現(xiàn),用于業(yè)務(wù)擴(kuò)展及宣導(dǎo)。

作者:京東物流 李菲菲


1 前言

現(xiàn)有的大部分監(jiān)控方案都是針對(duì)服務(wù)端的,而針對(duì)前端的監(jiān)控很少,諸如線上頁(yè)面的白屏?xí)r間是多少、靜態(tài)資源的加載情況如何、接口請(qǐng)求耗時(shí)好久、什么時(shí)候掛掉了、為什么掛掉,這些都不清楚。

同時(shí),在產(chǎn)品推廣過(guò)程中,經(jīng)常需要統(tǒng)計(jì)頁(yè)面的使用情況及用戶行為,從而可以從運(yùn)營(yíng)和產(chǎn)品的角度去了解用戶群體,進(jìn)而迭代升級(jí)產(chǎn)品,使其更加貼近用戶,為業(yè)務(wù)的擴(kuò)展提供更多可能性。

因而,我們需要一個(gè)前端的頁(yè)面監(jiān)控系統(tǒng),持續(xù)監(jiān)控和預(yù)警頁(yè)面性能的狀況,并且在發(fā)現(xiàn)瓶頸時(shí)用于指導(dǎo)優(yōu)化工作。

2 前端監(jiān)控目標(biāo)

前端監(jiān)控主要包含兩大塊:性能監(jiān)控及異常監(jiān)控

  1. 保證穩(wěn)定性(異常監(jiān)控)
    錯(cuò)誤監(jiān)控包括 JavaScript 代碼錯(cuò)誤,Promsie 錯(cuò)誤,接口(XHR,fetch)錯(cuò)誤,資源加載錯(cuò)誤(script,link等)等,這些錯(cuò)誤大多會(huì)導(dǎo)致頁(yè)面功能異常甚至白屏。
  2. 提升用戶體驗(yàn)(性能監(jiān)控)
    性能監(jiān)控包括頁(yè)面的加載時(shí)間,接口響應(yīng)時(shí)間等,側(cè)面反應(yīng)了用戶體驗(yàn)的好壞。

3 性能監(jiān)控

3.1 簡(jiǎn)單描述頁(yè)面加載

簡(jiǎn)單看一下,從輸入url到頁(yè)面加載完成的過(guò)程如下:

首先需要通過(guò) DNS(域名解析系統(tǒng))將 URL 解析為對(duì)應(yīng)的 IP 地址,然后與這個(gè) IP 地址確定的那臺(tái)服務(wù)器建立起 TCP 網(wǎng)絡(luò)連接,隨后我們向服務(wù)端拋出 HTTP 請(qǐng)求,服務(wù)端處理完我們的請(qǐng)求之后,把目標(biāo)數(shù)據(jù)放在 HTTP 響應(yīng)里返回給客戶端,拿到響應(yīng)數(shù)據(jù)的瀏覽器就可以開(kāi)始走一個(gè)渲染的流程。渲染完畢,頁(yè)面便呈現(xiàn)給了用戶。

我們可以將這個(gè)過(guò)程分為如下的過(guò)程片段:

  1. DNS 解析
  2. TCP 連接
  3. HTTP 請(qǐng)求拋出
  4. 服務(wù)端處理請(qǐng)求,HTTP 響應(yīng)返回
  5. 瀏覽器拿到響應(yīng)數(shù)據(jù),解析響應(yīng)內(nèi)容,把解析的結(jié)果展示給用戶

3.2 從開(kāi)發(fā)者角度,看頁(yè)面加載各階段

從輸入url到用戶可以使用頁(yè)面的全過(guò)程時(shí)間統(tǒng)計(jì),會(huì)返回一個(gè)PerformanceTiming對(duì)象,單位均為毫秒。
關(guān)于performace,已經(jīng)在《從前端角度淺談性能》中進(jìn)行過(guò)介紹,,下面再?gòu)?qiáng)調(diào)一下:

各階段的性能耗時(shí)可以通過(guò)API:window.performance來(lái)獲取,對(duì)應(yīng)的具體方法有:performance.timing、performance.getEntriesByType(‘resource’)、performance.navigation等。
如上,開(kāi)發(fā)者可以通過(guò)performance中各階段的時(shí)間戳,分別獲取到 頁(yè)面各階段的性能指標(biāo),具體的個(gè)靜態(tài)資源的加載耗時(shí)、及 頁(yè)面是否重定向和重定向耗時(shí)。

按觸發(fā)順序排列所有屬性:

  • navigationStart:在同一個(gè)瀏覽器上下文中,前一個(gè)網(wǎng)頁(yè)(與當(dāng)前頁(yè)面不一定同域)unload 的時(shí)間戳,如果無(wú)前一個(gè)網(wǎng)頁(yè) unload ,則與 fetchStart 值相等
  • redirectStart:第一個(gè) HTTP 重定向發(fā)生時(shí)的時(shí)間。有跳轉(zhuǎn)且是同域名內(nèi)的重定向才算,否則值為 0
  • unloadEventStart:前一個(gè)網(wǎng)頁(yè)(與當(dāng)前頁(yè)面同域)unload 的時(shí)間戳,如果無(wú)前一個(gè)網(wǎng)頁(yè) unload 或者前一個(gè)網(wǎng)頁(yè)與當(dāng)前頁(yè)面不同域,則值為 0
  • redirectEnd:最后一個(gè) HTTP 重定向完成時(shí)的時(shí)間。有跳轉(zhuǎn)且是同域名內(nèi)的重定向才算,否則值為 0
  • unloadEventEnd:和 unloadEventStart 相對(duì)應(yīng),返回前一個(gè)網(wǎng)頁(yè) unload 事件綁定的回調(diào)函數(shù)執(zhí)行完畢的時(shí)間戳
  • fetchStart:瀏覽器準(zhǔn)備好使用 HTTP 請(qǐng)求抓取文檔的時(shí)間,這發(fā)生在檢查本地緩存之前
  • domainLookupStart:DNS 域名查詢開(kāi)始的時(shí)間,如果使用了本地緩存(即無(wú) DNS 查詢)或持久連接,則與 fetchStart 值相等
  • domainLookupEnd:DNS 域名查詢完成的時(shí)間,如果使用了本地緩存(即無(wú) DNS 查詢)或持久連接,則與 fetchStart 值相等
  • connectStart:HTTP(TCP) 開(kāi)始建立連接的時(shí)間,如果是持久連接,則與 fetchStart 值相等,如果在傳輸層發(fā)生了錯(cuò)誤且重新建立連接,則這里顯示的是新建立的連接開(kāi)始的時(shí)間
  • secureConnectionStart:HTTPS 連接開(kāi)始的時(shí)間,如果不是安全連接,則值為 0
  • connectEnd:HTTP(TCP) 完成建立連接的時(shí)間(完成握手),如果是持久連接,則與 fetchStart 值相等,如果在傳輸層發(fā)生了錯(cuò)誤且重新建立連接,則這里顯示的是新建立的連接完成的時(shí)間
  • requestStart:HTTP 請(qǐng)求讀取真實(shí)文檔開(kāi)始的時(shí)間(完成建立連接),包括從本地讀取緩存,連接錯(cuò)誤重連時(shí),這里顯示的也是新建立連接的時(shí)間
  • responseStart:HTTP 開(kāi)始接收響應(yīng)的時(shí)間(獲取到第一個(gè)字節(jié)),包括從本地讀取緩存
  • responseEnd:HTTP 響應(yīng)全部接收完成的時(shí)間(獲取到最后一個(gè)字節(jié)),包括從本地讀取緩存
  • domLoading:開(kāi)始解析渲染 DOM 樹(shù)的時(shí)間,此時(shí) Document.readyState 變?yōu)?loading,并將拋出 readystatechange 相關(guān)事件
  • domInteractive:完成解析 DOM 樹(shù)的時(shí)間,Document.readyState 變?yōu)?interactive,并將拋出 readystatechange 相關(guān)事件
  • domContentLoadedEventStart:DOM 解析完成后,網(wǎng)頁(yè)內(nèi)資源加載開(kāi)始的時(shí)間,文檔發(fā)生 DOMContentLoaded事件的時(shí)間
  • domContentLoadedEventEnd:DOM 解析完成后,網(wǎng)頁(yè)內(nèi)資源加載完成的時(shí)間(如 JS 腳本加載執(zhí)行完畢),文檔的DOMContentLoaded 事件的結(jié)束時(shí)間
  • domComplete:DOM 樹(shù)解析完成,且資源也準(zhǔn)備就緒的時(shí)間,Document.readyState 變?yōu)?complete,并將拋出 readystatechange 相關(guān)事件
  • loadEventStart:load 事件發(fā)送給文檔,也即 load 回調(diào)函數(shù)開(kāi)始執(zhí)行的時(shí)間,如果沒(méi)有綁定 load 事件,值為 0
  • loadEventEnd:load 事件的回調(diào)函數(shù)執(zhí)行完畢的時(shí)間,如果沒(méi)有綁定 load 事件,值為 0

3.3 各階段性能的計(jì)算(自定義)

const { timing, navigation } = window.performance
const loadPageInfo = {};

// 頁(yè)面加載類型,區(qū)分第一次load還是reload, 0初次加載、1重加載
loadPageInfo.loadType = navigation.type;

// 頁(yè)面加載完成的時(shí)間 - 幾乎代表了用戶等待頁(yè)面白屏的時(shí)間
loadPageInfo.loadPage = timing.loadEventEnd - timing.navigationStart;

// 重定向的時(shí)間
loadPageInfo.redirect = timing.redirectEnd - timing.redirectStart;

// 卸載頁(yè)面的時(shí)間
loadPageInfo.unloadEvent = timing.unloadEventEnd - timing.unloadEventStart;

// 查詢 DNS 本地緩存的時(shí)間
loadPageInfo.appCache = timing.domainLookupStart - timing.fetchStart;

// 【重要】DNS 查詢時(shí)間
// 頁(yè)面內(nèi)是不是使用了太多不同的域名,導(dǎo)致域名查詢的時(shí)間太長(zhǎng)?推薦 DNS 預(yù)加載。
// 可使用 HTML5 Prefetch 預(yù)查詢 DNS
loadPageInfo.lookupDomain = timing.domainLookupEnd - timing.domainLookupStart;

// HTTP(TCP)建立連接完成握手的時(shí)間
loadPageInfo.connect = timing.connectEnd - timing.connectStart;

// 【重要】HTTP請(qǐng)求及獲取 文檔內(nèi)容的時(shí)間
loadPageInfo.request = timing.responseEnd - timing.responseStart;

// 【重要】前一個(gè)頁(yè)面 unload 到 HTTP獲取到 頁(yè)面第一個(gè)字節(jié)的時(shí)間
// 【原因】這可以理解為用戶拿到你的資源占用的時(shí)間,推薦 加異地機(jī)房,加 CDN 處理,加寬帶,加 CPU 運(yùn)算速度
// TTFB 即 Time To First Byte
loadPageInfo.ttfb = timing.responseStart - timing.navigationStart;

// 解析 DOM 樹(shù)結(jié)構(gòu)的時(shí)間
loadPageInfo.domReady = timing.domComplete - timing.responseEnd;

// 【重要】執(zhí)行 onload 回調(diào)函數(shù)的時(shí)間
// 【原因】是否太多不必要的操作都放在 onload 回調(diào)函數(shù)里執(zhí)行了,推薦 延遲加載、按需加載的策略
loadPageInfo.loadEvent = timing.loadEventEnd - timing.loadE

4 異常監(jiān)控

前端需要監(jiān)控的錯(cuò)誤主要有兩類:

  1. Javascript錯(cuò)誤(js錯(cuò)誤、promise錯(cuò)誤)
  2. 監(jiān)聽(tīng)error錯(cuò)誤(資源加載錯(cuò)誤)

4.1 console.error

// 重寫(xiě)console.error,可以捕獲更全面的報(bào)錯(cuò)信息
var oldError = console.error;


console.error = function(tempErrorMsg){
var errorMsg = ( arguments[0] && arguments[0].message ) || tempErrorMsg;
var lineNumber = 0;
var columnNumber = 0;
var errorStack = arguments[0] && arguments[0].stack;


if( !errorStack ){
saveJSError( 'console_error', errorMsg, '', lineNumber, columnNumber, 'CustomizeError: ' + errorMsg );
}else{
saveJSError( 'console_error', errorMsg, '', lineNumber, columnNumber, errorStack );
}


return oldError.apply( console, arguments );

4.2 error事件

通過(guò)對(duì)error事件的監(jiān)聽(tīng),可以捕捉到 js語(yǔ)法 及 資源加載 的錯(cuò)誤。根據(jù) event.target.src / href 來(lái)判斷是否為資源加載錯(cuò)誤。

window.addEventListener( 'error', function(e){
var errorMsg = e.error && e.error.message,
errorStack = e.error && e.error.stack,
pageUrl = e.filename,
lineNumber = e.lineno,
columnNumber = e.colno;


saveJSError( 'on_error', errorMsg, pageUrl, lineNumber, columnNumber, errorStack );
} );

4.3 Promise

// 捕獲未處理的Promise錯(cuò)誤
window.onunhandledrejection = function(e){
var errorMsg = '';
var errorStack = '';
if( typeof e.reason === 'object' ){
errorMsg = e.reason.message;
errorStack = e.reason.stack;
}else{
errorMsg = e.reason;
errorStack = '';
}
saveJSError( 'on_error', errorMsg, '', 0, 0, 'UncaughtInPromiseError: ' + errorStack );
}

5 總結(jié)

以上,通過(guò)簡(jiǎn)單的js代碼,即可實(shí)現(xiàn)對(duì)頁(yè)面性能與異常的監(jiān)控與數(shù)據(jù)上報(bào),后續(xù)還需要相應(yīng)具體的平臺(tái)匯總,及相應(yīng)的業(yè)務(wù)所需數(shù)據(jù)(如PV、UV等)的計(jì)算,才能真正實(shí)現(xiàn)對(duì)產(chǎn)品的頁(yè)面數(shù)據(jù)呈現(xiàn),用于業(yè)務(wù)擴(kuò)展及宣導(dǎo)。

6 后續(xù)

上述代碼,實(shí)現(xiàn)了對(duì)頁(yè)面性能及異常的監(jiān)控,但其實(shí)前端的監(jiān)控還包括了請(qǐng)求接口的監(jiān)控與埋點(diǎn)的實(shí)現(xiàn),后續(xù)將陸續(xù)推出,敬請(qǐng)期待。

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

2022-10-10 18:39:01

legendapp前端框架

2018-09-14 16:20:37

2015-08-20 10:23:23

前端代碼日志收集

2012-11-05 13:59:12

WebFdSafeJS

2019-04-08 16:50:33

前端性能監(jiān)控

2011-02-22 15:16:56

VSFTPD

2022-11-28 07:35:52

前端錯(cuò)誤

2025-06-12 02:22:00

Netflix前端系統(tǒng)

2022-06-10 14:09:18

前端監(jiān)控異常數(shù)據(jù)

2020-09-04 13:50:35

前端異常監(jiān)控代碼

2012-08-20 13:42:48

Web

2020-08-25 18:56:19

前端開(kāi)發(fā)技術(shù)

2021-05-31 08:30:50

監(jiān)控網(wǎng)站性能

2021-09-13 05:00:09

監(jiān)控Trends 性能

2021-09-11 21:02:24

監(jiān)控Sentry Web性能

2010-05-26 18:40:54

Linux性能監(jiān)控

2021-09-09 12:28:50

Sentry Web性能監(jiān)控

2011-11-08 21:47:37

Linux 監(jiān)控 IO

2010-05-26 18:21:04

Linux性能監(jiān)控

2010-05-26 18:31:51

Linux性能監(jiān)控
點(diǎn)贊
收藏

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

国产成人91久久精品| a亚洲天堂av| 久久精品国产欧美亚洲人人爽| 性生活在线视频| 高清视频在线观看三级| 久久精品无码一区二区三区| 国产伦精品一区二区三区精品视频| 91人妻一区二区三区蜜臀| 在线播放一区二区精品视频| 丰满岳妇乱一区二区三区| 亚洲欧美日韩在线综合| 韩国av电影在线观看| 日韩专区欧美专区| 欧美精品激情在线| аⅴ天堂中文在线网| 国产成人免费视频网站视频社区| 偷拍亚洲欧洲综合| 自拍视频一区二区三区| 外国精品视频在线观看| 久久精品二区亚洲w码| 少妇高潮久久77777| 青青草成人免费视频| 二区三区精品| 在线看一区二区| av日韩一区二区三区| 免费一级毛片在线观看| 国产精品资源在线| 国产欧美日韩亚洲精品| 欧美日韩精品亚洲精品| 精品免费视频| 亚洲经典中文字幕| 天堂av.com| 成人国产网站| 日本电影亚洲天堂一区| 日日摸日日碰夜夜爽无码| а天堂中文在线官网| 在线日韩影院| 免费一级片视频| 蜜臀av午夜一区二区三区| 亚洲精品久久久久久久久久久久久 | 懂色av粉嫩av蜜乳av| 男人亚洲天堂网| 亚洲天堂网在线视频| 麻豆亚洲精品| 555www成人网| www.日本精品| 一区二区久久| 久久久久久网址| 欧美日韩在线视频免费| 亚洲成av人片一区二区密柚| 色婷婷成人综合| 五月天精品在线| 欧美军人男男激情gay| 国产午夜精品全部视频在线播放| 在线免费观看成年人视频| 成人台湾亚洲精品一区二区| 日韩精品一区二区三区在线播放| 色呦色呦色精品| 日日狠狠久久| 日韩午夜在线观看视频| 激情文学亚洲色图| 亚洲精品一区国产| 日韩一级完整毛片| 亚洲视频 中文字幕| 美女视频亚洲色图| 亚洲精品美女在线观看播放| 在线免费播放av| 五月国产精品| 国产一区二区三区精品久久久 | 国产一区二区视频免费| 日本午夜一区二区| 成人黄色午夜影院| 国产日韩一区二区三区| 欧美一区二区三区人| 成人资源在线| 中文字幕永久在线视频| 少妇性l交大片| 91精品久久久久久久久久久久久久| 色哟哟国产精品免费观看| 久草热8精品视频在线观看| 中文字幕一区免费在线观看| 天堂va久久久噜噜噜久久va| 日本在线视频网| 中文字幕一区二区不卡| 久久人人爽人人爽人人av| 在线免费看h| 欧美唯美清纯偷拍| 国产人妻精品午夜福利免费| 你懂的在线观看一区二区| 亚洲电影在线观看| 摸摸摸bbb毛毛毛片| 色综合久久一区二区三区| 欧美高清自拍一区| 91青青草视频| 大桥未久av一区二区三区中文| 麻豆久久久9性大片| 成人影欧美片| 色综合久久88色综合天天| 日韩有码免费视频| 91麻豆精品国产91久久久久推荐资源| 亚洲欧洲在线免费| 久久久.www| 日韩激情在线观看| 国产福利不卡| 亚洲成人三级| 色综合久久综合网97色综合| 精品亚洲视频在线| 欧美日韩爱爱| 97视频免费在线看| 国产超碰人人模人人爽人人添| 久久影院视频免费| 2018中文字幕第一页| 黑森林国产精品av| 日韩三区在线观看| 亚洲一二三四五六区| 久久国产精品毛片| 2022国产精品| 天堂аⅴ在线地址8| 狠狠色狠色综合曰曰| 中文字幕55页| 99精品美女| 国产精品久久9| 全国男人的天堂网| 亚洲一区二区在线免费观看视频 | 日韩免费一区二区三区在线播放| 日本人亚洲人jjzzjjz| 99在线精品免费视频九九视| 99在线视频首页| 午夜免费视频在线国产| jzzjzzjzz亚洲成熟少妇| 日韩av一卡二卡三卡| 日本精品一二区| 韩国成人一区| 色综合91久久精品中文字幕| 精品一区二区三区欧美| 日韩一级免费一区| 久久精品日韩无码| 久久婷婷亚洲| 欧美凹凸一区二区三区视频| 国产激情视频在线观看| 色狠狠综合天天综合综合| 中文字幕人妻无码系列第三区| 日韩综合网站| 国产精品久久久久久久久久| 亚洲日本中文字幕在线| 亚洲国产视频一区| 中文字幕人妻一区| 影音先锋一区| 91视频婷婷| 免费观看久久久久| 制服丝袜激情欧洲亚洲| 在线观看天堂av| 久久精品久久99精品久久| 亚洲欧美日韩国产成人综合一二三区| 欧美最新精品| 中文字幕在线看视频国产欧美| 精品乱码一区内射人妻无码| 国产精品妹子av| 亚洲美女免费精品视频在线观看| 欧美第一页在线观看| 国内久久精品视频| 激情视频小说图片| 凹凸av导航大全精品| 欧美极品少妇xxxxⅹ喷水| 人成网站在线观看| 色综合天天做天天爱| 人妻精品久久久久中文| 精品一区二区免费看| 亚洲第一精品区| 综合激情网...| 韩国视频理论视频久久| 四虎影视在线观看2413| 色婷婷亚洲综合| 99国产精品免费| 国产乱码精品一区二区三区五月婷| 日韩久久不卡| 精品视频一区二区三区在线观看| 欧美国产日韩精品| 手机福利在线| 欧美精品国产精品| 国产精品suv一区二区| 成人免费观看男女羞羞视频| 国模杨依粉嫩蝴蝶150p| 999精品在线| 国产精品 日韩| 成人亚洲免费| 久久男人资源视频| 国产高清av在线| 日韩精品中文字幕一区| 国产成人无码精品| 中文字幕在线一区免费| 国产伦精品一区三区精东| 狂野欧美一区| 中文字幕精品—区二区日日骚| 136福利精品导航| 国产极品jizzhd欧美| 天堂8中文在线| 精品中文字幕久久久久久| 国产在线一级片| 成人av免费网站| 午夜精品久久久久久久99樱桃| 亚洲激情视频在线播放| 午夜影院福利社| 天堂资源在线中文精品| 日本一二三区视频在线| 国产a久久精品一区二区三区 | 亚洲国产精品免费在线观看| 26uuu另类欧美亚洲曰本| 精品人妻一区二区三| 日韩极品在线观看| 日本日本19xxxⅹhd乱影响| 我不卡影院28| 日本在线免费观看一区| 欧美黄色一级| 欧美日韩二区三区| 国产精品 欧美在线| 亚洲永久精品ww.7491进入| 日韩国产欧美三级| 日韩 欧美 自拍| 国产一区调教| www.久久爱.cn| 欧洲亚洲精品| 欧日韩在线观看| www成人免费观看| 欧美超级免费视 在线| 天天影院图片亚洲| 久草中文综合在线| 精品国产乱码久久久久久免费 | 国产精品久久久久久影院8一贰佰| 精品欧美一区二区久久久伦| 一区中文字幕电影| 91成人免费视频| 三级成人黄色影院| 日本久久久a级免费| 97超碰在线免费| 欧美精品999| 秋霞成人影院| 亚洲欧美日韩精品久久亚洲区| 色婷婷av一区二区三| 日韩欧美成人午夜| www.中文字幕| 欧美va亚洲va| 粉嫩小泬无遮挡久久久久久| 日韩欧美成人一区二区| 国产福利小视频| 欧美大片一区二区三区| 国产超碰人人模人人爽人人添| 欧美一区二区免费观在线| 国产免费福利视频| 欧美日韩中文字幕精品| 在线观看免费视频a| 欧美日韩高清影院| 国产哺乳奶水91在线播放| 欧美一区二区三区色| 国产成人精品a视频| 67194成人在线观看| 一级aaaa毛片| 日韩一区二区三区四区五区六区| 97久久人国产精品婷婷 | 九色在线观看视频| 国产一区二区三区日韩欧美| 成人亚洲性情网站www在线观看| 中文字幕精品网| 成人在线播放免费观看| 欧美精品video| 免费成人直播| 国产在线精品自拍| 青青国产精品| 国产精品日韩二区| 久久大胆人体视频| 日本欧洲国产一区二区| 国产精品二区不卡| 国产精品久久成人免费观看| 狠狠干成人综合网| 国产第一页视频| 久久精品国产免费| 中文字幕天堂av| 中文字幕第一页久久| 国产在线一卡二卡| 狠狠干狠狠久久| 国产乱淫av免费| 日韩国产欧美精品在线| 素人av在线| 57pao成人国产永久免费| 国语自产精品视频在线看抢先版结局| 91影院未满十八岁禁止入内| 在线视频亚洲专区| 狠狠色噜噜狠狠色综合久| 久久亚洲国产| 91国视频在线| 国产在线播放一区| 一级国产黄色片| 亚洲欧美偷拍三级| 豆国产97在线 | 亚洲| 日韩欧中文字幕| www.黄色国产| 国产一区二区三区在线观看网站 | 一本在线高清不卡dvd| a在线观看免费| 亚洲国产毛片完整版| 免费黄色网址在线观看| 日韩av观看网址| 操欧美女人视频| 免费观看黄色的网站| 免费看的黄色欧美网站| 91亚洲一线产区二线产区| 国产精品欧美一级免费| 成年人视频在线免费看| 欧美精品一级二级| 国产一区二区影视| 欧美激情一级精品国产| 青青在线精品| 亚洲日本一区二区三区在线不卡| 韩国精品一区二区三区| 三区视频在线观看| 国产喷白浆一区二区三区| 日本黄色片视频| 日韩精品中文字幕一区二区三区| 最新97超碰在线| 97精品国产aⅴ7777| 亚洲不卡在线| 最新av在线免费观看| 麻豆视频一区二区| 五月天综合视频| 色综合视频在线观看| 天堂中文在线资| 91福利视频网| 男人的天堂久久| 免费看黄在线看| 成人丝袜视频网| 久久午夜无码鲁丝片| 欧美一区二区三区啪啪| 日本不卡三区| 国产精品美女www爽爽爽视频| 国产伦一区二区三区| 欧美日韩中文在线视频| 成人午夜av电影| 久久综合成人网| 亚洲第一综合天堂另类专| 日本三级在线观看网站| 99热国产免费| 91精品国产视频| 中文字幕55页| 一区二区不卡在线视频 午夜欧美不卡在| 999精品国产| 欧美激情一区二区三区成人| 亚洲开心激情| 男女视频网站在线观看| av在线不卡网| 国产亚洲欧美在线精品| 国产亚洲一区二区精品| 欧美影视资讯| 91社在线播放| 美国欧美日韩国产在线播放| 成人精品一二三区| 日韩欧美专区在线| 啊啊啊久久久| 欧美另类网站| 蜜桃久久av一区| 粉嫩av性色av蜜臀av网站| 欧美成人精品福利| 国产激情在线播放| 日本欧美色综合网站免费| 久久精品国产免费| 18精品爽视频在线观看| 亚洲加勒比久久88色综合 | 99久久99久久精品国产片| 亚洲黄色高清| 久久精品综合视频| 欧美性感一区二区三区| 在线播放免费av| 久久av一区二区三区漫画| 亚洲在线视频| 成年人免费视频播放| 亚洲精品一区在线观看| 日韩电影免费观| 天堂精品视频| 国产一区二区三区黄视频 | 日本精品不卡| 蜜桃视频成人在线观看| av激情亚洲男人天堂| 成人黄色片在线观看| 欧美黑人狂野猛交老妇| 国产精品手机在线播放| 手机在线免费毛片| 欧美性猛交xxxx乱大交3| 麻豆视频在线观看免费网站| 国产伦精品一区| 美女视频一区二区三区| 久久综合成人网| 在线播放日韩av| 麻豆成人入口| 国产永久免费网站| 精品久久久久久电影| 好吊日视频在线观看| 蜜桃av噜噜一区二区三| 国产精品一二三四| 中文天堂在线资源| 欧美中文字幕在线| 午夜欧美精品久久久久久久|