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

如何解決Nodejs中CPU密集型的任務(wù)

開發(fā) 前端
nodejs子線程和nodejs主線程共享一個(gè)libuv線程池,如果在子線程中使用了libuv的線程池,會(huì)和主線程競(jìng)爭(zhēng)libuv子線程。從而影響主線程的任務(wù)執(zhí)行。如果是純cpu的計(jì)算,則可以這樣使用。

[[340904]]

本文轉(zhuǎn)載自微信公眾號(hào)「編程雜技」,作者theanarkh  。轉(zhuǎn)載本文請(qǐng)聯(lián)系編程雜技公眾號(hào)。

一. 方案對(duì)比

 

二. 其他的線程池方案

1 Libuv和nginx的線程池:線程數(shù)固定,多個(gè)線程共享一個(gè)任務(wù)隊(duì)列,沒有任務(wù)時(shí)主動(dòng)掛起,不會(huì)主動(dòng)退出。

2 Java:線程數(shù)運(yùn)行時(shí)可以動(dòng)態(tài)增加,支持空閑退出、任務(wù)過(guò)載多種處理策略,多種類型的線程池。

三. 訴求

1 提交一個(gè)js文件處理cpu型任務(wù),這樣比較方便。而不是傳一個(gè)函數(shù),需要經(jīng)過(guò)各種序列化反序列化。

2 一個(gè)全局的線程池,可以支持多種類型的任務(wù),類似libuv線程池

3 空閑過(guò)久的線程可以主動(dòng)退出

4 任務(wù)過(guò)載可以動(dòng)態(tài)擴(kuò)展線程數(shù)

Nodejs線程池的調(diào)研:

1 machenjie/node-thread-pool 任務(wù)只能是代碼字符串,固定線程數(shù),不支持空閑線程主動(dòng)退出

2 Truth1984/thread_pools 任務(wù)只能是代碼字符串,沒有實(shí)現(xiàn)池化,每次創(chuàng)建一個(gè)線程,執(zhí)行完任務(wù)退出。

3 bruno303/node-workers-pool 任務(wù)只能是代碼字符串,不支持空閑退出

4 zebrajaeger/threadpool 不是線程池的概念 5

psastras/node-threadpool 沒有實(shí)現(xiàn)池化,不支持空閑退出

6 node-worker-threads-pool 周下載量20k左右,star 80。任務(wù)只能是代碼字符串,不支持空閑線程退出,固定線程數(shù)

7 threads 周下載量20k左右,star 1.1k 是對(duì)線程模塊的封裝,沒有實(shí)現(xiàn)池化能力

8 poolifier 周下載量5000左右,star 59,任務(wù)可以是js文件,一個(gè)類型的任務(wù)新建一個(gè)線程池,無(wú)法共享線程池

目前的npm包看起來(lái)還不太能滿足需求。所以決定寫一個(gè)。

四.線程池的設(shè)計(jì)需要考慮的問題

1 對(duì)于純cpu型的任務(wù),線程數(shù)和cpu核數(shù)要相等才能達(dá)到最優(yōu)的性能,否則過(guò)多的線程引起的上下文切換反而會(huì)導(dǎo)致性能下降。

2 對(duì)于io型的任務(wù),更多的線程理論上是會(huì)更好,因?yàn)榭梢愿绲亟o硬盤發(fā)出命令,磁盤會(huì)優(yōu)化并持續(xù)地處理請(qǐng)求。當(dāng)然,線程數(shù)也不是越多越好。線程過(guò)多會(huì)引起系統(tǒng)負(fù)載過(guò)高,過(guò)多上下文切換也會(huì)帶來(lái)性能的下降。

3 使用方便、簡(jiǎn)單

整體架構(gòu)(原圖[1])

 

五. 設(shè)計(jì)思想

1 任務(wù)隊(duì)列的設(shè)計(jì)

1.1傳統(tǒng)的線程池設(shè)計(jì) 維護(hù)一個(gè)共享的任務(wù)隊(duì)列,然后多個(gè)線程通過(guò)加鎖互斥的方式訪問該隊(duì)列,取出任務(wù)執(zhí)行。比如libuv,nginx。

1.2 我們的設(shè)計(jì) 因?yàn)槲覀兪峭ㄟ^(guò)js使用nodejs線程池的,隊(duì)列也是使用js數(shù)據(jù)結(jié)構(gòu)表示的。所以我們無(wú)法通過(guò)加鎖的方式互斥訪問共享隊(duì)列。這就會(huì)引起競(jìng)態(tài)條件。我們使用的方式是,每個(gè)子線程維護(hù)自己的任務(wù)隊(duì)列,調(diào)度中心把任務(wù)提交給子線程,子線程自己插入所維護(hù)的隊(duì)列中。

2 線程類型和任務(wù)數(shù) 把線程分為核心線程和替補(bǔ)線程。分為幾個(gè)關(guān)鍵的概念:子線程當(dāng)前的任務(wù)數(shù),線程池的總?cè)蝿?wù)數(shù)、核心線程數(shù)和最大線程數(shù)。在總?cè)蝿?wù)數(shù)還沒有得到閾值時(shí),所有任務(wù)都由核心線程處理,達(dá)到閾值后,會(huì)創(chuàng)建替補(bǔ)線程處理。

3 過(guò)載處理策略和選擇線程的策略 任務(wù)過(guò)載時(shí),就會(huì)觸發(fā)過(guò)載處理策略。分為報(bào)錯(cuò)、在主線程執(zhí)行任務(wù)、繼續(xù)交給子線程處理、刪除最老的任務(wù)。選擇線程的策略為選擇任務(wù)數(shù)最少的線程。

4 空閑策略 當(dāng)沒有任務(wù)可處理的時(shí)候,線程池的線程怎么辦?

4.1 傳統(tǒng)的設(shè)計(jì) 使用條件變量機(jī)制,把線程阻塞在條件變量中,這時(shí)候操作系統(tǒng)不會(huì)調(diào)度該線程執(zhí)行,所以不會(huì)浪費(fèi)cpu,等到有新任務(wù)到來(lái)時(shí),主線程會(huì)喚醒被阻塞的子線程。不過(guò)阻塞的線程依然占據(jù)著系統(tǒng)資源,如果一直沒有任務(wù),則浪費(fèi)資源。

4.2 我們的設(shè)計(jì) 我們?cè)趈s層無(wú)法像底層線程一樣使用條件變量,所以我們無(wú)法阻塞自己,這就意味著我們會(huì)一直在空轉(zhuǎn)、浪費(fèi)資源。所以我們?cè)O(shè)計(jì)了線程的空閑退出時(shí)間,達(dá)到這個(gè)時(shí)間后,線程退出。盡快釋放資源。

5 如何設(shè)計(jì)用戶和線程池的通信 用戶提交任務(wù)后,如果知道任務(wù)什么時(shí)候執(zhí)行完?如何拿到執(zhí)行結(jié)果?執(zhí)行任務(wù)的時(shí)候,參數(shù)如何傳進(jìn)去?

5.1 傳統(tǒng)的設(shè)計(jì) 用戶把需要處理的邏輯封裝到函數(shù)中,然后子線程中阻塞時(shí)執(zhí)行,執(zhí)行完后,同步拿到結(jié)果。

5.2 我們的設(shè)計(jì) 但是在nodejs中不太一樣。Nodejs使用work_thread模塊創(chuàng)建的線程,其實(shí)是一個(gè)和主線程獨(dú)立的事件循環(huán)。所以我們?cè)谧泳€程里執(zhí)行任務(wù)時(shí),其實(shí)就相當(dāng)于在執(zhí)行一個(gè)nodejs的實(shí)例,這就意味著我們可以以同步和異步的方式編程我們?nèi)蝿?wù)函數(shù)代碼。那么以異步方式進(jìn)行處理的任務(wù),我們?nèi)绾文玫浇Y(jié)果?為了解決以上問題,我們使用函數(shù)和Promise方案。用戶提交的任務(wù)具體表現(xiàn)為一個(gè)返回Promise的函數(shù),使用函數(shù)是因?yàn)槲覀兛梢栽谔幚砣蝿?wù)(執(zhí)行函數(shù))時(shí),把用戶自定義的參數(shù)傳進(jìn)去,使用Promise可以等到用戶返回的Promise決議時(shí),拿到返回的值,從而返回給用戶。

具體實(shí)現(xiàn):用戶定義的邏輯test.js

  1. module.exports = function() { 
  2.     return new Promise((resolve, reject) => { 
  3.         setTimeout(() => { 
  4.             resolve({code: 0}); 
  5.         },3000) 
  6.     }) 

子線程邏輯

  1. const result = await require('./test')(options); 

六.成果

線程池支持的參數(shù)

  1. 1 coreThreads:核心線程數(shù),默認(rèn)10個(gè) 
  2. 2 maxThreads:最大線程數(shù),默認(rèn)50,只在支持動(dòng)態(tài)擴(kuò)容的情況下,該參數(shù)有效,否則該參數(shù)等于核心線程數(shù) 
  3. 3 sync:線程處理任務(wù)的模式,同步則串行處理任務(wù),異步則并行處理任務(wù),不同步等待用戶代碼的執(zhí)行結(jié)果 
  4. 4 discardPolicy:任務(wù)超過(guò)閾值時(shí)的處理策略,策略如下 
  5. 5 preCreate:是否預(yù)創(chuàng)建線程池 
  6. 6 maxIdleTime:線程空閑多久后自動(dòng)退出 
  7. 7 pollIntervalTime:線程隔多久輪詢是否有任務(wù)需要處理 
  8. 8 maxWork:線程池最大任務(wù)數(shù)  
  9. 9 expansion:是否支持動(dòng)態(tài)擴(kuò)容線程,閾值是最大線程數(shù) 

支持的線程池類型

  1. // 串行處理任務(wù)隊(duì)列里的任務(wù) 
  2. const defaultSyncThreadPool = new SyncThreadPool(); 
  3. // 并行處理任務(wù)隊(duì)列里的任務(wù) 
  4. const defaultAsyncThreadPool = new AsyncThreadPool(); 
  5. // 針對(duì)cpu密集型任務(wù)的線程池,線程數(shù)等于cpu核數(shù) 
  6. const defaultCpuThreadPool = new CPUThreadPool(); 
  7. // 線程數(shù)固定的線程池 
  8. const defaultFixedThreadPool = new FixedThreadPool(); 
  9. // 只有一個(gè)線程的線程池,任務(wù)在線程池中按序執(zhí)行 
  10. const defaultSingleThreadPool = new SingleThreadPool(); 

七. 使用方式

方式1

 

nodejs子線程和nodejs主線程共享一個(gè)libuv線程池,如果在子線程中使用了libuv的線程池,會(huì)和主線程競(jìng)爭(zhēng)libuv子線程。從而影響主線程的任務(wù)執(zhí)行。如果是純cpu的計(jì)算,則可以這樣使用。下面是這種使用方式下,nodejs的架構(gòu)。

 

方式2

 

在nodejs主進(jìn)程外開啟一個(gè)新的進(jìn)程進(jìn)行任務(wù)的處理,和主進(jìn)程保持獨(dú)立,保證穩(wěn)定性的同時(shí),也不會(huì)和主進(jìn)程競(jìng)爭(zhēng)libuv的線程。如果在子線程中需要用到libuv線程池,則使用方式2比較好。下面是方式2對(duì)應(yīng)的nodejs架構(gòu)。

 

八. 具體例子

 

References

[1] 原圖: https://www.processon.com/view/link/5f53a187e401fd60bde1bab1

 

[2] github地址: https://github.com/theanarkh/nodejs-threadpool

 

責(zé)任編輯:武曉燕 來(lái)源: 編程雜技
相關(guān)推薦

2025-02-24 09:00:00

CPUI/O密集型任務(wù)

2011-11-11 09:11:09

云計(jì)算HPC集群

2018-03-22 09:16:06

密集型場(chǎng)景SSD

2012-10-23 09:30:18

計(jì)算應(yīng)用虛擬機(jī)Java

2025-03-03 11:41:11

2012-12-14 11:00:02

VDI桌面虛擬化

2020-09-30 10:56:13

Facebook 開發(fā)開源

2023-01-03 19:11:09

CPUI/O速度

2025-05-13 01:00:00

HippoRAG大語(yǔ)言模型LLMs

2012-10-08 09:45:22

數(shù)據(jù)密集型處理系統(tǒng)

2022-06-27 14:01:31

LZ4 分析數(shù)據(jù)密集型壓縮算法

2012-12-17 11:20:51

VDI桌面虛擬化

2011-11-14 13:29:22

移動(dòng)應(yīng)用開發(fā)移動(dòng)開發(fā)移動(dòng)互聯(lián)網(wǎng)

2015-05-11 11:37:04

惠普

2010-04-14 15:30:41

Oracle數(shù)據(jù)庫(kù)

2013-08-15 15:24:07

戴爾

2016-05-09 10:08:05

IBMIBM FlashSy

2011-03-23 14:42:47

CPU過(guò)度消耗

2011-07-25 08:49:32

服務(wù)器整合虛擬化

2012-11-05 15:53:18

高性能計(jì)算北龍超云
點(diǎn)贊
收藏

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

92久久精品一区二区| 色噜噜狠狠一区二区| 天堂中文在线资源| 久久精品导航| 日韩在线视频网站| 一区二区三区国产好的精华液| 国产美女av在线| 成年人国产精品| 国产成人综合亚洲| 老司机成人免费视频| 黄色欧美网站| 欧美日韩免费一区二区三区 | av污在线观看| 青草视频在线免费直播 | 人人艹在线视频| 北条麻妃一区二区三区在线观看 | 一区二区三区四区精品视频| 一本大道久久a久久综合| 尤物国产精品| 深夜福利免费在线观看| 国产一区二区三区精品欧美日韩一区二区三区 | 精品无码久久久久成人漫画| 欧美成人基地| 日韩一区二区视频| 久久精品影视大全| 美女视频在线免费| 亚洲影视在线播放| 亚洲精品一区二区毛豆| 日日夜夜精品免费| 国产乱码字幕精品高清av| 国产精品黄色av| 亚洲黄色小说图片| 激情久久婷婷| 欧美激情国产高清| 人妻少妇精品一区二区三区| 欧美日韩激情在线一区二区三区| 亚洲电影免费观看高清完整版在线| 亚洲免费一级视频| 欧美大片免费高清观看| 激情成人中文字幕| 国产不卡一区二区视频| 日韩专区av| 亚洲另类在线一区| 亚洲国产精品影视| 91这里只有精品| 国产网站一区二区三区| 久久福利电影| 亚洲人视频在线观看| 成人免费高清在线观看| 99精彩视频在线观看免费| 亚洲在线免费观看视频| 日本欧美加勒比视频| 国产成人aa精品一区在线播放| 亚洲国产精品成人无久久精品| 欧美精品首页| 九九热最新视频//这里只有精品| 欧美在线视频第一页| 888久久久| 久热精品视频在线免费观看| 5566中文字幕| 欧美/亚洲一区| 欧美日韩成人在线视频| 五月婷婷一区二区| 国产综合网站| 91av视频在线播放| 视频一区二区三区四区五区| 性8sex亚洲区入口| 国产精品国产福利国产秒拍 | 91超碰在线免费| 亚洲成av人在线观看| 精品无码国模私拍视频| 色是在线视频| 欧美日韩专区在线| 欧美特黄aaa| 高清一区二区三区av| 日韩西西人体444www| 大尺度在线观看| 亚洲ab电影| 少妇av一区二区三区| 在线观看亚洲网站| 亚洲精品男同| 国产91免费观看| 888奇米影视| 成人免费高清在线| 日本一区二区三不卡| 日韩美女网站| 黄色精品在线看| 一区二区三区网址| 日本在线一区二区三区| 日韩h在线观看| a资源在线观看| 欧美在线国产| 日本韩国在线不卡| 国产伦子伦对白视频| 成人国产亚洲欧美成人综合网| 久久亚洲免费| 国产鲁鲁视频在线观看特色| 婷婷久久综合九色国产成人| 天天色综合天天色| 波多野结衣欧美| 日韩中文字幕视频| 99久在线精品99re8热| 久久精品国产精品亚洲红杏| 国产欧美一区二区视频 | 人人精品亚洲| 日韩视频免费观看| 日韩少妇裸体做爰视频| 久久99精品久久久久久| 久久久精品动漫| 成人在线播放免费观看| 一本大道av一区二区在线播放| 午夜激情影院在线观看| 九九久久成人| 91精品国产九九九久久久亚洲| 亚洲图片欧美在线| 99久久精品国产一区二区三区| 亚洲色图自拍| 97成人资源| 欧美精品一区视频| 999精品视频在线观看播放| 亚洲男女自偷自拍| 翡翠波斯猫1977年美国| 国产最新在线| 欧美日韩一区在线| 日本黄色特级片| 黄色免费成人| 91精品国产91久久久久青草| 色欧美激情视频在线| 91久久人澡人人添人人爽欧美| 一二三区视频在线观看| 午夜片欧美伦| 国产一区视频在线| 国产黄在线观看| 欧美日韩亚洲视频一区| 中文字幕天堂网| 国产综合欧美| 国产精品夜夜夜一区二区三区尤| 成人福利片网站| 4438x成人网最大色成网站| 国产99在线 | 亚洲| 日韩精品一卡二卡三卡四卡无卡| 久久综合婷婷综合| 青青青免费在线视频| 亚洲电影免费观看高清完整版在线观看| 91日韩中文字幕| 国产一区二区按摩在线观看| 欧美h视频在线观看| 日韩电影精品| 久久久国产精品亚洲一区| 一级片在线免费观看视频| 日本一区二区三区高清不卡 | 久久网免费视频| 国产成人免费视频网站| 2022中文字幕| 狠狠一区二区三区| 欧美在线性爱视频| 欧美中文在线| 91黄色免费观看| 久久午夜精品视频| 九色综合国产一区二区三区| 国产日韩第一页| 亚洲国产aⅴ精品一区二区| 欧美国产亚洲视频| 污视频软件在线观看| 色94色欧美sute亚洲线路一久 | 国产精品91久久久久久| 高清性色生活片在线观看| 欧美午夜一区二区| 日本一级特级毛片视频| 成人免费视频app| 337p粉嫩大胆噜噜噜鲁| 免费观看久久av| 国产免费久久av| 午夜dj在线观看高清视频完整版| 欧美大片日本大片免费观看| 色播视频在线播放| 欧美激情资源网| 欧美一级特黄aaa| 狠狠色丁香久久综合频道| 欧美激情一区二区三区在线视频| 日韩制服诱惑| 欧美激情2020午夜免费观看| 日本高清中文字幕二区在线| 欧美日韩精品专区| 国产一级特黄毛片| 国产视频一区在线观看| 亚洲网中文字幕| 国产精品久久久久久久久久妞妞| 日韩国产精品一区二区| 精品一区二区三区视频在线播放| 国内外成人免费激情在线视频 | 精品中文字幕在线2019| 亚洲欧洲视频在线观看| 欧美精品亚洲二区| 日韩av大片在线观看| 国产精品电影一区二区| 亚洲综合自拍网| 黑人精品欧美一区二区蜜桃| 黄色网页免费在线观看| 小小影院久久| 欧美精品尤物在线| 久久久久久久久成人| 欧美一区深夜视频| 在线观看操人| 一区二区三区四区视频| 六月丁香色婷婷| 欧美日产国产精品| 国产一级免费视频| 亚洲自拍另类综合| 蜜桃视频最新网址| 久久亚洲综合色一区二区三区| 欧美性受xxxxxx黑人xyx性爽| 一本久道久久久| 九九久久九九久久| 色综合久久一区二区三区| 久久草.com| 成人av婷婷| 亚洲资源在线看| 久久亚洲国产精品尤物| 日本a级片电影一区二区| 婷婷av在线| 久久精品国产免费观看| 国产天堂在线| 精品在线欧美视频| 色婷婷在线视频| 欧美videofree性高清杂交| 国产一区二区在线不卡| 欧美色大人视频| 波多野结衣在线观看视频| 精品久久久香蕉免费精品视频| 激情五月少妇a| 亚洲婷婷在线视频| 国产精品久久国产精麻豆96堂| 久久久精品免费观看| 朝桐光av一区二区三区| 国产成人精品免费网站| 久久艹这里只有精品| 国内精品国产三级国产a久久| 亚洲第一狼人区| 麻豆高清免费国产一区| 无限资源日本好片| 蜜臀av一区二区在线观看| 国内自拍视频一区| 日韩1区2区日韩1区2区| 亚洲一区二区蜜桃| 蜜桃视频第一区免费观看| 日韩一级片播放| 日本美女视频一区二区| 一区二区三区网址| 久久精品国产精品亚洲红杏 | 99久久综合国产精品| 成人在线电影网站| 99精品视频在线观看免费| 欧美一区二区免费在线观看| 成人av资源网站| a天堂视频在线观看| 99久久精品情趣| 中文人妻一区二区三区| 久久久久成人黄色影片| 一级黄色片网址| 国产精品久久久久久福利一牛影视| 国产福利在线导航| 一区二区三区在线观看网站| 免费中文字幕视频| 午夜精品一区二区三区电影天堂 | 蜜臀国产一区二区三区在线播放| 在线免费观看视频黄| 国产中文字幕精品| 最新国产精品自拍| 97精品电影院| 久久久久亚洲av无码a片| 国产精品美女视频| 天天看片中文字幕| 午夜精品一区二区三区电影天堂| 少妇一级淫片免费放中国 | 五月婷婷激情在线| 亚洲热线99精品视频| 欧美一区二区三区| 欧美激情视频在线观看| 深夜在线视频| 成人亲热视频网站| 国产精品美女在线观看直播| 人偷久久久久久久偷女厕| 99久久99热这里只有精品 | 日韩伦理在线| 国产精品久久久一区| 精品国产鲁一鲁****| 精品视频在线观看| 91日韩免费| 99视频在线免费播放| 麻豆成人久久精品二区三区小说| 免费看91视频| 国产亚洲精品7777| 九九九久久久久| 欧美又粗又大又爽| 欧美一级特黄aaaaaa| 在线丨暗呦小u女国产精品| 欧美人与性动交α欧美精品济南到 | 久操免费在线视频| 日本乱码高清不卡字幕| 性猛交xxxx乱大交孕妇印度| 亚洲欧美三级伦理| 91网址在线观看| 国产极品精品在线观看| 91综合精品国产丝袜长腿久久| 欧美中日韩免费视频| 黄页网站一区| 午夜啪啪小视频| 久久青草欧美一区二区三区| wwwav国产| 欧美网站大全在线观看| 五月激情丁香婷婷| 综合网中文字幕| 精品极品在线| 69174成人网| 91久久夜色精品国产按摩| 国产视频一区二区三区在线播放| 国产91精品久久久久久久网曝门| 国产在线免费av| 日韩欧美在线一区| 内射无码专区久久亚洲| 久久资源免费视频| 福利精品在线| 日本不卡一区二区三区视频| 一区二区三区四区五区精品视频| 亚洲图片 自拍偷拍| 国产精品全国免费观看高清| 色屁屁影院www国产高清麻豆| 精品国产亚洲一区二区三区在线观看| 久cao在线| 国产日产久久高清欧美一区| 日韩免费一区| 99视频在线视频| 国产日韩欧美高清在线| 一二三区免费视频| 亚洲女人天堂色在线7777| 忘忧草在线影院两性视频| 国产伦精品一区二区三区视频孕妇| 在线观看国产精品入口| 性欧美在线视频| 亚洲天堂久久久久久久| 国产又黄又大又爽| 在线a欧美视频| 高清av一区| 亚洲人成77777| 麻豆免费看一区二区三区| 日本高清黄色片| 欧美久久久久免费| 国产黄色小视频在线| 亚洲综合中文字幕在线观看| 欧美一区成人| 亚洲午夜久久久久久久久| 亚洲综合在线五月| 日本xxxxxwwwww| 51精品国产黑色丝袜高跟鞋| 欧美禁忌电影网| 杨幂毛片午夜性生毛片| 国产精品视频观看| 国产日韩在线观看一区| 欧美激情伊人电影| 蜜桃久久久久| 亚洲高清在线免费观看| 中文字幕中文字幕在线一区| 国产乱码久久久久| 欧美极品美女电影一区| 欧美大胆视频| 能看的毛片网站| 成人免费在线播放视频| www天堂在线| 欧美一区第一页| 成人一区不卡| 手机看片国产精品| 天天色综合天天| 91视频在线观看| 5g影院天天爽成人免费下载| 99亚洲一区二区| 大胸美女被爆操| 日韩欧美精品在线视频| 91精品论坛| 亚洲精品偷拍视频| 99视频精品在线| 一区二区日韩在线观看| 久久久久国产精品www| 精品免费一区二区| 成年人网站av| 欧美日韩午夜剧场| 欧美一区二区三区| 久久精品五月婷婷| 国产一区免费电影| www毛片com| 欧美大片欧美激情性色a∨久久| 日韩精品社区| 中文国产在线观看| 91久久精品一区二区三区| 尤物视频在线看| 神马影院一区二区| 不卡一二三区首页| 一区二区三区免费在线视频| 91黑丝高跟在线| 在线中文一区|