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

探索Node.js異步Hooks

開發(fā) 前端
你聽說過 Node.js 的`async hooks` [1]模塊嗎?如果沒有,那你應(yīng)該了解一下。

[[391346]]

 你聽說過 Node.js 的`async hooks` [1]模塊嗎?如果沒有,那你應(yīng)該了解一下。

盡管它是與 Node.js 9 一起發(fā)布的新特性,但是因?yàn)樵撃K仍處于測(cè)試階段,我并不建議將其用于生產(chǎn)環(huán)境,不過你仍然應(yīng)該對(duì)它有所了解。

簡(jiǎn)而言之,Node.js 中的異步掛鉤,具體來說是 async_hooks 模塊,提供了一個(gè)清晰易用的 API 去追蹤 Node.js 中的異步資源。

該 API 最簡(jiǎn)單的使用方式就是用 JS 中的 require import:

  1. const async_hooks = require('async_hooks'); 

我們?cè)谶@里討論的異步特性指的是Node.js創(chuàng)建的具有關(guān)聯(lián)回調(diào)的對(duì)象,與回調(diào)可能被調(diào)用多少次沒有關(guān)系。這就有很多種類了例如:Promises、創(chuàng)建服務(wù)的操作、超時(shí)等。

請(qǐng)記住,大多數(shù)語言都可以關(guān)閉資源。其中一些通過容器關(guān)閉,其他的則是通過語言本身關(guān)閉。所以你的回調(diào)函數(shù)可能自始至終都沒有被調(diào)用過。但是沒有關(guān)系,AsyncHook 不會(huì)區(qū)分這些不同的情況。

這篇文章的目的是為了更深入的探討hooks,并且嘗試通過一些示例幫助你更深入的理解。準(zhǔn)備好了嗎?

👋 在探索異步掛鉤時(shí),你可能還希望了解 AppSignal forNode.js[2]。我們?yōu)槟闾峁?duì)Node.js Core,Express,Next.js,Apollo Server,node-postgres和node-redis的現(xiàn)成支持[3]。

API使用

我總是覺得官方文檔過于復(fù)雜以及苛刻。這就是為什么我通常會(huì)選擇傳統(tǒng)、友好的博客文章。

讓我們首先了解一下Async Hooks API提供的 5 個(gè)可用事件函數(shù):

  •  init: 顧名思義,當(dāng)特定的異步資源初始化時(shí)會(huì)調(diào)用它。僅作記錄,此時(shí),我們已經(jīng)將鉤子與異步資源相關(guān)聯(lián)。
  •  before 和 after: 這與普通語言中的函數(shù)的執(zhí)行前和執(zhí)行后非常相似。在資源執(zhí)行之前和之后分別調(diào)用它們。
  •  destroy: 很明顯,無論資源的回調(diào)函數(shù)發(fā)生了什么,只要資源被銷毀就會(huì)調(diào)用它。
  •  promiseResolve: promiseResolve與Promise有關(guān),當(dāng)你的Promise調(diào)用它的 resolve 函數(shù)時(shí),掛鉤就會(huì)觸發(fā)此函數(shù)。

非常的簡(jiǎn)單直接,接下來讓我們看一個(gè)基本的例子:

  1. const myFirstAsyncHook = async_hooks.createHook({ init, before, after, destroy, promiseResolve }); 

是的,你必須先創(chuàng)建每個(gè)事件函數(shù),然后再將其分配給createHook函數(shù)。另外,必須顯式啟用該掛鉤:

  1. myFirstAsyncHook.enable(); 

讓我們繼續(xù)看一個(gè)更加完整的例子: 

  1. const fs = require("fs");  
  2. const async_hooks = require("async_hooks");  
  3. // Sync write to the console  
  4. const writeSomething = (phase, more) => {  
  5.    fs.writeSync(  
  6.       1,  
  7.       `Phase: "${phase}", Exec. Id: ${async_hooks.executionAsyncId()} ${  
  8.             more ? ", " + more : ""  
  9.         }\n`  
  10.    ); 
  11. };  
  12. // Create and enable the hook  
  13. const timeoutHook = async_hooks.createHook({  
  14.    init(asyncId, type, triggerAsyncId) {  
  15.       writeSomething(  
  16.          "Init",  
  17.          `asyncId: ${asyncId}, type: "${type}", triggerAsyncId: ${triggerAsyncId}` 
  18.       );  
  19.    },  
  20.    before(asyncId) {  
  21.       writeSomething("Before", `asyncId: ${asyncId}`);  
  22.    },  
  23.    destroy(asyncId) {  
  24.       writeSomething("Destroy", `asyncId: ${asyncId}`);  
  25.    },  
  26.    after(asyncId) {  
  27.       writeSomething("After", `asyncId: ${asyncId}`);  
  28.    },  
  29. });  
  30. timeoutHook.enable();  
  31. writeSomething("Before call");  
  32. // Set the timeout  
  33. setTimeout(() => {  
  34.    writeSomething("Exec. Timeout");  
  35. }, 1000); 

這個(gè)例子通過眾所周知的原生函數(shù) setTimeout 去追蹤超時(shí)的異步執(zhí)行過程。

在我們深入研究之前,先快速瀏覽一下第一個(gè)函數(shù) writeSomething 。你也許很好奇為什么在我們已經(jīng)有函數(shù)可以在控制臺(tái)輸出的情況下仍然創(chuàng)建了一個(gè)新的函數(shù)去完成相同的功能。

原因是你不能使用任何 console 函數(shù)去測(cè)試異步鉤子,因?yàn)樗鼈儽旧砭褪钱惒降摹R虼水?dāng)我們?cè)谙旅嫣峁┝艘粋€(gè) init 函數(shù)時(shí),它會(huì)產(chǎn)生一個(gè)無限循環(huán)。該函數(shù)會(huì)調(diào)用 console 的 log ,此日志又會(huì)再次觸發(fā)初始化,以此類推,陷入死循環(huán)。

這就是為什么我們需要重新寫一個(gè)“同步”日志功能。

好了,現(xiàn)在我們回過頭去看代碼。我們的異步鉤子提供了四個(gè)功能:init、 before、 after 以及 destory。而且,我們還在超時(shí)之前和執(zhí)行期間打印一條消息,所以你可以看到整個(gè)過程是如何線性進(jìn)行的。

在你的命令行執(zhí)行 node index.js,你會(huì)得到如下圖所示的結(jié)果:

觀察下鉤子是如何一步一步執(zhí)行追蹤的。看起來是一種很有趣的跟蹤方式,尤其是當(dāng)你考慮將數(shù)據(jù)輸入到監(jiān)視工具中或者是你已經(jīng)使用的日志追蹤工具。

一個(gè)Promise例子

讓我們看看我們的示例在Promise下的執(zhí)行效果。思考下面這些代碼片段: 

  1. const calcPow = async(n, exp) => {  
  2.    writeSomething("Exec. Promise");  
  3.    return Math.pow(n, exp);  
  4. };  
  5. (async() => {  
  6.    await calcPow(3, 4);  
  7. })(); 

你也可以用之前的 setTimeout 示例來替代這個(gè)例子。在這段代碼中,我們有一個(gè)異步函數(shù)用來進(jìn)行冪運(yùn)算。同時(shí)也有一個(gè)相同的函數(shù)在異步塊中被調(diào)用。到目前為止,Node.js創(chuàng)建了兩個(gè)Promise。

下圖是日志記錄的結(jié)果:

奇怪的是,我們有兩個(gè)Promise,卻調(diào)用了三次 init 函數(shù)。不用擔(dān)心,這是因?yàn)镹ode.js團(tuán)隊(duì)在版本12中引入了異步執(zhí)行性能方面的一些最新改進(jìn)。你可以點(diǎn)擊此處[4]了解更多信息。

盡管如此,執(zhí)行過程依然符合我們的預(yù)期。

解析:鉤子函數(shù)的性能與度量

Node.js提供的另一個(gè)非常有趣的API是性能評(píng)估API[5],既然我們?cè)谶@里討論度量,為什么不結(jié)合兩者的功能來了解我們可以收獲什么呢?

可以通過 perf_hooks 獲得該API,該API讓我們能夠用與W3C Web Performance API[6]相似的方式來獲得性能/用戶時(shí)間軸指標(biāo)。

將它與異步鉤子相結(jié)合我們可以做一些事情,比如追蹤異步函數(shù)執(zhí)行完畢需要的時(shí)間。讓我們看另外一個(gè)例子: 

  1. const async_hooks = require("async_hooks");  
  2. const {  
  3.    performance,  
  4.    PerformanceObserver  
  5. } = require("perf_hooks");  
  6. const hook = async_hooks.createHook({  
  7.    init(asyncId) {  
  8.       performance.mark(`init-${asyncId}`);  
  9.    },  
  10.    destroy(asyncId) {  
  11.       performance.mark(`destroy-${asyncId}`);  
  12.       performance.measure(  
  13.          `entry-${asyncId}`,  
  14.          `init-${asyncId}`,  
  15.          `destroy-${asyncId}`  
  16.       );  
  17.    },  
  18. });  
  19. hook.enable();  
  20. const observer = new PerformanceObserver((data) =>  
  21.    console.log(data.getEntries())  
  22. );  
  23. observer.observe({  
  24.    entryTypes: ["measure"],  
  25.    buffered: true  
  26. });  
  27. setTimeout(() => {  
  28.    console.log("I'm a timeout");  
  29. }, 1200); 

既然我們只是追蹤記錄執(zhí)行時(shí)間,就沒有必要用之前用的中間事件函數(shù)。用 init 和 destroy 就足夠了。

就像異步鉤子那樣,性能API通過創(chuàng)建觀察者來工作。不過,無論什么時(shí)候開始或者結(jié)束,你都必須明確標(biāo)記每個(gè)事件的id。這樣,當(dāng)我們調(diào)用API的 measure 函數(shù)時(shí),它將匯總收集到的數(shù)據(jù)并將其立即發(fā)送給觀察者,觀察者將為我們記錄全部的日志。

注意了,這里我們使用了兩次 console.log 函數(shù)。第一次是無影響的因?yàn)樗谟^察者中執(zhí)行。但是第二次它在 setTimeout 函數(shù)中執(zhí)行,另一個(gè)異步中的異步,這意味著在最后它會(huì)產(chǎn)生不同的輸出。

下圖是日志記錄:

本示例本并沒有考慮事件類型之間的差異。在這里,我們?cè)谕粶y(cè)量場(chǎng)景中發(fā)生了超時(shí)和異步日志操作。

但是,考慮到生產(chǎn)環(huán)境,建議你創(chuàng)建一個(gè)更強(qiáng)大的機(jī)制在每次調(diào)用 init 時(shí)存儲(chǔ)事件類型,并在稍后調(diào)用 destroy 函數(shù),倒霉的沒有接收到參數(shù)類型時(shí)檢查存儲(chǔ)是否依然存在。

異步資源

Async Hooks中的另一個(gè)有用功能是 `AsyncResource`[7] 類。每當(dāng)你為框架或庫(kù)創(chuàng)建自己的資源時(shí),它都會(huì)為你提供幫助。

只需輸入以下代碼即可使用: 

  1. const AsyncResource = require('async_hooks').AsyncResource; 

用這種方式,你可以使用它實(shí)例化一個(gè)新對(duì)象,并手動(dòng)定義其每個(gè)階段在整個(gè)代碼中何時(shí)開始。舉個(gè)例子: 

  1. const resource = new AsyncResource('MyOwnResource');  
  2. someFunction(function someCallback() {  
  3.    resource.emitBefore();  
  4.    // do your stuff...  
  5.    resource.emitAfter();  
  6. });  
  7. someOnClose() {  
  8.    resource.emitDestroy();  

這仍是資源生命周期的一個(gè)示例,如果要綁定本地的C++代碼,我們更建議使用它。我將為你提供官方文檔中的一個(gè)很好的例子[8]來簡(jiǎn)化它。

結(jié)論

就像我們討論的那樣,異步鉤子仍處于實(shí)驗(yàn)階段。因此,要謹(jǐn)慎使用它。

由于 hooks 僅在 Node.js 8 及更高版本中可用,因此你可以考慮遷移 Node.js 版本(很多時(shí)候這是不太合適的方法)或使用社區(qū)中的替代工具,例如 async-tracer[9]。 

 

責(zé)任編輯:龐桂玉 來源: 前端大全
相關(guān)推薦

2025-01-13 00:00:00

2021-01-26 08:07:44

Node.js模塊 Async

2020-12-08 06:28:47

Node.js異步迭代器

2021-08-12 01:00:29

NodejsAsync

2011-12-23 13:58:57

node.js

2021-12-01 00:05:03

Js應(yīng)用Ebpf

2021-03-04 23:12:57

Node.js異步迭代器開發(fā)

2022-03-20 06:40:31

Node.jsperf_hooks性能數(shù)據(jù)

2013-11-01 09:34:56

Node.js技術(shù)

2015-03-10 10:59:18

Node.js開發(fā)指南基礎(chǔ)介紹

2021-03-16 16:16:41

GeneratorWebsockets前端

2023-06-30 08:05:41

2021-09-07 07:53:43

工具

2011-11-01 10:30:36

Node.js

2011-09-08 13:46:14

node.js

2011-09-02 14:47:48

Node

2011-09-09 14:23:13

Node.js

2012-10-24 14:56:30

IBMdw

2011-11-10 08:55:00

Node.js

2021-12-25 22:29:57

Node.js 微任務(wù)處理事件循環(huán)
點(diǎn)贊
收藏

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

亚洲电影免费观看高清完整版在线 | 麻豆成人在线视频| 久久免费福利| 亚洲成人综合在线| 欧美精品久久久| 一级黄色片免费| 亚洲国产高清一区二区三区| 亚洲欧洲在线免费| www.成人黄色| 国产高潮在线| 国产亚洲一区二区在线观看| 成人午夜两性视频| 欧美在线观看不卡| 99久久婷婷| 亚洲国产精品大全| 亚洲天堂网2018| 美女高潮视频在线看| 亚洲色图欧洲色图婷婷| 精品999在线观看| 亚洲一级特黄毛片| 久久精品一区| 久久视频在线看| 亚洲av无码一区二区三区观看| 国产精品蜜月aⅴ在线| 精品久久久免费| 亚洲成人动漫在线| 国产高清免费在线播放| 大美女一区二区三区| 国产有码一区二区| 五月天婷婷导航| 影音先锋中文字幕一区| y97精品国产97久久久久久| 国产一级二级在线观看| 日韩欧美另类中文字幕| 色综合中文综合网| 欧美午夜小视频| 最新黄网在线观看| 中文欧美字幕免费| 久久精品国产精品国产精品污| 国产精品久久久久久久久毛片 | 欧美超级乱淫片喷水| 久久午夜福利电影| 首页亚洲中字| 精品国产乱码久久久久久影片| 五月婷婷六月合| 国产综合色区在线观看| 岛国精品视频在线播放| 国产精品久久久久久久乖乖| 91在线中文| 日韩一区欧美小说| 亚洲成色最大综合在线| 激情综合闲人网| www国产成人免费观看视频 深夜成人网| 成人女人免费毛片| 精品人妻一区二区三区含羞草 | 亚洲午夜av在线| 日本丰满大乳奶| 黄色网址视频在线观看| 国产精品人妖ts系列视频| 日韩欧美视频一区二区三区四区| 欧美日韩在线中文字幕| 久久精品夜色噜噜亚洲aⅴ| 久久一区二区精品| 六十路在线观看| 久久久久九九视频| 日本日本精品二区免费| 国产黄在线看| 中文字幕一区二区三区四区不卡| 亚洲欧洲久久| 黄色在线论坛| 亚洲一级二级三级| 欧美二区在线视频| 伊人久久在线| 在线观看日韩精品| 日韩精品视频一二三| 999精品视频在线观看| 欧美一级国产精品| 日本wwwwwww| 欧美综合精品| 亚洲无线码在线一区观看| 日韩欧美黄色网址| 亚洲一区二区| 97国产精品久久| 激情视频网站在线观看| 久久成人羞羞网站| 91pron在线| 午夜影院免费视频| 中文字幕免费不卡| 久久视频免费在线| 色在线中文字幕| 欧美日韩精品专区| 欧美一级片在线免费观看| 你懂的在线观看一区二区| 亚洲网站在线看| 亚洲国产成人精品综合99| 国产欧美一区二区色老头 | 成人国产免费视频| 日韩亚洲视频| 日本性爱视频在线观看| 欧美视频在线视频| 网站在线你懂的| 女一区二区三区| 日韩中文字幕在线看| 国产无遮挡又黄又爽| 热久久国产精品| 国产精华一区二区三区| 成人欧美亚洲| 一区二区三区精品视频| 能看的毛片网站| 五月亚洲婷婷| 最新中文字幕亚洲| 欧美激情亚洲综合| 国产乱码字幕精品高清av| 蜜桃视频日韩| 亚洲婷婷噜噜| 欧美性xxxxxxxx| 精品国产一区在线| 亚洲a在线视频| 热久久免费视频精品| 精品人妻少妇AV无码专区| 中文av一区二区| 免费无遮挡无码永久视频| 国产精品久一| 色妞久久福利网| 欧美精品韩国精品| 成人午夜av电影| av磁力番号网| 日韩城人网站| 国产一区二区免费| 国语对白永久免费| 99久久久无码国产精品| 男人的天堂avav| 亚洲黑人在线| 正在播放欧美一区| 69国产精品视频免费观看| 岛国精品在线播放| 菠萝蜜视频在线观看入口| 欧美亚洲综合视频| 综合激情国产一区| 免费又黄又爽又猛大片午夜| 91在线国内视频| 妞干网在线视频观看| 中文字幕一区图| 欧美刺激性大交免费视频| 国产精品无码天天爽视频| 国产精品无码永久免费888| 男人舔女人下面高潮视频| 日韩一级电影| 2021久久精品国产99国产精品| 高清乱码毛片入口| 亚洲国产日韩精品| 亚洲午夜久久久久久久久| 欧美婷婷在线| 国产成人精品福利一区二区三区 | 日本一区二区三区视频视频| 国产精品免费观看久久| 亚洲动漫在线观看| 日韩av123| 成人动漫在线播放| 欧美三级一区二区| 国产wwwwxxxx| 国产麻豆精品久久一二三| 国产内射老熟女aaaa| 日韩精品一区二区三区中文| 久久久久久久爱| 手机在线精品视频| 色综合天天综合网国产成人综合天 | 伊人久久av导航| 亚洲精品大片| 欧美—级a级欧美特级ar全黄 | 亚洲欧洲日本专区| 国产偷人爽久久久久久老妇app| 国产精品欧美一级免费| 国产精品嫩草影院8vv8| 欧美黄免费看| 精品国产一区二区三区麻豆免费观看完整版| 多野结衣av一区| 精品视频在线播放免| 少妇又紧又色又爽又刺激视频| 国产精品不卡视频| 韩国三级视频在线观看| 亚洲在线观看| 一本色道婷婷久久欧美| 亚洲网一区二区三区| 91极品女神在线| www.国产精品.com| 日韩美女视频在线| 精品人妻一区二区三区免费看| 国产精品天干天干在线综合| 伦伦影院午夜理论片| 国产欧美在线| 天天做天天爱天天高潮| 卡通动漫国产精品| 国产日韩在线一区| av在线最新| 最近2019年日本中文免费字幕 | 九九**精品视频免费播放| 97超碰在线视| 国内黄色精品| 成人免费看片网址| av成人亚洲| 7m精品福利视频导航| 女女色综合影院| 亚洲精品美女视频| 国产裸体无遮挡| 日韩欧美综合在线视频| 欧美成人一区二区三区高清| 欧美激情一区二区三区| 日韩大尺度视频| 蜜臀久久久久久久| 激情伊人五月天| 亚洲国产日韩欧美在线| 欧美精品亚洲精品| 成人性生交大片免费看96| 成人激情av在线| 亚洲四虎影院| 欧美有码在线视频| 激情av在线| 久久网福利资源网站| 国内三级在线观看| 亚洲国产91色在线| 国产成人麻豆精品午夜在线| 欧美怡红院视频| 国产美女激情视频| 亚洲高清免费视频| 欧美 日韩 国产 一区二区三区| 国产欧美一二三区| 在线免费观看日韩av| bt欧美亚洲午夜电影天堂| 黄页网站在线看| 久久精品国产一区二区三 | 精品国产乱码久久久久久鸭王1| 国产免费久久精品| 白丝女仆被免费网站| av欧美精品.com| 日本性生活一级片| 成人深夜在线观看| 91成人在线观看喷潮蘑菇| 国产在线国偷精品免费看| 久久国产精品国产精品| 青草av.久久免费一区| 可以免费观看av毛片| 亚洲专区免费| 黄色一级视频片| 一本久道久久综合婷婷鲸鱼| 成年人午夜免费视频| 99成人免费视频| 老太脱裤让老头玩ⅹxxxx| 亚洲国产日韩欧美一区二区三区| 国产精品无码免费专区午夜| 亚洲小说欧美另类婷婷| 国产一区二区三区小说| 国产一区二区三区自拍| 久久国产午夜精品理论片最新版本| 中文字幕日韩一区二区不卡| 美国av在线播放| 国产精品jizz在线观看美国| 污污污污污污www网站免费| 欧美日韩精品| 岛国大片在线播放| 亚洲美女啪啪| 人妻无码视频一区二区三区| 日韩精品电影一区亚洲| 色片在线免费观看| 国精品**一区二区三区在线蜜桃 | 91社区在线播放| 自拍偷拍视频亚洲| 国产精品高清亚洲| avove在线播放| 亚洲一区二区四区蜜桃| 精品成人久久久| 一本大道久久a久久综合婷婷| 一级片在线观看免费| 欧美丝袜自拍制服另类| 91在线你懂的| 欧美tk丨vk视频| 日韩大胆人体| 日韩在线视频线视频免费网站| 毛片在线不卡| 97香蕉久久夜色精品国产| 欧美大片免费高清观看| 国产免费观看久久黄| 综合伊人久久| 欧美日韩国产高清视频| 99国产**精品****| 黄色大片中文字幕| 日韩国产一区二| 下面一进一出好爽视频| 91看片淫黄大片一级在线观看| 天天干天天舔天天操| 亚洲精品水蜜桃| 亚洲精品男人的天堂| 777午夜精品免费视频| 日本美女一级片| 在线播放日韩精品| 欧美另类tv| 国产精品九九九| 极品国产人妖chinesets亚洲人妖| 日本成人黄色| 欧美午夜免费影院| 国产成人在线视频| 中文字幕在线中文| 欧美丰满日韩| 熟女少妇在线视频播放| 久久97超碰色| 一级国产黄色片| 亚洲麻豆国产自偷在线| 日本视频在线观看免费| 日韩一区二区免费高清| 国产成人天天5g影院在线观看| 久久6精品影院| 欧美videos粗暴| 精品一区二区不卡| 欧美成熟视频| av污在线观看| 久久综合久久99| 青青草国产在线观看| 欧美视频在线一区二区三区| 天天干视频在线观看| 另类专区欧美制服同性| 成人精品国产| 欧美不卡在线一区二区三区| 黑丝一区二区| 午夜视频在线网站| 欧美激情一二三区| 特级西西444www大精品视频免费看| 日韩午夜激情av| 麻豆网站在线| 国产精品入口夜色视频大尺度| 亚州精品视频| 青青青国产在线观看| 成人禁用看黄a在线| 精品无码一区二区三区蜜臀 | 免费看欧美一级片| 国产精品影视在线观看| 欧美性x x x| 欧美日韩不卡视频| 在线免费av电影| 国产精品女人久久久久久| 九九久久婷婷| 男人透女人免费视频| 91小视频在线观看| 日韩精品一区二区在线播放| 精品国偷自产国产一区| 欧美黄色视屏| 福利视频久久| 激情久久五月| 国产伦精品一区三区精东| 一区二区久久久| 亚洲国产综合一区| 久久久久久国产| 视频一区日韩精品| a级免费在线观看| 成人动漫一区二区三区| 日韩高清精品免费观看| 亚洲高清福利视频| 绿色成人影院| 欧美一级爽aaaaa大片| 首页亚洲欧美制服丝腿| 公肉吊粗大爽色翁浪妇视频| 91久久国产综合久久| av福利精品| 成人免费xxxxx在线观看| 亚洲综合激情在线| 4438x全国最大成人| 亚洲成人一区二区| 欧洲天堂在线观看| 国产精品久在线观看| 99re6这里只有精品| 青娱乐精品在线| 亚洲国产精品麻豆| 欧美日韩影视| 国产在线观看不卡| 精品9999| 国产真实乱人偷精品人妻| 欧美亚洲愉拍一区二区| 黄色小网站在线观看| 国产精品免费视频一区二区| 免费精品视频| 亚洲欧美精品久久| 精品国产一区久久| 欧美成人资源| 日本久久高清视频| 91在线看国产| 一区二区三区免费在线| 欧美激情精品久久久久久免费印度 | 欧美日韩一区二区在线观看视频| 成人午夜在线影视| 久久久久久九九九九| 久久国产三级精品| 日本三级欧美三级| 色系列之999| 激情视频极品美女日韩| 欧美日韩亚洲自拍| 一区二区久久久| 成人在线播放视频| 国产精品日本一区二区| 麻豆国产精品官网| 日韩精品在线免费看| 自拍偷拍亚洲欧美|