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

推薦一個檢測 JavaScript 內存泄漏的神器

開發 架構
最近,Meta 開源了一款檢測 JavaScript 代碼內存泄漏的框架:MemLab,我們來一起看看這個框架有啥神奇之處吧。

大家好,我是 ConardLi?。作為一名 Web? 應用程序開發者,排查和修復 JavaScript 代碼的內存泄漏一直是最困擾我的問題之一。

最近,Meta? 開源了一款檢測 JavaScript? 代碼內存泄漏的框架:MemLab,我們來一起看看這個框架有啥神奇之處吧~

2020? 年,Meta? 的工程師將 Facebook.com? 重構為了單頁應用(SPA?),程序的大部分渲染和導航都會在客戶端使用 JavaScript? 完成。后來他們又使用類似的架構來重構了 Meta? 的大多數其他流行的網絡應用程序,包括 Instagram? 和 Workplace?。雖然這種架構能夠提供更快的用戶交互、更好的開發者體驗和更像原生應用程序的感覺,但是在客戶端維護 Web 應用的狀態會讓內存的管理變得更加復雜。

使用 Meta? 網站的用戶經常會快速注意到一些性能和功能正常使用的問題。然而,內存泄漏就是另一回事了。它不會立即被察覺出來,因為它一次會占用一大塊內存 — 然后逐漸影響整個 Web 會話并讓后續的交互和響應變得更慢。

Meta? 的工程師花費了大量時間來測試、優化和控制頁面加載和交互時間,以及 JavaScript? 的代碼大小。相比之下,他們在管理 Web? 瀏覽器內存方面做的工作并不多。當分析新 Facebook.com? 的內存使用情況時,發現客戶端的內存使用情況和內存不足 (OOM) 崩潰的數量一直在攀升。較高的內存使用對頁面加載、交互性能、用戶參與度等核心指標都有負面影響。

為了幫助開發者解決這個問題,Meta? 的工程師構建了 MemLab?,這是一個 JavaScript? 內存測試框架,可以自動進行內存泄漏檢測,并且更容易找到內存泄漏的根本原因。Meta? 使用 MemLab 成功地控制了不可持續的內存增長,并識別出了產品和基礎設施中的內存泄漏和內存優化的一些手段。

導致 Web 應用內存過高的原因

因為內存泄漏通常不是很明顯,在開發過程中,以及做 Code Review? 的時候都很難發現,而且在生產環境中通常也很難找到根本原因。雖然主流的 JavaScript 運行時都有垃圾回收機制,那么為什么還會有內存泄漏呢?

JavaScript 代碼中可能會有很多隱藏對象的引用,而隱藏的引用會以許多意想不到的方式導致內存泄漏。

例如:

var obj = {};
console.log(obj);
obj = null;

在 Chrome? 中,即使我們將引用設置為 null? ,這段代碼也會泄漏 obj? 。發生這種情況是因為 Chrome? 需要保留對打印對象的內部引用,以便以后可以在 Web 控制臺中對其進行檢查(即使在 Web 控制臺沒打開的情況下)。

在某些情況下,內存在技術上并沒有發生泄漏,而是在用戶會話期間線性增長而且沒有限制。最常見的原因是客戶端緩存沒有內置任何釋放的邏輯,無限滾動列表沒有任何虛擬化的功能,無法在添加新內容時從列表中刪除較早的內容。

我們也沒有適當的自動化系統和流程來控制內存,因此防止此類問題的唯一防御措施就是專家通過 Chrome DevTools 定期挖掘內存泄漏,一些大型的項目幾乎每天都會有發布和變更,這樣的工作方式是不可持續的。

MemLab 的工作原理

MemLab? 通過預定義的測試場景運行無頭瀏覽器并比較和分析 JavaScript 堆快照來發現內存泄漏的問題。

圖片

這個過程可以分為下面六個步驟:

1.「瀏覽器交互」:MemLab? 使用 Puppeteer 自動化瀏覽器,在目標頁面上查找泄露的對象;

2.「區分堆」:導航到一個頁面然后離開它,正常情況下該頁面分配的大部分內存也應該被釋放,如果沒有,可能暗示著存在內存泄漏。MemLab? 通過區分 JavaScript? 堆并記錄在頁面 B? 上分配的一組對象,這些對象沒有在頁面 ?A 上分配,但在重新加載頁面 A 時仍然存在,從而發現潛在的內存泄漏;

3.「細化內存泄漏列表」:內存泄漏檢測器進一步結合了特定框架的知識來細化泄漏對象的列表。例如,React? 分配的 Fiber? 節點(React? 用于渲染虛擬 DOM 的內部數據結構)應該在我們訪問多個選項卡后清理時釋放。

4.「生成 retainer traces」:遍歷堆并為每個泄漏的對象生成 retainer traces? 。trace? 顯示了泄漏對象為何以及如何在內存中保持活動狀態。打破引用鏈意味著泄漏的對象將不再可以從 GC? 的根訪問,因此可以進行垃圾回收。通過一步步地跟蹤,就可以找到應該設置為 null 的引用;

5.「聚合 retainer traces」:將所有 retainer traces? 聚集在一起,并為每個共享相似 retainer traces 的泄漏對象聚合顯示為一個跟蹤,其中還包括調試信息,例如支配節點和保留大小。

6.「報告泄漏」:定期運行 MemLab?,以持續收集 retainer traces?,任何新的 traces? 都會記錄到內部儀表板,開發者可以查看每個內存泄漏的 retainer traces 上的對象屬性。

MemLab 有哪些能力

內存泄漏檢測

對于瀏覽器內存泄漏的檢測,MemLab? 需要開發者提供的唯一輸入就是一個測試場景文件,這個文件定義了如何通過使用 Puppeteer API? 和 CSS? 選擇器覆蓋三個回調來與網頁交互。MemLab? 會自動區分 JavaScript 堆、優化內存泄漏并聚合結果。

圖片

JavaScript 堆的 Graph-view API

MemLab? 支持一個自定義的泄漏檢測器,作為篩選器回調,應用于每個由目標交互分配的泄漏候選對象,但之后從不釋放。泄漏過濾器回調函數可以遍歷堆并確定哪些對象是內存泄漏。例如,我們的內置檢漏器會跟蹤 React Fiber? 節點的返回鏈路,檢查 Fiber? 節點是否與 React Fiber 樹分離。

圖片

為了分析每個可能內存泄漏的上下文,MemLab? 提供了一個 JavaScript? 堆的內存效率圖。這可以在不了解 V8? 堆快照文件結構的任何領域知識的情況下查詢和遍歷 JavaScript 堆。

在視圖中,堆中的每個 JavaScript? 對象或原生對象都是一個圖節點,堆中的每個 JavaScript? 引用都是一個圖的邊。實際應用程序的堆大小通常很大,因此圖視圖需要在提供直觀的面向對象堆遍歷 API? 的同時提高內存效率。因此,圖節點被設計成了虛擬的,不通過 JavaScript? 引用進行連接。當分析代碼遍歷堆時,虛擬圖會部分地即時構建圖的接觸部分。圖的任何部分都可以很容易地釋放,因為這些虛擬節點彼此之間沒有 JavaScript 引用。

堆視圖可以從基于 Chromium? 的瀏覽器、Node.js、Electron? 和 Hermes? 獲取的 JavaScript? 堆快照加載。這允許分析復雜的模式并回答諸如 “有多少 React Fiber? 節點是備用的 Fiber 節點,它們用于不完整的并發渲染?”之類的問題。

import {getHeapFromFile} from '@memlab/heap-analysis';
const heapGraph = await getHeapFromFile(heapFile);
heapGraph.nodes.forEach(node => {
// heap node traversal
node.type
node.references
);

內存斷言

Node.js? 程序或 Jest? 測試也可以使用 graph-view API 來獲取其自身狀態的堆視圖,進行自內存檢查,并編寫各種內存斷言。

import type {IHeapSnapshot} from '@memlab/core';
import {config, takeNodeMinimalHeap, tagObject} from '@memlab/core';

test('memory test', async () => {
config.muteConsole = true;
const o1 = {};
let o2 = {};

// tag o1 with marker: "memlab-mark-1", does not modify o1 in any way
tagObject(o1, 'memlab-mark-1');
// tag o2 with marker: "memlab-mark-2", does not modify o2 in any way
tagObject(o2, 'memlab-mark-2');

o2 = null;

const heap: IHeapSnapshot = await takeNodeMinimalHeap();

// expect object with marker "memlab-mark-1" exists
expect(heap.hasObjectWithTag('memlab-mark-1')).toBe(true);

// expect object with marker "memlab-mark-2" can be GCed
expect(heap.hasObjectWithTag('memlab-mark-2')).toBe(false);

}, 30000);

內存工具箱

除了內存泄漏檢測,MemLab? 還包括一組內置的 CLI? 命令和 API,用于尋找可能的內存優化機會:

圖片圖片

Meta 使用 MemLab 的實踐

在過去的幾年中,Meta? 一直在使用 MemLab 檢測和診斷內存泄漏,并收集了很多有助于優化內存、減少 OOM 崩潰并改善用戶體驗的手段。

圖片

在 2021? 年上半年, Facebook.com? 上的 OOM? 崩潰減少了 50%。

React Fiber 節點清理

為了渲染組件,React? 構建了 Fiber? 樹 — 一個 React? 用于渲染虛擬 DOM? 的內部數據結構。雖然 Fiber? 樹看起來像一棵樹,但它是一個雙向圖,將所有 Fiber? 節點、React? 組件實例和關聯的 HTML DOM? 元素強連接起來。理想情況下,React? 維護對組件 Fiber? 樹的根的引用,并防止 Fiber? 樹被垃圾回收。當一個組件被卸載時,React 會斷開組件的根與 Fiber 樹的其余部分之間的連接,然后這些部分就可以被垃圾回收了。

擁有這樣的強連接圖的缺點是,如果有任何外部引用指向圖的任何部分,就無法對整個圖進行垃圾回收。例如,下面 export? 語句在模塊范圍級別緩存 React? 組件,因此相關的 Fiber? 樹和分離的 DOM 元素永遠不會被釋放。

export const Component = (( 
<List> ... </List>
): React.Element<typeof List>);

也不僅僅是 React 數據結構要 keep alive? ,Hooks? 和它們的閉包也可以讓各種其他對象保活。這意味著單個 React 組件泄漏可能會導致頁面對象的重要部分泄漏,從而導致巨大的內存泄漏。

圖片

為了防止 Fiber? 樹中內存泄漏的級聯效應,MemLab? 添加了一個樹的完整遍歷,當組件在 React 18? 中卸載時會進行清理。這可以讓垃圾回收器在清理未掛載的樹方面做得更好一點。這個優化將 Facebook? 上的平均內存使用量減少了近 25%?,其他使用 React? 的站點在升級時也有了很大的改進。你可能會擔心這種比較激進的清理方式可能會減慢 React 組件的卸載速度,但令人驚訝的是,由于內存的減少,性能也有顯著的提升。

string interning

通過利用 MemLab? 中的 heap analysis API,Meta? 團隊發現字符串占據了 70%? 的堆內存,其中一半的字符串至少有一個重復的實例。(V8? 對 string interning 支持的不是很好,這是一種對具有相同值的字符串實例進行重復數據刪除的優化。)

另外很大一部分字符串內存被 Relay? 中緩存的鍵字符串消耗。通過與 Relay? 和 React Apps? 團隊合作,可以在客戶端插入和縮短過長的字符串鍵來優化 Relay 緩存鍵字符串。

這種優化使 Relay? 能夠緩存更多數據,允許站點向用戶顯示更多內容,尤其是在客戶端 RAM? 有限的情況下。內存 p99? 和 OOM? 崩潰減少了 20%,頁面渲染速度更快,用戶體驗得到改善,在收入上也有一定提升。

試用 MemLab:

npm i -g memlab

最后:MemLab Github:https://github.com/facebookincubator/memlab

責任編輯:趙寧寧 來源: code秘密花園
相關推薦

2025-08-27 08:24:23

2025-08-27 00:01:55

2023-05-14 23:38:43

Glarity用戶視頻

2020-10-23 10:50:39

內存泄漏語言代碼

2011-06-16 09:28:02

C++內存泄漏

2009-06-16 11:20:22

內存泄漏

2021-08-05 15:28:22

JS內存泄漏

2020-06-08 09:18:59

JavaScript開發技術

2025-04-11 08:20:00

NetQuality網絡質量檢測網絡性能

2023-10-31 16:40:38

LeakCanary內存泄漏

2018-12-07 10:52:08

內存泄漏方法

2015-07-10 09:15:47

LeakCanary內存泄漏

2010-09-25 11:07:45

Java內存泄漏

2022-05-26 09:51:50

JavaScrip內存泄漏

2009-06-10 22:03:40

JavaScript內IE內存泄漏

2022-05-27 09:02:31

Openbase開源前端

2025-07-26 00:00:00

AI驅動工具

2025-08-04 01:00:00

JavaScript內存泄漏前端

2025-07-09 03:00:00

2023-11-22 08:26:03

HutoolJava工具集
點贊
收藏

51CTO技術棧公眾號

精品国产99国产精品| 成人v精品蜜桃久久一区| 正在播放欧美一区| 亚洲第一天堂久久| 性直播体位视频在线观看| 国产高清不卡二三区| 国内免费精品永久在线视频| 好吊日免费视频| 经典三级一区二区| 亚洲人精品午夜| 含羞草久久爱69一区| 免费无码国产精品| 亚洲大全视频| 日韩精品有码在线观看| 日韩va在线观看| а√天堂中文在线资源8| 中文字幕不卡的av| 国产精品一级久久久| 男人天堂视频网| 欧美日韩亚洲三区| 在线视频中文亚洲| 亚洲高清无码久久| 日韩一级特黄| 精品日韩视频在线观看| 精品少妇人妻av一区二区| 亚洲av电影一区| 国产一区美女在线| 国产精品九九九| 精品一区在线视频| 91精品综合久久久久久久久久久 | 成人国产电影网| 国产精品久久久久久久app| 精品小视频在线观看| 五月激情久久久| 这里只有精品丝袜| av网站免费在线播放| 999久久精品| 欧美一区二区视频在线观看2022| 国产一区视频免费观看| 国产精品国精产品一二| 亚洲欧美二区三区| 自拍偷拍亚洲色图欧美| h网站视频在线观看| 久久综合成人精品亚洲另类欧美| 国产精品午夜av在线| 亚洲免费国产视频| 国产精品一区二区不卡| 91在线精品播放| 国产剧情精品在线| 国产一区二区在线观看免费| 91精品国产综合久久香蕉最新版| 免费黄色一级大片| 日本视频在线一区| 国产精品成人在线| 亚洲视屏在线观看| 日本女优在线视频一区二区| 国产精品夫妻激情| 中文字幕av影视| 久久精品国产成人一区二区三区 | 欧美第一黄网免费网站| 麻豆精品一区二区三区视频| av在线小说| 亚洲免费在线看| 一本—道久久a久久精品蜜桃| 天堂中文а√在线| 日韩久久一区二区| av中文字幕av| heyzo高清在线| 欧美日韩免费一区| 乱子伦视频在线看| 草民电影神马电影一区二区| 欧美日韩免费高清一区色橹橹| 成人亚洲精品777777大片| 国产福利亚洲| 日韩一区二区在线观看视频播放| av在线网站免费观看| 亚洲图色一区二区三区| 亚洲精品美女在线观看| 国产中年熟女高潮大集合| 国产精品一区二区99| 最近免费中文字幕视频2019| 乱h高h女3p含苞待放| 国内自拍视频一区二区三区| 456国产精品| 在线免费观看高清视频| 国产成人精品影院| 蜜桃臀一区二区三区| 草草影院在线观看| 一区二区三区在线播| 日韩在线视频在线观看| 国产精品.xx视频.xxtv| 欧美成人伊人久久综合网| 三叶草欧洲码在线| 图片区亚洲欧美小说区| 国产做受高潮69| 日韩xxx视频| 国产成人精品午夜视频免费| 欧美午夜视频在线| 永久免费网站在线| 在线观看亚洲专区| 日本一级大毛片a一| 欧美午夜精彩| 国内精品久久久| 91成人国产综合久久精品| 成人看片黄a免费看在线| 先锋影音亚洲资源| 岛国片av在线| 欧美久久久久中文字幕| 水蜜桃av无码| 91精品秘密在线观看| 欧洲精品在线视频| 高潮一区二区三区乱码| 国产精品免费视频网站| 大肉大捧一进一出好爽视频| 国产视频一区二区在线播放| 一本色道久久综合狠狠躁篇怎么玩 | 性欧美xxxx视频在线观看| 在线观看毛片网站| 久久午夜国产精品| 成人午夜精品久久久久久久蜜臀| 成人黄色毛片| 亚洲美女性生活视频| 激情综合五月网| 精品亚洲欧美一区| 视频一区二区在线| 美女18一级毛片一品久道久久综合| 欧美第一区第二区| 波多野结衣在线网址| 人人爽香蕉精品| 欧美大陆一区二区| 日韩伦理在线| 日韩二区三区在线| 亚洲国产精品午夜在线观看| 国产精品综合二区| a级网站在线观看| 国外成人福利视频| 国产一区二区三区毛片| 伊人手机在线视频| 91在线视频网址| 91丨porny丨探花| 97久久综合区小说区图片区| 欧美日韩成人精品| 亚洲精品911| 亚洲风情在线资源站| 国产乱淫av片| 日韩一区二区免费看| 国产精品一区二区在线观看 | 国产51人人成人人人人爽色哟哟| 欧美日韩激情小视频| 屁屁影院国产第一页| 国产日韩一区二区三区在线播放| 黄色小网站91| 超碰aⅴ人人做人人爽欧美| 精品亚洲aⅴ在线观看| 黄色一级片免费在线观看| 久久综合色8888| 日本熟妇人妻中出| 久久五月天小说| 亚洲v日韩v综合v精品v| 日本乱理伦在线| 精品国产髙清在线看国产毛片| 国产精品变态另类虐交| 99这里都是精品| 成人午夜视频免费在线观看| 欧美日韩性在线观看| 成人亚洲欧美一区二区三区| 天堂va在线| 国产婷婷成人久久av免费高清| 亚洲自拍一区在线观看| 欧美激情一区在线观看| 亚洲精品在线视频播放| 激情欧美一区| 欧美日韩一区二区三区在线视频 | 国产一区二区三区久久悠悠色av| 黄色a级片免费看| 美女呻吟一区| 国产精品影院在线观看| 在线中文字幕视频观看| 日韩激情视频在线播放| 久草热在线观看| 亚洲精品写真福利| 深爱五月激情网| 久久99精品国产.久久久久| 国产在线观看欧美| 国产一区二区三区电影在线观看 | 一区在线视频| 日韩精品久久一区二区三区| 国产一区二区三区免费在线| 久久艳片www.17c.com| 国产一区二区三区视频免费观看| 亚洲一卡二卡三卡四卡 | 亚洲aⅴ乱码精品成人区| 欧日韩精品视频| 久草网视频在线观看| 国产丝袜在线精品| xxxx视频在线观看| 蜜桃视频一区二区三区| 秋霞无码一区二区| 91精品天堂福利在线观看| 久久久福利视频| 久久久久久久久成人| 奇米四色中文综合久久| 伊人222成人综合网| 国产一区二区三区丝袜| 动漫av一区二区三区| 欧美日韩中文国产| 天堂网av手机版| 亚洲精品五月天| 免费黄色国产视频| 久久男人中文字幕资源站| 欧美一级大片免费看| 青青草97国产精品免费观看 | 美脚恋feet久草欧美| 欧美黑人巨大xxx极品| 午夜视频成人| 国产亚洲人成a一在线v站| 刘亦菲久久免费一区二区| 欧美精品视频www在线观看| 狠狠人妻久久久久久| 亚洲成人在线观看视频| 中文字幕在线有码| 亚洲欧洲国产日本综合| av网站免费在线看| 99国产欧美另类久久久精品 | 国产精品毛片久久久久久久| 中文字幕在线免费看线人| 国产成人亚洲精品狼色在线| 亚洲精品20p| 秋霞午夜av一区二区三区| aa免费在线观看| 一区二区三区精品视频在线观看| 香港三级日本三级a视频| 99久久亚洲精品蜜臀| 亚洲精品在线观看免费| 国产探花在线精品一区二区| 久久99精品国产99久久| 麻豆视频一区| 国产精品手机视频| 乱亲女h秽乱长久久久| 福利视频久久| 国产精品一线| 久久久99爱| 国产a久久精品一区二区三区| 欧美大香线蕉线伊人久久| 国产成人一区| 亚洲精品一区二区三| 外国成人激情视频| 无码人妻精品一区二区蜜桃百度| 欧美aa国产视频| 国产专区在线视频| 伊人成人网在线看| 六月丁香婷婷在线| 久久综合激情| 九九热精品在线播放| 精品一区二区三区不卡| 6080国产精品| 丁香桃色午夜亚洲一区二区三区| 少妇熟女视频一区二区三区| 成人av资源网站| 国产成人av一区二区三区不卡| 久久精子c满五个校花| 国产第一页精品| 亚洲欧美一区二区三区极速播放| 免费无码毛片一区二区app| 婷婷夜色潮精品综合在线| 欧美videossex极品| 91豆麻精品91久久久久久| 一区二区小视频| 欧美一区二区私人影院日本| 欧美性猛交 xxxx| 亚洲视频国产视频| 国内精品久久久久久野外| 欧美极品美女视频网站在线观看免费| 高潮在线视频| 国产精品自拍偷拍视频| 亚洲视频一起| 日韩精品一区二区三区丰满| 小小影院久久| 日韩在线综合网| 老司机免费视频一区二区三区| 久久发布国产伦子伦精品| 97精品国产露脸对白| 日本女人性生活视频| 亚洲成人免费电影| 中文区中文字幕免费看| 日韩免费观看高清完整版| 你懂的在线免费观看| 日韩中文字幕网址| 爱福利在线视频| 国产精品久久久久影院日本| 在线日韩成人| 色综合久久88色综合天天提莫| 午夜日韩激情| 韩国视频一区二区三区| 从欧美一区二区三区| 夫妇露脸对白88av| 婷婷综合久久一区二区三区| 国产毛片久久久久| 亚洲男人第一av网站| 色爱综合区网| 国产精品网红福利| 色橹橹欧美在线观看视频高清| 在线视频精品一区| 久久久久国产精品一区二区 | 国产熟女一区二区丰满| 亚洲精品一区二三区不卡| 污影院在线观看| 国产日韩在线视频| 视频一区欧美| 激情深爱综合网| 国产精品系列在线观看| 中文字幕第69页| 色av一区二区| 天天操天天干天天干| 九九热这里只有精品6| 成人国产精品| 欧洲国产精品| 男人的天堂成人在线| 久久人妻一区二区| 亚洲一区二区三区影院| 国产农村老头老太视频| 中文字幕少妇一区二区三区| www.成人爱| 精品国产乱码久久久久久蜜柚| 午夜精品亚洲| 国产精品久久久久久久99| 国产精品久久久久aaaa| 国产情侣免费视频| 中文字幕国产精品久久| 播放一区二区| 日本不卡在线播放| 日韩精品欧美精品| a级在线免费观看| 色八戒一区二区三区| 国产日产精品久久久久久婷婷| 欧美孕妇性xx| 一道本一区二区三区| 国产精品视频一区二区三区四区五区| www.66久久| 好吊操这里只有精品| 亚洲第一区在线观看| 福利网站在线观看| 国产精品久久7| 亚洲人成高清| 大黑人交xxx极品hd| 欧美视频一区二区三区…| 肉丝一区二区| 日韩av片电影专区| 欧美一区电影| 亚洲欧美国产日韩综合| 日韩一区日韩二区| 精品国产av鲁一鲁一区 | 日本黄色片视频| 亚洲欧美日韩精品久久亚洲区| 亚洲www.| 在线一区高清| 国产成人av电影在线观看| 亚洲国产精品成人无久久精品| 亚洲国产美女久久久久| 亚洲一级少妇| 日韩视频精品| 国产一区二区三区国产| 国产精品19乱码一区二区三区| 日韩精品久久久久| 日韩中文视频| 国产激情片在线观看| 久久嫩草精品久久久久| 国产麻豆91视频| 97超级碰碰碰| 日本久久综合| 人妻 丝袜美腿 中文字幕| 色综合中文字幕国产| 欧美r级在线| 国产精品我不卡| 免费观看在线综合| 久久综合成人网| 亚洲色图美腿丝袜| 国产一区二区三区黄网站| 欧美成人高潮一二区在线看| 欧美激情一区在线| 亚洲国产999| 国产精品91在线| 欧美亚洲不卡| 国产综合精品久久久久成人av| 欧美一区二区三区免费观看视频| 日本а中文在线天堂| 在线无限看免费粉色视频| 99久久亚洲一区二区三区青草| 中文字幕制服诱惑| 韩日欧美一区二区| 日韩欧美电影| 黄色国产在线观看| 欧美一区二区精品| 色成人免费网站| 一二三四视频社区在线| 中文字幕一区二区三区在线观看| 午夜影院免费视频| 91成人免费看| 蜜乳av一区二区| 日韩精品在线观看免费|