亭亭五月天在线观看,亭亭五月天在线观看,国产最新av一区二区,国产 高清 中文字幕,99re热久久亚洲综合精品成人,熟妇 一区二区三区,一级做a爰片性色毛片武则天,美女的骚穴视频播放,国产美女午夜免费视频

首頁>國內(nèi) > 正文

VLDB 頂會論文 Async-fork 解讀與 Redis 實(shí)踐

2023-04-17 11:13:10來源:得物技術(shù)

1、背景

在 Redis 中,在 AOF 文件重寫、生成 RDB 備份文件以及主從全量同步過程中,都需要使用系統(tǒng)調(diào)用 fork 創(chuàng)建一個子進(jìn)程來獲取內(nèi)存數(shù)據(jù)快照,在 fork() 函數(shù)創(chuàng)建子進(jìn)程的時候,內(nèi)核會把父進(jìn)程的「頁表」復(fù)制一份給子進(jìn)程,如果頁表很大,復(fù)制頁表的過程耗時會非常長,那么在此期間,業(yè)務(wù)訪問 Redis 讀寫延遲會大幅增加。

最近,阿里云聯(lián)合上海交大,在數(shù)據(jù)庫頂級會議 VLDB 上發(fā)表了一篇文章《Async-fork: Mitigating Query Latency Spikes Incurred by the Fork-based Snapshot Mechanism from the OS Level》,文章介紹到,他們設(shè)計了一個新的 fork(稱為 Async-fork),將 fork 調(diào)用過程中最耗時的頁表拷貝部分從父進(jìn)程移動到子進(jìn)程,父進(jìn)程因而可以快速返回用戶態(tài)處理用戶查詢,子進(jìn)程則在此期間完成頁表拷貝,從而減少 fork 期間到達(dá)請求的尾延遲。所以該特性在類似 Redis 類型的內(nèi)存數(shù)據(jù)庫上均能取得不錯的效果。


(資料圖)

2、基本概念2.1物理內(nèi)存地址

也即實(shí)際的物理內(nèi)存地址空間。

2.2 虛擬地址空間

虛擬地址空間(Virtual Address Space)是每一個程序被加載運(yùn)行起來后,操作系統(tǒng)為進(jìn)程分配的虛擬內(nèi)存,它為每個進(jìn)程提供了一個假象,即每個進(jìn)程都在獨(dú)占地使用主存。

每個進(jìn)程所能訪問的最大的虛擬地址空間由計算機(jī)的硬件平臺決定,具體地說是由 CPU 的位數(shù)決定的。比如 32 位的 CPU 就是我們常說的 4GB 虛擬內(nèi)存空間。

程序訪問內(nèi)存地址使用虛擬地址空間,然后由操作系統(tǒng)將這個虛擬地址映射到適當(dāng)?shù)奈锢韮?nèi)存地址上。這樣,只要操作系統(tǒng)處理好虛擬地址到物理內(nèi)存地址的映射,就可以保證不同的程序最終訪問的內(nèi)存地址位于不同的區(qū)域,彼此沒有重疊,就可以達(dá)到內(nèi)存地址空間隔離的效果。

當(dāng)進(jìn)程創(chuàng)建時,每個進(jìn)程都會有一個自己的 4GB 虛擬地址空間。要注意的是這個 4GB 的地址空間是“虛擬”的,并不是真實(shí)存在的,而且每個進(jìn)程只能訪問自己虛擬地址空間中的數(shù)據(jù),無法訪問別的進(jìn)程中的數(shù)據(jù),通過這種方法實(shí)現(xiàn)了進(jìn)程間的地址隔離。

對于 Linux,4GB 的虛擬地址空間包含用戶態(tài)虛擬內(nèi)存空間和內(nèi)核態(tài)虛擬內(nèi)存空間兩部分,默認(rèn)分配狀態(tài)如下:

2.3內(nèi)存頁表

「頁表」保存的是虛擬內(nèi)存地址與物理內(nèi)存地址的映射關(guān)系。

CPU 訪問數(shù)據(jù)的時候,CPU 發(fā)出的地址是虛擬地址,CPU 中內(nèi)存管理單元(MMU)通過查詢頁表,把虛擬地址轉(zhuǎn)換為物理地址,再去訪問物理內(nèi)存條。

2.3.1 內(nèi)存分頁

分頁是把整個虛擬和物理內(nèi)存空間切成一段段固定尺寸的大小,這樣一個連續(xù)并且尺寸固定的內(nèi)存空間,我們叫頁(Page)。在 Linux 下,每一頁的大小為 4KB。

在 32 位的環(huán)境下,虛擬地址空間共有 4GB,假設(shè)一個頁的大小是 4KB(2^12),那么就需要大約 100 萬(2^20)個頁,每個「頁表項」需要 4 個字節(jié)大小來存儲,那么整個 4GB 空間的映射就需要有 4MB 的內(nèi)存來存儲頁表。

這 4MB 大小的頁表,看起來也不是很大。但是每個進(jìn)程都是有自己的虛擬地址空間,也就說都有自己的頁表。每個機(jī)器上同時運(yùn)行多個進(jìn)程,頁表將占用大量內(nèi)存。

2.3.2 多級頁表

要解決上面提到的存儲進(jìn)程頁表項占用大量內(nèi)存空間的問題,就需要采用一種叫作多級頁表(Multi-Level Page Table)的解決方案。

我們把這個 100 多萬個「頁表項」的單級頁表再分頁,將頁表(一級頁表)分為 1024 個頁表(二級頁表),每個二級頁表中包含 1024 個「頁表項」,形成二級分頁。這樣,一級頁表就可以覆蓋整個 4GB 虛擬地址空間,但如果某個一級頁表的頁表項沒有被用到,也就不需要創(chuàng)建這個頁表項對應(yīng)的二級頁表了,即可以在需要時才創(chuàng)建二級頁表。也就是,內(nèi)存中只需要保存一級頁表以及使用到的二級頁表,大量的未被使用的二級頁表則不需要分配內(nèi)存并加載在內(nèi)存中,因此,達(dá)到節(jié)省頁表占用內(nèi)存空間的目的。

對于 64 位的系統(tǒng),使用四級分頁目錄,分別是:

頁全局目錄項 PGD(Page Global Directory);頁上級目錄項 PUD(Page Upper Directory);頁中間目錄項 PMD(Page Middle Directory);頁表項 PTE(Page Table Entry);

2.4 虛擬內(nèi)存區(qū)域(VMA)

進(jìn)程的虛擬內(nèi)存空間包含一段一段的虛擬內(nèi)存區(qū)域(Virtual memory area, 簡稱 VMA),每個 VMA 描述虛擬內(nèi)存空間中一段連續(xù)的區(qū)域,每個 VMA 由許多虛擬頁組成,即每個 VMA 包含許多頁表項 PTE。

3、Fork 原理

在默認(rèn) fork 的調(diào)用過程中,父進(jìn)程需要將許多進(jìn)程元數(shù)據(jù)(例如文件描述符、信號量、頁表等)復(fù)制到子進(jìn)程,而頁表的復(fù)制是其中最耗時的部分(占據(jù) fork 調(diào)用耗時的 97% 以上)。

Linux 的 fork() 使用寫時拷貝 (copy-on-write) 頁的方式實(shí)現(xiàn)。寫時拷貝是一種可以推遲甚至避免拷貝數(shù)據(jù)的技術(shù)。在創(chuàng)建子進(jìn)程的過程中,操作系統(tǒng)會把父進(jìn)程的「頁表」復(fù)制一份給子進(jìn)程,這個頁表記錄著虛擬地址和物理地址映射關(guān)系,此時,操作系統(tǒng)并不復(fù)制整個進(jìn)程的物理內(nèi)存,而是讓父子進(jìn)程共享同一個物理內(nèi)存。同時,操作系統(tǒng)內(nèi)核會把共享的所有的內(nèi)存頁的權(quán)限都設(shè)為 read-only。

那什么時候會發(fā)生物理內(nèi)存的復(fù)制呢?

當(dāng)父進(jìn)程或者子進(jìn)程在向共享內(nèi)存發(fā)起寫操作時,內(nèi)存管理單元 MMU 檢測到內(nèi)存頁是 read-only 的,于是觸發(fā)缺頁中斷異常(page-fault),處理器會從中斷描述符表(IDT)中獲取到對應(yīng)的處理程序。在中斷程序中,內(nèi)核就會把觸發(fā)異常的物理內(nèi)存頁復(fù)制一份,并重新設(shè)置其內(nèi)存映射關(guān)系,將父子進(jìn)程的內(nèi)存讀寫權(quán)限設(shè)置為可讀寫,于是父子進(jìn)程各自持有獨(dú)立的一份,之后進(jìn)程才會對內(nèi)存進(jìn)行寫操作,這個過程也被稱為寫時復(fù)制(Copy On Write)。

4、Fork 的痛點(diǎn)

在原生 fork 下,在父進(jìn)程調(diào)用 fork() 創(chuàng)建子進(jìn)程的過程中,雖然使用了寫時復(fù)制頁表的方式進(jìn)行優(yōu)化,但由于要復(fù)制父進(jìn)程的頁表,還是會造成父進(jìn)程出現(xiàn)短時間阻塞,阻塞的時間跟頁表的大小有關(guān),頁表越大,阻塞的時間也越長。

我們在測試中很容易觀察到 fork 產(chǎn)生的阻塞現(xiàn)象,以及 fork 造成的 Redis 訪問抖動現(xiàn)象。

4.1測試環(huán)境

Redis 版本:優(yōu)化前 Redis-server

機(jī)器操作系統(tǒng):無 Async-fork 特性的系統(tǒng)

測試數(shù)據(jù)量:21.63G

127.0.0.1:6380> info memory# Memoryused_memory:23220597688used_memory_human:21.63G
4.2 阻塞現(xiàn)象復(fù)現(xiàn)

在使用 Redis-benchmark 壓測的過程中,手動執(zhí)行 bgsave 命令,觀察 fork 耗時和壓測指標(biāo) TP100。

使用info stats返回上次 fork 耗時:latest_fork_usec:183632,可以看到 fork 耗時 183 毫秒。

在壓測過程中分別不執(zhí)行 bgsave 和執(zhí)行 bgsave,結(jié)果如下:

# 壓測過程中未執(zhí)行 bgsave[root@xxx bin]# Redis-benchmark -d 256 -t set -n 1000000  -a xxxxxx -p 6380====== SET ======  1000000 requests completed in 8.15 seconds  50 parallel clients  256 bytes payload  keep alive: 199.90% <= 1 milliseconds100.00% <= 1 milliseconds122669.27 requests per second# 壓測過程中執(zhí)行 bgsave[root@xxx bin]# Redis-benchmark -d 256 -t set -n 1000000  -a xxxxxx -p 6380====== SET ======  1000000 requests completed in 13.97 seconds  50 parallel clients  256 bytes payload  keep alive: 186.41% <= 1 milliseconds86.42% <= 2 milliseconds99.95% <= 3 milliseconds99.99% <= 4 milliseconds99.99% <= 10 milliseconds99.99% <= 11 milliseconds99.99% <= 12 milliseconds100.00% <= 187 milliseconds100.00% <= 187 milliseconds71561.47 requests per second

從壓測數(shù)據(jù)可以看到,單機(jī)環(huán)境下壓測,壓測時未執(zhí)行 bgsave,TP100 約 1 毫秒;如果壓測過程中,手動執(zhí)行 bgsave 命令,觸發(fā) fork 操作,TP100 達(dá)到 187 毫秒。

4.3 Strace 跟蹤 fork 過程耗時

strace 常用來跟蹤進(jìn)程執(zhí)行時的系統(tǒng)調(diào)用和所接收的信號。

$ strace -p 32088 -T -tt -o strace00.out14:01:33.623495 clone(child_stack=NULL, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7fbe5242fa50) = 37513 <0.183533>14:01:33.807142 open("/data1/6380/6380.log", O_WRONLY|O_CREAT|O_APPEND, 0666) = 60 <0.000018>14:01:33.807644 lseek(60, 0, SEEK_END)  = 8512 <0.000017>14:01:33.807690 stat("/etc/localtime", {st_mode=S_IFREG|0644, st_size=528, ...}) = 0 <0.000010>14:01:33.807732 fstat(60, {st_mode=S_IFREG|0644, st_size=8512, ...}) = 0 <0.000007>14:01:33.807756 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fbe52437000 <0.000009>14:01:33.807787 write(60, "35994:M 21 Mar 14:01:33.807 * Ba"..., 69) = 69 <0.000015>14:01:33.807819 close(60)               = 0 <0.000008>14:01:33.807845 munmap(0x7fbe52437000, 4096) = 0 <0.000013>

由于 Linux 中通過 clone() 系統(tǒng)調(diào)用實(shí)現(xiàn) fork();我們可以看到追蹤到 clone 系統(tǒng)調(diào)用,并且耗時 183 毫秒,與info stats統(tǒng)計的 fork 耗時一致。

5、Async-fork

鑒于以上 linux 原生 fork 系統(tǒng)調(diào)用的痛點(diǎn),對于像 Redis 這樣的高性能內(nèi)存數(shù)據(jù)庫,將會增加 fork 期間的用戶訪問延遲,論文中設(shè)計了一個新的 fork(稱為 Async-fork)來解決上述問題。

Async-fork 設(shè)計的核心思想是將 fork 調(diào)用過程中最耗時的頁表拷貝工作從父進(jìn)程移動到子進(jìn)程,縮短父進(jìn)程調(diào)用 fork 時陷入內(nèi)核態(tài)的時間,父進(jìn)程因而可以快速返回用戶態(tài)處理用戶查詢,子進(jìn)程則在此期間完成頁表拷貝。與 Linux 中的默認(rèn)原生 fork 相比,Async-fork 顯著減少了 Redis 快照期間到達(dá)請求的尾延遲。

5.1 Async-fork 的挑戰(zhàn)

然而,Async-fork 的實(shí)現(xiàn)過程中,實(shí)際工作并非描述的這么簡單。頁表的異步復(fù)制操作可能導(dǎo)致快照不一致。以下圖為例,Redis 在 T0 時刻保存內(nèi)存快照,而某個用戶請求在 T2 時刻向 Redis 插入了新的鍵值對(k2, v2),這將導(dǎo)致父進(jìn)程修改它的頁表項(PTE2)。假如 T2 時刻這個被修改的頁表項(PTE2)還沒有被子進(jìn)程復(fù)制完成, 這個修改后的內(nèi)存頁表項及對應(yīng)內(nèi)存頁后續(xù)將被復(fù)制到子進(jìn)程,這個新插入的鍵值對將被子進(jìn)程最終寫入硬盤,破壞了快照一致性。(快照文件應(yīng)該記錄的是保存拍攝內(nèi)存快照那一刻的內(nèi)存數(shù)據(jù))

圖片來源于:參考資料[1] 第 8 頁

5.2 Async-fork 詳解

前面提到,每個進(jìn)程都有自己的虛擬內(nèi)存空間,Linux 使用一組虛擬內(nèi)存區(qū)域 VMA 來描述進(jìn)程的虛擬內(nèi)存空間,每個 VMA 包含許多頁表項。

在默認(rèn) fork 中,父進(jìn)程遍歷每個 VMA,將每個 VMA 復(fù)制到子進(jìn)程,并自上而下地復(fù)制該 VMA 對應(yīng)的頁表項到子進(jìn)程,對于 64 位的系統(tǒng),使用四級分頁目錄,每個 VMA 包括 PGD、PUD、PMD、PTE,都將由父進(jìn)程逐級復(fù)制完成。在 Async-fork 中,父進(jìn)程同樣遍歷每個 VMA,但只負(fù)責(zé)將 PGD、PUD 這兩級頁表項復(fù)制到子進(jìn)程。

隨后,父進(jìn)程將子進(jìn)程放置到某個 CPU 上使子進(jìn)程開始運(yùn)行,父進(jìn)程返回到用戶態(tài),繼續(xù)響應(yīng)用戶請求。由子進(jìn)程負(fù)責(zé)每個 VMA 剩下的 PMD 和 PTE 兩級頁表的復(fù)制工作。

如果在父進(jìn)程返回用戶態(tài)后,子進(jìn)程復(fù)制內(nèi)存頁表期間,父進(jìn)程需要修改還未完成復(fù)制的頁表項,怎樣避免上述提到的破壞快照一致性問題呢?

圖片來源于:參考資料[1] 第 7 頁

5.2.1 主動同步機(jī)制

父進(jìn)程返回用戶態(tài)后,父進(jìn)程的 PTE 可能被修改。如果在子進(jìn)程復(fù)制內(nèi)存頁表期間,父進(jìn)程檢測到了 PTE 修改,則會觸發(fā)主動同步機(jī)制,也就是父進(jìn)程也加入頁表復(fù)制工作,來主動完成被修改的相關(guān)頁表復(fù)制,該機(jī)制用來確保 PTE 在修改前被復(fù)制到子進(jìn)程。

當(dāng)一個 PTE 將被修改時,父進(jìn)程不僅復(fù)制這一個 PTE,還同時將位于同一個頁表上的所有 PTE(一共 512 個 PTE),連同它的父級 PMD 項復(fù)制到子進(jìn)程。

父進(jìn)程中的 PTE 發(fā)生修改時,如果子進(jìn)程已經(jīng)復(fù)制過了這個 PTE,父進(jìn)程就不需要復(fù)制了,否則會發(fā)生重復(fù)復(fù)制。怎么區(qū)分 PTE 是否已經(jīng)復(fù)制過?

Async-fork 使用 PMD 項上的 RW 位來標(biāo)記是否被復(fù)制。具體而言,當(dāng)父進(jìn)程第一次返回用戶態(tài)時,它所有 PMD 項被設(shè)置為寫保護(hù)(RW=0),代表這個 PMD 項以及它指向的 512 個 PTE 還沒有被復(fù)制到子進(jìn)程。當(dāng)子進(jìn)程復(fù)制一個 PMD 項時,通過檢查這個 PMD 是否為寫保護(hù),即可判斷該 PMD 是否已經(jīng)被復(fù)制到子進(jìn)程。如果還沒有被復(fù)制,子進(jìn)程將復(fù)制這個 PMD,以及它指向的 512 個 PTE。

在完成 PMD 及其指向的 512 個 PTE 復(fù)制后,子進(jìn)程將父進(jìn)程中的該 PMD 設(shè)置為可寫(RW=1),代表這個 PMD 項以及它指向的 512 個 PTE 已經(jīng)被復(fù)制到子進(jìn)程。當(dāng)父進(jìn)程觸發(fā)主動同步時,也通過檢查 PMD 項是否為寫保護(hù)判斷是否被復(fù)制,并在完成復(fù)制后將 PMD 項設(shè)置為可寫。同時,在復(fù)制 PMD 項和 PTE 時,父進(jìn)程和子進(jìn)程都鎖定 PTE 表,因此它們不會出現(xiàn)同時復(fù)制同一 PMD 項指向的 PTE。

在操作系統(tǒng)中,PTE 的修改分為兩類:

1)VMA 級的修改。例如,創(chuàng)建、合并、刪除 VMA 等操作作用于特定 VMA 上,VMA 級的修改通常會導(dǎo)致大量的 PTE 修改,因此涉及大量的 PMD。

2)PMD 級的修改。PMD 級的修改僅涉及一個 PMD。

5.2.2 錯誤處理

Async-fork 在復(fù)制頁表時涉及到內(nèi)存分配,難免會發(fā)生錯誤。例如,由于內(nèi)存不足,進(jìn)程可能無法申請到新的 PTE 表。當(dāng)錯誤發(fā)生時,應(yīng)該將父進(jìn)程恢復(fù)到它調(diào)用 Async-fork 之前的狀態(tài)。

在 Async-fork 中,父進(jìn)程 PMD 項目的 RW 位可能會被修改。因此,當(dāng)發(fā)生錯誤時,需要將 PMD 項全部回滾為可寫。

6、Redis 優(yōu)化實(shí)踐6.1 Async-fork 阻塞現(xiàn)象

在支持 Async-fork 的操作系統(tǒng)(即 Tair 專屬操作系統(tǒng)鏡像)機(jī)器上測試,理論上來說,按照文章的預(yù)期,用戶不需要作任何修改(Async-fork 使用了原生 fork 相同的接口,沒有另外新增接口),就可以享受 Async-fork 優(yōu)化帶來的優(yōu)勢,但是,使用 Redis 實(shí)際測試過程中,結(jié)果不符合預(yù)期,在 Redis 壓測過程中手動執(zhí)行 bgsave 命令觸發(fā) fork 操作,還是觀察到了 TP100 抖動現(xiàn)象。

測試環(huán)境

Redis 版本:優(yōu)化前 Redis-Server

機(jī)器操作系統(tǒng):Tair 專屬操作系統(tǒng)鏡像

測試數(shù)據(jù)量:54.38G

127.0.0.1:6679> info memory# Memoryused_memory:58385641120used_memory_human:54.38G
問題現(xiàn)象

現(xiàn)象:fork 耗時正常,但是壓測過程中執(zhí)行 bgsave,TP100 不正常

在壓測過程中執(zhí)行 bgsave,使用info stats返回上次 fork 耗時:latest_fork_usec:426

TP100 結(jié)果如下:

# 壓測過程中執(zhí)行 bgsave[root@xxx ~]# /usr/bin/Redis-benchmark -d 256 -t set -n 1000000  -a xxxxxx -p 6679====== SET ======  1000000 requests completed in 7.88 seconds  50 parallel clients  256 bytes payload  keep alive: 1100.00% <= 411 milliseconds100.00% <= 412 milliseconds100.00% <= 412 milliseconds126871.35 requests per second

也就是說,觀察到的 fork 耗時正常,但是壓測過程中Redis 依然出現(xiàn)了尾延遲,這顯然不符合預(yù)期。

追蹤過程

使用 strace 命令進(jìn)行分析,結(jié)果如下:

$ strace -p 32088 -T -tt -o strace00.out14:18:12.933441 clone(child_stack=NULL, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7f461c0daa50) = 13772 <0.000380>14:18:12.933884 open("/data1/6679/6679.log", O_WRONLY|O_CREAT|O_APPEND, 0666) = 60 <0.000019>14:18:12.933948 lseek(60, 0, SEEK_END)  = 11484 <0.000013>14:18:12.933983 stat("/etc/localtime", {st_mode=S_IFREG|0644, st_size=556, ...}) = 0 <0.000016>14:18:12.934032 fstat(60, {st_mode=S_IFREG|0644, st_size=11484, ...}) = 0 <0.000014>14:18:12.934062 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f461c0e4000 <0.358768>14:18:13.292883 write(60, "32088:M 21 Mar 14:18:12.933 * Ba"..., 69) = 69 <0.000032>14:18:13.292951 close(60)               = 0 <0.000014>14:18:13.292980 munmap(0x7f461c0e4000, 4096) = 0 <0.000019>
$ strace -p 11559 -T -tt -e trace=memory -o trace00.out14:18:12.934062 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f461c0e4000 <0.358768>14:18:13.292980 munmap(0x7f461c0e4000, 4096) = 0 <0.000019>

可以觀察到,clone 耗時 380 微秒,已經(jīng)大幅降低,也就 fork 快速返回了用戶態(tài)響應(yīng)用戶請求。然而,注意到,緊接著出現(xiàn)了一個 mmap 耗時 358 毫秒,與 TP100 數(shù)據(jù)接近。

由于 mmap 系統(tǒng)調(diào)用會在當(dāng)前進(jìn)程的虛擬地址空間中,尋找一段滿足大小要求的虛擬地址,并且為此虛擬地址分配一個虛擬內(nèi)存區(qū)域( vm_area_struct 結(jié)構(gòu)),也就是會觸發(fā) VMA 級虛擬頁表變化,也就觸發(fā)父進(jìn)程主動同步機(jī)制,父進(jìn)程主動幫助完成相應(yīng)頁表復(fù)制動作。VMA 級虛擬頁表變化,需要將對應(yīng)的三級和四級所有頁目錄都復(fù)制到子進(jìn)程,因此,耗時比較高。

那么,這個 mmap 調(diào)用又是哪里來的呢?

定位問題

perf是 Linux下的一款性能分析工具,能夠進(jìn)行函數(shù)級與指令級的熱點(diǎn)查找。

通過 perf trace 可以看到響應(yīng)調(diào)用堆棧及耗時,分析結(jié)果如下:

$ perf trace -p 11559 -o trace01.out --max-stack 15 -T616821913.647 (358.740 ms): Redis-server_4/32088 mmap(len: 4096, prot: READ|WRITE, flags: PRIVATE|ANONYMOUS            ) = 0x7f461c0e4000                                       __mmap64 (/usr/lib64/libc-2.17.so)                                       __GI__IO_file_doallocate (inlined)                                       __GI__IO_doallocbuf (inlined)                                       __GI__IO_file_overflow (inlined)                                       _IO_new_file_xsputn (inlined)                                       _IO_vfprintf_internal (inlined)                                       __GI_fprintf (inlined)                                       serverLogRaw (/usr/local/Redis/Redis-server)                                       serverLog (/usr/local/Redis/Redis-server)                                       rdbSaveBackground (/usr/local/Redis/Redis-server)                                       bgsaveCommand (/usr/local/Redis/Redis-server)                                       call (/usr/local/Redis/Redis-server)                                       processCommand (/usr/local/Redis/Redis-server)                                       processInputBuffer (/usr/local/Redis/Redis-server)                                       aeProcessEvents (/usr/local/Redis/Redis-server)616822272.562 ( 0.010 ms): Redis-server_4/32088 munmap(addr: 0x7f461c0e4000, len: 4096                                ) = 0                                       __munmap (inlined)                                       __GI__IO_setb (inlined)                                       _IO_new_file_close_it (inlined)                                       _IO_new_fclose (inlined)                                       serverLogRaw (/usr/local/Redis/Redis-server)                                       serverLog (/usr/local/Redis/Redis-server)                                       rdbSaveBackground (/usr/local/Redis/Redis-server)                                       bgsaveCommand (/usr/local/Redis/Redis-server)                                       call (/usr/local/Redis/Redis-server)                                       processCommand (/usr/local/Redis/Redis-server)                                       processInputBuffer (/usr/local/Redis/Redis-server)                                       aeProcessEvents (/usr/local/Redis/Redis-server)                                       aeMain (/usr/local/Redis/Redis-server)                                       main (/usr/local/Redis/Redis-server)

也就可以看到,在 bgsave 執(zhí)行邏輯中,有一處打印日志中的 fprintf 調(diào)用了 mmap,很顯然這應(yīng)該是 fork 返回父進(jìn)程后,父進(jìn)程中某處調(diào)用。

6.2 Async-fork 適配優(yōu)化

針對找出來的代碼位置,可以進(jìn)行相應(yīng)優(yōu)化,針對此處的日志影響,我們可以屏蔽日志或者將日志移動到子進(jìn)程進(jìn)行打印,通過同樣的分析手段,如果存在其他影響,均可進(jìn)行對應(yīng)優(yōu)化。進(jìn)行相應(yīng)適配優(yōu)化修改后,我們再次進(jìn)行測試。

測試環(huán)境

Redis 版本:優(yōu)化后 Redis-Server

機(jī)器操作系統(tǒng):Tair 專屬操作系統(tǒng)鏡像

測試數(shù)據(jù)量:54.38G

127.0.0.1:6680> info memory# Memoryused_memory:58385641144used_memory_human:54.38G
現(xiàn)象

在壓測過程中執(zhí)行 bgsave,fork 耗時和 TP100 均正常。

使用info stats返回上次 fork 耗時:latest_fork_usec:414

TP100 結(jié)果如下:

# 壓測過程中執(zhí)行 bgsave[root@xxx Redis]# /usr/bin/Redis-benchmark -d 256 -t set -n 1000000  -a dRedis123456 -p 6680====== SET ======  1000000 requests completed in 7.50 seconds  50 parallel clients  256 bytes payload  keep alive: 199.99% <= 1 milliseconds99.99% <= 2 milliseconds100.00% <= 2 milliseconds133386.69 requests per second
跟蹤驗證

再次使用 strace 和 perf 工具跟蹤驗證

strace 跟蹤父進(jìn)程只看到 clone,并且耗時只有 378 微秒,

# strace -p 14697 -T -tt -o strace04.out14:42:00.723224 clone(child_stack=NULL, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0x7fa5340d0a50) = 15470 <0.000378>

Perf trace 跟蹤父進(jìn)程也只看到 clone 調(diào)用

# perf trace -p 14697 -o trace04.out --max-stack 15 -T618249694.830 ( 0.423 ms): Redis-server/14697  ... [continued]: clone()) = 15470 (Redis-server)                                       __GI___fork (inlined)                                       rdbSaveBackground (/usr/local/Redis/Redis-server)                                       bgsaveCommand (/usr/local/Redis/Redis-server)                                       call (/usr/local/Redis/Redis-server)                                       processCommand (/usr/local/Redis/Redis-server)                                       processInputBuffer (/usr/local/Redis/Redis-server)                                       aeProcessEvents (/usr/local/Redis/Redis-server)                                       aeMain (/usr/local/Redis/Redis-server)                                       main (/usr/local/Redis/Redis-server)

由于我們的優(yōu)化是將觸發(fā) mmap 的相關(guān)日志修改到子進(jìn)程中,使用 Perf trace 跟蹤 fork 產(chǎn)生的子進(jìn)程,命令為:

strace -p 14697 -T -tt -f -ff -o strace05.out

通過 Redis 日志文件找到子進(jìn)程 pid 為 15931;打開對應(yīng)生成的保存子進(jìn)程 strace 信息的文件strace05.out.15931(父進(jìn)程 strace 信息保存在文件strace05.out.14697)

# 以下為子進(jìn)程 strace 信息14:47:40.878387 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fa5340da000 <0.000008>14:47:40.878415 write(6, "15931:C 21 Mar 14:47:40.878 * Ba"..., 69) = 69 <0.000015>14:47:40.878447 close(6)                = 0 <0.000006>14:47:40.878467 munmap(0x7fa5340da000, 4096) = 0 <0.000010>14:47:40.878494 open("temp-15931.rdb", O_WRONLY|O_CREAT|O_TRUNC, 0666) = 6 <0.000020>14:47:40.878563 fstat(6, {st_mode=S_IFREG|0644, st_size=0, ...}) = 0 <0.000006>14:47:40.878584 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7fa5340da000 <0.000006>

在子進(jìn)程中看到了 mmap 調(diào)用,子進(jìn)程中調(diào)用不會影響父進(jìn)程對業(yè)務(wù)訪問的響應(yīng)。

7性能測試

修改 Redis 代碼,針對 Async-fork 適配優(yōu)化后,我們針對 fork 與 Async-fork 進(jìn)行了性能對比測試;測試包含不同數(shù)據(jù)量下 fork() 命令耗時與 fork() 操作對壓測過程中 TP100 的影響。

7.1 fork() 命令耗時

fork() 命令耗時,即針對 Redis 執(zhí)行bgsave命令后,通過 Redis 提供的info stats命令觀察到的latest_fork_usec用時。

注:由于 fork 與 Async-fork 系統(tǒng)下,fork() 操作產(chǎn)生的latest_fork_usec數(shù)據(jù)差距懸殊非常大,使用單縱軸會導(dǎo)致 Async-fork 的數(shù)據(jù)在圖表中顯示不明顯,不方便查看,因此,該圖表使用了雙縱軸;雖然 Async-fork 的圖表看起來比較高,但是實(shí)際右縱軸范圍小,所以數(shù)據(jù)小

從圖表可以看出,使用支持 Async-fork 的操作系統(tǒng),fork() 操作產(chǎn)生的耗時非常小,不管數(shù)據(jù)量多大,耗時都非常穩(wěn)定,基本在 200 微秒左右;而原生 fork 產(chǎn)生的耗時會隨著數(shù)據(jù)量增長而增長,而且是從幾十毫秒增長到幾百毫秒。

7.2 TP100 抖動

在使用 Redis-benchmark 壓測過程中,手動執(zhí)行 bgsave 命令,觸發(fā)操作系統(tǒng) fork() 操作,觀察不同數(shù)據(jù)量下,fork 與 Async-fork 對 Redis 壓測時 TP100 的影響。

從圖上可以看出,使用支持Async-fork的操作系統(tǒng),fork() 操作對 Redis 壓測產(chǎn)生的性能影響非常小,性能提升非常明顯,不管數(shù)據(jù)量多大,耗時都非常穩(wěn)定,基本在 1-2 毫秒左右;而原生 fork 產(chǎn)生的抖動影響時間會隨著數(shù)據(jù)量增長而增長, TP100 從幾十毫秒增長到幾百毫秒。

8、總結(jié)

通過不同數(shù)據(jù)量下對比測試,我們可以看到,Async-fork 相比原生 fork,阻塞時間大大減少,性能提升非常明顯。而且阻塞時間非常穩(wěn)定,不會因為數(shù)據(jù)量的增長出現(xiàn)倍數(shù)級增長。

在單機(jī)測試場景下,8G 數(shù)據(jù)量大小下,TP100 和latest_fork_usec耗時均減少 98% 以上。

基于論文中 Async-fork 的設(shè)計思想,Tair 專屬操作系統(tǒng)鏡像已支持該特性,并且將該特性集成在原生 fork 中,沒有新增系統(tǒng)調(diào)用接口,理論上用戶只需要使用支持 Async-fork 的操作系統(tǒng),程序無需做任何修改,就可以享受到 Async-fork 特性帶來的性能提升。對于 Redis 而言,我們也只需要對 Redis 稍加適配就可以獲得該技術(shù)帶來的紅利。

在 Redis 應(yīng)用場景中,在添加從節(jié)點(diǎn)、RDB 文件備份、AOF 持久化文件重寫等場景下,應(yīng)用支持 Async-fork 的操作系統(tǒng),都將極大的減少對業(yè)務(wù)的影響。

關(guān)鍵詞:

相關(guān)新聞

Copyright 2015-2020   三好網(wǎng)  版權(quán)所有 聯(lián)系郵箱:435 22 640@qq.com  備案號: 京ICP備2022022245號-21
欧美精品熟妇免费在线| 亚洲欧美成人午夜一区二区| 免费在线小视频你懂的| 国内精品一区二区2021在线| 西野翔人妻中文字幕中字在| 成人大片男人的天堂| 青青青在线视频观看97| 人妻女侠被擒受辱记| 黄版视频在线免费观看| 好看的日本中文字幕在线观看二区| 国产人妻777人伦精品hd超碰| 中文字幕日韩首页欧美在线激情| 无码精品黑人一区二区老人| 国产一区二区三区四区精| 福利美女视频在线观看| 亚洲最大的自拍偷拍网| 国产精品成人免费电影| 色丁香久久激情综合网| 黑人侵犯人妻森泽佳奈| 91精品夜夜夜一区二区| 七色福利视频在线观看| 最近在线中文字幕免费| 99久久精品视频16| 午夜精品久久久久久久精品乱码| 天天爱天天日天天爽| 顶级欧美色妇4khd| 中文字幕在线免费观看人妻| 9久re热视频在线精品 | 97视频人人爱麻豆| 日韩欧美一区二区三区免费看| 中文字幕日韩首页欧美在线激情| 北野中文字幕一区二区| 成人av中文字幕在线看| 台湾18禁久久久久久久激情视频| 国产av啊啊啊啊啊啊啊| 69国产在线视频网站| 老司机在线视频福利观看| 国语精品视频自产自拍| av男人站在线观看| 日韩A级毛片免费视频| 黑人侵犯人妻森泽佳奈| 在线视频国产精品欧美| av成人三级高清日韩| 久久人妻人人草人人爽| 国产福利三级在线观看| 岳母的诱惑电影在线观看| 婷婷色九月综合激情丁香| 亚洲高清免费在线观看视频| 欧美 日韩 精品 中文| 岳的大肥屁熟妇五十路| 91污污在线观看视频| 成熟了的熟妇毛茸茸| 亚洲av毛片一区二区三区网| 97精品人妻免费视频| 高清国产美女a一级毛片| 精品人妻人人做人人爽| 啪啪啪网站免费在线看| 国产一级一国产一级毛片| 久久人人爽人人爽人人av东京热 | 天天躁狠狠躁狠狠躁性色| 无人区一码二码三码区别在哪 | 荣立三等功退休有什么待遇 | 亚洲日本欧美韩国另类综合| av里面的动作是真进去吗 | 一区二区三区五区六区| 久久人妻诱惑我视频| 天天日 天天舔 天天射| 东京热日本一区二区三区| 97超碰人人爽人人做| a级黄片免费观看| 亚洲一区二区中文字幕久久| 夜色17s精品人妻熟女av| 国产 少妇 一区二区| 天天做天天日天天搞| 99热在线只有的精品| 五月天天堂视频在线| 天天早上头和脸出汗是怎么办| 99久久久久久久久久久久久| 大香蕉尹人在线最新| 91大神在线免费观看视频| 黑人爆操女人免费视频| 中文字幕 一区二区在线观看| 黑人和日本人av一区二区| 亚洲成人五月婷婷久久综合| 国产漂亮白嫩美女在线图片| 国产中年夫妇激情高潮| 不卡高清一区二区三区| 97成人老师在线视频| 在线观看视频免费一区二区三区| 日韩欧美国产一区二区在线观看| av毛片在线观看网址| 天天干天天操天天要| 男人资源站中文字幕| 成人人妻h在线观看| 天天碰天天摸天天搞| 放荡人妻极品少妇全集| 9420高清视频在线观看国语版| 精品欧美黑人一区二区三区| 婷婷色综合五月天视频| 亚洲在线观看中文字幕av| 免费高清av一区二区| 国产av啊啊啊啊啊啊啊| 亚洲成a人77777| 日本黄色一级电影网址| 超碰在线免费观看视频97| 伊人精品久久一区二区| 最近日韩免费在线观看| 亚洲三级综合在线观看| 亚洲黄色免费在线观看网站| 自拍丝袜国产欧美日韩| 福利在线国产小视频| 欧美日本在线免费视频| 一二区二区不卡视频| 伊人精品成人综合网| 日韩一级欧美一级片| www一区二区91| 视频免费在线观看网站| 秋霞成人午夜鲁丝一区二区三区| 玖玖资源站在线观看亚洲| 在线成人教育平台排名| 免费24小时人妻视频| 中文字幕一区二区三区久久久| 亚洲午夜熟女在线观看| 国产激情在线观看一区二区三区| 亚洲精品激情视频在线观看| 亚洲av网站一区二区三区| avtt中文字幕手机版| 欧美男男在线观看视频网站| 日本福利网站一区二区| 91偷拍被偷拍在线播放| 91porny九色视频偷拍| 男人的天堂aⅴ在线| 99久久国产精品免费消防器材| 美国伦理片午夜理论片| 九十九步都是爱最后一步是尊严| 成人免费电影二区三区| 日本电影一级人妻在线播放四区| 国产自拍偷拍视频在线免费观看| 亚洲a区在线免费观看| 天天干天天色综合久久| 天天操天天干天天谢| 开心五月综合激情婷婷| 欧美成人一二三在线网| 亚洲人成大片在线观看| 少妇熟女天堂网av| 欧美黄色一区二区三区视频| 青娱乐这里只有精品| 午夜亚洲国产精品中字| 欧美成人久久久桃色aa| 交换的一天中文字幕在线视频| 久久无码高清免费视频| aa福利影视在线观看| 亚洲乱码av一区二区蜜桃av | 亚欧洲乱码视频一二三区| 新亚洲天堂男子av| 女生抠逼自慰啊啊啊啊啊啊啊下载| 日本四十路人妻熟女| 日韩少妇免费在线播放| 黑人侵犯人妻森泽佳奈| 国产一区二区三区四区精| 一区二区三区资源视频| 色网站在线观看免费| 人妻激情偷乱一区二区三区av| 人妻少妇视频系列视频在线| 色噜噜噜噜色噜噜色合久一| 红桃视频国产av在线| 国产人妻777人伦精品hd超碰| 99精品久久一区二区| 日韩精品欧美一区二区| 亚洲精品乱码久久久久app| 在线观看网站伊人网| 青娱乐不卡视频在线| 美女av色播在线播放| 久久久久久免费观看av| 二十四小时日本高清在线观看| 狠狠操深爱婷婷综合一区| 中文字幕欧美一区二区视频| 在线观看视频免费一区二区三区| 老色鬼精品视频在线观看播放| 国产免费久久精品99re丫丫| 国产高清自拍偷拍在线| 亚洲 综合 欧美 一区| 亚洲gay视频在线观看| 色就色综合偷拍区欧美在线| 亚洲精品国品乱码久久久久| 欧美性感美女热舞视频| 国产精品午夜无码AV体验区| 久久99国产中文丝袜| 河北全程露脸对白自拍| 欧美日韩综合精品无人区| 蜜桃臀av在线一区二区| 黑人3p日本女优中出| 欧美在线观看视频欧美| 日本a级2020在线观看| yellow在线亚洲精品一区| 最新国产午夜激情视频| 国产最新av在线免费观看| 中文字幕国产一区在线视频| 97cao在线视频| 91超碰九色porny| 男生用大肌巴操美女骚穴| 91久久精品美女高潮喷水白浆| 中文字幕人妻一区二区视频系列| 99久久碰碰人妻国产| 91亚洲最新蜜桃在线| 中文字幕在线观看av观看| 97视频人人爱麻豆| 久久99国产中文丝袜| 亚洲午夜高清在线观看| 国产91黑丝小视频在线观看| 亚洲美女露隐私av一区二区精品| 69久久夜色精品国产69乱电影| 可在线免费观看av| 亚洲午夜精品视频节目| 91亚洲精品久久蜜桃| 亚洲天堂av最新在线| 3344永久在线观看视频下载| 亚洲精品9999蜜桃| 亚洲制服丝袜资源网| 午夜福利国产精品久久久久| 美女张开腿给男人桶爽的软件| 天天日天天干天天日天天干天天| 91精品国产成人久久久久久| 天堂av国产av伦理av| 午夜美女福利视频在线| 人妻少妇精品二三区| 国产精品视频网站污污污| 久久中文字幕av一区二区| 久久综合狠狠综合久久综| 天天操天天舔天天射天天日天天干| 午夜在线成人免费电影| 国产精美视频精品视频精品| 欧美性受黑人猛交裸体视频| 麻豆午夜激情在线观看| 911精产国品一二三产区区| 中文字幕 一区二区在线观看| 99国产精品国产精品毛片19| 亚洲欧美成人午夜一区二区| 我爱搞在线观看视频| 青青青在线视频观看97| 亚洲午夜高清在线观看| 天天夜夜久久精品综合| 亚洲人成小说网站色| 核xp工厂精品久久亚洲| 青青在线视频看看| 91性高湖久久久久久久久久| 91性高湖久久久久久久久久| 精品人妻人人做人人爽| 欧美vs亚洲vs日韩| 欧美黑人1区2区3区| 大鸡扒操大逼大片免费关看| 国产不卡免费在线观看| 亚洲妹妹我爱你在线观看| 国产自拍偷拍在线精品| 18禁男女啪啪啪无遮挡| 97人妻在线视频自拍| 丰满少妇高潮喷水视频| 手机看电影一区二区三区| 国产 少妇 一区二区| 九九热视频1这里只有精品| 亚洲乱码av一区二区蜜桃av | 亚洲一区二区在线视频观看免费| 97精品国产91久久久| 精品高潮呻吟久久av| 日本欧美视频在线免费| 久久99国产中文丝袜| 欧美区一区二区三视频| 西野翔人妻中文字幕中字在| 视频在线 一区二区| 亚洲图片另类综合小说| 97人妻在线视频自拍| 91精品夜夜夜一区二区蜜桃| 日韩少妇免费在线播放| 国产青青青青草免费在线视频| 天天日天天干天天日天天干天天| 人人人妻人人人妻精品少妇| 羞羞漫画无限免费观看秋蝉| 在线中文字幕人妻av| 国产视频成人一区二区| 亚洲午夜熟女在线观看| 北野中文字幕一区二区| 久久久久久高清一区| 国产天堂av不卡网| 精品国产污污污免费入口| 精产国品一二三产品区别97| 欧美老熟妇xxoo老妇| 日本福利片在线播放| 精品不卡一区二区三区| 99热在线只有的精品| 丰满少妇人妻一区二区三区蜜桃| 美女扒开逼逼给你看| 超碰在线pro中文字幕| avtt中文字幕手机版| 裸日本资源在线午夜| 成人精品动漫一区二区| 亚洲一区二区精品在线播放| 亚洲韩精品一区二区三区| 欧美色视频网址大全| 不卡一区二区视频在线| 久久无码高清免费视频| 九九热精品视频在线播放| 无码精品黑人一区二区老人| 国色天香一二三期区别大象| 国内自拍第一区二区三区| 成人精品影视一区二区| 青青青青午夜手机国产视频| 性色蜜桃臀x88av天美传媒| 亚洲成a人77777| 91美女在线观看视频| 国产av啊啊啊啊啊啊啊| 伊人精品成人综合网| 天天操天天搞天天操| 日本国产亚洲欧美色综合| 68福利精品在线视频| 夜夜躁婷婷av蜜桃妖| 亚洲熟妇丰满多毛xxxx网站| 天天操天天日天天碰| 在线人成视频免费观看尤物| 亚洲欧洲无码一区2区无码| 欧美日韩成人高清中文网| 熟妇人妻丰满久久久久久久| 国产成人情侣av在线| 黑人3p日本女优中出| 999久久久人妻精品一区| av激情四射五月婷婷| 成人18禁高潮片免费日本| 69国产在线视频网站| 欧美大胆a级视频秒播| —区二区三区女厕偷拍| 99精品视频在线在线观看| 成人av中文字幕在线看| 亚洲女人自熨在线视频| 久久亚洲国产成人精品麻豆| 五月天天堂视频在线| 亚洲av激情综合网| 自拍偷拍 国产激情| 91麻豆精品国产在线| 亚洲中文字幕在线视频观看二区| 欧美黄色性视频网站| 婷婷综合缴情亚洲五月伊人| 超级黄肉动漫在线观看| 欧美人与动欧交视频| av在线播放观看h| 最新免费在线观看污视频| 日本四十路人妻熟女| 韩国毛片w妈妈的朋友7| 人妻激情综合久久久久蜜桃| 美女张开腿给男人桶爽的软件 | 97精品视频,全部免费| 国际精品熟女一区二区| 97精品国产91久久久| 亚洲永远av在线播放| 岳母的诱惑电影在线观看| 欧美啪啪一区二区三区| 国产高清视频www夜色资源| av一区二区三区蜜桃| 杜达雄啪啪毛片视频| 亚洲va999天堂va| 日本少妇丰满大bbb的小乳沟| 中文人妻av一区二区三区| 蜜桃臀av在线一区二区| av日韩视频在线观看| 无人区一码二码三码区别在哪 | 不卡视频在线 欧美日韩| 日日躁夜夜躁狠狠操| 18禁男女啪啪啪无遮挡| 中文字幕 中文字幕 亚洲| 日本欧美高清在线观看视频| 日本老女人日比视频| 大屁股熟女一区二区视频| 在线国产精品欧美| 亚洲成人自拍图片网站| 91porny九色视频偷拍| 一区二区三区资源视频| 猫咪亚洲中文在线中文字幕| 亚洲熟女一区二区三区250p| 日韩av熟妇在线观看| 亚洲资源在线免费观看| 在线免费观看欧美小视频| 亚洲人成小说网站色| 亚洲一区二区三区国产精品电影| 黄色av网址在线播放| 99福利一区二区视频| 黑人3p日本女优中出| 免费在线观看视频啪啪| 美女把腿张开给男的捅| 人妻在线中文视频视频| 久久人妻人人草人人爽| 国产乱码有码一区二区三区| 在线观看中文字幕少妇av| 台湾18禁久久久久久久激情视频| av成人三级高清日韩| 亚洲精品一区二区gif| 最新激情中文字幕视频| 欧美日韩黄片免费在线观看| iga肾三级算严重吗| 久久av色噜噜ai换脸| 日韩国产欧美久久一区| 亚洲国产精品一区51动漫| 国产美女主播av在线| 极品风骚人妻3p视频| 亚洲同性同志一二三专区| 激情久久在线免费观看视频| 亚洲自拍偷拍一区二区中文字幕| 福利视频免费在线播放| 大乳人妻一区二区三区| 精品人妻人人做人人爽| 99精品视频在线在线观看| 日韩人妻中文字幕区| av在线男人的天堂亚洲| 人妻被强av系列一区二区| avgo成人短视频| 亚洲国产精品自拍偷拍视频在线| 国产美女主播av在线| 天天日 天天舔 天天射| 亚洲高清一区二区三区久久| 亚洲无人区乱码中文字幕一区| av天堂新资源在线| 久久人妻人人草人人爽| 69视频在线精品国自产拍| 亚洲成人欧洲成人在线| 国产女主播在线观看一区| 午夜呻吟亚洲精品中文字幕在上面| 国际日韩日韩日韩日韩日韩| 强乱人妻中文字幕日本| 久久久西西gogo日本美女人体| 99热这里只有精品免费播放| 亚洲黄色成人一级片| 国产精品 亚洲欧美 自拍偷拍| 豆豆专区操逼性视频在线| 国产剧情av在线免费观看 | 国产av嗯嗯啊啊av| lutu玩弄人妻短视频| 久久久久高潮白浆久久| 黄色av 在线观看| 伊人久久综合国产精品| 4日日夜夜精品视频免费| 国产91九色视频在线观看| 亚洲国产精品一区二区第二页| 国产激情免费在线视频 | 午夜福利片无码10000| 在线免费观看欧美小视频| 91系列视频在线播放| 久久国产半精品99精品国产| 2021国产剧情麻豆| 99精品视频在线在线观看| 最近在线中文字幕免费| 中文字幕 首页 人妻| 亚洲人精品午夜射精日韩| 日韩欧美中文字幕老司机三分钟 | 人人妻人人爽人人爽欧美一区| 日韩A级毛片免费视频| 亚洲av日韩久久网站| 亚洲一区视频中文字幕在线播放 | 中文字幕在线字幕乱码怎么设置| 成人免费电影二区三区| 91人妻人人做人人爽高清| 最新国产精品拍在线观看| 天天色天天射天天日天天干| 欧美极品少妇高潮喷水| 婷婷色九月综合激情丁香| 国产高清自拍偷拍在线| 极品风骚人妻3p视频| 欧美情色av在线观看| 午夜精品久久久久久久久久蜜桃 | 首页欧美日韩中文字幕| 国产激情视频在线观看的| 午夜精品视频免费观看| 亚洲成人欧洲成人在线| 超碰在线观看97资源| 国产午夜羞羞一区二区三区| 久久av色噜噜ai换脸| 在线播放 日韩 av| 免费在线观看视频啪啪| 色网站在线观看免费| 51精品视频在线免费观看| 欧美精品激情在线不卡| 乱子伦国产一区二区三区| 玖玖资源站在线观看亚洲| 欧美极品少妇高潮喷水| 制服丝袜中文字幕熟女人妻| 99re这里是国产精品首页| 大片a免费观看在线视频观看| 七色福利视频在线观看| 国产中年夫妇激情高潮| 国产精品蝌蚪自拍视频| 日本不卡视频一二三区| 亚洲激情噜噜噜久久久| 中出小骚货在线观看| 最近最新最好看的中文字幕 | 欧美情色av在线观看| 日韩人妻中文字幕二区 | 夜夜躁av麻豆男| 国产黄色主播网址大全在线播放| 99国产精品国产精品毛片19| 久久久久久久精品乱码| 欧美精品一区二区三区观看| 69国产在线视频网站| 成人人妻h在线观看| 国产自拍偷拍视频在线免费观看| 久久99嫩草99久久精品| 亚洲国产精品自拍偷拍视频在线| 人人妻人人爽人人摸| 东京热日韩av影片| 人妻熟女 亚洲 一页二页 | 亚洲va999天堂va| 久久久亚洲综合国产精品| 成人十欧美亚洲综合在线 | 欧洲精品在线免费观看| 成人黄色录像在线观看| 亚洲va999天堂va| 网站在线观看蜜臀91| 精久久久久久久久久久久| 亚洲熟女在线免费观看| 最新国产精品综合网高清| 大屁股熟女一区二区视频| 高清av在线婷一区二区色日韩| 色老头一区二区三区四区五区| 国产激情一区二区视频| 大香焦一道本一区二区三区| 老鸭窝在线毛片观看免费播放| 日产国产欧美精品另类| 黄色av 在线观看| 天天干夜夜操夜夜骑| 精品av天堂毛片久久久| 欧美aaaa性bbbbaaaa| 欧美性感美女热舞视频| 欧美大胆a级视频秒播| 精品视频在线观看免费99| 美女把逼扒开让男人桶| av里面的动作是真进去吗| 国产高清在线观看av| 人妻在线中文视频视频| 91精品国产成人久久久久久| 男人的天堂av中文字幕| 最新免费在线观看污视频| 91人妻人人爽色啊啊啊| 欧美最新一区二区三区| 成熟了的熟妇毛茸茸| avtt中文字幕手机版| 开心五月综合激情婷婷| 大秀成年人国产精品视频| 欧美亚洲愉拍一区二区三区| 91大神福利视频网| 国产激情一区二区视频| 日本一区二区三区的资源| 中文字幕在线字幕乱码怎么设置| 国产成人在线观看hd| 午夜呻吟亚洲精品中文字幕在上面| 亚洲精品激情视频在线观看| 亚洲一级熟妇丰满的女人| 日韩人妻精品久久久久| www,日韩av,com| 国产黄色主播网址大全在线播放| 精品国产污污污免费入口| 人人妻人人爽人人爽欧美一区 | 青青青免费手机视频在线观看| 操死你美女在线视频| 一区二区九日韩美女| 亚洲一区视频中文字幕在线播放 | 午夜宅男电影av网站| 啊不行啊操逼好爽大鸡吧视频| 亚洲av毛片在在线播放| 亚洲一区二区在线激情| 午夜精品小视频在线播放| 亚洲春色av中文字幕| 55夜色66夜色亚洲精品| 日本高清久久人人爽| 日本东京热视频欧美视频| 福利美女视频在线观看| 黄版视频在线免费观看| 天天操天天干加勒比久久| 久久久亚洲熟女一区二区| 91大神在线免费观看视频| 国产av啊啊啊啊啊啊啊| 午夜夫妻性生活视频| 911精产国品一二三产区区| 亚洲欧美韩国日本一区二区| 美女妩媚午夜诱惑网站| 超碰在线观看97资源| 七色福利视频在线观看| 人妻色综合aaaaaa网| 天天日夜夜操人人爽| 亚洲av毛片在在线播放| 中国特黄色性生活片| 天堂网成人av电影| 久久久久久久久久久久久国产| 国产人妻熟女ⅹxx丝袜| 92麻豆一区二区三区| 青青青在线视频免费播放| 青青在线免费手机播放视频| 中文字幕日韩首页欧美在线激情 | 国产男人的天堂一区| 亚洲欧美国产人成在线| 韩国在线播放一区二区三区| 天天插天天透天天爽| 亚洲一区二区三区国产精品电影| alisontyler和黑人| 欧美操大黑鸡巴视频在线观看| 啊不行啊操逼好爽大鸡吧视频| 亚洲理论在线a中文字幕97| ysl蜜桃色7425| 夜色福利视频免费观看| 国产 少妇 一区二区| 亚洲午夜精品视频节目| 亚洲午夜精品一级毛片app| 国产天堂av不卡网| 蜜臀一区二区日韩美女少妇视频 | 日韩一级视频一区二区三区| 日本高清激情乱一区二区三区| 天天天天天天天天日日日| 美女网站福利在线观看| 97视频人人爱麻豆| 91人妻人人爽色啊啊啊| 99免费观看在线视频| 欧美日韩在线观看免费播放| 国产主播诱惑毛片av| 青娱乐免费最新视频| 天天操天天干加勒比久久| 国产视频1区2区3区| 美女妩媚午夜诱惑网站| 中文字幕在线观看av观看| 欧美视频亚洲视频在线| 天天在线播放日韩av| 午夜久久久久久av五月| 亚洲宅男噜噜噜66在线观看| 国产剧情av在线免费观看| 国产激情免费在线视频| 丝袜美女诱惑佐佐三上| 亚洲欧美日韩中文在线观看 | 国产在线观看一区二区三区四区| 欧美日本亚欧在线观看| 夜色福利视频免费观看| 天天插天天操天天射天天干| 999精品视频免费在线观看| 免费在线观看亚洲福利| 日本少妇丰满大bbb的小乳沟| 国语对白性爱三级片免费看| 亚洲三级综合在线观看| 中文字幕熟女人妻一区| 美女张开腿给男人桶爽的软件| 天天干夜夜撸天天操| 天天搞天天操天天干| 人妻人妻在线视频网站| 五月天男人的天堂中文字幕| 后入日韩翘臀蜜桃臀美女| 久久内射天天玩天天懂色| 国产 亚洲 欧美 自拍| 久久久久久久精品乱码| 男女真人做带声音视频图片| 黄版视频在线免费观看| 亚洲永远av在线播放| av天堂a亚洲va天堂va里番| 亚洲中文字幕在线视频观看二区 | 九九热视频1这里只有精品| 亚洲高清一区二区三区久久| 成年人免费福利在线| 中文字幕观看中文字幕免费 | 日本熟妇乱妇熟色视频| 亚洲最强的25个城市| 国产熟女五十路一区二区三区| 成熟了的熟妇毛茸茸| 国产精品午夜无码AV体验区| 最新国产精品综合网高清| 天天日天天玩天天摸| 91精产国品一二三产区区别网站 | 91久久精品美女高潮喷水白浆| av资源中文字幕在线观看 | 国产成人91色精品免费看片| 日本美女爱爱视频网站| 亚洲国产精品 久久久| 最新国产精品综合网高清| 大奶熟妇激情操逼逼| 亚洲中文字幕无线乱码人妻精品| 一区二区欧美 国产日韩| 国产熟妇色xxⅹ交白浆视频| 一区二区三区四区久久久久韩日| 在线有码人妻自拍视频| 午夜情色一区二区三区| 美女扒开逼逼给你看| 五月天天堂视频在线| 不卡高清一区二区三区| 亚洲制服丝袜资源网| 欧美一区二区播放视频| 无码精品黑人一区二区老人| 最新日韩av电影在线播放| 亚洲美女午夜激情视频在线观看| 色欲天天媓色媓香视频综合网| 一区二区三区四区 在线播放| 岳母的诱惑电影在线观看| 成年男女免费视频网站无毒| 亚洲女人自熨在线视频| 每日更新日韩欧美在线| 天堂av在线最新地址| 91青青青国产免费高清| 亚洲欧美成人午夜一区二区| 天天摸天天干夜夜操| 91九色91在线视频| 亚洲码av一区二区三区| 91九色国产在线视频| 久久99久久99久久97的人| av日韩视频在线观看| 亚洲第一中文字幕成人| jiee日本美女视频网站| 国产男女无套?免费网站下载| 国产av高清二区三区| 69xx精品久久久久| 2021国产在线视频| 又爽又粗又猛又色又黄视频| 亚洲avav天堂av在线网毛片| 核xp工厂精品久久亚洲| 久久久人妻免费视频| 亚洲欧美成人午夜一区二区| 男生用大肌巴操美女骚穴| 婷婷色综合五月天视频| julia人妻av一区二区三区| 亚洲欧美小说中文字幕| 激情久久在线免费观看视频| 久久内射天天玩天天懂色| 白白色在线免费视频发布视频| 97香蕉久久国产超碰| 亚洲自拍偷拍一区二区中文字幕| 一区二区三区av免费天天看| 天天摸天天干夜夜操| 2020国产成人精品视频| 九九热精品视频在线播放| 欧美肥妇久久久久久| 国产伦理二区三区在干嘛呢| 欧美性受黑人猛交裸体视频| 亚洲激情视频在线观看免费| 国产精品福利久久久久| 精品欧美乱码久久久| 一区二区三区国产精华液区别大吗 | 黄很色很在线免费视频网站| 午夜福利在线不卡视频| 成年男女免费视频网站无毒| 强乱人妻中文字幕日本| 国产亚洲综合5388| 日本福利视频网站导航| 91精品国产综合99| 亚洲制服丝袜美腿在线| 精品国产污污污免费入口| 制服丝袜 中文字幕 日韩| 福利视频免费在线播放| 日韩精品视频一区二区三区在线| 亚洲欧美激情国产综合久久久| 久久精品四虎夜夜拍拍拍| 农村大炕有肉大屁股熟妇| 制服丝袜 中文字幕 日韩| 精品国产av虐杀两警花| 97视频538在线观看| 日韩激情文学在线视频| 亚洲人精品午夜射精日韩| alisontyler和黑人| 国产在线小视频一区二区| 大鸡扒操大逼大片免费关看| 亚洲欧美精品海量播放 | 99久久久久久久久久久久久| 天天干天天日天天弄| 国产成人情侣激情视频| 在线有码人妻自拍视频| lutu玩弄人妻短视频| av在线免费在线观看| 欧美精品熟妇免费在线| 自拍偷拍 亚洲性图 欧美另类| 99免费观看在线视频| 不卡视频在线 欧美日韩| 不卡一二三区别视频| 亚洲熟女一区二区三区250p| 亚洲欧美激情久久久| 黑人和日本人av一区二区| 国产女主播在线观看一区| 日韩一区二区在线播放观看| 一区二区三区av免费天天看| 国产做A爱免费视频在线观看| 熟妇人妻av无码中文字幕| 黑鸡巴肏少妇逼视频| 欧美情色av在线观看| 精品一区二区三区免费毛片W| 抽插小穴啊啊啊视频| 天堂网免费在线电影| 国产精品 亚洲欧美 自拍偷拍| 一区二区三区免费版在线| 日本不卡 中文字幕| 欧美亚洲精品色图网站| 可以免费观看日韩av| 欧美在线观看一区二区不卡| 国产精品美女免费视频观看| 久久无码高清免费视频| 免费在线观看视频啪啪| 操操操操操操操操操网| 国产精品视频网站污污污| aa福利影视在线观看| 成熟了的熟妇毛茸茸| 人妻视频网站快射视频网站| 911精产国品一二三产区区| 久草视频在线视频在线视频| 亚洲天堂av最新在线| 天天日天天干天天日天天干天天| 亚洲情色777中文字幕| 亚洲成人欧洲成人在线| 97人妻人人揉人人躁人人夜夜爽| 狠狠操深爱婷婷综合一区| 欧美日韩在线观看免费播放| 99福利一区二区视频| 午夜精品视频免费观看| 亚洲18片综合国产av| 一区二区在线观看视频网站| 911精产国品一二三产区区| 亚洲午夜精品视频节目| 欧美男女一区二区三区| 九色91操最新在线观看网址| 亚洲黑人欧美二区三区| 性色蜜桃臀x88av天美传媒| 亚洲18片综合国产av| 欧美大鸡吧男操女啊啊啊视频| 4日日夜夜精品视频免费| 亚洲天堂av最新在线| 91精品久久久久久久久99蜜臀| 青青免费观看视频| a级片特黄免费看| 日韩无码国产一区二区| 国产91九色视频在线观看| 中文字幕人妻一区二区视频系列| 国产自拍偷拍在线精品| 日韩av水蜜桃一区二区三区| 在线播放 日韩 av| 全彩漫画口工18禁| 小妹妹爱大棒棒免费观看视频| 91九色91在线视频| 国产高清视频www夜色资源| 成人精品影视一区二区| 国内精品一区二区2021在线 | 男人av一区二区三区| yy4080黄色片| 天天插天天透天天爽| 啊~插得好快别揉我胸了视频| 伊人久久综合国产精品| tobu8日本高清| 欧美日韩亚洲tv不卡久久| 一区二区在线观看视频网站| 黄色av网址在线播放| 亚洲国产美女主播在线观看| 日韩免费黄色片在线观看| 日韩欧美中文字幕老司机三分钟| 最新国产精品久久精品app| 亚洲码av一区二区三区| 60路70路日本熟妇| 最新日韩av电影在线播放| 偷拍欧美日韩另类图片| 天天天天天天天天干夜夜| 天天插天天干天天狠| 妈妈的朋友中字在线免费观看| 亚洲国产精品青青草| 欧美一级aaaaaaa片| 顶级欧美色妇xxxx| av一区二区三区蜜桃| 伊人免费观看视频一| 91人妻人人做人人爽高清| 亚欧洲乱码视频一二三区| 夜夜人人干人人爱人人操| 国产精品美女免费视频观看| 熟女人妻aⅴ一区二区三| 在线免费视频999| 中日韩又粗又硬又大精品| 夜夜骚av一二三区| 亚洲欧美精品海量播放| 中文字幕在线观看亚洲情色| 熟女人妻少妇一区二区| 国际精品熟女一区二区| 91精品麻豆91夜夜骚| 韩国资源视频一区二区三区| 美利坚合众国av天堂| 青青操久久综合激情| 69久久夜色精品国产69乱电影 | 中文字幕在线字幕乱码怎么设置| 亚洲蜜桃久久久久久| 久操资源在线免费播放| 快使劲弄我视频在线播放| 久99久视频免费观看中文字幕| 99久久久久久亚洲精品免费| 黑人爆操女人免费视频| 伊人网在线欧美日韩在线| 黑人和日本人av一区二区| 亚洲色图日韩在线视频观看| 久久久西西gogo日本美女人体| 午夜在线成人免费电影| 人妻免费视频黄片在线视频| 午夜偷拍的视频久久久免费大全| 国产一级一国产一级毛片| 98热视频精品在线观看| 欧美熟女xx00视频| 亚洲制服丝袜资源网| 欧美在线观看视频欧美| 污网址在线观看视频| 超级黄肉动漫在线观看| 两个人在一起靠逼啊啊啊| 免费中文字幕a级激情| 亚洲精品国品乱码久久久久| 青青操久久综合激情| 桃色成人开心激情网| 午夜在线观看一级毛| 大香蕉伊人97在线| 日本老熟妇av老熟妇| 亚洲宅男噜噜噜66在线观看| 99久9在线视频播放| 九十九步都是爱最后一步是尊严| 日本高清在线观看不卡视频| 国产黄色主播网址大全在线播放 | 先锋人妻啪啪中文字幕| 欧美三区四区在线视频| 丰满少妇高潮喷水视频| 高清av在线婷一区二区色日韩| 抽插小穴啊啊啊视频| 天天看天天爱天天日| 亚洲欧美不卡专业视频| 青青免费观看视频| 涩涩黄片在线免费观看| 精品一区二区三区免费毛片W| 国产精美视频精品视频精品| 青青草一个释放的网站| 美女张开腿给男人桶爽的软件| 开心五月综合激情婷婷| 一区二区三区五区六区| 亚洲最大的自拍偷拍网| 日本久久久久久黄色| www一区二区91| 在线视频国产精品欧美| 亚欧洲乱码视频一二三区| 中文字幕欧美人妻在线.| 国产做A爱免费视频在线观看| av天堂新资源在线| 日本人妻少妇xxxxxxx| 91系列视频在线播放| 精品国产污污污免费入口| 182tv精品免费在线观看| 在线播放 日韩 av| 熟妇精品午夜久久久久| 亚洲欧美小说中文字幕| 日本一本午夜在线播放| 九九热在线精品播放| 不卡视频在线 欧美日韩| 天堂av在线最新地址| 中文字幕免费啪啪啪| 美女黄色啊啊啊啊视频| 九热精品视频在线观看| 午夜五十路久久福利| 在线观看黄页网站视频网站| 60路70路日本熟妇| 欧美第一激情综合网欧美激情| 92在线播放观看视频| 在线播放 日韩 av| 久久99嫩草99久久精品| 天天爱天天日天天爽| 亚洲午夜精品一级毛片app| 免费看一级高潮喷水片| 开心五月综合激情婷婷| 久久99精品热在线观看| 嗯~嗯~啊啊啊~高潮了软件| 久久人妻诱惑我视频| 黑川堇人妻88av| 一区二区三区午夜福利在线| 国产成人综合久久婷婷| 2020精品视频在线| 美女激情久久久久久久| 亚洲中文字幕在线视频观看二区 | 亚洲午夜高清在线观看| 亚洲激情视频在线观看免费| 99re这里是国产精品首页| 久久亚洲国产成人精品麻豆 | 日本高清激情乱一区二区三区| 91精品资源在线观看| 亚洲无人区乱码中文字幕一区| 婷婷色综合五月天视频| 中文字幕人妻一区色偷偷久久| 最近中文字幕免费视频一| 九九九九九久久久国产 | xxnxx国产美女| 亚洲精品久久久人妻| 欧美国产精品久久久免费| 国产一区两区三区福利小视频| 亚洲黑人欧美二区三区| 亚洲欧洲一区二区三区在线| av在线播放观看h| 91精品在线视频免费视频| 亚洲欧美韩国日本一区二区| 国产av在线免费视频| 天天曰天天摸天天爽 | 女生裸体视频免费网站| 亚洲资源在线免费观看| 成人大片男人的天堂| 国产熟妇色xxⅹ交白浆视频| 国长拍拍视频免费孕妇| 天天干天天操天天要| 情趣视频在线观看91| 丰满人妻被猛烈进入中文字幕| 亚洲乱码国产乱码精品精视频| 搞乱在线在线观看视频| 黑人巨大精品一区二区在线| 天天日夜夜操人人爽| 亚洲理论在线a中文字幕97| 国产精品蝌蚪自拍视频| 天天天天天天天天日日日| 亚州av嫩草av极品在线观看| 中文字幕av人妻一区二区三区| 在线免费观看欧美小视频| 裸日本资源在线午夜| 亚洲男人天堂最新网址大全| 宅男噜噜噜66国产在线观看| 爱搞视频在线观看视频91| 午夜国产免费视频亚洲| 欧美黑人性猛交小矮人| 激情久久在线免费观看视频| 亚洲成人欧洲成人在线| 美利坚合众国av天堂| 可以直接看av网站| 天海翼亚洲一区在线观看| 黄色片免费网站在线| 天天躁狠狠躁狠狠躁性色| 4438全国成人免费视频| 999精品视频免费在线观看| 182tv精品免费在线观看| 蜜乳视频一区二区三区| 欧美啪啪一区二区三区| 福利视频免费在线播放| 一区二区三区四区影片| 女同大尺度视频网站在线观看| 成人精品影视一区二区| 日韩精品视频一区二区三区在线 | 2021国产在线视频| 五月激情婷婷四射基地| 亚洲天堂色综合久久| 2021国产在线视频| 国产 亚洲 欧美 自拍| 日韩人妻中文字幕二区| 亚洲最大先锋资源采集站| 老熟女xxxⅹhd老熟女性| 5d蜜桃臀女无痕裸感| 在线成人教育平台排名| 国产91黑丝小视频在线观看| 成人黄色录像在线观看| 亚洲成人av在线一区二区| 亚洲色大WWW永久网站| av资源中文字幕在线观看| www一区二区91| 免费绝清毛片a在线播放| 天天操天天日天天碰| 国产精美视频精品视频精品| 亚洲男人天堂最新网址大全| 午夜久久久久久av五月| 精产国品一二三产品区别97| 国产美女主播av在线| 视频免费在线观看网站| 天天天天天天天天干夜夜| 国产视频1区2区3区| 国产不卡免费在线观看| 老鸭窝在线毛片观看免费播放| 亚洲天堂色综合久久| 午夜福利午夜福利影院| 99福利一区二区视频| 91精品麻豆91夜夜骚| 日本一区二区三区区别| 日韩av电影中文在线免费观看| 中文字幕亚洲乱码精品无限| 鸡巴插进美女的嫩小穴视频| 国产欧美福利在线观看| 男人的天堂aⅴ在线| 天天操,天天射,天天爽| 国产原创一区二区三区在线播放| 天天日天天亲天天操| 天天曰天天摸天天爽| 国语精品视频自产自拍| 制服丝袜 中文字幕 日韩| 松本菜奈实最新av在线| 最近最新欧美日韩精品| 人妻中文字幕亚洲在线| 欧美日韩不卡视频合集 | 蜜乳视频一区二区三区| 欧美日韩一区二区三区成人影院| 男人的天堂av中文字幕| 日本东京热视频欧美视频| 免费的啪啪视频软件 | 精品不卡一区二区三区| 七色福利视频在线观看| 国产精品午夜无码AV体验区 | 夫妻黄色一级性生活片| 欧美性受黑人猛交裸体视频| 亚洲最大的自拍偷拍网| 亚洲第一区av中文字幕| 亚洲综合一区二区三区四区| 蜜乳av中文字幕一区二区| 台湾18禁久久久久久久激情视频| 亚洲永远av在线播放| 99热99这里免费的精品| 九九视频在线观看全部| 国产一区二区三区四区精| 亚洲欧美综合另类最新| 视频在线+欧美十亚洲曰本 | 中文字幕熟女人妻丝袜丝在线| 9久re热视频在线精品| 亚洲avav天堂av在线网毛片| 中文字幕欧美人妻在线.| 久久av色噜噜ai换脸| 亚洲女人自熨在线视频| 免费中文三级在线观看| 国产精品乱码高清在线观看h| 自拍偷拍 亚洲性图 欧美另类| 久久中文字幕av一区二区| 欧美精品999不卡| 蜜臀久久精品久久久久久av | 日本欧美高清在线观看视频| 欧美一级aaaaaaa片| 天天曰天天摸天天爽| 在线观看中文字幕少妇av| 大屁股熟女一区二区视频| 91精品一区一区三区| 日本少妇三级交换做爰做| 日本亚洲精品视频在线观看| 亚洲国产精品自拍偷拍视频在线| 得得爱在线视频观看| 欧美强奸视频在线观看 | 999久久久人妻精品一区 | 亚洲自拍偷拍av在线| 日韩最近中文在线观看| 日韩欧美一区二区三区免费看 | 在线免费观看欧美小视频| 欧美精品一区二区三区观看| 天堂av在线最新地址| 伊人久久综合国产精品| 亚洲男人天堂最新网址大全| 免费在线观看亚洲福利| 国产精品成人免费电影| 瑟瑟干视频在线观看| 女人的天堂 av在线| 亚洲欧美不卡专业视频| 一区二区三区四区久久久久韩日| av福利免费体验观看| 91九色pony蝌蚪| 欧美黑人性猛交小矮人| 91污污在线观看视频| 国产一区二区三区四区精| 国产精品美女免费视频观看| 女人的天堂 av在线| 成人黄色录像在线观看| 亚洲宅男噜噜噜66在线观看| 精久久久久久久久久久久 | 视频在线+欧美十亚洲曰本| 55夜色66夜色亚洲精品| 骚穴被阴茎插免费视频| 岳的大肥屁熟妇五十路| 伊人网在线欧美日韩在线| 国长拍拍视频免费孕妇| 国产自拍偷拍视频在线免费观看| 五十岁熟妇高潮喷水| 欧美日韩福利视频网| 91福利高清在线播放| 亚洲天堂男人的天堂| 欧美国产精品久久久免费| 国产视频1区2区3区| 中文字幕在线观看亚洲情色| 中文字幕亚洲无线乱码| 一级做性色a爱片久久片| 天天摸天天干夜夜操| 人妻色综合aaaaaa网| 麻豆出品视频在线观看| 日产国产欧美精品另类| 欧美成人一二三在线网| www,日韩av,com| 亚州av嫩草av极品在线观看| 中文字幕福利视频第四页| 干逼又爽又黄又免费的视频| 成年人黄色日本视频| 男人电影天堂在线观看| 免费24小时人妻视频| 黑人3p日本女优中出| 国产视频成人自拍蝌蚪视频| 自拍丝袜国产欧美日韩| 日本韩国福利在线播放| 福利美女视频在线观看| 国产肥胖熟女又色又爽免费视频| 68福利精品在线视频| 川上优所有中文字幕在线| 中国特黄色性生活片| 一区二区三区av免费天天看| av在线免费在线观看| 全国熟妇精品一区二区免费视频| 国产精品乱码高清在线观看h| 成人av在线视频免费| 荣立三等功退休有什么待遇| 亚洲制服丝袜资源网| 日韩成人精品久久久免费看| 亚洲色视频在线播放网站| 天天透天天舔天天操| 成人精品动漫一区二区| 日本有码精品一区二区三区| 欧美亚洲愉拍一区二区三区| 色丁香久久激情综合网| 国产一区二区三区四区精| 亚洲综合首页综合在线观看 | 视频自拍偷拍视频自拍| 污网址在线观看视频| 日产国产欧美精品另类| 漂亮人妻口爆久久精品| 交换的一天中文字幕在线视频| 天天操天天日天天碰| 国内精品一区二区2021在线| 放荡人妻极品少妇全集| 日韩成人在线电影首页| 亚洲国产综合久久精品| 老司机在线视频福利观看| 在线视频国产精品欧美| 天天早上头和脸出汗是怎么办| 一级做性色a爱片久久片| 亚洲欧美综合另类最新| 51精品视频在线免费观看| 国产视频1区2区3区| 五月婷婷激情视频网| 美国十次了亚洲天堂网国产| 网友自拍第一页99热| 91麻豆精品国产在线| 人妻免费视频黄片在线视频| 亚成区一区二区人妻熟女| jizzjizz国产精品传媒| 中文字幕人妻一区色偷偷久久| 国产美女视频带a∨黄色片| 2020精品视频在线| 91精品国产人妻麻豆| 久久99精品热在线观看| 久久久久久免费观看av| 91精品国产人妻麻豆| 男生用大肌巴操美女骚穴| 91亚洲精品久久蜜桃| 成人av中文字幕在线看| 免费在线观看亚洲福利| 国产 亚洲 欧美 自拍| 熟妇人妻av无码中文字幕| 欧美日韩亚洲国产视频二区| 四季av人妻一区二区三区| 最新激情中文字幕视频| 人妻色综合aaaaaa网| 放荡人妻极品少妇全集| av在线免费在线观看| 区一区二区三免费观看视频| 亚洲乱熟女一区二区三区山| 日本一区二区三区调教性奴视频| 美国男的操女孩的小嫩逼| 免费中文三级在线观看| 熟女人妻少妇一区二区| 凹凸视频一区二区在线观看| 韩国毛片w妈妈的朋友7| 天天操天天干天天谢| 国产天堂av不卡网| 日韩成人免费观看电影| 黄色网络中文字幕日本| 天天日天天玩天天摸| 丝袜美腿日韩av一区| 亚洲码av一区二区三区| 中字幕人妻熟女人妻a62v网| 成人做爰av在线观看网站| 日本欧美亚洲国产啊啊啊| 国产熟女五十路一区二区三区 | 中文字幕亚洲无线乱码| 欧美一区二区三区视频看| 青青免费观看视频| 国产 少妇 一区二区| 制服丝袜 中文字幕 日韩| 国产中年夫妇激情高潮| 男人av一区二区三区| 99久久人人爽亚洲精品美女| 操死你美女在线视频| 亚洲高清一区二区三区久久| 国语精品视频自产自拍| 丰满人妻熟女aⅴ一区| 日韩一级欧美一级片| 精品av天堂毛片久久久| xxxx69在线观看视频| 女人的天堂 av在线| 国产高清视频www夜色资源| 91亚洲最新蜜桃在线| 在线观看视频免费一区二区三区| 一区二区三区婷婷中文字幕| 加勒比东京热绿帽人妻多人操| 污网址在线观看视频| 欧美日韩不卡视频合集| 69xx精品久久久久| 99在线视频精品观看高| 午夜国产成人精品视频观看| 18在线观看免费观看| 99免费观看在线视频| 东北老女人熟女啪啪视频| 亚洲欧美一级特黄大片| 亚洲a级视频在线播放| 亚洲欧美成人午夜一区二区| 亚洲国内精品久久久久久久| 亚洲av 综合av| 亚洲女人自熨在线视频| 18禁男女啪啪啪无遮挡| 国际精品熟女一区二区| 老鸭窝在线毛片观看免费播放| 99色在线观看免费观看| 2020国产成人精品视频| 日本欧美高清在线观看视频| 欧美在线视频不卡一区| 不卡一二三区别视频| 日本清纯中文字幕版| 亚洲最大先锋资源采集站 | 精品国模一区二区三区欧美| 91佛爷视频在线观看| tushy一区二区三区视频| —区二区三区女厕偷拍| 亚洲人成大片在线观看| 精品国产污污污免费入口| av成人三级高清日韩| 九九九九九久久久国产| 自拍偷拍亚洲综合第一页| 亚洲人妻系列在线视频| 国产av啊啊啊啊啊啊啊| 91偷拍被偷拍在线播放| 日本久久久久久黄色| 国产igao激情在线视频入口| 欧美一级aaaaaaa片| 99 re国产精品| 亚洲一区亚洲二区成人福利| 亚洲制服丝袜美腿在线| 91精品夜夜夜一区二区| 黑吊操欧美极品美女| 最新国产精品久久精品app| 99久久99九九九99九| www一区二区91| 免费观看在线中文字幕视频| 大屁股熟女一区二区视频| 欧洲亚洲一区二区三区四区| 熟妇精品午夜久久久久| 熟女国内精品一区二区三区| 韩国毛片w妈妈的朋友7| 五月天天堂视频在线| 中文字幕观看中文字幕免费 | 鸡巴在里面福利视频在线观看| 99热在线只有的精品| 激情久久在线免费观看视频| 日本在线免费观看国产精品| 91精品资源在线观看| 台湾18禁久久久久久久激情视频| 中文字幕福利视频在线一区| 日本人妻少妇xxxxxxx| 99re这里是国产精品首页| 国产成人在线观看hd| 亚洲高清一区二区三区久久| 高潮喷水在线视频观看| 日韩一区二区在线播放观看| 日本熟女0930视频| 福利美女视频在线观看| 中文字幕日韩首页欧美在线激情 | 亚洲美女露隐私av一区二区精品 | 中文字幕久久久国产| 亚洲日本欧美韩国另类综合| 亚洲午夜熟女在线观看| 日本少妇人妻凌辱在线| 久久视频 在线播放| 综合久久伊人久久88| 午夜92福利1000| 日本有码精品一区二区三区| 日本老女人日比视频| 中文字幕福利视频第四页| 人妻中文字幕亚洲在线| 一区二区三区婷婷中文字幕| 国产一区两区三区福利小视频| 久久久亚洲熟女一区二区| 亚洲精品色图1234| 国产精品午夜无码AV体验区| 黄版视频在线免费观看| 中文字幕av人妻一区二区三区 | 亚洲在线免费观看18| 极品少妇高潮喷水日出白浆| 午夜美女福利视频在线| 60路70路日本熟妇| 午夜福利在线不卡视频| 久久久久久高清一区| 夜夜躁av麻豆男| 亚洲免费午夜污福利| 亚洲人成大片在线观看| 视频在线+欧美十亚洲曰本 | 亚洲激情视频在线观看免费| 国产一区两区三区福利小视频| 50熟妇一区二区三区| 国产成人情侣av在线| 91精品91久久久久| 免费看一级高潮喷水片| 亚洲精品国产99999| 亚洲a级视频在线播放| 在线观看视频免费一区二区三区| 两个人在一起靠逼啊啊啊| 55夜色66夜色亚洲精品| 国产熟女五十路一区二区三区| 亚洲成人激情在线综合| 久久久精品人妻无码专区不卡 | 国产精品无码无卡免费观| 免费看超污视频在线观看| 亚洲图片另类综合小说| 国产福利三级在线观看| 天天爽天天操天天插| 999国产精品视频免费看| 亚洲综合成人精品成人精品| 2026天天操天天干| 天天夜夜久久精品综合| 午夜偷拍的视频久久久免费大全| 欧美成人红桃视频在线观看| 色视频免费观看网址| 亚洲欧美成人激情在线| 亚洲午夜高清在线观看| 日本黄页在线观看视频| 视频自拍偷拍视频自拍 | 中文字幕人妻一区二区视频系列| 午夜精品久久久久久久精品乱码| 日本熟妇乱妇熟色视频| 午夜精品秘一区二区三区| 日本美女爱爱视频网站| 欧美区一区二区三视频| 男女啪啪啪网站在线观看免费| 99女福利女女视频在线播放| 99久久99九九九99九| 夜夜爽夜夜操夜夜爱| 搞乱在线在线观看视频| 亚洲黑人欧美二区三区| 一区二区三区免费版在线| 午夜亚洲国产精品中字| 美女av色播在线播放| 99精品久久99久久久久一| 久久久精品人妻无码专区不卡 | 日本欧美国产在线一区| 欧美一区二区三区爽爽| 亚洲成人 国产精品| 欧美成人性生活视频播放| aaaa级少妇高潮在线观看 | 日本少妇三级交换做爰做| 91精品在线视频免费视频| 一区二区三区高清视频3| 黑人大巨屌操美女逼| 亚洲精品9999蜜桃| 秋霞成人午夜鲁丝一区二区三区| 91九色人妻在线播放| 中文字幕精品人妻久久久久| 日本国产亚洲欧美色综合| 91精品在线视频免费视频| 伦理在线观看未删减中文字幕| 色屁屁一区二区三区在线观看| 日韩欧美中文字幕老司机三分钟| 麻豆出品视频在线观看| 伊人情人成综合视频| 最新福利二区三区视频| 大尺度av毛片在线网址| 精品免费一区二区三区四区视频| 国产 少妇 一区二区| 黑人黄色免费一级av| 国产成人在线观看hd| 成人免费电影二区三区 | 97精品人妻免费视频| 国产成人情侣激情视频| 极品少妇高潮喷水日出白浆| 最新国产精品综合网高清| av一区二区三区四区五区在线| 日韩成人免费观看电影| 久久精品久久久久观看99水蜜桃| 福利小视频免费在线| 欧美色视频网址大全| 欧美精品激情在线不卡| 55夜色66夜色亚洲精品| 亚洲美女黄色福利视频网站大全| 免费看一级高潮喷水片| 98热视频精品在线观看| 日韩激情文学在线视频| 免费绝清毛片a在线播放| 99国产精品久久99久久久| 中国特黄色性生活片| aa福利影视在线观看| 久久中文字幕av一区二区| 四虎国产精品国产精品国产精品| 亚洲天堂男人的天堂| 91精品久久久久久久久99蜜臀| 日本四十路人妻熟女| 免费成人av麻豆|