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

Fasthttp 為什么比標準庫快 10 倍 ?

開發 前端
本文不會講解 fasthttp 的應用方法,而是會重點分析 fasthttp 高性能的背后實現原理。

概述

fasthttp? 是一個使用 Go 語言開發的 HTTP 包,主打高性能,針對 HTTP 請求響應流程中的 hot path? 代碼進行了優化,達到零內存分配,性能比標準庫的 net/http 快 10 倍。

上面是來自官方 Github 主頁的項目介紹,拋開其介紹內容不談,光從名字本身來看,作者對項目代碼的自信程度可見一斑。

本文不會講解 fasthttp? 的應用方法,而是會重點分析 fasthttp 高性能的背后實現原理。

基準測試

我們可以通過基準測試看看 fasthttp? 是否真的如描述所言,吊打標準庫的 net/http,下面是官方提供的基準測試結果:

net/http

$ GOMAXPROCS=4 go test -bench='HTTPClient(Do|GetEndToEnd)' -benchmem -benchtime=10s
BenchmarkNetHTTPClientDoFastServer-4 2000000 8774 ns/op 2619 B/op 35 allocs/op
BenchmarkNetHTTPClientGetEndToEnd1TCP-4 500000 22951 ns/op 5047 B/op 56 allocs/op
BenchmarkNetHTTPClientGetEndToEnd10TCP-4 1000000 19182 ns/op 5037 B/op 55 allocs/op
BenchmarkNetHTTPClientGetEndToEnd100TCP-4 1000000 16535 ns/op 5031 B/op 55 allocs/op
BenchmarkNetHTTPClientGetEndToEnd1Inmemory-4 1000000 14495 ns/op 5038 B/op 56 allocs/op
BenchmarkNetHTTPClientGetEndToEnd10Inmemory-4 1000000 10237 ns/op 5034 B/op 56 allocs/op
BenchmarkNetHTTPClientGetEndToEnd100Inmemory-4 1000000 10125 ns/op 5045 B/op 56 allocs/op
BenchmarkNetHTTPClientGetEndToEnd1000Inmemory-4 1000000 11132 ns/op 5136 B/op 56 allocs/op

fasthttp

$ GOMAXPROCS=4 go test -bench='kClient(Do|GetEndToEnd)' -benchmem -benchtime=10s
BenchmarkClientDoFastServer-4 50000000 397 ns/op 0 B/op 0 allocs/op
BenchmarkClientGetEndToEnd1TCP-4 2000000 7388 ns/op 0 B/op 0 allocs/op
BenchmarkClientGetEndToEnd10TCP-4 2000000 6689 ns/op 0 B/op 0 allocs/op
BenchmarkClientGetEndToEnd100TCP-4 3000000 4927 ns/op 1 B/op 0 allocs/op
BenchmarkClientGetEndToEnd1Inmemory-4 10000000 1604 ns/op 0 B/op 0 allocs/op
BenchmarkClientGetEndToEnd10Inmemory-4 10000000 1458 ns/op 0 B/op 0 allocs/op
BenchmarkClientGetEndToEnd100Inmemory-4 10000000 1329 ns/op 0 B/op 0 allocs/op
BenchmarkClientGetEndToEnd1000Inmemory-4 10000000 1316 ns/op 5 B/op 0 allocs/op

基準結果對比

從基準測試結果來看,fasthttp? 的執行速度要比標準庫的 net/http? 快很多,此外,fasthttp? 的內存分配方面優化到了 0?, 完勝 net/http。

核心優化點

筆者選擇的 valyala/fasthttp[1] 版本為 v1.45.0。

對象復用

workerPool

workerpool? 對象表示 連接處理? 工作池,這樣可以控制連接建立后的處理方式,而不是像標準庫 net/http? 一樣,對每個請求連接都啟動一個 goroutine? 處理, 內部的 ready? 字段存儲空閑的 workerChan? 對象,workerChanPool? 字段表示管理 workerChan 的對象池。

// workerpool.go
type workerPool struct {
ready []*workerChan

workerChanPool sync.Pool
}

type workerChan struct {
lastUseTime time.Time
ch chan net.Conn
}

請求/響應 對象

請求對象 Request? 和響應對象 Response 都是通過對象池進行管理的,對應的代碼如下:

// client.go

var (
requestPool sync.Pool
responsePool sync.Pool
)

// 從對象池中獲取 Request 對象
func AcquireRequest() *Request {
...
}

// 歸還 Request 對象到對象池中
func ReleaseRequest(req *Request) {
...
}

// 從對象池中獲取 Response 對象
func AcquireResponse() *Response {
...
}

// 歸還 Response 對象到對象池中
func ReleaseResponse(resp *Response) {
...
}

Cookie 對象

Cookie 對象也是通過對象池進行管理的,對應的代碼如下:

// cookie.go

var cookiePool = &sync.Pool{
New: func() interface{} {
return &Cookie{}
},
}

// 從對象池中獲取 Cookie 對象
func AcquireCookie() *Cookie {
...
}

// 歸還 Cookie 對象到對象池中
func ReleaseCookie(c *Cookie) {
...
}

其他對象復用

$ grep -inr --include \*.go "sync.Pool" $(go list -f {{.Dir}} github.com/valyala/fasthttp) | wc -l

# 輸出如下
38

通過輸出結果可以看到,fasthttp? 中一共有 38 個對象是通過對象池進行管理的,可以說幾乎復用了所有對象,So Crazy!

[]byte 復用

fasthttp? 中復用的對象在使用完成后歸還到對象池之前,需要調用對應的 Reset? 方法進行重置,如果對象中包含 []byte? 類型的字段, 那么會直接進行復用,而不是初始化新的 []byte?, 例如 URI? 對象的 Reset 方法:

// 重置 URI 對象
// 從方法的內部實現中可以看到,類型為 []byte 的所有字段都被復用了
func (u *URI) Reset() {
u.pathOriginal = u.pathOriginal[:0]
u.scheme = u.scheme[:0]
u.path = u.path[:0]
u.queryString = u.queryString[:0]
u.hash = u.hash[:0]
u.username = u.username[:0]
u.password = u.password[:0]

u.host = u.host[:0]
...
}

此外,涉及到單個字段的修改,如果字段是 []byte? 類型,還是會直接復用,例如 Cookie 對象的這幾個方法:

func (c *Cookie) SetValue(value string) {
c.value = append(c.value[:0], value...)
}

func (c *Cookie) SetValueBytes(value []byte) {
c.value = append(c.value[:0], value...)
}

func (c *Cookie) SetKey(key string) {
c.key = append(c.key[:0], key...)
}

func (c *Cookie) SetKeyBytes(key []byte) {
c.key = append(c.key[:0], key...)
}

上面幾個方法的內部實現中,無一例外,都對 []byte 類型的參數進行了復用。

[]byte 和 string 轉換

fasthttp? 專門提供了 []byte? 和 string? 這兩種常見的數據類型相互轉換的方法 ,避免了 內存分配 + 復制,提升性能。

// s2b_new.go
func b2s(b []byte) string {
return *(*string)(unsafe.Pointer(&b))
}

// b2s_new.go
func s2b(s string) (b []byte) {
bh := (*reflect.SliceHeader)(unsafe.Pointer(&b))
sh := (*reflect.StringHeader)(unsafe.Pointer(&s))
bh.Data = sh.Data
bh.Cap = sh.Len
bh.Len = sh.Len
return b
}

高性能的 bytebufferpool

fasthttp? 并沒有直接使用標準庫中的 bytes.Buffer? 對象,而是引用了作者的另外一個包 valyala/bytebufferpool[2], 這個包的核心優化點是 避免內存拷貝 + 底層 byte 切片復用,感興趣的讀者可以看看官方給出的 基準測試結果[3]。

避免反射

fasthttp? 中的所有 對象深拷貝? 內部實現中都沒有使用 反射?,而是手動實現的,這樣可以完全規避 反射? 帶來的影響,例如 Cookie 對象的拷貝實現:

// cookie.go
// Cookie 對象拷貝實現
func (c *Cookie) CopyTo(src *Cookie) {
c.Reset()
c.key = append(c.key, src.key...)
c.value = append(c.value, src.value...)
c.expire = src.expire
c.maxAge = src.maxAge
c.domain = append(c.domain, src.domain...)
c.path = append(c.path, src.path...)
c.httpOnly = src.httpOnly
c.secure = src.secure
c.sameSite = src.sameSite
}

從上面的代碼中可以看到,拷貝? 的內部實現就是手動挨個復制字段,非常 原始 的解決方案。

另外,請求對象 Request? 和響應對象 Response? 的拷貝實現和 Cookie 有異曲同工之處:

// client.go
func (req *Request) CopyTo(dst *Request) {
...
}

func (resp *Response) CopyTo(dst *Response) {
...
}

fasthttp 的問題

軟件工程沒有銀彈,高性能的背后必然是以某些條件作為代價的,fasthttp 的主要問題有:

  • ? 降低了代碼可讀性 (如果不了解 fasthttp 的設計理念,貿然讀代碼很可能無法理解各種方法實現)
  • ? 增加了開發復雜性,代碼開發量要比使用標準庫高,對象復用導致了 申請/歸還 流程彷佛回到了 C/C++ 語言手動管理內存模式
  • ? 增加了開發者心智負擔,如果已經習慣了標準庫的開發模式,很容易寫出 Bug
  • ? 如果業務中有 異步? 處理場景,框架核心的 對象復用 機制可能導致各種問題,如對象提前歸還、對象指針 hang 起、還有更嚴重的對象字段被重置后繼續引用 (這類業務邏輯問題比較難排查)

多核系統的性能優化技巧

  • ? 使用 reuseport 監聽 (SO_REUSEPORT 允許在多核服務器上線性擴展服務器性能,詳細信息請參閱 這個鏈接[4] )
  • ? 使用 GOMAXPROCS=1 為每個 CPU 核運行一個單獨的服務器實例 (進程和 CPU 綁定)
  • ? 確保多隊列網卡的中斷均勻分布在 CPU 內核之間,詳細信息請參閱 [這個鏈接](https://blog.cloudflare.com/how-to-achieve-low-latency/

fasthttp 最佳實踐

  • ? 盡可能復用對象和 []byte buffers, 而不是重新分配
  • ? 使用 []byte 特性技巧
  • ? 使用 sync.Pool 對象池
  • ? 在生產環境對程序進行性能分析,go tool pprof --alloc_objects app mem.pprof 通常比 go tool pprof app cpu.pprof 更容易體現性能瓶頸
  • ? 為 hot path 上的代碼編寫測試和基準測試
  • ? 避免 []byte 和 string 直接進行類型轉換,因為這可能會導致 內存分配 + 復制,可以參考 fasthttp 包內的 s2b 方法和 b2s 方法
  • ? 定期對代碼進行 競態檢測[5], 一般會直接集成到 CI 中
  • ? 使用 quicktemplate 而非 html/template 模板

是否采用 fasthttp

fasthttp? 是為一些高性能邊緣場景設計的,如果你的業務需要支撐較高的 QPS? 并且保持一致的低延遲時間,那么采用 fasthttp? 是非常合理的, 反之 fasthttp? 可能并不適合 (增加開發復雜度和開發者心智負擔)。大多數情況下,標準庫 net/http? 是更好的選擇,因為它簡單易用并且兼容性很高。 如果你的業務流量很少,那么兩者之間的 所謂性能差異 幾乎可以忽略。

Reference

  • ? Go 高性能代碼的 30 個 Tips
  • ? valyala/fasthttp[6]
  • ? fasthttp中運用哪些go優化技巧?
  • ? fasthttp 快在哪里[7]
  • ? fasthttp剖析[8]

引用鏈接

[1]? valyala/fasthttp: ??https://github.com/valyala/fasthttp??

[2]? valyala/bytebufferpool: ??https://github.com/valyala/bytebufferpool??

[3]? 基準測試結果: ??https://omgnull.github.io/go-benchmark/buffer/??

[4]? 這個鏈接: ??https://www.nginx.com/blog/socket-sharding-nginx-release-1-9-1/??

[5]? 競態檢測: ??https://go.dev/doc/articles/race_detector??

[6]? valyala/fasthttp: ??https://github.com/valyala/fasthttp??

[7]? fasthttp 快在哪里: ??https://xargin.com/why-fasthttp-is-fast-and-the-cost-of-it/??

[8]? fasthttp剖析: https://www.jianshu.com/p/a0e766f8dcb0

責任編輯:武曉燕 來源: 洋芋編程
相關推薦

2024-03-08 07:58:13

QPShttpsync

2016-12-14 12:02:01

StormHadoop大數據

2017-02-14 14:20:02

StormHadoop

2022-11-02 08:12:47

TurbopackVite

2017-03-23 14:37:19

WebAssemblyasm.js編程

2025-07-10 14:54:13

AI模型圖像生成

2015-01-16 10:43:09

WiGigWiFi

2011-06-29 09:31:58

3G4G5G

2022-10-27 08:31:31

架構

2021-07-28 14:20:13

正則PythonFlashText

2021-01-21 07:53:29

面試官Promis打印e

2024-03-26 10:13:54

日志引擎SigLens

2025-01-22 08:29:18

索引查詢優化

2025-02-04 17:24:22

2016-08-09 21:18:31

5G4G5G網絡

2025-08-18 09:21:07

2021-03-08 09:05:47

數據傳輸新線纜數據中心

2020-02-12 15:02:15

人工智能機器學習技術

2020-02-27 21:03:30

調度器架構效率

2024-02-26 21:15:20

Kafka緩存參數
點贊
收藏

51CTO技術棧公眾號

亚洲欧美日韩精品| 亚洲综合免费观看高清完整版 | 亚洲日本欧美日韩高观看| 激情视频综合网| 欧美激情二区| 99视频在线观看一区三区| 国产成人精品电影| 免费在线观看黄视频| 精品国内自产拍在线观看视频| 91精品国产综合久久精品app| 日本a视频在线观看| 日韩在线观看www| 99久久婷婷国产| 成人午夜两性视频| 波多野结衣视频网站| 一区二区电影在线观看| 亚洲欧美三级伦理| zjzjzjzjzj亚洲女人| 成人在线高清| 精品欧美国产一区二区三区| 91xxx视频| 国产鲁鲁视频在线观看免费| 99re66热这里只有精品3直播| 亚洲va欧美va国产综合久久| 日韩av免费播放| 夜夜嗨网站十八久久| 欧美少妇激情| 午夜视频一区二区三区| 青春草在线视频免费观看| 免费毛片在线| www.亚洲免费av| 97碰碰视频| 91高潮大合集爽到抽搐| 日韩制服丝袜av| 日韩av第一页| 欧美亚洲精品天堂| 亚洲激情在线| 久久久久久久久久婷婷| 91在线播放观看| 91成人精品| 久久中文久久字幕| 欧美肥妇bbwbbw| 青青草成人影院| 国产亚洲精品91在线| 日本高清不卡三区| 欧洲成人av| 久久无码av三级| 欧美连裤袜在线视频| 天堂av中文在线资源库| 99国产精品99久久久久久| 国产在线欧美日韩| 天天插天天干天天操| 99re这里只有精品6| 蜜桃av噜噜一区二区三| 九色在线免费| 国产欧美一区二区精品性色超碰| 欧美连裤袜在线视频| 亚洲精品在线网址| jizz亚洲| 国产精品国产三级国产aⅴ无密码| 日韩欧美一区二区视频在线播放| 国内在线免费高清视频| 国产精品视频你懂的| 久久免费看毛片| 成人高清免费在线| 一区二区三区在线高清| 无码 制服 丝袜 国产 另类| 川上优av中文字幕一区二区| 136国产福利精品导航| 黄黄视频在线观看| 国产精品一区二区日韩| 色综合天天综合网国产成人综合天| 欧美两根一起进3p做受视频| 青娱乐极品盛宴一区二区| 欧美一区二区成人6969| 欧产日产国产精品98| 国产成人短视频在线观看| 中文字幕日韩在线观看| 欧美日韩大片在线观看| 国产欧美三级| 91精品视频在线免费观看| 欧美一区二区三区激情| 国产日韩精品一区二区浪潮av| 中文网丁香综合网| 蜜臀av国内免费精品久久久夜夜| 天天综合色天天| www.se五月| 欧美久久香蕉| 久久综合久久99| 亚洲白拍色综合图区| 亚洲av成人片无码| 日韩精品一区二区三区免费观看| 精品自拍视频在线观看| 丰满少妇xoxoxo视频| 国模大尺度一区二区三区| 国产私拍一区| 黄a在线观看| 福利二区91精品bt7086| 亚洲午夜激情影院| 日韩av不卡一区| 日韩中文字幕久久| 中文字幕亚洲精品一区| 韩日精品视频一区| 欧美一区二区三区四区五区六区 | 欧美肥婆姓交大片| 国产美女www| 成人高清在线视频| 在线一区日本视频| 欧美一区久久久| 亚洲国产精品国自产拍av秋霞| 992在线观看| 亚洲尤物精选| 国产精品推荐精品| 超碰在线观看免费| 欧美午夜片在线观看| 国产美女久久精品香蕉69| 免费黄色特级片| 日本一区二区三区视频在线看| 亚洲欧美资源在线| 国产成人亚洲欧洲在线| 国产精品羞羞答答xxdd| 亚洲啪啪av| 91看片一区| 亚洲女人天堂网| 日本亚洲欧美在线| 国产精品白丝av| 伊人久久青草| 成人午夜毛片| 中文字幕av一区二区| 51国产偷自视频区视频| 99久久综合99久久综合网站| 奇米视频888战线精品播放| h片在线观看下载| 欧美成人免费网站| 国内偷拍精品视频| 国产一区啦啦啦在线观看| 在线丝袜欧美日韩制服| 亚洲欧洲专区| xvideos成人免费中文版| 中文字幕日韩第一页| 国产欧美日韩视频在线观看| 任你操这里只有精品| 精品中文字幕一区二区三区av| 91精品国产高清久久久久久91 | 亚洲精品在线视频| 中文字幕视频网| 久久五月婷婷丁香社区| 青青青在线播放| 国产一区二区三区91| 国产999精品久久久| 黄色美女网站在线观看| 在线亚洲+欧美+日本专区| 97超碰在线资源| 日本美女一区二区| 永久免费精品视频网站| 国产美女视频一区二区| 欧美黑人国产人伦爽爽爽| 成人免费公开视频| 亚洲国产另类av| 狠狠人妻久久久久久综合蜜桃| 亚洲欧美日韩国产综合精品二区| 欧美精品一区二区视频 | 99国内精品久久久久久久软件| 成人video亚洲精品| 日韩精品一区在线| 男人的天堂一区二区| 久久久久久黄色| 超碰人人草人人| 欧美黄色免费| 久久久久久久免费| 亚洲天堂网站| 97av在线播放| 在线国产91| 日韩欧美国产午夜精品| 中文字幕亚洲精品一区| 国产精品国产自产拍高清av王其| 日本网站在线看| 国产亚洲亚洲| 黄色一级片网址| 香蕉视频一区二区三区| 国产精品入口夜色视频大尺度| 伊人电影在线观看| 亚洲精品中文字幕av| 国产丝袜视频在线观看| 精品国产乱码久久久久久天美| 舐め犯し波多野结衣在线观看| 97精品国产99久久久久久免费| 久久久久久电影| 国产男女无遮挡猛进猛出| 一本色道88久久加勒比精品| 亚洲一卡二卡区| 欧美综合自拍| 91精品天堂| 欧美国产日韩电影| 午夜精品久久久久久久久久久久 | 久久精品论坛| 成人a视频在线观看| 大桥未久在线视频| www.久久久久| 免费在线国产| 日韩欧美三级在线| 亚洲精品毛片一区二区三区| 亚洲一区二区视频在线观看| 国产日韩精品中文字无码| 成人av免费在线观看| 亚洲精品成人在线播放| 鲁大师成人一区二区三区| 日本高清xxxx| 天天干天天爱天天操| 日韩午夜精品| 亚洲最新在线| 国产午夜一区| 精品国产乱码久久久久久108| 亚洲成人精品综合在线| 国产精品扒开腿做爽爽爽视频 | 国产精彩精品视频| 美女扒开腿让男人桶爽久久软| 美女精品视频一区| 日本天堂在线观看| 国产一区二区免费| 无码精品人妻一区二区三区影院| 精品久久国产老人久久综合| 97精品人妻一区二区三区香蕉| 91黄色免费看| 久久国产精品免费看| 香蕉成人伊视频在线观看| 免费在线视频观看| 亚洲精品福利视频网站| 黑人操日本美女| 国产精品入口麻豆九色| 日本黄色小视频在线观看| 久久久久国产一区二区三区四区| 国产肉体xxxx裸体784大胆| 成人综合婷婷国产精品久久蜜臀| 亚洲欧洲日韩综合| 国产不卡高清在线观看视频| 午夜天堂在线视频| 国产一区二区在线视频| 日本免费不卡一区二区| 一区二区三区精品视频在线观看 | 一个人www视频在线免费观看| 国内精品久久久| 91高清视频在线观看| 久久久久久久久久久久av| 变态调教一区二区三区| 97精品在线视频| cao在线视频| 日本国产一区二区三区| 日韩精品免费观看视频| 国产精品欧美日韩久久| 久久青草视频| 亚洲一区中文字幕在线观看| 亚洲欧美日本国产| 国产精品一区在线播放| 色先锋久久影院av| 欧美午夜精品理论片a级大开眼界| 性欧美lx╳lx╳| 色噜噜狠狠一区二区三区| 日韩欧美精品一区| 人人妻人人澡人人爽精品欧美一区| 91精品啪在线观看国产81旧版| 国产在线无码精品| 在线亚洲国产精品网站| 日韩在线第三页| 国精品**一区二区三区在线蜜桃| 韩国三级与黑人| 99久久99久久精品免费观看| 蜜桃av免费看| 最新热久久免费视频| 91精品国产高清一区二区三蜜臀| 亚洲国产一区二区在线播放| 国产精品久久久久久久久久精爆| 欧美午夜影院一区| 99久久国产热无码精品免费| 日韩hd视频在线观看| 1024视频在线| 久久久亚洲精选| av激情成人网| 亚洲专区国产精品| 国产不卡av一区二区| 一级全黄肉体裸体全过程| 亚洲日本欧美| 亚洲欧美自偷自拍另类| 成人一区二区三区在线观看 | 亚洲乱码日产精品bd| 日日夜夜综合网| 日韩亚洲欧美中文三级| 男女污视频在线观看| 美女精品久久久| 日韩在线观看不卡| 国产精品swag| 色一区二区三区四区| www.av片| 国产一区在线不卡| 女人又爽又黄免费女仆| 亚洲综合色噜噜狠狠| 依依成人在线视频| 亚洲老板91色精品久久| 在线中文字幕电影| 国产精品mp4| 国产精品网在线观看| 致1999电视剧免费观看策驰影院| 国产一区二区三区的电影| 午夜大片在线观看| 国产日产精品一区| 日本一二三区视频| 91精品国产综合久久精品性色| 国产在线自天天| 88xx成人精品| 超碰成人在线观看| 性生活免费观看视频| 老司机午夜精品| 国产一区二区三区四区五区六区 | 欧美视频三区在线播放| 丰满大乳国产精品| 久久九九精品99国产精品| 精品欧美一区二区三区在线观看| 国内一区在线| 韩日在线一区| 国产又粗又猛大又黄又爽| 国产精品毛片久久久久久久| 精品人妻一区二区三区潮喷在线 | 免费视频久久| 国产污在线观看| 一区二区三区精品久久久| 国产又粗又黄又爽视频| 日日骚av一区| 成人在线视频免费| 午夜精品福利一区二区| 日韩av网站免费在线| 瑟瑟视频在线观看| 欧美性极品少妇精品网站| 色婷婷视频在线| 久久久久久国产| 91成人入口| 97中文字幕在线| 成人免费视频视频| 久久综合亚洲色hezyo国产| 日韩精品一区国产麻豆| 黄色羞羞视频在线观看| 国产99午夜精品一区二区三区 | 精品国产一区二区三区| 国模吧无码一区二区三区| 91啪九色porn原创视频在线观看| 日本少妇做爰全过程毛片| 亚洲国产欧美自拍| 末成年女av片一区二区下载| 免费亚洲精品视频| 丝袜脚交一区二区| 亚洲色图第四色| 欧美猛男男办公室激情| 欧美18一19xxx性| 91精品网站| 国产欧美一区二区三区国产幕精品| 女尊高h男高潮呻吟| 在线视频你懂得一区二区三区| 国产系列在线观看| 欧美国产在线观看| 国产精品成人免费一区久久羞羞| 亚洲一区二区三区在线| 欧美 日韩 国产 在线| 欧美中文字幕视频在线观看| 加勒比久久综合| 五月婷婷之婷婷| 一区二区三区中文字幕在线观看| 韩国av永久免费| 日本成熟性欧美| 天堂网在线观看国产精品| 日本久久久久久久久久| 欧美性猛交xxxx偷拍洗澡| 在线中文资源天堂| 99在线免费观看视频| 日韩天天综合| 国产wwwwxxxx| 亚洲风情亚aⅴ在线发布| 色综合一本到久久亚洲91| 中文字幕一区二区三区有限公司 | 亚洲成人精品视频在线观看| 日韩av影片| 影音先锋男人的网站| 91一区二区在线| 97视频免费在线| 97av在线视频| 婷婷综合激情| 精品人妻一区二区三区视频| 欧美日本精品一区二区三区| 超碰97免费在线| 一区二区高清视频| 不卡一区在线观看| 一级全黄裸体免费视频| 96精品视频在线| 欧美xxx在线观看| 中文字幕成人动漫| 欧美大片一区二区| av成人在线观看| 国产91在线免费| 亚洲激情在线播放| av电影在线网| 久久99精品久久久久子伦| 国内精品免费**视频|