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

通過 eBPF 深入探究 Go GC

開發 前端
對程序員來說,內存管理是很重要的。編程語言按內存管理方式一般可以分為手動內存管理和自動內存管理。手動內存管理典型代表有 C、C++;自動內存管理代表有 Java、C# 等。

大家好,我是程序員幽鬼。

對程序員來說,內存管理是很重要的。編程語言按內存管理方式一般可以分為手動內存管理和自動內存管理。手動內存管理典型代表有 C、C++;自動內存管理代表有 Java、C# 等。通常,自動內存管理即自帶垃圾收集器,即 GC(當然,Rust 另辟蹊徑,它既沒有 GC,也不需要手動內存管理,感興趣的可以了解下)。Go 語言也采用了 GC 的方式管理內存,雖然 Gopher 不需要手動管理內存了,但了解 Go 如何分配和釋放內存可以讓我們編寫更好、更高效的應用程序。垃圾收集器是這個難題的關鍵部分。本文就探討 Go 中的 GC。

為了更好地理解垃圾收集器的工作原理,我決定在實時應用程序上跟蹤它的底層行為。本文將使用 eBPF uprobes 檢測 Go 垃圾收集器。這篇文章的源代碼在這里[1]。

1、前提知識

在深入研究之前,讓我們快速了解一下 uprobes、垃圾收集器的設計以及我們將使用的演示應用程序。

為什么用 uprobes?

uprobes[2] 很酷,因為它們讓我們無需修改代碼即可動態收集新信息。當你不能或不想重新部署你的應用程序時,這會非常有用。

函數參數、返回值、延遲和時間戳都可以通過 uprobes 收集。在這篇文章中,我將把 uprobes 部署到 Go 垃圾收集器的關鍵函數上。這讓我們能看到它在正在運行的應用程序中的實際表現。

uprobes 可以跟蹤延遲、時間戳、參數和函數的返回值片

注意:這篇文章使用的 Go 版本是 1.16。我將在 Go 運行時中跟蹤私有函數,因此這些功能在 Go 的后續版本中可能會發生變化。

垃圾回收的階段

Go 使用并發標記和清除垃圾收集器。對于那些不熟悉這些術語的人,閱讀以下內容,方便你理解本文其他內容。

Go 的垃圾收集器被稱為并發的,因為它可以安全地與主程序并行運行。換句話說,它不需要停止你程序的執行來完成它的工作(稍后會詳細介紹)。

垃圾收集有兩個主要階段:

標記(Mark)階段:識別并標記程序不再需要的對象。

清除(Sweep)階段:對于標記階段標記為“無法訪問”的每個對象,釋放內存以供其他地方使用。

一種節點著色算法。黑色表示仍在使用中。白色表示已準備好清理。灰色表示仍然需要分類為黑色或白色

一個簡單的演示應用程序

這是一個簡單的端點(endpoint),我將使用它來觸發垃圾收集器。它創建一個可變大小的字符串數組,然后通過調用 runtime.GC() 來啟動垃圾收集器。

實際代碼中,你不需要手動調用垃圾收集器,因為 Go 會自動為你處理。

http.HandleFunc("/allocate-memory-and-run-gc", func(w http.ResponseWriter, r *http.Request) {
arrayLength, bytesPerElement := parseArrayArgs(r)
arr := generateRandomStringArray(arrayLength, bytesPerElement)
fmt.Fprintf(w, fmt.Sprintf("Generated string array with %d bytes of data\n", len(arr) * len(arr[0])))
runtime.GC()
fmt.Fprintf(w, "Ran garbage collector\n")
})

2、跟蹤垃圾收集的主要階段

我們已經了解了 uprobes 和 Go 垃圾收集器的基礎知識,接下來深入觀察它的行為。

跟蹤 runtime.GC()

首先,我們計劃在 Go 的 runtime 庫中的以下函數中添加 uprobes:

函數

描述

GC[3]

調用 GC

gcWaitOnMark[4]

等待標記階段完成

gcSweep[5]

執行清除階段

(如果你有興趣了解 uprobes 是如何生成的,這里是代碼[6]。)

部署 uprobes 后,點擊端點并生成了一個包含 10 個字符串的數組,每個字符串為 20 個字節。

$ curl '127.0.0.1:8080/allocate-memory-and-run-gc?arrayLength=10&bytesPerElement=20'
Generated string array with 200 bytes of data
Ran garbage collector

這時 uprobes 會觀察到以下事件:

在運行垃圾收集器后,為 GC、gcWaitOnMark 和 gcSweep 收集事件

從源代碼[7]來看這是有道理的——gcWaitOnMark被調用兩次,一次是在開始下一個循環之前對前一個循環進行驗證。標記階段觸發清除階段。

接下來,使用各種輸入請求 /allocate-memory-and-run-gc 端點對 runtime.GC 后的延遲進行了一些測量。

arrayLength

bytesPerElement

Approximate size (B)

GC latency (ms)

GC throughput (MB/s)

100

1,000

100,000

3.2

31

1,000

1,000

1,000,000

8.5

118

10,000

1,000

10,000,000

53.7

186

100

10,000

1,000,000

3.2

313

1,000

10,000

10,000,000

12.4

807

10,000

10,000

100,000,000

96.2

1,039

跟蹤標記和清除階段

雖然這是一個很好的高級視圖,但我們可以使用更多細節。接下來探索一些用于內存分配、標記和清除的輔助函數,以獲取下一級信息。

這些輔助函數有參數或返回值,可以幫助我們更好地可視化正在發生的事情(例如分配的內存頁)。

函數

描述

捕獲的信息

allocSpan[8]

分配新內存

分配的內存頁

gcDrainN[9]

執行 N 個單位的標記工作

完成的標記工作單位

sweepone[10]

從 span 中清除內存

清除的內存頁

$ curl '127.0.0.1:8080/allocate-memory-and-run-gc?arrayLength=20000&bytesPerElement=4096'
Generated string array with 81920000 bytes of data
Ran garbage collector

在以更大的負載命中垃圾收集器之后,以下是原始結果:

調用垃圾收集器后,allocSpan、gcDrainN 和 sweepone 收集的事件示例

繪制為時間序列更容易解釋:

allocSpan 隨時間分配的內存頁

gcDrain 標記在一段時間內完成的工作

sweepone 隨時間清除的內存頁

現在我們可以看到發生了什么:

  • Go 分配了幾千內存頁,這是正常的,因為我們直接向堆中添加了大約 80MB 的字符串。
  • 標記工作拉開了序幕(注意它的單位不是頁,而是標記工作單位)
  • 有標記的內存頁被清除器清除。(這應該是所有內存頁,因為在調用完成后我們不會重用字符串數組)。

追蹤 Stop The World 事件

“Stopping the world”是指垃圾收集器暫時停止除自身之外的一切,以安全地修改狀態。我們通常更喜歡最小化 STW 階段,因為 STW 會減慢我們的程序速度(通常是在最不方便的時候……)。

一些垃圾收集器會在垃圾收集運行的整個過程中 stop the world。這些是“非并發”垃圾收集器。雖然 Go 的垃圾收集器在很大程度上是并發的,但我們可以從代碼中看到,它在技術上確實在兩個地方 STW 了。

我們跟蹤以下函數:

函數

描述

stopTheWorldWithSema[11]

停止其他 goroutine 直到??startTheWorldWithSema??被調用

startTheWorldWithSema[12]

啟動暫停的 goroutine

再次觸發 GC:

$ curl '127.0.0.1:8080/allocate-memory-and-run-gc?arrayLength=10&bytesPerElement=20'
Generated string array with 200 bytes of data
Ran garbage collector

這次產生了如下事件:

生成啟動和停止 STW 事件

我們可以從GC事件中看到垃圾收集需要 3.1 毫秒才能完成。在我檢查了確切的時間戳之后,事實證明 STW 第一次停止了 300 μs,第二次停止了 365 μs。換句話說,~80%垃圾收集是同時執行的。當垃圾收集器在實際內存壓力下自動調用時,我們預計這個比率會變得更好。

為什么 Go 垃圾收集器需要 STW?

1st Stop The World(標記階段之前):設置狀態并打開寫屏障。寫屏障確保在 GC 運行時正確跟蹤新的寫入(這樣它們就不會被意外釋放或保留)。

2nd Stop The World(標記階段之后):清理標記狀態并關閉寫屏障。

3、垃圾收集器如何調整自己的速度?

知道何時運行垃圾收集是 Go 等并發垃圾收集器的重要考慮因素。

早期的垃圾收集器被設計為一旦達到一定的內存消耗水平就會啟動。如果垃圾收集器是非并發的,這可以正常工作。但是使用并發垃圾收集器,主程序在垃圾收集期間仍在運行 —— 因此可能仍在進行內存分配。

這意味著如果太晚運行垃圾收集器,可能會超出內存目標。(Go 也不能一直運行垃圾收集 —— GC 會從主應用程序中奪走資源和性能。)

Go 的垃圾收集器使用 pacer[13] 來估計垃圾收集的最佳時間。這有助于 Go 滿足其內存和 CPU 目標,而不會犧牲不必要的應用程序性能。

pacer,可以理解為定速裝置

觸發率

Go 的并發垃圾收集器依賴于一個 pacer 來確定何時進行垃圾收集。但它是如何做出這個決定的呢?

每次調用垃圾收集器時,pacer 都會更新其內部目標,即下次應該何時運行 GC。這個目標稱為觸發率。觸發率0.6意味著一旦堆大小增加 60%,系統應該運行垃圾收集。觸發率是CPU、內存和其他因素共同決定的數字。

讓我們看看當我們一次分配大量內存時,垃圾收集器的觸發率是如何變化的。我們可以通過跟蹤函數來獲取觸發率gcSetTriggerRatio。

$ curl '127.0.0.1:8080/allocate-memory-and-run-gc?arrayLength=20000&bytesPerElement=4096'
Generated string array with 81920000 bytes of data
Ran garbage collector

觸發率隨時間的變化

從圖中可以看到,最初,觸發率相當高。運行時已經確定,在程序使用 450% 或更多內存之前,不需要進行垃圾收集。這是有道理的,因為應用程序沒有做太多事情(并且沒有使用很多堆)。

然而,一旦我們請求端點進行 ~81MB 堆分配時,觸發率迅速下降到 ~1。現在如果增加 100% 的內存就可以進行垃圾收集(因為我們的內存消耗增加了)。

標記和清除

助手當分配內存但不調用垃圾收集器會發生什么?接下來,請求 /allocate-memory 端點,它和 /allocate-memory-and-gc 類似,但不調用runtime.GC()。

$ curl '127.0.0.1/allocate-memory?arrayLength=10000&bytesPerElement=10000'
Generated string array with 100000000 bytes of data

根據最近的觸發率,垃圾收集器應該還沒有啟動。但是,我們看到標記和清除仍然發生了:

gcDrain 標記在一段時間內完成的工作

sweepone 隨時間清除的內存頁

事實證明,垃圾收集器還有另一個技巧可以防止失控的內存增長。如果堆內存開始增長過快,垃圾收集器將對任何分配新內存的請求收“稅”。請求新堆分配的 Goroutines 將必須先協助垃圾收集,然后才能獲得它們所要求的東西。

這種“輔助”系統增加了分配的延遲,因此有助于系統抗壓(backpressure)。這非常重要,因為它解決了并發垃圾收集器可能引起的問題。在并發垃圾收集器中,內存分配在垃圾收集運行時仍進行內存分配。如果程序分配內存的速度快于垃圾收集器釋放它的速度,那么內存增長將是無限的。通過減慢(背壓)新內存的凈分配來幫助解決這個問題。

我們可以跟蹤 gcAssistAlloc1[14] 以查看此過程的運行情況。gcAssistAlloc1 接受一個名為 scanWork 的參數,它是請求的輔助工作量。

gcAllocAssist1 在一段時間內執行的輔助工作量

可以看到,gcAssistAlloc1 就是 mark 和 sweep 工作的來源。它收到了完成大約 30 萬個工作單元的請求。在之前的標記階段圖中,gcDrainN 在相同的時間段完成了大約 30 萬個標記工作單元(只是稍微分散一點)。

4、總結

還有很多關于 Go 中的內存分配和垃圾收集的知識!這里有一些其他的資源可以查看:

  • Go 對小對象的特殊清除[15]
  • 通過逃逸分析[16]查看對象是分配在堆還是棧
  • sync.Pool[17],一種并發數據結構,通過池的方式共享對象來減少分配[18]

就像我們在本文例子中所做的那樣,創建 uprobes 通常最好在更高級別的 BPF 框架中完成。對于這篇文章,我使用了 Pixie 的 Dynamic Go 日志記錄[19]功能(仍處于 alpha 階段)。bpftrace[20] 是另一個創建 uprobes 的好工具。

檢查 Go 垃圾收集器行為的另一個不錯的選擇是 gc 跟蹤器。只需在你啟動程序時傳入 GODEBUG=gctrace=1。這會輸出有關垃圾收集器正在做什么的各種有用信息。

原文鏈接:https://blog.px.dev/go-garbage-collector/。

參考資料

參考資料

[1]這里: https://github.com/pixie-io/pixie-demos/tree/main/go-garbage-collector

[2]uprobes: https://jvns.ca/blog/2017/07/05/linux-tracing-systems/#uprobes

[3]GC: https://github.com/golang/go/blob/go1.16/src/runtime/mgc.go#L1126

[4]gcWaitOnMark: https://github.com/golang/go/blob/go1.16/src/runtime/mgc.go#L1201

[5]gcSweep: https://github.com/golang/go/blob/go1.16/src/runtime/mgc.go#L2170

[6]代碼: https://github.com/pixie-io/pixie-demos/tree/main/go-garbage-collector

[7]從源代碼: https://github.com/golang/go/blob/go1.16/src/runtime/mgc.go#L1126

[8]allocSpan: https://github.com/golang/go/blob/go1.16/src/runtime/mheap.go#L1124

[9]gcDrainN: https://github.com/golang/go/blob/go1.16/src/runtime/mgcmark.go#L1095

[10]sweepone: https://github.com/golang/go/blob/go1.16/src/runtime/mgcsweep.go#L188

[11]stopTheWorldWithSema: https://github.com/golang/go/blob/go1.16/src/runtime/proc.go#L1073

[12]startTheWorldWithSema: https://github.com/golang/go/blob/go1.16/src/runtime/proc.go#L1151

[13]pacer: https://go.googlesource.com/proposal/+/a216b56e743c5b6b300b3ef1673ee62684b5b63b/design/44167-gc-pacer-redesign.md

[14]gcAssistAlloc1: https://github.com/golang/go/blob/go1.16/src/runtime/mgcmark.go#L504

[15]特殊清除: https://github.com/golang/go/blob/master/src/runtime/mgc.go#L93

[16]逃逸分析: https://medium.com/a-journey-with-go/go-introduction-to-the-escape-analysis-f7610174e890

[17]sync.Pool: https://pkg.go.dev/sync#Pool

[18]減少分配: https://medium.com/swlh/go-the-idea-behind-sync-pool-32da5089df72

[19]Dynamic Go 日志記錄: https://docs.px.dev/tutorials/custom-data/dynamic-go-logging/

[20]bpftrace: https://github.com/iovisor/bpftrace

本文轉載自微信公眾號「幽鬼」,可以通過以下二維碼關注。轉載本文請聯系幽鬼公眾號。

責任編輯:武曉燕 來源: 幽鬼
相關推薦

2017-05-18 15:02:36

AndroidGC原理JVM內存回收

2025-01-02 14:50:34

MyBatis開發緩存

2013-07-15 11:03:52

802.11ac技術802.11ac

2011-12-22 14:27:11

2009-11-27 10:37:41

GPRS路由

2009-11-12 14:32:00

BGP路由協議

2010-02-04 16:52:01

多層交換技術

2010-08-04 09:43:28

Flex應用程序

2010-11-29 11:22:36

SYBASE數據庫日志

2009-12-09 10:07:19

Linux靜態路由

2009-11-20 09:56:27

軟交換路由技術

2009-12-09 13:35:09

靜態路由配置

2021-09-29 09:24:21

GCGo STW

2010-09-29 14:54:34

J2MEHashtable

2010-09-15 14:00:06

position屬性DIV

2023-06-27 08:37:35

Java反射動態代理機制

2009-11-06 13:27:47

寬帶接入網

2009-10-19 18:26:44

網絡綜合布線工程

2009-12-23 16:40:51

寬帶路由器

2021-07-05 22:13:09

Node內存控制
點贊
收藏

51CTO技術棧公眾號

国产片一区二区| 国模一区二区三区| 在线观看区一区二| 在线一区高清| 天天躁日日躁狠狠躁喷水| 麻豆久久婷婷| 久久久精品中文字幕| 亚洲免费观看在线| 澳门av一区二区三区| 亚洲私人黄色宅男| 九色视频成人porny| 国产偷人爽久久久久久老妇app| 久久国产亚洲| 亚洲国产日韩精品在线| 日韩不卡一二三| 2019中文字幕在线电影免费| 久久久精品黄色| 91美女片黄在线观| 亚洲欧美一区二区三区在线观看| 天天做天天爱天天爽综合网| 日韩风俗一区 二区| 亚洲va综合va国产va中文| free性m.freesex欧美| 国产午夜精品福利| 懂色av一区二区三区在线播放| 天天操天天摸天天干| 国产精品久久观看| 亚洲男人第一av网站| av地址在线观看| 91天天综合| 性欧美大战久久久久久久久| 在线看视频不卡| 狠狠狠综合7777久夜色撩人| 成人午夜激情在线| 91日本在线观看| 中文字幕免费视频观看| 在线一区视频| 精品中文字幕乱| 91ts人妖另类精品系列| 国产va免费精品观看精品视频 | 国产91色综合久久免费分享| 国产精品老女人视频| 在线观看中文字幕视频| 狠狠干成人综合网| 久久69精品久久久久久国产越南| 国产在线免费av| 国产剧情在线观看一区| 日韩精品免费观看| 在线xxxxx| 97久久综合精品久久久综合| 91精品国产综合久久精品性色| 污版视频在线观看| 韩国理伦片久久电影网| 在线观看亚洲一区| www.日本xxxx| 91在线亚洲| 高潮毛片在线观看| 中文亚洲字幕| 91国内产香蕉| 精品成人免费视频| 国产一级一区二区| 欧美一级片在线播放| 日韩精品一区二区av| 99精品国产福利在线观看免费| 欧美激情精品在线| 日韩精品成人在线| 亚洲一区图片| 国产精品aaaa| 一级片aaaa| 国产一区久久久| 成人情视频高清免费观看电影| 亚洲AV无码精品自拍| www.99精品| 日韩国产一区久久| 香蕉视频免费在线播放| 亚洲精品中文在线影院| 国产成a人亚洲精v品在线观看| 国产精品186在线观看在线播放| 婷婷久久综合九色国产成人| 成人av一级片| 欧美视频第一| 日韩欧美在线1卡| 色婷婷精品久久二区二区密| 曰本一区二区三区视频| 日韩中文字幕不卡视频| 欧美成人黄色网| 在线观看国产免费视频| 丁香影院在线| 欧美丝袜美女中出在线| 邪恶网站在线观看| 精品久久亚洲| 日韩av中文字幕在线| www色com| 黄色亚洲免费| 国产91九色视频| 国产日韩一级片| 91网站视频在线观看| 午夜精品电影在线观看| 在线āv视频| 欧美性色19p| 婷婷中文字幕在线观看| 美腿丝袜亚洲图片| 色午夜这里只有精品| 国产真实乱偷精品视频| 免费观看日韩av| 国产精品一区二区免费看| 精彩国产在线| 亚洲一区二区三区视频在线| www黄色在线| 2023国产精华国产精品| 在线播放国产精品| 国产一级中文字幕| 麻豆精品视频在线观看视频| a级国产乱理论片在线观看99| 你懂的在线网址| 亚洲精品伦理在线| 亚洲黄色av网址| 久久精品福利| 欧美成人激情视频免费观看| 国产精品一区二区三区四| 国产在线日韩欧美| 日韩av图片| 美女扒开腿让男人桶爽久久软| 欧美酷刑日本凌虐凌虐| 欧美成人午夜精品免费| 综合久久亚洲| 国产欧美精品一区二区| 欧美成人片在线| 亚洲国产wwwccc36天堂| 四虎国产精品永久免费观看视频| 欧美日韩在线观看视频小说| 欧美亚洲第一页| 亚洲黄色片视频| 亚洲欧美偷拍卡通变态| 浓精h攵女乱爱av| 一本久久青青| 久久青草福利网站| 国产suv精品一区二区69| 国产精品三级电影| 91在线视频观看免费| 欧美激情久久久久久久久久久| 久久国产精品偷| 一二三四区在线| 亚洲国产精品成人综合色在线婷婷 | 欧美成人剧情片在线观看| 成人黄色片在线观看| 久久精品一区二区三区不卡牛牛| 内射国产内射夫妻免费频道| 影音先锋欧美激情| 欧美另类交人妖| www.色呦呦| 一级女性全黄久久生活片免费| 国产传媒免费观看| 天天影视欧美综合在线观看| 国产日本欧美视频| 日本三级视频在线播放| 欧美日韩国产经典色站一区二区三区| 国产视频不卡在线| 免费高清不卡av| 中国成人在线视频| 国产精品成人3p一区二区三区| 久久精品中文字幕一区| 国产特级黄色片| 一区二区三区日韩欧美精品| 女人扒开腿免费视频app| 欧美在线看片| 国产91视觉| 蜜桃麻豆av在线| 亚洲人成在线一二| 在线观看毛片av| 亚洲欧美日韩精品久久久久| 999热精品视频| 国产一区清纯| 精品免费国产| 91看片一区| xx视频.9999.com| 精品国产区一区二| 精品国产乱码久久久久久虫虫漫画| 亚洲av无码一区二区三区观看| 久久精品男女| 亚洲一区二区三区色| 欧美日本三级| 欧美在线不卡区| 91这里只有精品| 欧美一区二区免费观在线| 国产精久久久久久| 国产午夜精品美女毛片视频| 国内av一区二区| 在线一区视频| 最新av在线免费观看| 草草视频在线一区二区| 日本久久精品视频| 黄色网址免费在线观看| 亚洲国产成人精品女人久久久| 黄色片视频免费| 亚洲一区在线观看免费| 男人天堂av电影| 国产剧情在线观看一区二区| 国产中文字幕视频在线观看| 日本电影一区二区| 国产精品一区二区三区精品| 全球最大av网站久久| 韩剧1988免费观看全集| 91短视频版在线观看www免费| 精品少妇一区二区三区日产乱码| 亚洲毛片一区二区三区| 夜夜嗨av一区二区三区中文字幕| 国产精品无码一区二区三区| 国产酒店精品激情| 美女网站免费观看视频| 欧美视频导航| 先锋影音亚洲资源| 韩国女主播一区二区三区| 成人欧美一区二区三区在线湿哒哒 | 在线精品免费视| 一区二区三区四区在线播放 | 欧美日韩aaaa| wwwww在线观看免费视频| 精品国产乱码久久久久久久| 中文字幕在线一| 日韩欧中文字幕| 精品少妇久久久久久888优播| 中文字幕av不卡| 国产精品无码一区二区三区免费 | 亚洲色偷偷色噜噜狠狠99网| 久久精品久久精品| 苍井空浴缸大战猛男120分钟| 欧美三级乱码| 国产麻豆电影在线观看| 国产伦一区二区三区| 九九99玖玖| 8848成人影院| 91在线中文字幕| 久久久国产精品网站| 68精品国产免费久久久久久婷婷| av片哪里在线观看| 久久九九全国免费精品观看| 国产视频精品久久| 亚洲欧美激情一区| 天堂成人在线| 日韩欧美的一区二区| 91在线观看喷潮| 欧美日韩三级视频| 亚洲视频一区二区三区四区| 在线免费不卡视频| 成人免费视频国产免费| 欧美午夜电影在线| 五月天激情国产综合婷婷婷| 欧美日韩一区二区免费视频| 国产在线免费视频| 亚洲妇熟xx妇色黄| 国产污片在线观看| 亚洲1区2区3区4区| 国产情侣自拍av| 欧美性猛交xxxx富婆| 日日噜噜噜噜人人爽亚洲精品| 精品久久久久久久久久久久久久| 久草精品视频在线观看| 欧美日韩亚洲激情| 亚洲色成人www永久网站| 在线观看免费亚洲| 中文在线最新版天堂| 欧美精品在线一区二区三区| 国产丝袜在线视频| 精品1区2区在线观看| 三级视频在线看| 亚洲欧洲偷拍精品| sese在线视频| 欧美插天视频在线播放| 亚洲综合图区| 韩国福利视频一区| 天堂√8在线中文| 国产精品美女无圣光视频| 久久av影院| dy888夜精品国产专区| 国产精品一线| 欧美一区二区在线视频观看| 久久神马影院| 青青在线视频免费观看| 亚洲精品精选| 男人搞女人网站| 国产一区二区三区日韩| 大尺度做爰床戏呻吟舒畅| 久久午夜色播影院免费高清| 日韩欧美视频免费观看| 亚洲曰韩产成在线| 亚洲日本视频在线观看| 欧美三级在线视频| 亚洲黄色在线播放| 一道本无吗dⅴd在线播放一区| 国产视频在线播放| 97高清免费视频| 欧美综合影院| 国产尤物99| 久久精品青草| 免费观看日韩毛片| 国产综合色产在线精品| 在线免费播放av| 国产精品久久久久7777按摩 | 欧美日韩国产精品一区二区亚洲| 成人免费观看cn| 久久er99热精品一区二区| 91九色蝌蚪porny| 欧美国产亚洲另类动漫| 精品处破女学生| 欧美日韩在线直播| 五月婷婷六月色| 麻豆国产精品va在线观看不卡 | 日本电影一区二区在线观看| xxxx性欧美| 综合久久2023| 国产高清在线一区| 日本一区二区三区视频| 青娱乐自拍偷拍| 国内精品写真在线观看| a天堂中文字幕| 香蕉av福利精品导航| 国产伦子伦对白视频| 亚洲香蕉成人av网站在线观看| 男女在线观看视频| 91视频国产精品| 精品午夜久久| 日日摸日日碰夜夜爽av| 成人激情校园春色| 欧美精品乱码视频一二专区| 精品视频在线免费看| 国产在线观看免费网站| 欧美一级电影免费在线观看| 一区二区三区在线资源| 中文精品视频一区二区在线观看| 狂野欧美一区| 国产ts丝袜人妖系列视频| 亚洲国产日韩a在线播放| av av片在线看| 深夜福利91大全| 中文字幕系列一区| 日日噜噜噜噜夜夜爽亚洲精品| 亚洲综合国产激情另类一区| 岛国精品资源网站| 亚洲国产毛片aaaaa无费看| 999免费视频| 久久久国产成人精品| 日韩黄色在线| 伊人久久婷婷色综合98网| 免费视频一区二区| 国产又粗又长又黄的视频| 欧美性猛交xxxx乱大交退制版| 精品久久av| 国产精品久久久久99| 日韩欧美视频| 天堂网在线免费观看| 国产精品每日更新在线播放网址 | 久久综合影音| www.av欧美| 91国产成人在线| yiren22综合网成人| 国产精品中文字幕在线观看| 日本久久综合| 亚洲网中文字幕| 樱花草国产18久久久久| 丁香六月天婷婷| 韩国视频理论视频久久| 在线一级成人| 奇米影音第四色| 亚洲精品视频在线看| 99草在线视频| 亚洲91精品在线| 国产探花在线精品| 五月婷婷六月丁香激情| 亚洲欧洲国产专区| 欧美亚洲精品在线观看| 欧美一级大片在线免费观看| 精品国精品国产自在久国产应用| 欧美特级aaa| 一区二区三区中文在线观看| 亚洲乱码国产乱码精品精软件| 97视频在线观看免费| 怕怕欧美视频免费大全| 天天综合天天添夜夜添狠狠添| 一区二区三区鲁丝不卡| 婷婷色在线观看| 国产精品国产三级国产aⅴ浪潮| 91精品秘密在线观看| 国产黑丝一区二区| 在线看不卡av| 亚洲奶水xxxx哺乳期| 久久精品人成| 久久se这里有精品| 免费在线不卡视频| 色偷偷av一区二区三区乱| 91成人午夜| www.欧美日本| 亚洲精品伦理在线| 国产福利小视频在线观看| 7777精品久久久大香线蕉小说| 日韩天天综合| 免费看一级大片| 国产视频在线观看一区二区| 亚州精品国产| 人妻精品无码一区二区三区|