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

使用Go處理每分鐘百萬請求

開發 后端
我們經常聽說使用Go的goroutine和channel很容易實現高并發,那是不是全部代碼都放在goroutine中運行就可以實現高并發程序了呢?很顯然并不是。這篇文章將教大家如何一步一步寫出一個簡單的, 高并發的Go程序。

這篇文章在medium上很火,作者以實際案例來分析,講得很好。

我們經常聽說使用Go的goroutine和channel很容易實現高并發,那是不是全部代碼都放在goroutine中運行就可以實現高并發程序了呢?很顯然并不是。這篇文章將教大家如何一步一步寫出一個簡單的, 高并發的Go程序。

正文

我在幾家不同的公司從事反垃圾郵件,防病毒和反惡意軟件的工作超過15年,現在我知道這些系統最終會因為我們要每天處理大量數據而變得越來越復雜。

目前,我是smsjunk.com的CEO和 KnowBe4的***架構師,他們都是網絡安全行業的公司。

有趣的是,在過去的10年里,作為一名軟件工程師,我參與過的所有Web后端開發大部分都是使用RubyonRails完成的。不要誤會我的意思,我喜歡 RubyonRails,我相信這是一個了不起的生態,但是過了一段時間,你開始以 Ruby的方式思考和設計系統,忘了如何高效和原本可以利用多線程、并行、快速執行和小的內存消耗來簡化軟件架構。多年來,我是一名C/C++,Delphi和 C#開發人員,而且我剛開始意識到如何正確的使用工具進行工作可能會有多復雜。

我對互聯網中那些語言和框架戰爭并不太感興趣,比如哪門語言更好,哪個框架更快。 我始終相信效率,生產力和代碼可維護性主要取決于如何簡單的構建解決方案。

問題

在處理我們的匿名監測和分析系統時,我們的目標是能夠處理來自數百萬端點的大量POST請求。Web處理程序將收到一個JSON文檔,該文檔可能包含需要寫入 AmazonS3的多個有效內容的集合,以便我們的 map-reduce系統稍后對這些數據進行操作。

傳統上,我們會考慮創建一個工作層架構,利用諸如以下的技術棧:

  • Sidekiq
  • Resque
  • DelayedJob
  • ElasticbeanstalkWorkerTier
  • RabbitMQ
  • ...

并搭建2個不同的集群,一個用于web前端,一個用于worker,因此我們可以隨意擴容機器來處理即將到來的請求。

從一開始,我們的團隊就知道我們可以在Go中這樣做,因為在討論階段我們看到這可能是一個非常大流量的系統。我一直在使用Go,大約快2年時間了,而且我們也使用Go開發了一些系統,但是沒有一個系統的流量能夠達到這個數量級。我們首先創建了幾個struct來定義我們通過POST調用接收到的Web請求,并將其上傳到S3存儲中。

 

  1. type PayloadCollection struct { 
  2.     WindowsVersion  string    `json:"version"
  3.     Token           string    `json:"token"
  4.     Payloads        []Payload `json:"data"
  5.  
  6. type Payload struct { 
  7.     // [redacted] 
  8.  
  9. func (p *Payload) UploadToS3() error { 
  10.     // the storageFolder method ensures that there are no name collision in 
  11.     // case we get same timestamp in the key name 
  12.     storage_path := fmt.Sprintf("%v/%v", p.storageFolder, time.Now().UnixNano()) 
  13.  
  14.     bucket := S3Bucket 
  15.  
  16.     b := new(bytes.Buffer) 
  17.     encodeErr := json.NewEncoder(b).Encode(payload) 
  18.     if encodeErr != nil { 
  19.         return encodeErr 
  20.     } 
  21.  
  22.     // Everything we post to the S3 bucket should be marked 'private' 
  23.     var acl = s3.Private 
  24.     var contentType = "application/octet-stream" 
  25.  
  26.     return bucket.PutReader(storage_path, b, int64(b.Len()), contentType, acl, s3.Options{}) 

Naive的做法-硬核使用Goroutine

最初,我們對POST處理程序進行了非常簡單粗暴的實現,將每個請求直接放到新的goroutine中運行:

 

  1. func payloadHandler(w http.ResponseWriter, r *http.Request) { 
  2.  
  3.     if r.Method != "POST" { 
  4.         w.WriteHeader(http.StatusMethodNotAllowed) 
  5.         return 
  6.     } 
  7.  
  8.     // Read the body into a string for json decoding 
  9.     var content = &PayloadCollection{} 
  10.     err := json.NewDecoder(io.LimitReader(r.Body, MaxLength)).Decode(&content) 
  11.     if err != nil { 
  12.         w.Header().Set("Content-Type""application/json; charset=UTF-8"
  13.         w.WriteHeader(http.StatusBadRequest) 
  14.         return 
  15.     } 
  16.      
  17.     // Go through each payload and queue items individually to be posted to S3 
  18.     for _, payload := range content.Payloads { 
  19.         go payload.UploadToS3()   // <----- DON'T DO THIS 
  20.     } 
  21.  
  22.     w.WriteHeader(http.StatusOK) 

對于一般的并發量,這其實是可行的,但這很快就證明不能適用于高并發場景。我們可能有更多的請求,當我們將***個版本部署到生產環境時,我們開始看到的數量級并不是如此,我們低估了并發量。

上述的方法有幾個問題。沒有辦法控制正在工作的goroutine的數量。而且,由于我們每分鐘有100萬個POST請求,所以系統很快就崩潰了。

重來

我們需要找到另一種的方法。從一開始我們就開始討論如何讓請求處理程序的生命周期盡可能的短,并在后臺產生處理。當然,這是在 RubyonRails必須要做的事情,否則,不管你是使用puma,unicorn還是 passenger,你的所有的可用的web worker都將阻塞。

那么我們就需要利用常見的解決方案來完成這項工作,比如Resque,Sidekiq, SQS等。當然還有其他工具,因為有很多方法可以實現。

因此,我們第二次改進是創建一個buffer channel,我們可以將一些作業請求扔進隊列并將它們上傳到S3,由于我們可以控制隊列的***長度,并且有足夠的RAM來排隊處理內存中的作業,因此我們認為只要在通道隊列中緩沖作業就行了。

 

  1. var Queue chan Payload 
  2.  
  3. func init() { 
  4.     Queue = make(chan Payload, MAX_QUEUE) 
  5.  
  6. func payloadHandler(w http.ResponseWriter, r *http.Request) { 
  7.     ... 
  8.     // Go through each payload and queue items individually to be posted to S3 
  9.     for _, payload := range content.Payloads { 
  10.         Queue <- payload 
  11.     } 
  12.     ... 

然后,為了將任務從buffer channel中取出并處理它們,我們正在使用這樣的方式:

 

  1. func StartProcessor() { 
  2.     for { 
  3.         select { 
  4.         case job := <-Queue: 
  5.             job.payload.UploadToS3()  // <-- STILL NOT GOOD 
  6.         } 
  7.     } 

說實話,我不知道我們在想什么,這肯定是一個難熬的夜晚。這種方法并沒有給我們帶來什么提升,我們用一個緩沖的隊列替換了有缺陷的并發,也只是推遲了問題的產生時間而已。我們的同步處理器每次只向S3上傳一個有效載荷,由于傳入請求的速率遠遠大于單個處理器上傳到S3的能力,因此我們的buffer channel迅速達到極限,隊列已經阻塞并且無法再往里邊添加作業。

我們只是簡單的繞過了這個問題,最終導致我們的系統完全崩潰。在我們部署這個有缺陷的版本后,我們的延遲持續的升高。

使用Go處理每分鐘百萬請求

更好的解決方案

我們決定在Go channel上使用一個通用模式來創建一個 2-tier(雙重)channel系統,一個用來處理排隊的job,一個用來控制有多少worker在 JobQueue上并發工作。

這個想法是將上傳到S3的并行速度提高到一個可持續的速度,同時不會造成機器癱瘓,也不會引發S3的連接錯誤。

所以我們選擇創建一個 Job/Worker模式。對于那些熟悉Java,C#等的人來說,可以將其視為Golang使用channel來實現WorkerThread-Pool的方式。

 

  1. var ( 
  2.     MaxWorker = os.Getenv("MAX_WORKERS"
  3.     MaxQueue  = os.Getenv("MAX_QUEUE"
  4.  
  5. // Job represents the job to be run 
  6. type Job struct { 
  7.     Payload Payload 
  8.  
  9. // A buffered channel that we can send work requests on
  10. var JobQueue chan Job 
  11.  
  12. // Worker represents the worker that executes the job 
  13. type Worker struct { 
  14.     WorkerPool  chan chan Job 
  15.     JobChannel  chan Job 
  16.     quit        chan bool 
  17.  
  18. func NewWorker(workerPool chan chan Job) Worker { 
  19.     return Worker{ 
  20.         WorkerPool: workerPool, 
  21.         JobChannel: make(chan Job), 
  22.         quit:       make(chan bool)} 
  23.  
  24. // Start method starts the run loop for the worker, listening for a quit channel in 
  25. // case we need to stop it 
  26. func (w Worker) Start() { 
  27.     go func() { 
  28.         for { 
  29.             // register the current worker into the worker queue. 
  30.             w.WorkerPool <- w.JobChannel 
  31.  
  32.             select { 
  33.             case job := <-w.JobChannel: 
  34.                 // we have received a work request. 
  35.                 if err := job.Payload.UploadToS3(); err != nil { 
  36.                     log.Errorf("Error uploading to S3: %s", err.Error()) 
  37.                 } 
  38.  
  39.             case <-w.quit: 
  40.                 // we have received a signal to stop 
  41.                 return 
  42.             } 
  43.         } 
  44.     }() 
  45.  
  46. // Stop signals the worker to stop listening for work requests. 
  47. func (w Worker) Stop() { 
  48.     go func() { 
  49.         w.quit <- true 
  50.     }() 

我們修改了我們的Web請求處理程序以創建具有有效負載的Job struct,并將其發送到 JobQueueChannel以供worker處理。

 

  1. func payloadHandler(w http.ResponseWriter, r *http.Request) { 
  2.  
  3.     if r.Method != "POST" { 
  4.         w.WriteHeader(http.StatusMethodNotAllowed) 
  5.         return 
  6.     } 
  7.  
  8.     // Read the body into a string for json decoding 
  9.     var content = &PayloadCollection{} 
  10.     err := json.NewDecoder(io.LimitReader(r.Body, MaxLength)).Decode(&content) 
  11.     if err != nil { 
  12.         w.Header().Set("Content-Type""application/json; charset=UTF-8"
  13.         w.WriteHeader(http.StatusBadRequest) 
  14.         return 
  15.     } 
  16.  
  17.     // Go through each payload and queue items individually to be posted to S3 
  18.     for _, payload := range content.Payloads { 
  19.  
  20.         // let's create a job with the payload 
  21.         work := Job{Payload: payload} 
  22.  
  23.         // Push the work onto the queue. 
  24.         JobQueue <- work 
  25.     } 
  26.  
  27.     w.WriteHeader(http.StatusOK) 

在我們的Web服務器初始化期間,我們創建一個Dispatcher并調用Run()來創建worker池并開始監聽JobQueue中出現的Job。

 

  1. dispatcher := NewDispatcher(MaxWorker)  
  2. dispatcher.Run() 

以下是我們調度程序實現的代碼:

 

  1. type Dispatcher struct { 
  2.     // A pool of workers channels that are registered with the dispatcher 
  3.     WorkerPool chan chan Job 
  4.  
  5. func NewDispatcher(maxWorkers int) *Dispatcher { 
  6.     pool := make(chan chan Job, maxWorkers) 
  7.     return &Dispatcher{WorkerPool: pool} 
  8.  
  9. func (d *Dispatcher) Run() { 
  10.     // starting n number of workers 
  11.     for i := 0; i < d.maxWorkers; i++ { 
  12.         worker := NewWorker(d.pool) 
  13.         worker.Start() 
  14.     } 
  15.  
  16.     go d.dispatch() 
  17.  
  18. func (d *Dispatcher) dispatch() { 
  19.     for { 
  20.         select { 
  21.         case job := <-JobQueue: 
  22.             // a job request has been received 
  23.             go func(job Job) { 
  24.                 // try to obtain a worker job channel that is available. 
  25.                 // this will block until a worker is idle 
  26.                 jobChannel := <-d.WorkerPool 
  27.  
  28.                 // dispatch the job to the worker job channel 
  29.                 jobChannel <- job 
  30.             }(job) 
  31.         } 
  32.     } 

請注意,我們實例化了***數量的worker,并將其保存到worker池中(就是上面的 WorkerPoolChannel)。由于我們已經將Amazon Elasticbeanstalk用于Docker化的Go項目,并且我們始終嘗試遵循12要素方法來配置生產中的系統,因此我們從環境變量中讀取這些值,這樣我們就可以快速調整這些值以控制工作隊列的數量和***規模,而不需要重新部署集群。

 

  1. var (  
  2.   MaxWorker = os.Getenv("MAX_WORKERS")  
  3.   MaxQueue  = os.Getenv("MAX_QUEUE")  

在我們發布了這個版本之后,我們立即看到我們的所有的請求延遲都下降到了一個很低的數字,我們處理請求的效率大大提升。

使用Go處理每分鐘百萬請求

在我們的彈性負載均衡器完全熱身之后的幾分鐘,我們看到我們的ElasticBeanstalk應用程序每分鐘提供近100萬次請求。通常在早晨的幾個小時里,流量高峰會超過每分鐘100萬個請求。

我們部署了新的代碼,服務器的數量從100臺減少到大約20臺。

使用Go處理每分鐘百萬請求

在恰當地配置了集群和自動縮放設置以后,我們在生成環境用4臺EC2 c4就能完成工作了。如果CPU在連續5分鐘內超過90%,彈性自動縮放系統就自動擴容一個新的實例。

使用Go處理每分鐘百萬請求

結論

簡單總是我的制勝法寶。我們可以設計一個擁有多隊列,多后臺進程和難以部署的復雜系統,但是相反我們決定利用Elasticbeanstalk的自動縮放和高效簡單的方式去并發,Go語言很好的提供了這些功能。

經驗告訴我們,用最合適的工具去完成工作。有時,當你的 RubyonRails系統需要實現一個非常強大的處理程序時,可以考慮在 Ruby生態系統之外尋找更簡單且更強大的替代解決方案。

責任編輯:未麗燕 來源: Go語言中文網
相關推薦

2017-09-15 09:43:59

Go語言web請求開發

2023-10-31 07:52:10

2025-11-17 07:43:24

2025-03-13 08:33:37

RPMTPM代碼

2011-09-05 10:07:49

聯想激光打印機

2022-10-08 00:05:00

HammerDB自動化測試

2021-07-27 06:05:07

網絡犯罪網絡攻擊網絡威脅

2011-09-19 13:27:36

惠普激光打印機

2011-11-23 13:54:21

惠普激光打印機

2011-09-06 08:42:58

惠普激光打印機

2012-01-09 15:14:41

惠普激光打印機

2012-05-24 11:38:00

惠普激光打印機

2012-02-23 14:10:16

惠普激光打印機

2013-08-19 11:27:24

谷歌宕機損失

2012-08-07 14:33:49

打印機

2012-06-04 11:18:02

HP激光打印機

2012-08-01 10:18:47

打印機

2010-08-26 17:39:48

谷歌

2012-04-20 14:42:45

夏普復合一體機

2011-11-25 13:39:55

聯想激光打印機
點贊
收藏

51CTO技術棧公眾號

欧美精品乱码久久久久久按摩| 久久久久久日产精品| 欧美精品一二区| 国产艳妇疯狂做爰视频| 久久国产精品免费看| 国产精品久久久久久久久久齐齐| 国产精品日韩精品欧美在线| 亚洲一区二区三区视频| 日韩美女视频网站| 成人看的视频| 欧美精品一区在线观看| 日本熟妇人妻中出| 国产黄大片在线观看画质优化| 福利一区福利二区| 国产精品成人国产乱一区| 国产一区二区精彩视频| 日韩a级大片| 欧美疯狂性受xxxxx喷水图片| 一区二区传媒有限公司| 免费av在线播放| 99久久国产综合精品女不卡| 久久久精品国产一区二区| 在线播放av网址| 国产精品99久久久久久董美香| 一区二区三区高清| 性欧美精品一区二区三区在线播放| 国产sm主人调教女m视频| 久久最新视频| 亚洲美女视频网站| 动漫av在线免费观看| 电影久久久久久| 夜夜嗨av一区二区三区| 在线视频欧美一区| 久久久久久青草| aaa亚洲精品| 91久久久久久久一区二区| 老熟妇一区二区三区| 亚洲香蕉网站| 久色乳综合思思在线视频| 国产传媒国产传媒| 天天躁日日躁狠狠躁欧美巨大小说| 91精品国模一区二区三区| 在线免费一区| 成人免费视频| 久久久精品综合| 国产日韩欧美综合精品| www国产在线| 精品午夜久久福利影院| 国产精品嫩草影院久久久| 欧美特黄aaaaaa| 99国产精品久久久久久久| 欧美激情中文字幕乱码免费| xxxx日本少妇| 91精品蜜臀一区二区三区在线| 在线观看不卡av| 蜜臀久久99精品久久久久久| 精品中文一区| 亚洲欧美日韩高清| 国产精品扒开腿做爽爽| 亚洲区小说区图片区qvod按摩| 亚洲激情电影中文字幕| 精品国产一区在线| 亚洲国产精品嫩草影院久久av| 亚洲激情自拍图| 狠狠人妻久久久久久综合蜜桃| 国产美女撒尿一区二区| 亚洲精品在线观看网站| 强迫凌虐淫辱の牝奴在线观看| 国内精品免费| 亚洲欧美日韩高清| 中文字幕黄色网址| 日韩国产一区二区三区| www.精品av.com| 手机看片福利视频| 99久久精品费精品国产| 久久视频这里只有精品| 国产精品老熟女一区二区| 欧美激情五月| 欧美激情视频一区| 黄色片视频网站| 日韩精品诱惑一区?区三区| 一区二区三区精品99久久| 日本欧美一区二区三区不卡视频| 久久国产精品亚洲人一区二区三区 | 欧美高清视频看片在线观看 | av大全在线免费看| 国产精品美女久久久久久2018 | 日韩av在线看免费观看| 不卡视频在线| 欧美精品免费看| 少妇一级淫片免费放中国| 日本少妇一区二区| 亚洲a一级视频| 飘雪影视在线观看免费观看 | 在线观看亚洲视频| 深夜福利影院在线观看| 国产日韩欧美一区在线| 国产噜噜噜噜久久久久久久久| 99热这里只有精| 91在线免费播放| 一区二区视频在线免费| 国产黄大片在线观看| 欧美色图片你懂的| 88av在线播放| 91视频一区| 97热在线精品视频在线观看| 在线观看国产成人| 国产日韩一区二区三区在线| 国产精品欧美一区二区| 亚洲精品97久久中文字幕| 国产偷v国产偷v亚洲高清| 无颜之月在线看| 色尼玛亚洲综合影院| 天天爽夜夜爽夜夜爽精品视频| 国产嫩草在线观看| 精品亚洲免a| 久久久av网站| 精人妻无码一区二区三区| 国产jizzjizz一区二区| 香蕉久久免费影视| free性护士videos欧美| 欧美一区二区三区视频在线观看| 91网站免费视频| 伊人精品在线| 97中文在线| 91精品国产综合久久久久久豆腐| 亚洲成av人片一区二区梦乃| 亚洲第一天堂久久| 欧美色图国产精品| 欧亚精品中文字幕| 日本成人一级片| 99久久国产免费看| 国产精品自拍合集| 四虎地址8848精品| 伊人一区二区三区久久精品| 免费观看一区二区三区毛片 | 91亚洲精品久久久| 日韩免费啪啪| 中文字幕字幕中文在线中不卡视频| 国产日韩一区二区在线观看| 久久久久97| 欧美福利在线观看| 精品人妻一区二区三区含羞草 | 99精品在线观看视频| 大地资源网在线观看免费官网| 爱情电影网av一区二区| 综合久久五月天| 人妻中文字幕一区二区三区| 久久夜色精品一区| 欧美私人情侣网站| 亚洲资源网你懂的| 国产盗摄xxxx视频xxx69| 偷拍25位美女撒尿视频在线观看| 91美女片黄在线观看91美女| 农民人伦一区二区三区| 在线一区二区三区视频| 欧美成人在线影院| av中文字幕免费| 亚洲一二三区在线观看| 四虎精品一区二区| 一区二区高清| 欧美人xxxxx| 电影亚洲一区| 日韩在线视频中文字幕| 国产精品视频久久久久久| 亚洲人成网站色在线观看| 国产探花在线观看视频| 韩国亚洲精品| 乱色588欧美| 高清av一区二区三区| 久久精品亚洲一区| www香蕉视频| 精品久久久久久久久中文字幕| 亚洲av成人片色在线观看高潮| 久久成人在线| 亚洲高清在线观看一区| 久久在线观看| 午夜精品视频网站| 国产高清av在线| 91精品国产aⅴ一区二区| 久久黄色小视频| 久久亚洲欧美国产精品乐播 | 国产九色精品成人porny| 日韩激情视频一区二区| 亚洲区小说区图片区qvod按摩| 国产精品午夜国产小视频| 1区2区3区在线视频| 亚洲精品国产免费| 中文文字幕一区二区三三| 亚洲免费观看高清完整版在线观看| 91精品91久久久中77777老牛| 精品一区免费| 91青青草免费在线看| 三级中文字幕在线观看| 日日骚久久av| 日韩中文字幕综合| 欧美日韩性生活| 97超碰人人干| 国产精品久久777777| 四虎精品一区二区| 另类小说欧美激情| 国产91xxx| 亚洲国产精品成人| 欧美影视一区二区| 91精品尤物| 国产精品视频26uuu| 国产夫妻在线播放| 欧美成人免费全部| h视频在线免费| 亚洲精品一区二区三区蜜桃下载| 亚洲视频一区在线播放| 亚洲v中文字幕| 亚洲女人毛茸茸高潮| 99re在线精品| wwwww在线观看| 美女久久久精品| 免费av观看网址| 你懂的一区二区| 亚洲三区在线| 九九热线有精品视频99| 国产乱码一区| 久久影院一区二区三区| 成人精品一区二区三区电影免费 | 欧美日韩国产免费观看| 一本色道久久综合亚洲精品婷婷| 综合国产视频| 精品在线观看一区二区| 1区2区3区在线| 不卡伊人av在线播放| 99精品老司机免费视频| 亚洲美女在线视频| 午夜国产在线视频| 精品久久久久久无| 99热这里只有精品5| 91麻豆精品国产91久久久久久久久 | 欧美一区午夜视频在线观看| 伊人免费在线观看| 在线观看日韩av先锋影音电影院| 亚洲最大成人综合网| 91视视频在线观看入口直接观看www | 果冻天美麻豆一区二区国产| 91久久偷偷做嫩草影院| 国产视频一区二区在线播放| 国产精品久久久久久av下载红粉| 国产不卡网站| 国产99在线|中文| 国产高清不卡| 国产精品久久久久久久久借妻 | 色婷婷精品久久二区二区蜜臂av | 国产精品久久久久久久免费软件| 久久精品无码中文字幕| 欧美三级黄美女| 日本大片免费看| 亚洲精品1234| www国产黄色| 久久久蜜桃一区二区人| 久久综合久久色| 蜜臀av在线播放一区二区三区| 色综合色综合色综合色综合| 捆绑调教一区二区三区| 九一精品久久久| 国产成+人+日韩+欧美+亚洲| 久久久高清视频| 久久女同性恋中文字幕| 精品欧美一区二区久久久| 欧美国产禁国产网站cc| 亚洲少妇xxx| 亚洲精品免费一二三区| 久久高清免费视频| 一本大道久久a久久精品综合| 天天干,天天干| 欧美日本国产一区| 亚洲xxx在线| 精品丝袜一区二区三区| 中文字幕在线播放| 色中色综合影院手机版在线观看| www.超碰在线| 国产精品久久一| 成人综合日日夜夜| 精品亚洲一区二区三区四区五区高| 在线看成人短视频| 日韩第一页在线观看| 欧美三级乱码| 可以免费在线看黄的网站| 老司机一区二区| 五月天丁香社区| 国产视频一区在线观看 | 欧美福利影院| 国产无套内射久久久国产| 喷白浆一区二区| 亚洲成年人av| 欧美国产激情二区三区| 久久黄色免费视频| 欧美三级中文字幕| 蜜桃av中文字幕| www亚洲精品| 国产伦子伦对白在线播放观看| 国产精品日韩精品| 红杏成人性视频免费看| 亚洲精品国产精品国自产观看| 国语精品一区| 欧美特黄aaa| 久久久99精品久久| 精品无码一区二区三区电影桃花| 91福利小视频| 五月天福利视频| 不用播放器成人网| 欧美性片在线观看| 久久99国产精品99久久| 91精品国产91久久久久久密臀| 欧美性大战久久久久xxx | 国产一区二区三区的电影 | 免费97视频在线精品国自产拍| 亚洲美女久久精品| 韩国三级电影久久久久久| 国产91在线精品| 精品国产一区二区三区四区精华| 亚洲激情中文| 日本肉体xxxx裸体xxx免费| 99久久99久久精品免费看蜜桃| 福利所第一导航| 欧美日韩国产影片| 福利片在线观看| 欧美在线视频一区| jizz性欧美23| 国产又粗又长又爽视频| 久久se这里有精品| 亚洲图片另类小说| 欧美性猛交xxxxx免费看| 男人天堂网在线视频| 久久av红桃一区二区小说| 久久99久久久精品欧美| 亚洲成色最大综合在线| 首页国产欧美久久| 人妻精品久久久久中文字幕| 亚洲高清视频中文字幕| 丰满熟妇乱又伦| 欧美高清在线视频观看不卡| 国产在线视频欧美一区| 中文字幕一区二区三区四区五区人| 七七婷婷婷婷精品国产| 潮喷失禁大喷水aⅴ无码| 在线观看91精品国产入口| lutube成人福利在线观看| 国产精品久久久久影院日本| 成人精品亚洲| 色啦啦av综合| 18欧美亚洲精品| www.日本在线观看| 久久99久久久久久久噜噜| a级日韩大片| 国产一区二区视频播放| 99精品视频在线播放观看| 中日韩黄色大片| 亚洲精品自产拍| 日韩av首页| 伊人色综合影院| 国产在线精品一区二区夜色| 极品魔鬼身材女神啪啪精品| 日韩欧美不卡在线观看视频| 黄网av在线| 成人av在线播放网站| 亚洲欧美一区二区激情| av福利在线导航| 蜜桃狠狠色伊人亚洲综合网站| 久久亚洲国产精品一区二区| 日本少妇xxxxx| 91精品国产高清一区二区三区| 日韩三级电影视频| 精品国产免费一区二区三区| 久久综合五月| 神马久久精品综合| 精品国产免费人成在线观看| 男人的天堂免费在线视频| 日韩三级电影网站| 999国产精品视频| 日韩av成人网| 色婷婷久久久综合中文字幕| 欧美激情午夜| 国产精品免费在线| 久久精品系列| 久久久久久视频| 日韩av在线资源| 欧美aaa级| 成人午夜精品久久久久久久蜜臀| 国产亚洲精品bt天堂精选| 国产免费av观看| 欧美在线视频网| 欧美二区不卡| 国产毛片久久久久久久| 欧美一级生活片| 午夜精品成人av| 欧美日韩激情四射| 欧美国产激情二区三区| 六月丁香色婷婷| 91精品免费久久久久久久久| 国产精品美女| 欧美精品色哟哟| 影音先锋欧美精品| 精品国产午夜肉伦伦影院|