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

Go 為什么這么“快”

開發(fā) 架構(gòu)
本文主要從 Go 調(diào)度器架構(gòu)層面上介紹了 G-P-M 模型,通過該模型怎樣實現(xiàn)少量內(nèi)核線程支撐大量 Goroutine 的并發(fā)運行。以及通過 NetPoller、sysmon 等幫助 Go 程序減少線程阻塞,充分利用已有的計算資源,從而最大限度提高 Go 程序的運行效率。

 本文主要介紹了 Go 程序為了實現(xiàn)極高的并發(fā)性能,其內(nèi)部調(diào)度器的實現(xiàn)架構(gòu)(G-P-M 模型),以及為了最大限度利用計算資源,Go 調(diào)度器是如何處理線程阻塞的場景。

怎么讓我們的系統(tǒng)更快

隨著信息技術(shù)的迅速發(fā)展,單臺服務器處理能力越來越強,迫使編程模式由從前的串行模式升級到并發(fā)模型。

并發(fā)模型包含 IO 多路復用、多進程以及多線程,這幾種模型都各有優(yōu)劣,現(xiàn)代復雜的高并發(fā)架構(gòu)大多是幾種模型協(xié)同使用,不同場景應用不同模型,揚長避短,發(fā)揮服務器的最大性能。

而多線程,因為其輕量和易用,成為并發(fā)編程中使用頻率最高的并發(fā)模型,包括后衍生的協(xié)程等其他子產(chǎn)品,也都基于它。

并發(fā) ≠ 并行

并發(fā) (concurrency) 和 并行 ( parallelism) 是不同的。

在單個 CPU 核上,線程通過時間片或者讓出控制權(quán)來實現(xiàn)任務切換,達到 "同時" 運行多個任務的目的,這就是所謂的并發(fā)。但實際上任何時刻都只有一個任務被執(zhí)行,其他任務通過某種算法來排隊。

多核 CPU 可以讓同一進程內(nèi)的 "多個線程" 做到真正意義上的同時運行,這才是并行。

進程、線程、協(xié)程

進程:進程是系統(tǒng)進行資源分配的基本單位,有獨立的內(nèi)存空間。

線程:線程是 CPU 調(diào)度和分派的基本單位,線程依附于進程存在,每個線程會共享父進程的資源。

協(xié)程:協(xié)程是一種用戶態(tài)的輕量級線程,協(xié)程的調(diào)度完全由用戶控制,協(xié)程間切換只需要保存任務的上下文,沒有內(nèi)核的開銷。

線程上下文切換

由于中斷處理,多任務處理,用戶態(tài)切換等原因會導致 CPU 從一個線程切換到另一個線程,切換過程需要保存當前進程的狀態(tài)并恢復另一個進程的狀態(tài)。

上下文切換的代價是高昂的,因為在核心上交換線程會花費很多時間。上下文切換的延遲取決于不同的因素,大概在在 50 到 100 納秒之間。考慮到硬件平均在每個核心上每納秒執(zhí)行 12 條指令,那么一次上下文切換可能會花費 600 到 1200 條指令的延遲時間。實際上,上下文切換占用了大量程序執(zhí)行指令的時間。

如果存在跨核上下文切換(Cross-Core Context Switch),可能會導致 CPU 緩存失效(CPU 從緩存訪問數(shù)據(jù)的成本大約 3 到 40 個時鐘周期,從主存訪問數(shù)據(jù)的成本大約 100 到 300 個時鐘周期),這種場景的切換成本會更加昂貴。

Golang 為并發(fā)而生

Golang 從 2009 年正式發(fā)布以來,依靠其極高運行速度和高效的開發(fā)效率,迅速占據(jù)市場份額。Golang 從語言級別支持并發(fā),通過輕量級協(xié)程 Goroutine 來實現(xiàn)程序并發(fā)運行。

Goroutine 非常輕量,主要體現(xiàn)在以下兩個方面:

上下文切換代價小: Goroutine 上下文切換只涉及到三個寄存器(PC / SP / DX)的值修改;而對比線程的上下文切換則需要涉及模式切換(從用戶態(tài)切換到內(nèi)核態(tài))、以及 16 個寄存器、PC、SP…等寄存器的刷新;

內(nèi)存占用少:線程棧空間通常是 2M,Goroutine 棧空間最小 2K;

Golang 程序中可以輕松支持10w 級別的 Goroutine 運行,而線程數(shù)量達到 1k 時,內(nèi)存占用就已經(jīng)達到 2G。

Go 調(diào)度器實現(xiàn)機制:

Go 程序通過調(diào)度器來調(diào)度Goroutine 在內(nèi)核線程上執(zhí)行,但是 Goroutine 并不直接綁定 OS 線程 M - Machine運行,而是由 Goroutine Scheduler 中的 P - Processor (邏輯處理器)來作獲取內(nèi)核線程資源的『中介』。

Go 調(diào)度器模型我們通常叫做G-P-M 模型,他包括 4 個重要結(jié)構(gòu),分別是G、P、M、Sched:

G:Goroutine,每個 Goroutine 對應一個 G 結(jié)構(gòu)體,G 存儲 Goroutine 的運行堆棧、狀態(tài)以及任務函數(shù),可重用。

G 并非執(zhí)行體,每個 G 需要綁定到 P 才能被調(diào)度執(zhí)行。

P: Processor,表示邏輯處理器,對 G 來說,P 相當于 CPU 核,G 只有綁定到 P 才能被調(diào)度。對 M 來說,P 提供了相關(guān)的執(zhí)行環(huán)境(Context),如內(nèi)存分配狀態(tài)(mcache),任務隊列(G)等。

P 的數(shù)量決定了系統(tǒng)內(nèi)最大可并行的 G 的數(shù)量(前提:物理 CPU 核數(shù) >= P 的數(shù)量)。

P 的數(shù)量由用戶設置的 GoMAXPROCS 決定,但是不論 GoMAXPROCS 設置為多大,P 的數(shù)量最大為 256。

M: Machine,OS 內(nèi)核線程抽象,代表著真正執(zhí)行計算的資源,在綁定有效的 P 后,進入 schedule 循環(huán);而 schedule 循環(huán)的機制大致是從 Global 隊列、P 的 Local 隊列以及 wait 隊列中獲取。

M 的數(shù)量是不定的,由 Go Runtime 調(diào)整,為了防止創(chuàng)建過多 OS 線程導致系統(tǒng)調(diào)度不過來,目前默認最大限制為 10000 個。

M 并不保留 G 狀態(tài),這是 G 可以跨 M 調(diào)度的基礎。

Sched:Go 調(diào)度器,它維護有存儲 M 和 G 的隊列以及調(diào)度器的一些狀態(tài)信息等。

調(diào)度器循環(huán)的機制大致是從各種隊列、P 的本地隊列中獲取 G,切換到 G 的執(zhí)行棧上并執(zhí)行 G 的函數(shù),調(diào)用 Goexit 做清理工作并回到 M,如此反復。

理解 M、P、G 三者的關(guān)系,可以通過經(jīng)典的地鼠推車搬磚的模型來說明其三者關(guān)系:

 

 

 

[[316501]]

 

地鼠(Gopher)的工作任務是:工地上有若干磚頭,地鼠借助小車把磚頭運送到火種上去燒制。M 就可以看作圖中的地鼠,P 就是小車,G 就是小車里裝的磚。

弄清楚了它們?nèi)叩年P(guān)系,下面我們就開始重點聊地鼠是如何在搬運磚塊的。

Processor(P):

根據(jù)用戶設置的 GoMAXPROCS 值來創(chuàng)建一批小車(P)。

Goroutine(G):

通過 Go 關(guān)鍵字就是用來創(chuàng)建一個 Goroutine,也就相當于制造一塊磚(G),然后將這塊磚(G)放入當前這輛小車(P)中。

Machine (M):

地鼠(M)不能通過外部創(chuàng)建出來,只能磚(G)太多了,地鼠(M)又太少了,實在忙不過來,剛好還有空閑的小車(P)沒有使用,那就從別處再借些地鼠(M)過來直到把小車(P)用完為止。

這里有一個地鼠(M)不夠用,從別處借地鼠(M)的過程,這個過程就是創(chuàng)建一個內(nèi)核線程(M)。

需要注意的是:地鼠(M) 如果沒有小車(P)是沒辦法運磚的,小車(P)的數(shù)量決定了能夠干活的地鼠(M)數(shù)量,在 Go 程序里面對應的是活動線程數(shù);

在 Go 程序里我們通過下面的圖示來展示 G-P-M 模型:

 

 

 

 

P 代表可以“并行”運行的邏輯處理器,每個 P 都被分配到一個系統(tǒng)線程 M,G 代表 Go 協(xié)程。

Go 調(diào)度器中有兩個不同的運行隊列:全局運行隊列(GRQ)和本地運行隊列(LRQ)。

每個 P 都有一個 LRQ,用于管理分配給在 P 的上下文中執(zhí)行的 Goroutines,這些 Goroutine 輪流被和 P 綁定的 M 進行上下文切換。GRQ 適用于尚未分配給 P 的 Goroutines。

從上圖可以看出,G 的數(shù)量可以遠遠大于 M 的數(shù)量,換句話說,Go 程序可以利用少量的內(nèi)核級線程來支撐大量 Goroutine 的并發(fā)。多個 Goroutine 通過用戶級別的上下文切換來共享內(nèi)核線程 M 的計算資源,但對于操作系統(tǒng)來說并沒有線程上下文切換產(chǎn)生的性能損耗。

為了更加充分利用線程的計算資源,Go 調(diào)度器采取了以下幾種調(diào)度策略:

任務竊取(work-stealing)

我們知道,現(xiàn)實情況有的 Goroutine 運行的快,有的慢,那么勢必肯定會帶來的問題就是,忙的忙死,閑的閑死,Go 肯定不允許摸魚的 P 存在,勢必要充分利用好計算資源。

為了提高 Go 并行處理能力,調(diào)高整體處理效率,當每個 P 之間的 G 任務不均衡時,調(diào)度器允許從 GRQ,或者其他 P 的 LRQ 中獲取 G 執(zhí)行。

減少阻塞

如果正在執(zhí)行的 Goroutine 阻塞了線程 M 怎么辦?P 上 LRQ 中的 Goroutine 會獲取不到調(diào)度么?

在 Go 里面阻塞主要分為一下 4 種場景:

場景 1:由于原子、互斥量或通道操作調(diào)用導致 Goroutine 阻塞,調(diào)度器將把當前阻塞的 Goroutine 切換出去,重新調(diào)度 LRQ 上的其他 Goroutine;

場景 2:由于網(wǎng)絡請求和 IO 操作導致 Goroutine 阻塞,這種阻塞的情況下,我們的 G 和 M 又會怎么做呢?

Go 程序提供了網(wǎng)絡輪詢器(NetPoller)來處理網(wǎng)絡請求和 IO 操作的問題,其后臺通過 kqueue(MacOS),epoll(Linux)或 iocp(Windows)來實現(xiàn) IO 多路復用。

通過使用 NetPoller 進行網(wǎng)絡系統(tǒng)調(diào)用,調(diào)度器可以防止 Goroutine 在進行這些系統(tǒng)調(diào)用時阻塞 M。這可以讓 M 執(zhí)行 P 的 LRQ 中其他的 Goroutines,而不需要創(chuàng)建新的 M。有助于減少操作系統(tǒng)上的調(diào)度負載。

下圖展示它的工作原理:G1 正在 M 上執(zhí)行,還有 3 個 Goroutine 在 LRQ 上等待執(zhí)行。網(wǎng)絡輪詢器空閑著,什么都沒干。

 

 

 

 

接下來,G1 想要進行網(wǎng)絡系統(tǒng)調(diào)用,因此它被移動到網(wǎng)絡輪詢器并且處理異步網(wǎng)絡系統(tǒng)調(diào)用。然后,M 可以從 LRQ 執(zhí)行另外的 Goroutine。此時,G2 就被上下文切換到 M 上了。

 

 

 

 

最后,異步網(wǎng)絡系統(tǒng)調(diào)用由網(wǎng)絡輪詢器完成,G1 被移回到 P 的 LRQ 中。一旦 G1 可以在 M 上進行上下文切換,它負責的 Go 相關(guān)代碼就可以再次執(zhí)行。這里的最大優(yōu)勢是,執(zhí)行網(wǎng)絡系統(tǒng)調(diào)用不需要額外的 M。網(wǎng)絡輪詢器使用系統(tǒng)線程,它時刻處理一個有效的事件循環(huán)。

 

 

 

 

這種調(diào)用方式看起來很復雜,值得慶幸的是,Go 語言將該“復雜性”隱藏在 Runtime 中:Go 開發(fā)者無需關(guān)注 socket 是否是 non-block 的,也無需親自注冊文件描述符的回調(diào),只需在每個連接對應的 Goroutine 中以“block I/O”的方式對待 socket 處理即可,實現(xiàn)了 goroutine-per-connection 簡單的網(wǎng)絡編程模式(但是大量的 Goroutine 也會帶來額外的問題,比如棧內(nèi)存增加和調(diào)度器負擔加重)。

用戶層眼中看到的 Goroutine 中的“block socket”,實際上是通過 Go runtime 中的 netpoller 通過 Non-block socket + I/O 多路復用機制“模擬”出來的。Go 中的 net 庫正是按照這方式實現(xiàn)的。

場景 3:當調(diào)用一些系統(tǒng)方法的時候,如果系統(tǒng)方法調(diào)用的時候發(fā)生阻塞,這種情況下,網(wǎng)絡輪詢器(NetPoller)無法使用,而進行系統(tǒng)調(diào)用的 Goroutine 將阻塞當前 M。

讓我們來看看同步系統(tǒng)調(diào)用(如文件 I/O)會導致 M 阻塞的情況:G1 將進行同步系統(tǒng)調(diào)用以阻塞 M1。

 

 

 

 

調(diào)度器介入后:識別出 G1 已導致 M1 阻塞,此時,調(diào)度器將 M1 與 P 分離,同時也將 G1 帶走。然后調(diào)度器引入新的 M2 來服務 P。此時,可以從 LRQ 中選擇 G2 并在 M2 上進行上下文切換。

 

 

 

 

阻塞的系統(tǒng)調(diào)用完成后:G1 可以移回 LRQ 并再次由 P 執(zhí)行。如果這種情況再次發(fā)生,M1 將被放在旁邊以備將來重復使用。

 

 

 

 

場景 4:如果在 Goroutine 去執(zhí)行一個 sleep 操作,導致 M 被阻塞了。

Go 程序后臺有一個監(jiān)控線程 sysmon,它監(jiān)控那些長時間運行的 G 任務然后設置可以強占的標識符,別的 Goroutine 就可以搶先進來執(zhí)行。

只要下次這個 Goroutine 進行函數(shù)調(diào)用,那么就會被強占,同時也會保護現(xiàn)場,然后重新放入 P 的本地隊列里面等待下次執(zhí)行。

小結(jié)

本文主要從 Go 調(diào)度器架構(gòu)層面上介紹了 G-P-M 模型,通過該模型怎樣實現(xiàn)少量內(nèi)核線程支撐大量 Goroutine 的并發(fā)運行。以及通過 NetPoller、sysmon 等幫助 Go 程序減少線程阻塞,充分利用已有的計算資源,從而最大限度提高 Go 程序的運行效率。

責任編輯:武曉燕 來源: 騰訊技術(shù)工程
相關(guān)推薦

2024-02-26 21:15:20

Kafka緩存參數(shù)

2020-02-27 15:44:41

Nginx服務器反向代理

2020-03-30 15:05:46

Kafka消息數(shù)據(jù)

2023-08-29 07:46:08

Redis數(shù)據(jù)ReHash

2021-05-27 20:56:51

esbuild 工具JavaScript

2020-10-15 09:19:36

Elasticsear查詢速度

2023-03-21 08:02:36

Redis6.0IO多線程

2017-06-06 16:30:55

戴爾交付保障

2020-10-21 09:17:52

Redis面試內(nèi)存

2022-01-04 08:54:32

Redis數(shù)據(jù)庫數(shù)據(jù)類型

2021-03-18 14:34:34

達達集團京東云電商

2020-04-27 07:13:37

Nginx底層進程

2024-07-24 08:38:07

2023-11-02 10:22:29

gRPC后端通信

2024-11-26 08:52:34

SQL優(yōu)化Kafka

2013-06-14 10:12:22

共享并行

2021-06-27 22:48:28

Redis數(shù)據(jù)庫內(nèi)存

2019-06-17 14:20:51

Redis數(shù)據(jù)庫Java

2013-06-19 10:55:40

Disruptor并發(fā)框架

2013-06-17 14:41:10

Disruptor并發(fā)編程
點贊
收藏

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

国产又粗又猛又爽又黄| 国产色91在线| 91福利小视频| 欧美国产在线电影| 黄大色黄女片18第一次| 免费激情视频网站| 久久久久久久久久久9不雅视频| 亚洲福利一二三区| 成人免费福利在线| jizz18女人高潮| 欧美大胆性生话| 成人在线综合网| 欧美成人合集magnet| 伊人成人222| 生活片a∨在线观看| 欧美激情在线精品一区二区三区| 亚洲蜜臀av乱码久久精品蜜桃| 国产成人一区二区三区电影| 亚洲欧美视频在线播放| 98在线视频| 热久久久久久久| 日韩大陆毛片av| 九一国产精品视频| 视频一区 中文字幕| 亚洲激情二区| 亚洲精品一区二区三区影院| 国产精品视频一二三四区| 国产精品一区二区三区在线免费观看 | 国产精品系列视频| 美女黄色成人网| 日韩精品高清视频| 欧美体内she精高潮| 成a人片在线观看www视频| 丝袜诱惑亚洲看片| 国产午夜一区二区| av五月天在线| 成人高清网站| 2021中文字幕一区亚洲| 国产成人精品一区| 亚洲视频免费播放| 精品久久国产| 欧美日韩国产电影| 樱空桃在线播放| 亚洲精品国产精| 亚洲综合国产激情另类一区| 一区二区在线视频播放| 奇米影视四色在线| 精品3atv在线视频| 欧美国产欧美综合| 亚洲一区二区三区视频播放| 国产一级片视频| 日韩福利视频一区| 欧美在线观看视频一区二区三区| 亚洲国产欧美一区二区三区不卡| 国产精品无码专区av免费播放| 奇米亚洲午夜久久精品| 国产精品成人一区二区| 欧美日韩午夜视频| 老牛国内精品亚洲成av人片| 在线一区二区三区四区| 亚洲啊啊啊啊啊| 污视频软件在线观看| 肉色丝袜一区二区| 免费av一区二区| 欧美大片xxxx| 午夜精品久久99蜜桃的功能介绍| 亚洲精品丝袜日韩| wwwxxx色| 粉嫩久久久久久久极品| 欧美日韩国产小视频在线观看| 欧美日韩大尺度| 伊人精品影院| 国产农村妇女精品| 国产精品区一区二区三在线播放| 久久国产黄色片| 91精品国产91久久久久久密臀 | 欧美电影一区二区| 男女超爽视频免费播放| 日本乱码一区二区三区不卡| 国产精品久久免费看| 国产一区二区不卡视频在线观看| 中文无码av一区二区三区| 亚洲五月婷婷| x99av成人免费| 中文字幕一区三区久久女搜查官| 日韩一区精品| 欧美日韩一区二区三区在线免费观看 | 91亚洲国产成人久久精品麻豆| 99精品国产福利在线观看免费| 久久精品成人动漫| 西西444www无码大胆| www.豆豆成人网.com| 7777精品伊人久久久大香线蕉超级流畅 | 精品国产不卡一区二区三区| 亚洲专区区免费| 日韩一区电影| 国产手机视频精品| 萌白酱视频在线| 欧美限制电影| 亚洲日本欧美日韩高观看| 手机免费看av片| 玖玖玖视频精品| 欧美精品久久久久久久久老牛影院| 99九九精品视频| 欧美天堂一区二区| 在线观看91精品国产入口| 国产精品久久久久久9999| 女同久久另类99精品国产| 精品免费国产二区三区| 亚洲精品乱码久久久久久9色| 四虎影视精品| 美女黄色丝袜一区| 亚洲av无码不卡| 日韩国产欧美在线视频| 999久久久| 亚洲伦理在线观看| 国产98色在线|日韩| 91视频网页| 国产午夜在线观看| 日本一区二区三区dvd视频在线| 潘金莲一级淫片aaaaa免费看| 日韩av中字| 亚洲第一网站男人都懂| 少妇一级淫免费观看| 午夜久久免费观看| 国产精品一二区| av男人天堂av| www.日韩在线| 鲁鲁狠狠狠7777一区二区| 欧美特黄一级视频| 椎名由奈av一区二区三区| 99精品视频网站| 在线观看男女av免费网址| 欧美性大战久久| 久久久久久九九九九九| 日韩激情图片| 国产91在线播放精品91| 一级片免费观看视频| 久久综合成人精品亚洲另类欧美 | 免费一级特黄3大片视频| 国产亚洲毛片在线| 国产www精品| 性xxxx搡xxxxx搡欧美| 亚洲国产va精品久久久不卡综合| 美女被艹视频网站| 综合激情网站| 78m国产成人精品视频| 久久精品无码av| 极品少妇xxxx精品少妇偷拍| 91久久国产精品91久久性色| 人妻精品一区二区三区| 亚洲在线视频网站| 欧美日韩大尺度| 国产精品一线天粉嫩av| 免费91麻豆精品国产自产在线观看 | 亚洲成人av免费在线观看| 黄色精品免费| 国产亚洲欧美一区二区三区| 激情黄产视频在线免费观看| 欧美日韩一区二区在线观看视频| 四虎国产精品永久免费观看视频| 一区二区三区在线电影| 91精品国产综合久久久久久丝袜| 91三级在线| 日韩精品中文字幕一区二区三区| 亚洲av无码一区二区三区人| 久久视频一区| 亚洲视频电影| 欧美巨大丰满猛性社交| 精品视频在线播放| 中文字幕永久在线| 成人免费一区二区三区在线观看| 两女双腿交缠激烈磨豆腐| 激情视频一区| 国产精品中文在线| 激情在线小视频| 91传媒视频在线播放| 熟女少妇一区二区三区| 蜜芽一区二区三区| 欧美精品成人一区二区在线观看| 色爱综合区网| 欧美精品少妇一区二区三区| 欧美亚洲日本在线| 狂野欧美一区| 亚洲欧美日韩国产成人综合一二三区| 99视频这里有精品| 中文字幕一区二区精品| 亚洲免费在线视频观看| 中文字幕va一区二区三区| 手机在线观看日韩av| 日韩亚洲精品在线| 一区二区免费电影| 菁菁伊人国产精品| 国产精品中文久久久久久久| av影视在线看| 欧美成人综合网站| 亚洲欧美偷拍一区| 亚洲美女在线一区| 国产熟妇久久777777| 国产成人在线视频免费播放| 在线视频不卡一区二区| 美女色狠狠久久| 久久久久久久激情视频| 亚洲成人中文字幕在线| 色噜噜狠狠色综合欧洲selulu| 动漫性做爰视频| 国产亚洲一二三区| 国产精品嫩草69影院| 欧美特黄视频| 国产视频一区二区不卡| 日本在线一区二区| 中文字幕亚洲第一| 人妻91麻豆一区二区三区| 欧美精选在线播放| 波多野结衣视频网址| 黄色91在线观看| 无套内谢大学处破女www小说| 久久国产精品露脸对白| 国产精品夜夜夜爽张柏芝| 亚洲精品亚洲人成在线| 国产91精品在线播放| gogo高清在线播放免费| 久久亚洲精品网站| 丰满少妇被猛烈进入| 欧美日韩一区二区三区在线| 羞羞影院体验区| 久久品道一品道久久精品| 国产chinesehd精品露脸| 精品一区二区综合| 日本免费观看网站| 久久久久久亚洲精品杨幂换脸| 大陆av在线播放| 竹菊久久久久久久| 国产女人水真多18毛片18精品| 欧美视频三区| 成人有码在线播放| 四虎影视成人精品国库在线观看| 国产999精品久久久| 一区二区精品伦理...| 在线观看欧美视频| 激情小说 在线视频| 9191国产精品| 夜夜嗨av禁果av粉嫩avhd| 亚洲免费观看视频| 日韩精品一区二区亚洲av性色| 国产精品久久看| 性爱在线免费视频| 国产成人精品综合在线观看| 国内自拍第二页| 亚洲三级免费| 欧美,日韩,国产在线| 日韩午夜av| 黄色片视频在线免费观看| 97视频精品| 精品无码久久久久国产| 精品国模一区二区三区| 国产不卡av在线免费观看| 神马久久资源| 国产精品日韩专区| 国产传媒av在线| 97成人在线视频| 欧美三级网址| 国产精品入口免费视| 日韩深夜福利网站| 亚洲最大的网站| 欧美久久精品| 婷婷四月色综合| 欧美成人专区| 欧美日韩高清在线一区| 成人综合专区| 欧美少妇在线观看| 亚洲经典三级| av五月天在线| 国产成+人+日韩+欧美+亚洲| 性久久久久久久久久久| 国产福利视频一区二区三区| 2一3sex性hd| 国产女人水真多18毛片18精品视频| 国产探花在线视频| 久久久精品天堂| 免费的av网站| 亚洲国产精品国自产拍av| 91九色丨porny丨极品女神| 亚洲一区二区在线免费看| 美女福利视频网| 亚洲综合色丁香婷婷六月图片| 国产欧美日韩另类| 欧美视频日韩视频在线观看| 亚洲爆乳无码一区二区三区| 亚洲欧美中文字幕| a在线免费观看| 久久网福利资源网站| 国产精品25p| 成人福利免费观看| 91精品视频在线看| 性欧美lx╳lx╳| 玖玖精品在线视频| 视频在线观看一区| 亚洲熟妇一区二区| 欧美激情一区二区三区在线| 久久精品人妻一区二区三区| 欧美丝袜第三区| 天天干天天爽天天操| 久久精品国产亚洲| 美女福利一区二区| 国产精品96久久久久久| 日日夜夜精品视频| 成人精品一二区| 欧美高清xxx| 国产无套精品一区二区| 91精品国产成人观看| 国产精品99久久免费黑人人妻| 亚洲欧美成人综合| 黑人性生活视频| 亚洲欧洲性图库| 波多野结衣视频网址| 日韩精品中文字幕有码专区 | 国产精品美女久久久久久久| 欧美激情亚洲综合| 欧美大片日本大片免费观看| 尤物视频在线免费观看| 欧美做爰性生交视频| 欧美大电影免费观看| 国产欧美韩日| 欧美成人一品| 亚洲黄色av片| 欧美国产日韩精品免费观看| 黄色污污网站在线观看| 欧美丝袜丝交足nylons图片| 日色在线视频| 亚洲性日韩精品一区二区| 超黄网站在线观看| 日韩av大片在线| 欧美在线导航| 老太脱裤让老头玩ⅹxxxx| 国产成人精品三级麻豆| 亚洲最大的黄色网址| 777欧美精品| 欧美性videos| 97在线视频一区| 91精品啪在线观看国产爱臀| 久久国产精品精品国产色婷婷| 日韩大片在线| 最新中文字幕2018| 国产99久久久国产精品潘金 | 在线观看一区视频| 亚洲精品乱码久久久久久9色| 亚洲激情av在线| 日韩在线播放中文字幕| 日韩激情在线视频| 亚洲天堂免费电影| 欧美日韩一区在线视频| 久久精品毛片| 国产美女永久免费无遮挡| 一区二区不卡在线视频 午夜欧美不卡在| 国产精品毛片一区二区在线看舒淇 | tube8在线hd| 狠狠色综合欧美激情| 亚洲影视在线| 亚洲无人区码一码二码三码的含义| 欧美在线观看禁18| 免费a在线看| 波多野结衣一区二区三区在线观看| 韩国亚洲精品| 中文字幕av观看| 欧美日韩专区在线| av在线播放观看| 国产在线一区二| 日韩精品五月天| 天天操天天舔天天射| 91精品国产免费久久综合| 欧美日韩在线精品一区二区三区激情综| 久久天天躁狠狠躁夜夜躁| 欧美午夜在线播放| 免费成人午夜视频| 国产成a人亚洲精品| 成人免费视频毛片| 搡老女人一区二区三区视频tv| 色多多在线观看| 午夜精品电影在线观看| 国产一区二区成人久久免费影院| 极品人妻videosss人妻| 69久久夜色精品国产69蝌蚪网| 日本片在线观看| 欧美xxxx黑人又粗又长密月| 久久丁香综合五月国产三级网站 | 婷婷成人激情| 国产精品国产亚洲精品看不卡15| 亚洲欧美卡通另类91av| 久久久久久久久久97| 亚洲国内精品在线| 欧美草逼视频| 97久久天天综合色天天综合色hd| 国产日韩亚洲| 国产精品丝袜一区二区| 日韩不卡在线观看| 精品国产一区二| 日本999视频| 亚洲一二三区在线观看| 92国产在线视频|