久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

再谈Linux epoll惊群问题的原因和解决方案

發布時間:2024/3/12 linux 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 再谈Linux epoll惊群问题的原因和解决方案 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

差別是什么?差別只是西裝!

緣起

近期排查了一個問題,epoll驚群的問題,起初我并不認為這是驚群導致,因為從現象上看,只是體現了CPU不均衡。一共fork了20個Server進程,在請求負載中等的時候,有三四個Server進程呈現出比較高的CPU利用率,其余的Server進程的CPU利用率都是非常低。

中斷,軟中斷都是均衡的,網卡RSS和CPU之間進行了bind之后依然如故,既然系統層面查不出個所以然,只能從服務的角度來查了。

自上而下的排查首先就想到了strace,沒想到一下子就暴露了原形:

accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable)

如果僅僅strace accept,即加上“-e trace=accept”參數的話,偶爾會有accept成功的現象:

accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, {sa_family=AF_INET, sin_port=htons(39306), sin_addr=inet_addr("172.16.1.202")}, [16]) = 19 accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable) accept(4, 0x9ecd930, [16]) = -1 EAGAIN (Resource temporarily unavailable)

大量的CPU空轉,進一步加大請求負載,CPU空轉明顯降低,這說明在預期的空轉期間,新來的請求降低了空轉率…現象明顯偏向于這就是驚群導致的之判斷!

本文將詳細說一下關于epoll的細節。現在開始!


關于epoll的文章,我很早前寫過一篇總結性的,可以參考這里:
Linux內核中網絡數據包的接收-第二部分 select/poll/epoll:https://blog.csdn.net/dog250/article/details/50528373
不過這篇文章主要是原理性的介紹,對于一開始并不充分理解epoll機制的人來講,可讀性并不強,所以我準備寫一篇稍微接地氣的,比如帶有一些“源碼分析”的文章,雖然我并不是很喜歡源碼分析,但有時對于快速理解為什么這樣還是必要的。

題目中為什么是“再談”,因為這個話題別人已經聊過很多了,我順勢繼續下去而已。

簡單介紹驚群和事件模型

關于什么是驚群,這里不再做概念上的解釋,能搜到這篇文章的想必已經有所了解,如果仍有概念上的疑惑,自行百度或者谷歌。


驚群問題一般出現在那些web服務器上,曾經Linux系統有個經典的accept驚群問題困擾了大家非常久的時間,這個問題現在已經在內核曾經得以解決,具體來講就是當有新的連接進入到accept隊列的時候,內核喚醒且僅喚醒一個進程來處理,這是通過以下的代碼來實現的:

list_for_each_entry_safe(curr, next, &q->task_list, task_list) {unsigned flags = curr->flags;if (curr->func(curr, mode, wake_flags, key) &&(flags & WQ_FLAG_EXCLUSIVE) && !--nr_exclusive)break;}

是的,添加了一個WQ_FLAG_EXCLUSIVE標記,告訴內核進行排他性的喚醒,即喚醒一個進程后即退出喚醒的過程,問題得以解決。

然而,沒有哪個web服務器會傻到多個進程直接阻塞在accept上準備接收請求,在更高層次上,多路復用的需求讓select,poll,epoll等事件模型更為受到歡迎,所謂的事件模型即阻塞在事件上而不是阻塞在事務上。內核僅僅通知發生了某件事,具體發生了什么事,則有處理進程或者線程自己來poll。如此一來,這個事件模型(無論其實現是select,poll,還是epoll)便可以一次搜集多個事件,從而滿足多路復用的需求。

好了,基本原理就介紹到這里,下面我將來詳細談一下Linux epoll中的驚群問題,我們知道epoll在實際中要比直接accept實用性強很多,據我所知,除非編程學習或者驗證性小demo,幾乎沒有直接accept的代碼,所有的線上代碼幾乎都使用了事件模型。然而由于select,poll沒有可擴展性,存在O(n)O(n)問題,因此在帶寬越來越高,服務器性能越來越強的趨勢下,越來越多的代碼將收斂到使用epoll的情形,所以有必要對其進行深入的討論。


Linux epoll驚群問題

知乎上有一個問題:
Linux 3.x 中epoll的驚群問題?:https://www.zhihu.com/question/24169490/answers/created
建議先看一下,但不要看回答,因為知乎上上的很多回答往往會讓事情變得更加混亂,除非你自己對這個問題已經有了自己的答案或者觀點,否則還是不要去指望在諸多的答案中選一個自己滿意的來用,還是要自己先思考。

下面我來就這個問題給一個答案,這也是我自己思考的答案:

  • 在ep_poll的睡眠中加入WQ_FLAG_EXCLUSIVE標記,確實實實在在解決了epoll的驚群問題
  • epoll_wait返回后確實也還有多個進程被喚醒只有一個進程能正確處理其他進程無事可做的情況發生,但這不是因為驚群,而是你的使用方法不對。
  • What?使用方法不對?

    是的,使用方法不對。若想了解Why,則必須對epoll的實現細節以及其對外提供的API的語義有充分的理解,接下來我們就循著這個思路來擼個所以然。請繼續閱讀。

    Linux epoll的實現機制

    說起實現原理,很多人喜歡擼源碼分析,我并不喜歡,我認為源碼是自己看看就行了,搞這個行業的能看懂代碼是一個最最基本的能力,我比較在意的是對某種機制內在邏輯的深入理解,而這個通過代碼是體現不出來的,我一般會做下面幾件事:

    • 運行起來并測得預期的數據
    • 看懂代碼并畫出原理圖
    • 自己重新實現一版(時間精力允許的情況下)
    • 寫個demo驗證一些具體邏輯細節

    不多說。

    下面是我總結的一張關于Linux epoll的原理圖:

    要說代碼實現上,其實也比較簡單,大致有以下的幾個邏輯:

  • 創建epoll句柄,初始化相關數據結構
  • 為epoll句柄添加文件句柄,注冊睡眠entry的回調
  • 事件發生,喚醒相關文件句柄睡眠隊列的entry,調用其回調
  • 喚醒epoll睡眠隊列的task,搜集并上報數據
  • 來,一個一個說

    1.創建epoll句柄,初始化相關數據結構

    這里主要就是創建一個epoll文件描述符,注意,后面操作epoll的時候,就是用這個epoll的文件描述符來操作的,所以這就是epoll的句柄,精簡過后的epoll結構如下:

    struct eventpoll {// 阻塞在epoll_wait的task的睡眠隊列wait_queue_head_t wq;// 存在就緒文件句柄的list,該list上的文件句柄事件將會全部上報給應用struct list_head rdllist;// 存放加入到此epoll句柄的文件句柄的紅黑樹容器struct rb_root rbr;// 該epoll結構對應的文件句柄,應用通過它來操作該epoll結構struct file *file; };

    2.為epoll句柄添加文件句柄,注冊睡眠entry的回調

    這個步驟中其實有兩個子步驟:
    1). 添加文件句柄
    將一個文件句柄,比如socket添加到epoll的rbr紅黑樹容器中,注意,這里的文件句柄最終也是一個包裝結構,和epoll的結構體類似:

    struct epitem {// 該字段鏈接入epoll句柄的紅黑樹容器struct rb_node rbn;// 當該文件句柄有事件發生時,該字段鏈接入“就緒鏈表”,準備上報給用戶態struct list_head rdllink;// 該字段封裝實際的文件,我已經將其展開struct epoll_filefd {struct file *file;int fd;} ffd;// 反向指向其所屬的epoll句柄struct eventpoll *ep; };

    以上結構實例就是epi,將被添加到epoll的rbr容器中的邏輯如下:

    struct eventpoll *ep = 待加入文件句柄所屬的epoll句柄; struct file *tfile = 待加入的文件句柄file結構體; int fd = 待加入的文件描述符ID;struct epitem *epi = kmem_cache_alloc(epi_cache, GFP_KERNEL); INIT_LIST_HEAD(&epi->rdllink); INIT_LIST_HEAD(&epi->fllink); INIT_LIST_HEAD(&epi->pwqlist); epi->ep = ep; ep_set_ffd(&epi->ffd, tfile, fd); ... ep_rbtree_insert(ep, epi);

    2). 注冊睡眠entry回調并poll文件句柄
    在第一個子步驟的代碼邏輯中,我有一段“…”省略掉了,這部分比較關鍵,所以我單獨抽取了出來作為第二個子步驟。
    我們知道,Linux內核的sleep/wakeup機制非常重要,幾乎貫穿了所有的內核子系統,值得注意的是,這里的sleep/wakeup依然采用了OO的思想,并沒有限制睡眠的entry一定要是一個task,而是將睡眠的entry做了一層抽象,即:

    struct __wait_queue {unsigned int flags;// 至于這個private到底是什么,內核并不限制,顯然,它可以是task,也可以是別的。void *private;wait_queue_func_t func;struct list_head task_list; };

    以上的這個entry,最終要睡眠在下面的數據結構實例化的一個鏈表上:

    struct __wait_queue_head {spinlock_t lock;struct list_head task_list; };

    顯然,在這里,一個文件句柄均有自己睡眠隊列用于等待自己發生事件的entry在沒有發生事件時來歇息,對于TCP socket而言,該睡眠隊列就是其sk_wq,通過以下方式取到:

    static inline wait_queue_head_t *sk_sleep(struct sock *sk) {return &rcu_dereference_raw(sk->sk_wq)->wait; }

    我們需要一個entry將來在發生事件的時候從上述wait_queue_head_t中被喚醒,執行特定的操作,即將自己放入到epoll句柄的“就緒鏈表”中。下面的函數可以完成該邏輯的框架:

    // 此處的whead就是上面例子中的sk_sleep返回的wait_queue_head_t實例。 static void ep_ptable_queue_proc(struct file *file, wait_queue_head_t *whead,poll_table *pt) {struct epitem *epi = ep_item_from_epqueue(pt);struct eppoll_entry *pwq;if (pwq = kmem_cache_alloc(pwq_cache, GFP_KERNEL)) {// 發生事件即調用ep_poll_callback回調函數,該回調函數會將自己這個epitem加入到epoll的“就緒鏈表”中去。init_waitqueue_func_entry(&pwq->wait, ep_poll_callback);// 是否排他喚醒取決于用戶的配置,有些IO是希望喚醒所有entry來處理,有些則不必。注意,這里是針對文件句柄IO而言的,并不是針對epoll句柄的。if (epi->event.events & EPOLLEXCLUSIVE)add_wait_queue_exclusive(whead, &pwq->wait);elseadd_wait_queue(whead, &pwq->wait);} }

    至于說什么時候調用上面的函數,Linux的poll機制仍然是采用了分層抽象的思想,即上述函數會作為另一個回調在相關文件句柄的poll函數中被調用。即:


    static inline unsigned int ep_item_poll(struct epitem *epi, poll_table *pt) {pt->_key = epi->event.events;return epi->ffd.file->f_op->poll(epi->ffd.file, pt) & epi->event.events; }

    對于TCP socket而言,其file_operations的poll回調即:

    unsigned int tcp_poll(struct file *file, struct socket *sock, poll_table *wait) {unsigned int mask;struct sock *sk = sock->sk;const struct tcp_sock *tp = tcp_sk(sk);// 此函數會調用poll_wait->wait._qproc// 而wait._qproc就是ep_ptable_queue_procsock_poll_wait(file, sk_sleep(sk), wait);... }

    現在,我們可以把子步驟1中的邏輯補全了:

    struct eventpoll *ep = 待加入文件句柄所屬的epoll句柄; struct file *tfile = 待加入的文件句柄file結構體; int fd = 待加入的文件描述符ID;struct epitem *epi = kmem_cache_alloc(epi_cache, GFP_KERNEL); INIT_LIST_HEAD(&epi->rdllink); INIT_LIST_HEAD(&epi->fllink); INIT_LIST_HEAD(&epi->pwqlist); epi->ep = ep; ep_set_ffd(&epi->ffd, tfile, fd); // 這里會將wait._qproc初始化成ep_ptable_queue_proc init_poll_funcptr(&epq.pt, ep_ptable_queue_proc); // 這里會調用wait._qproc即ep_ptable_queue_proc,安排entry的回調函數ep_poll_callback,并將entry“睡眠”在socket的sk_wq這個睡眠隊列上。 revents = ep_item_poll(epi, &epq.pt); ep_rbtree_insert(ep, epi); // 如果剛才的ep_item_poll取出了事件,隨即將該item掛入“就緒隊列”中,并且wakeup阻塞在epoll_wait系統調用中的task! if ((revents & event->events) && !ep_is_linked(&epi->rdllink)) {list_add_tail(&epi->rdllink, &ep->rdllist);if (waitqueue_active(&ep->wq))wake_up_locked(&ep->wq); }

    3.事件發生,喚醒相關文件句柄睡眠隊列的entry,調用其回調

    上面已經很詳細地描述了epoll的基礎設施了,現在我們假設一個TCP Listen socket上來了一個連接請求,已經完成了三次握手,內核希望通知epoll_wait返回,然后去取accept。
    內核在wakeup這個socket的sk_wq時,最終會調用到ep_poll_callback回調,這個函數我們說了好幾次了,現在看看它的真面目:

    static int ep_poll_callback(wait_queue_t *wait, unsigned mode, int sync, void *key) {unsigned long flags;struct epitem *epi = ep_item_from_wait(wait);struct eventpoll *ep = epi->ep;// 這個lock比較關鍵,操作“就緒鏈表”相關的,均需要這個lock,以防丟失事件。spin_lock_irqsave(&ep->lock, flags);// 如果發生的事件我們并不關注,則不處理直接返回即可。if (key && !((unsigned long) key & epi->event.events))goto out_unlock;// 實際將發生事件的epitem加入到“就緒鏈表”中。if (!ep_is_linked(&epi->rdllink)) {list_add_tail(&epi->rdllink, &ep->rdllist);}// 既然“就緒鏈表”中有了新成員,則喚醒阻塞在epoll_wait系統調用的task去處理。注意,如果本來epi已經在“就緒隊列”了,這里依然會喚醒并處理的。if (waitqueue_active(&ep->wq)) {wake_up_locked(&ep->wq);}out_unlock:spin_unlock_irqrestore(&ep->lock, flags);... }

    沒什么好多說的。現在“就緒鏈表”已經有epi了,接下來就要喚醒epoll_wait進程去處理了。

    4.喚醒epoll睡眠隊列的task,搜集并上報數據
    這個邏輯主要集中在ep_poll函數,精簡版如下:

    static int ep_poll(struct eventpoll *ep, struct epoll_event __user *events,int maxevents, long timeout) {unsigned long flags;wait_queue_t wait;// 當前沒有事件才睡眠if (!ep_events_available(ep)) {init_waitqueue_entry(&wait, current);__add_wait_queue_exclusive(&ep->wq, &wait);for (;;) {set_current_state(TASK_INTERRUPTIBLE);...// 例行的schedule timeout}__remove_wait_queue(&ep->wq, &wait);set_current_state(TASK_RUNNING);}// 往用戶態上報事件,即那些epoll_wait返回后能獲取的事件。ep_send_events(ep, events, maxevents); }

    其中關鍵在ep_send_events,這個函數實現了非常重要的邏輯,包括LT和ET的邏輯,我不打算深入去解析這個函數,只是大致說下流程:

    ep_scan_ready_list() {// 遍歷“就緒鏈表”ready_list_for_each() {// 將epi從“就緒鏈表”刪除list_del_init(&epi->rdllink);// 實際獲取具體的事件。// 注意,睡眠entry的回調函數只是通知有“事件”,具體需要每一個文件句柄的特定poll回調來獲取。revents = ep_item_poll(epi, &pt);if (revents) {if (__put_user(revents, &uevent->events) ||__put_user(epi->event.data, &uevent->data)) {// 如果沒有完成,則將epi重新加回“就緒鏈表”等待下次。list_add(&epi->rdllink, head);return eventcnt ? eventcnt : -EFAULT;}// 如果是LT模式,則無論如何都會將epi重新加回到“就緒鏈表”,等待下次重新再poll以確認是否仍然有未處理的事件。這也符合“水平觸發”的邏輯,即“只要你不處理,我就會一直通知你”。if (!(epi->event.events & EPOLLET)) {list_add_tail(&epi->rdllink, &ep->rdllist);}}}// 如果“就緒鏈表”上仍有未處理的epi,且有進程阻塞在epoll句柄的睡眠隊列,則喚醒它!(這將是LT驚群的根源)if (!list_empty(&ep->rdllist)) {if (waitqueue_active(&ep->wq))wake_up_locked(&ep->wq);} }

    這里的代碼邏輯的分析過程就到此為止了。以對這個代碼邏輯的充分理解為基礎,接下來我們就可以看具體的問題細節了。

    下面一小節先從LT(水平觸發模式)以及ET(即邊沿觸發模式)開始。

    epoll的LT和ET以及相關細節問題

    簡單點解釋:

    • LT水平觸發
      如果事件來了,不管來了幾個,只要仍然有未處理的事件,epoll都會通知你。
    • ET邊沿觸發
      如果事件來了,不管來了幾個,你若不處理或者沒有處理完,除非下一個事件到來,否則epoll將不會再通知你。

    理解了上面說的兩個模式,便可以很明確地展示可能會遇到的問題以及解決方案了,這將非常簡單。

    LT水平觸發模式的問題以及解決

    下面是epoll使用中非常常見的代碼框架,我將問題注釋于其中:

    // 否則會阻塞在IO系統調用,導致沒有機會再epoll set_socket_nonblocking(sd); epfd = epoll_create(64); event.data.fd = sd; epoll_ctl(epfd, EPOLL_CTL_ADD, sd, &event); while (1) {epoll_wait(epfd, events, 64, xx);... // 危險區域!如果有共享同一個epfd的進程/線程調用epoll_wait,它們也將會被喚醒!// 這個accept將會有多個進程/線程調用,如果并發請求數很少,那么將僅有幾個進程會成功:// 1. 假設accept隊列中有n個請求,則僅有n個進程能成功,其它將全部返回EAGAIN (Resource temporarily unavailable)// 2. 如果n很大(即增加請求負載),雖然返回EAGAIN的比率會降低,但這些進程也并不一定取到了epoll_wait返回當下的那個預期的請求。csd = accept(sd, &in_addr, &in_len); ... }

    這一切為什么會發生?

    我們結合理論和代碼一起來分析。

    再看一遍LT的描述“如果事件來了,不管來了幾個,只要仍然有未處理的事件,epoll都會通知你。”,顯然,epoll_wait剛剛取到事件的時候的時候,不可能馬上就調用accept去處理,事實上,邏輯在epoll_wait函數調用的ep_poll中還沒返回的,這個時候,顯然符合“仍然有未處理的事件”這個條件,顯然這個時候為了實現這個語義,需要做的就是通知別的同樣阻塞在同一個epoll句柄睡眠隊列上的進程!在實現上,這個語義由兩點來保證:

  • 保證1:在LT模式下,“就緒鏈表”上取出的epi上報完事件后會重新加回“就緒鏈表”;
  • 保證2:如果“就緒鏈表”不為空,且此時有進程阻塞在同一個epoll句柄的睡眠隊列上,則喚醒它。
  • ep_scan_ready_list() {// 遍歷“就緒鏈表”ready_list_for_each() {list_del_init(&epi->rdllink);revents = ep_item_poll(epi, &pt);// 保證1if (revents) {__put_user(revents, &uevent->events);if (!(epi->event.events & EPOLLET)) {list_add_tail(&epi->rdllink, &ep->rdllist);}}}// 保證2if (!list_empty(&ep->rdllist)) {if (waitqueue_active(&ep->wq))wake_up_locked(&ep->wq);} }

    我們來看一個情景分析。

    假設LT模式下有10個進程共享同一個epoll句柄,此時來了一個請求client進入到accept隊列,我們發現上述的1和2是一個循環喚醒的過程:

    1).假設進程a的epoll_wait首先被ep_poll_callback喚醒,那么滿足1和2,則喚醒了進程B;
    2).進程B在處理ep_scan_ready_list的時候,發現依然滿足1和2,于是喚醒了進程C….
    3).上面1)和2)的過程一直到之前某個進程將client取出,此時下一個被喚醒的進程在ep_scan_ready_list中的ep_item_poll調用中將得不到任何事件,此時便不會再將該epi加回“就緒鏈表”了,LT水平觸發結束,結束了這場悲傷的夢!

    問題非常明確了,但是怎么解決呢?也非常簡單,讓不同進程的epoll_waitI調用互斥即可。

    但是且慢!

    上面的情景分析所展示的是一個“驚群效應”嗎?其實并不是!對于Listen socket,當然要避免這種情景,但是對于很多其它的I/O文件句柄,說不定還指望著大家一起來read數據呢…所以說,要說互斥也僅僅要針對Listen socket的epoll_wait調用而言。

    換句話說,這里epoll LT模式下有進程被不必要喚醒,這一點并不是內核無意而為之的,內核肯定是知道這件事的,這個并不像之前accept驚群那樣算是內核的一個缺陷。epoll LT模式只是提供了一種模式,誤用這種模式將會造成類似驚群那樣的效應。但是不管怎么說,為了討論上的方便,后面我們姑且將這種效應稱作epoll LT驚群吧。

    除了epoll_wait互斥之外,還有一種解決問題的方案,即使用ET邊沿觸發模式,但是會遇到新的問題,我們接下來來描述。

    ET邊沿觸發模式的問題以及解決

    ET模式不滿足上述的“保證1”,所以不會將已經上報事件的epi重新鏈接回“就緒鏈表”,也就是說,只要一個“就緒隊列”上的epi上的事件被上報了,它就會被刪除出“就緒隊列”。

    由于epi entry的callback即ep_poll_callback所做的事情僅僅是將該epi自身加入到epoll句柄的“就緒鏈表”,同時喚醒在epoll句柄睡眠隊列上的task,所以這里并不對事件的細節進行計數,比如說,如果ep_poll_callback在將一個epi加入“就緒鏈表”之前發現它已經在“就緒鏈表”了,那么就不會再次添加,因此可以說,一個epi可能pending了多個事件,注意到這點非常重要!

    一個epi上pending多個事件,這個在LT模式下沒有任何問題,因為獲取事件的epi總是會被重新添加回“就緒鏈表”,那么如果還有事件,在下次check的時候總會取到。然而對于ET模式,僅僅將epi從“就緒鏈表”刪除并將事件本身上報后就返回了,因此如果該epi里還有事件,則只能等待再次發生事件,進而調用ep_poll_callback時將該epi加入“就緒隊列”。這意味著什么?

    這意味著,應用程序,即epoll_wait的調用進程必須自己在獲取事件后將其處理干凈后方可再次調用epoll_wait,否則epoll_wait不會返回,而是必須等到下次產生事件的時候方可返回。即,依然以accept為例,必須這樣做:

    // 否則會阻塞在IO系統調用,導致沒有機會再epoll set_socket_nonblocking(sd); epfd = epoll_create(64); event.data.fd = sd; // 添加ET標記 event.events |= EPOLLET; epoll_ctl(epfd, EPOLL_CTL_ADD, sd, &event); while (1) {epoll_wait(epfd, events, 64, xx);while ((csd = accept(sd, &in_addr, &in_len)) > 0) {do_something(...);} ... }

    好了,解釋完了。


    以上就是epoll的LT,ET相關的兩個問題和解決方案。接下來的一節,我將用一個小小的簡單Demo來重現上面描述的理論和代碼。

    測試demo

    是時候給出一個實際能run的代碼了:

    #include <stdlib.h> #include <stdio.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <sys/epoll.h> #include <netdb.h> #include <fcntl.h> #include <sys/wait.h> #include <time.h> #include <signal.h>#define COUNT 1int mode = 0; int slp = 0;int pid[COUNT] = {0}; int count = 0;void server(int epfd) {struct epoll_event *events;int num, i;struct timespec ts;events = calloc(64, sizeof(struct epoll_event));while (1) {int sd, csd;struct sockaddr in_addr;num = epoll_wait(epfd, events, 64, -1);if (num <= 0) {continue;}/*ts.tv_sec = 0;ts.tv_nsec = 1;if(nanosleep(&ts, NULL) != 0) {perror("nanosleep");exit(1);}*/// 用于測試ET模式下丟事件的情況if (slp) {sleep(slp);}sd = events[0].data.fd;socklen_t in_len = sizeof(in_addr);csd = accept(sd, &in_addr, &in_len);if (csd == -1) {// 打印這個說明中了epoll LT驚群的招了。printf("shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:%d\n", getpid()); continue;}// 本進程一共成功處理了多少個請求。count ++;printf("get client:%d\n", getpid()); close(csd);} }static void siguser_handler(int sig) {// 在主進程被Ctrl-C退出的時候,每一個子進程均要打印自己處理了多少個請求。printf("pid:%d count:%d\n", getpid(), count);exit(0); }static void sigint_handler(int sig) {int i = 0;// 給每一個子進程發信號,要求其打印自己處理了多少個請求。for (i = 0; i < COUNT; i++) {kill(pid[i], SIGUSR1);} }int main (int argc, char *argv[]) {int ret = 0;int listener;int c = 0;struct sockaddr_in saddr;int port;int status;int flags;int epfd;struct epoll_event event;if (argc < 4) {exit(1);}// 0為LT模式,1為ET模式mode = atoi(argv[1]);port = atoi(argv[2]);// 是否在處理accept之前耽擱一會兒,這個參數更容易重現問題slp = atoi(argv[3]);signal(SIGINT, sigint_handler);listener = socket(PF_INET, SOCK_STREAM, 0);saddr.sin_family = AF_INET;saddr.sin_port = htons(port);saddr.sin_addr.s_addr = INADDR_ANY;bind(listener, (struct sockaddr*)&saddr, sizeof(saddr));listen(listener, SOMAXCONN);flags = fcntl (listener, F_GETFL, 0);flags |= O_NONBLOCK;fcntl (listener, F_SETFL, flags);epfd = epoll_create(64);if (epfd == -1) {perror("epoll_create");abort();}event.data.fd = listener;event.events = EPOLLIN;if (mode == 1) {event.events |= EPOLLET;} else if (mode == 2) {event.events |= EPOLLONESHOT;} ret = epoll_ctl(epfd, EPOLL_CTL_ADD, listener, &event);if (ret == -1) {perror("epoll_ctl");abort();}for(c = 0; c < COUNT; c++) {int child;child = fork();if(child == 0) {// 安裝打印count值的信號處理函數signal(SIGUSR1, siguser_handler);server(epfd);}pid[c] = child;printf("server:%d pid:%d\n", c+1, child);}wait(&status);sleep(1000000);close (listener); }

    編譯之,為a.out。

    測試客戶端選用了簡單webbench,首先我們看一下LT水平觸發模式下的問題:

    [zhaoya@shit ~/test]$ sudo ./a.out 0 112 0 server:1 pid:9688 server:2 pid:9689 server:3 pid:9690 server:4 pid:9691 server:5 pid:9692 server:6 pid:9693 server:7 pid:9694 server:8 pid:9695 server:9 pid:9696 server:10 pid:9697

    另起一個終端運行webbench,并發10,測試5秒:

    [zhaoya@shit ~/test]$ webbench -c 10 -t 5 http://127.0.0.1:112/ Webbench - Simple Web Benchmark 1.5 Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software.Benchmarking: GET http://127.0.0.1:112/ 10 clients, running 5 sec.

    而a.out的終端有以下輸出:

    ... get client:9690 get client:9688 get client:9691 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:9693 get client:9692 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:9689 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:9697 get client:9691 get client:9696 get client:9690 get client:9690 get client:9695 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:9697 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:9689 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:9692 get client:9696 get client:9688 get client:9695 get client:9693 get client:9689 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:9691 get client:9695 get client:9691 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:9692 get client:9690 get client:9694 get client:9693 ...

    所有的“shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:”的行均是被epoll LT驚群不必要喚醒的進程打印的。

    接下來用ET模式運行:

    [zhaoya@shit ~/test]$ sudo ./a.out 1 112 0

    對應的輸出如下:

    ... get client:14462 get client:14462 get client:14464 get client:14464 get client:14462 get client:14462 get client:14467 get client:14469 get client:14468 get client:14468 get client:14464 get client:14467 get client:14467 get client:14469 get client:14469 get client:14469 get client:14464 get client:14464 get client:14466 get client:14466 get client:14469 get client:14469 ...

    沒有任何一行是shit,即沒有被不必要喚醒的驚群現象發生。

    以上兩個case確認了epoll LT模式的驚群效應是可以通過改用ET模式來解決的,接下來我們確認ET模式非循環處理會丟失事件

    用ET模式運行a.out,這時將slp參數設置為1,即在epoll_wait返回和實際accept之間耽擱1秒,這樣可以讓一個epi在被加入到“就緒鏈表”中之后,在其被實際accept處理之前,積累更多的未決事件,即未處理的請求,而我們實驗的目的則是,epoll ET會丟失這些事件。

    webbench的參數依然如故,a.out的輸出如下:

    [zhaoya@shit ~/test]$ sudo ./a.out 1 114 1 server:1 pid:31161 server:2 pid:31162 server:3 pid:31163 server:4 pid:31164 server:5 pid:31165 server:6 pid:31166 server:7 pid:31167 server:8 pid:31168 server:9 pid:31169 server:10 pid:31170 get client:31170 get client:31170 get client:31167 get client:31169 get client:31166 get client:31165 get client:31170 get client:31167 get client:31169 get client:31165 get client:31168 get client:31170 get client:31167 get client:31165 get client:31169 get client:31170 get client:31167 get client:31169 get client:31170 get client:31167 get client:31169^Cpid:31170 count:6 pid:31169 count:5 pid:31163 count:0 pid:31168 count:1 pid:31167 count:5 pid:31165 count:3 pid:31166 count:1 pid:31161 count:0 pid:31162 count:0 pid:31164 count:0 User defined signal 1

    同樣的webbench參數,僅僅處理了十幾個請求,可見大多數都丟掉了。如果我們用LT模式,同樣在sleep 1秒導致事件擠壓的情況下,是不是會多處理一些呢?我們的預期應該是肯定的,因為LT模式在事件被處理完之前,會一直促使epoll_wait返回繼續處理,那么讓我們試一下:

    [zhaoya@shit ~/test]$ sudo ./a.out 0 115 1 server:1 pid:363 server:2 pid:364 server:3 pid:365 server:4 pid:366 server:5 pid:367 server:6 pid:368 server:7 pid:369 server:8 pid:370 server:9 pid:371 server:10 pid:372 get client:372 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:371 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:365 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:366 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:363 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:367 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:369 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:364 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:368 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:370 get client:370 get client:364 get client:367 get client:368 get client:369 get client:365 get client:371 get client:372 get client:363 get client:366 get client:370 get client:367 get client:364 get client:369 get client:371 get client:368 get client:366 get client:363 get client:365 get client:372 get client:370 get client:367 get client:364 get client:371 get client:369 get client:366 get client:368 get client:363 get client:365 get client:372 get client:370 get client:367 get client:371 get client:364 get client:369 get client:366 get client:365 get client:368 get client:363 get client:372 get client:370 get client:364 get client:371 get client:367 get client:366 get client:369 get client:365 get client:363 get client:368 get client:372 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:371 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:370 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:364 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:367 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:366 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:369 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:365 shit xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx:363 ^Cpid:363 count:5 pid:368 count:5 pid:372 count:6 pid:369 count:5 pid:366 count:5 pid:370 count:5 pid:367 count:5 pid:371 count:5 pid:365 count:5 pid:364 count:5 User defined signal 1

    是的,多處理了很多,但是出現了LT驚群,這也是意料之中的事。

    最后,讓我們把這個Demo代碼小改一下,改成循環處理,依然采用ET模式,sleep 1秒,看看情況會怎樣。修改后的代碼如下:

    void server(int epfd) {struct epoll_event *events;int num, i;struct timespec ts;events = calloc(64, sizeof(struct epoll_event));while (1) {int sd, csd;struct sockaddr in_addr;num = epoll_wait(epfd, events, 64, -1);if (num <= 0) {continue;}if (slp)sleep(slp);sd = events[0].data.fd;socklen_t in_len = sizeof(in_addr);// 這里循環處理,一直到空。while ((csd = accept(sd, &in_addr, &in_len)) > 0) {count ++;printf("get client:%d\n", getpid());close(csd);}} }

    改完代碼后,再做同樣參數的測試,結果大大不同:

    [zhaoya@shit ~/test]$ sudo ./a.out 0 116 1 ... get client:3640 get client:3645 get client:3640 get client:3641 get client:3641 get client:3641 ^Cpid:3642 count:14 pid:3647 count:33531 pid:3646 count:21824 pid:3648 count:22 pid:3644 count:32219 pid:3645 count:94449 pid:3641 count:8 pid:3640 count:85385 pid:3643 count:13 pid:3639 count:10 User defined signal 1

    可以看到,大多數的請求都得到了處理,同樣的邏輯,epoll_wait返回后的循環讀和一次讀結果顯然不同。

    問題和解決方案都很明確了,可以結單了嗎?我想是的,但是在終結這個話題之前,我還想說一些結論性的東西以供備忘和參考。

    結論

    曾經,為了實現并發服務器,出現了很多的所謂范式,比如下面的兩個很常見:

    • 范式1:設置多個IP地址,多個IP地址同時偵聽相同的端口,前端用4層負載均衡或者反向代理來對這些IP地址進行請求分發;
    • 范式2:Master進程創建一個Listen socket,然后fork出來N個worker進程,這N個worker進程同時偵聽這個socket。

    第一個范式與本文講的epoll無關,更多的體現一種IP層的技術,這里不談,這里僅僅說一下第二個范式。


    為了保證元組的唯一性以及處理的一致性,很長時間以來對于服務器而言,是不允許bind同一個IP地址和端口對的。然而為了可以并發處理多個連接請求,則必須采用某種多處理的方式,為了多個進程可以同時偵聽同一個IP地址端口對,便出現了create listener+fork這種模型,具體來講就是:

    sd = create_listen_socket(); for (i = 0; i < N; i++) {if (fork() == 0) {// 繼承了父進程的文件描述符server(sd);} }

    然而這種模式僅僅是做到了進程級的可擴展性,即一個進程在忙時,其它進程可以介入幫忙處理,底層的socket句柄其實是同一個!簡單點說,這是一個沙漏模型:

    這種模型在處理同一個socket的時候,必須互斥,同時內核必須防止潛在的驚群效應,因為互斥的要求,有且僅有一個進程可以處理特定的請求。這就對編程造成了極大的干擾。

    以本文所描述的case為例,如果不清楚epoll LT模式和ET模式潛在的問題,那么就很容易誤用epoll導致比較令人頭疼的后果。

    非常幸運,reuseport出現后,模型徹底變成了桶狀:

    于是乎,使用了reuseport,一切都變得明朗了:

    • 不再依賴mem模型
    • 不再擔心驚群

    為什么reuseport沒有驚群?首先我們要知道驚群發生的原因,就是同時喚醒了多個進程處理一個事件,導致了不必要的CPU空轉。為什么會喚醒多個進程,因為發生事件的文件描述符在多個進程之間是共享的。而reuseport呢,偵聽同一個IP地址端口對的多個socket本身在socket層就是相互隔離的,在它們之間的事件分發是TCP/IP協議棧完成的,所以不會再有驚群發生。

    所以,結論是什么?

    結論就是全部統一采用reuseport的方式吧,徹底解決驚群問題。

    后記

    浙江溫州皮鞋濕!

    總結

    以上是生活随笔為你收集整理的再谈Linux epoll惊群问题的原因和解决方案的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    乱码av麻豆丝袜熟女系列 | 国产成人无码专区 | 澳门永久av免费网站 | 在线精品亚洲一区二区 | av在线亚洲欧洲日产一区二区 | 亚洲精品无码国产 | 欧美精品免费观看二区 | 一二三四社区在线中文视频 | 人人澡人人妻人人爽人人蜜桃 | 亚洲国产精品久久人人爱 | 亚洲成熟女人毛毛耸耸多 | 国产精品久久久久久久影院 | 国产美女极度色诱视频www | 欧美精品在线观看 | 嫩b人妻精品一区二区三区 | 麻花豆传媒剧国产免费mv在线 | 欧美丰满熟妇xxxx性ppx人交 | 99久久精品无码一区二区毛片 | 少妇性俱乐部纵欲狂欢电影 | 成人毛片一区二区 | 精品国产aⅴ无码一区二区 | 国产人妻精品午夜福利免费 | 极品尤物被啪到呻吟喷水 | 四十如虎的丰满熟妇啪啪 | 精品无码一区二区三区的天堂 | 国产无遮挡又黄又爽免费视频 | 国产激情综合五月久久 | 国产精品香蕉在线观看 | 学生妹亚洲一区二区 | 精品国产国产综合精品 | 小鲜肉自慰网站xnxx | 粗大的内捧猛烈进出视频 | 日日噜噜噜噜夜夜爽亚洲精品 | 成人综合网亚洲伊人 | 亚洲爆乳无码专区 | 熟妇人妻激情偷爽文 | ass日本丰满熟妇pics | 日本丰满熟妇videos | 欧美性猛交内射兽交老熟妇 | 国产精品亚洲综合色区韩国 | 亚洲中文字幕在线观看 | 丰满人妻精品国产99aⅴ | 久久精品中文字幕大胸 | 狂野欧美激情性xxxx | 国产国语老龄妇女a片 | 国产一区二区三区精品视频 | 天堂а√在线地址中文在线 | 久久国语露脸国产精品电影 | 精品亚洲韩国一区二区三区 | 亚洲一区二区观看播放 | 国产精品沙发午睡系列 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 西西人体www44rt大胆高清 | 亚洲s码欧洲m码国产av | 未满小14洗澡无码视频网站 | 国产特级毛片aaaaaaa高清 | 欧美自拍另类欧美综合图片区 | 无码人妻黑人中文字幕 | 久久人妻内射无码一区三区 | 国产两女互慰高潮视频在线观看 | 无码人妻出轨黑人中文字幕 | 成熟妇人a片免费看网站 | 天下第一社区视频www日本 | 18黄暴禁片在线观看 | a国产一区二区免费入口 | 亚洲中文字幕va福利 | 思思久久99热只有频精品66 | 妺妺窝人体色www婷婷 | 真人与拘做受免费视频一 | 精品熟女少妇av免费观看 | 国产亚洲欧美日韩亚洲中文色 | 奇米影视7777久久精品 | 男女爱爱好爽视频免费看 | 大肉大捧一进一出视频出来呀 | 免费人成在线观看网站 | 亚洲熟悉妇女xxx妇女av | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 熟妇人妻无码xxx视频 | 丰满人妻被黑人猛烈进入 | 小鲜肉自慰网站xnxx | 永久免费观看国产裸体美女 | 久久zyz资源站无码中文动漫 | 亚洲综合伊人久久大杳蕉 | 国产成人无码av一区二区 | 日本熟妇乱子伦xxxx | 99久久婷婷国产综合精品青草免费 | 国产乱人偷精品人妻a片 | 人人爽人人爽人人片av亚洲 | 国产在线无码精品电影网 | 久久精品国产99久久6动漫 | 又大又黄又粗又爽的免费视频 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲中文字幕乱码av波多ji | 国产农村妇女高潮大叫 | 国产精品久久久久久亚洲毛片 | 亚洲精品一区二区三区大桥未久 | 一本加勒比波多野结衣 | 精品国产aⅴ无码一区二区 | 精品无码av一区二区三区 | 欧美成人午夜精品久久久 | 国产熟妇高潮叫床视频播放 | 欧美日本免费一区二区三区 | 欧美激情内射喷水高潮 | 四虎影视成人永久免费观看视频 | 色老头在线一区二区三区 | 国产亚洲精品精品国产亚洲综合 | 国产麻豆精品一区二区三区v视界 | 18黄暴禁片在线观看 | 人人妻人人澡人人爽人人精品 | 一个人看的www免费视频在线观看 | 中文字幕+乱码+中文字幕一区 | 色综合久久久无码中文字幕 | 日韩精品无码一区二区中文字幕 | 荫蒂添的好舒服视频囗交 | 国产人妻久久精品二区三区老狼 | 亚洲乱码中文字幕在线 | 欧美 日韩 亚洲 在线 | 国产人妻大战黑人第1集 | 国产精品久久国产精品99 | aⅴ亚洲 日韩 色 图网站 播放 | 久久久久人妻一区精品色欧美 | 国产成人综合美国十次 | 亚洲熟妇色xxxxx欧美老妇 | 白嫩日本少妇做爰 | 国产精品香蕉在线观看 | 欧洲欧美人成视频在线 | 精品国产一区二区三区av 性色 | 日韩精品a片一区二区三区妖精 | 亚洲精品欧美二区三区中文字幕 | 中文无码成人免费视频在线观看 | av小次郎收藏 | 国产猛烈高潮尖叫视频免费 | 亚洲综合色区中文字幕 | 国产 浪潮av性色四虎 | 人妻互换免费中文字幕 | 国精产品一区二区三区 | 国产在线aaa片一区二区99 | 国产女主播喷水视频在线观看 | 日日摸夜夜摸狠狠摸婷婷 | 好男人www社区 | 午夜精品一区二区三区在线观看 | 性欧美熟妇videofreesex | 亚洲熟妇自偷自拍另类 | 中文字幕无码人妻少妇免费 | 特大黑人娇小亚洲女 | 国产一区二区三区影院 | 婷婷丁香六月激情综合啪 | 日韩少妇内射免费播放 | 亚洲无人区午夜福利码高清完整版 | 精品熟女少妇av免费观看 | 一二三四在线观看免费视频 | 少妇人妻大乳在线视频 | 久久午夜夜伦鲁鲁片无码免费 | 人人超人人超碰超国产 | 国产热a欧美热a在线视频 | 高潮毛片无遮挡高清免费视频 | 乱人伦中文视频在线观看 | 国产无套粉嫩白浆在线 | 又粗又大又硬又长又爽 | 男女猛烈xx00免费视频试看 | 欧美zoozzooz性欧美 | 精品国产麻豆免费人成网站 | 欧美老熟妇乱xxxxx | 日韩少妇白浆无码系列 | 国产人妻精品午夜福利免费 | 久久久中文字幕日本无吗 | 成人亚洲精品久久久久软件 | 亚洲成色在线综合网站 | 老司机亚洲精品影院 | 中国大陆精品视频xxxx | 亚洲精品久久久久avwww潮水 | aⅴ亚洲 日韩 色 图网站 播放 | 成人性做爰aaa片免费看 | 精品aⅴ一区二区三区 | 欧美性生交xxxxx久久久 | 蜜桃无码一区二区三区 | 老司机亚洲精品影院无码 | 色爱情人网站 | 中文字幕乱码亚洲无线三区 | 野狼第一精品社区 | 久久久久se色偷偷亚洲精品av | 欧美35页视频在线观看 | 夜夜高潮次次欢爽av女 | 狠狠色丁香久久婷婷综合五月 | 国产亚洲日韩欧美另类第八页 | 欧洲熟妇色 欧美 | 天天av天天av天天透 | 色 综合 欧美 亚洲 国产 | 性色欲情网站iwww九文堂 | 欧美熟妇另类久久久久久多毛 | 久久精品人妻少妇一区二区三区 | 高潮毛片无遮挡高清免费视频 | 两性色午夜免费视频 | 秋霞成人午夜鲁丝一区二区三区 | 精品厕所偷拍各类美女tp嘘嘘 | 亚洲色在线无码国产精品不卡 | 久久亚洲精品中文字幕无男同 | 香港三级日本三级妇三级 | 久热国产vs视频在线观看 | 好男人社区资源 | 欧洲美熟女乱又伦 | 国产精品久久久一区二区三区 | 一区二区三区乱码在线 | 欧洲 | 亚洲 a v无 码免 费 成 人 a v | 99久久人妻精品免费二区 | 18无码粉嫩小泬无套在线观看 | 国产在线精品一区二区三区直播 | 一本久道久久综合狠狠爱 | 日韩人妻系列无码专区 | 国产又粗又硬又大爽黄老大爷视 | 天堂亚洲2017在线观看 | 亚洲a无码综合a国产av中文 | 国产欧美精品一区二区三区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 人人妻人人澡人人爽欧美精品 | 高中生自慰www网站 | 亚洲熟妇自偷自拍另类 | 97久久国产亚洲精品超碰热 | 性欧美疯狂xxxxbbbb | 精品人妻av区 | 欧美猛少妇色xxxxx | 伊人久久大香线蕉av一区二区 | 伊人久久大香线蕉午夜 | 国产真实伦对白全集 | 欧美熟妇另类久久久久久不卡 | 国产两女互慰高潮视频在线观看 | 中文字幕人妻无码一夲道 | 成人亚洲精品久久久久 | av香港经典三级级 在线 | 亚洲性无码av中文字幕 | 成人无码精品1区2区3区免费看 | 一本久久a久久精品vr综合 | 人妻少妇被猛烈进入中文字幕 | 人人超人人超碰超国产 | 天天爽夜夜爽夜夜爽 | 99精品久久毛片a片 | 亚洲一区二区三区香蕉 | 九月婷婷人人澡人人添人人爽 | 国产乱人无码伦av在线a | 久久久国产一区二区三区 | 亚洲春色在线视频 | 久久久国产一区二区三区 | 亚无码乱人伦一区二区 | 亚洲国产一区二区三区在线观看 | 国产午夜精品一区二区三区嫩草 | 国产无套粉嫩白浆在线 | 正在播放老肥熟妇露脸 | 美女毛片一区二区三区四区 | 国产内射老熟女aaaa | 夫妻免费无码v看片 | 性史性农村dvd毛片 | 欧美人与物videos另类 | 丝袜足控一区二区三区 | 久久国产精品精品国产色婷婷 | 麻豆国产人妻欲求不满 | 亚洲色欲色欲天天天www | 少妇人妻av毛片在线看 | 国产精品久久精品三级 | 无码人妻出轨黑人中文字幕 | 国产精品久久国产精品99 | 久久zyz资源站无码中文动漫 | 亚洲自偷自偷在线制服 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲人成影院在线观看 | 任你躁国产自任一区二区三区 | 丰满岳乱妇在线观看中字无码 | 国产精品福利视频导航 | 疯狂三人交性欧美 | 色综合天天综合狠狠爱 | 精品厕所偷拍各类美女tp嘘嘘 | 国产精品a成v人在线播放 | 在线播放免费人成毛片乱码 | 亚洲精品国偷拍自产在线麻豆 | 呦交小u女精品视频 | 亚洲爆乳无码专区 | 日欧一片内射va在线影院 | 精品久久综合1区2区3区激情 | 国产婷婷色一区二区三区在线 | 日韩精品无码免费一区二区三区 | 激情亚洲一区国产精品 | 久久久久久国产精品无码下载 | 久久精品成人欧美大片 | 国产热a欧美热a在线视频 | 疯狂三人交性欧美 | 亚洲色www成人永久网址 | 欧美性生交xxxxx久久久 | 国产美女精品一区二区三区 | 精品人妻av区 | 欧美成人午夜精品久久久 | 精品久久综合1区2区3区激情 | 无码人妻丰满熟妇区毛片18 | 欧美乱妇无乱码大黄a片 | 亚洲色无码一区二区三区 | 国产精品久久久久久亚洲影视内衣 | 一本加勒比波多野结衣 | 狠狠色噜噜狠狠狠狠7777米奇 | 国精品人妻无码一区二区三区蜜柚 | 亚洲国产精品成人久久蜜臀 | 四虎影视成人永久免费观看视频 | 亚洲gv猛男gv无码男同 | 99在线 | 亚洲 | 丝袜美腿亚洲一区二区 | 国内精品人妻无码久久久影院 | 黑人巨大精品欧美一区二区 | 在线播放免费人成毛片乱码 | 欧美激情内射喷水高潮 | 亚洲国产成人a精品不卡在线 | 嫩b人妻精品一区二区三区 | 成人无码精品一区二区三区 | 色偷偷人人澡人人爽人人模 | 狠狠色丁香久久婷婷综合五月 | 精品无码一区二区三区的天堂 | 国产艳妇av在线观看果冻传媒 | 亚洲国产精品毛片av不卡在线 | 国内精品九九久久久精品 | 天堂一区人妻无码 | 人人妻人人澡人人爽欧美一区 | 亚洲中文字幕在线无码一区二区 | 日韩视频 中文字幕 视频一区 | 成熟妇人a片免费看网站 | 女高中生第一次破苞av | 无套内谢老熟女 | 久久精品中文闷骚内射 | 玩弄人妻少妇500系列视频 | 国产午夜福利亚洲第一 | 亚洲精品久久久久久久久久久 | 性色欲情网站iwww九文堂 | 欧美老熟妇乱xxxxx | 蜜臀av在线播放 久久综合激激的五月天 | 亚洲人成无码网www | 中文字幕久久久久人妻 | 国产在线aaa片一区二区99 | 熟女少妇在线视频播放 | 永久免费观看美女裸体的网站 | 国产无遮挡吃胸膜奶免费看 | 日本一区二区更新不卡 | 亚洲精品综合五月久久小说 | 国产激情艳情在线看视频 | 国产精品美女久久久 | 亚洲精品一区二区三区大桥未久 | 内射爽无广熟女亚洲 | 丰满妇女强制高潮18xxxx | 女人被男人躁得好爽免费视频 | 日韩 欧美 动漫 国产 制服 | 亚洲精品一区国产 | 麻豆精产国品 | yw尤物av无码国产在线观看 | 日本欧美一区二区三区乱码 | 国色天香社区在线视频 | 大色综合色综合网站 | 色窝窝无码一区二区三区色欲 | 国产三级精品三级男人的天堂 | 亚洲成av人片天堂网无码】 | 色婷婷综合中文久久一本 | 国产成人av免费观看 | 亚洲 日韩 欧美 成人 在线观看 | 欧美日韩综合一区二区三区 | 久久精品99久久香蕉国产色戒 | 亚洲色偷偷男人的天堂 | 色欲久久久天天天综合网精品 | a国产一区二区免费入口 | 搡女人真爽免费视频大全 | 久久 国产 尿 小便 嘘嘘 | 三上悠亚人妻中文字幕在线 | 国产suv精品一区二区五 | 狠狠色噜噜狠狠狠狠7777米奇 | 精品乱码久久久久久久 | 亚洲爆乳大丰满无码专区 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产绳艺sm调教室论坛 | 97久久超碰中文字幕 | 亚洲爆乳大丰满无码专区 | 国产特级毛片aaaaaa高潮流水 | 久久久久se色偷偷亚洲精品av | 性欧美牲交在线视频 | 久久国产精品偷任你爽任你 | 久久99精品久久久久久 | 国产精品久久久久久亚洲影视内衣 | 亚洲日韩av一区二区三区四区 | 欧美怡红院免费全部视频 | 日本乱人伦片中文三区 | 亚洲欧洲日本无在线码 | 国产精品人妻一区二区三区四 | 免费国产成人高清在线观看网站 | 成人精品视频一区二区 | 色窝窝无码一区二区三区色欲 | 国产亚洲tv在线观看 | 中文字幕无码热在线视频 | 日欧一片内射va在线影院 | 老熟妇仑乱视频一区二区 | 免费人成在线观看网站 | 精品久久久无码人妻字幂 | 亚洲成熟女人毛毛耸耸多 | 婷婷色婷婷开心五月四房播播 | 男女性色大片免费网站 | 国产亚洲tv在线观看 | 日韩欧美中文字幕公布 | 西西人体www44rt大胆高清 | 亚洲人成影院在线无码按摩店 | 国内少妇偷人精品视频免费 | 午夜福利试看120秒体验区 | 在线观看国产一区二区三区 | 日本爽爽爽爽爽爽在线观看免 | 激情综合激情五月俺也去 | 日本精品高清一区二区 | 午夜福利一区二区三区在线观看 | 99国产精品白浆在线观看免费 | 欧美日本精品一区二区三区 | 鲁鲁鲁爽爽爽在线视频观看 | 日本一区二区三区免费播放 | 亚洲第一无码av无码专区 | 国语自产偷拍精品视频偷 | 自拍偷自拍亚洲精品被多人伦好爽 | 色婷婷久久一区二区三区麻豆 | 日韩精品无码一本二本三本色 | 精品久久久久香蕉网 | 性欧美熟妇videofreesex | 久久无码中文字幕免费影院蜜桃 | 欧美野外疯狂做受xxxx高潮 | 午夜福利一区二区三区在线观看 | 国产极品视觉盛宴 | 亚洲人成人无码网www国产 | 国产成人精品久久亚洲高清不卡 | 精品无码av一区二区三区 | 波多野结衣高清一区二区三区 | 精品国产国产综合精品 | 欧美老妇交乱视频在线观看 | 精品偷拍一区二区三区在线看 | 中文字幕 亚洲精品 第1页 | 欧美午夜特黄aaaaaa片 | 日本xxxx色视频在线观看免费 | 少妇的肉体aa片免费 | 欧美亚洲日韩国产人成在线播放 | 性开放的女人aaa片 | 国产深夜福利视频在线 | 国产免费久久久久久无码 | 久久精品视频在线看15 | 西西人体www44rt大胆高清 | 最近免费中文字幕中文高清百度 | 噜噜噜亚洲色成人网站 | 日本www一道久久久免费榴莲 | ass日本丰满熟妇pics | 精品无码国产自产拍在线观看蜜 | 国产精品va在线观看无码 | 久久zyz资源站无码中文动漫 | 少妇愉情理伦片bd | 狠狠cao日日穞夜夜穞av | 乱码午夜-极国产极内射 | 国产亚洲精品久久久久久久 | 野狼第一精品社区 | 老熟妇乱子伦牲交视频 | 九九综合va免费看 | 日本熟妇人妻xxxxx人hd | 国产无遮挡又黄又爽又色 | 欧美成人免费全部网站 | 亚洲日韩av一区二区三区四区 | 国产网红无码精品视频 | 丰满人妻一区二区三区免费视频 | √天堂中文官网8在线 | 国产激情综合五月久久 | 亚洲呦女专区 | www国产亚洲精品久久久日本 | 中文字幕无码av波多野吉衣 | 国产精品免费大片 | 亚洲人成人无码网www国产 | 国产精品久久久久影院嫩草 | 麻豆成人精品国产免费 | 丰满少妇人妻久久久久久 | 日韩精品一区二区av在线 | 少妇一晚三次一区二区三区 | 色老头在线一区二区三区 | 最近中文2019字幕第二页 | 国产午夜手机精彩视频 | 一区二区三区高清视频一 | 国产在线精品一区二区三区直播 | 永久黄网站色视频免费直播 | 午夜性刺激在线视频免费 | 久久久久av无码免费网 | 中文无码成人免费视频在线观看 | 亚洲va欧美va天堂v国产综合 | 国产亚洲tv在线观看 | 日本护士毛茸茸高潮 | 精品无码国产自产拍在线观看蜜 | 国产成人综合色在线观看网站 | 精品国产国产综合精品 | 激情亚洲一区国产精品 | 99久久人妻精品免费二区 | 76少妇精品导航 | 麻花豆传媒剧国产免费mv在线 | 国产亚洲精品久久久久久大师 | 久久精品国产精品国产精品污 | 国産精品久久久久久久 | 国产亚洲视频中文字幕97精品 | 久久综合网欧美色妞网 | 鲁大师影院在线观看 | 一本一道久久综合久久 | 麻豆国产丝袜白领秘书在线观看 | 精品一区二区三区波多野结衣 | 亚洲精品午夜国产va久久成人 | 无码乱肉视频免费大全合集 | 日本熟妇人妻xxxxx人hd | 国产精品永久免费视频 | 无遮无挡爽爽免费视频 | 一本一道久久综合久久 | 久久国产自偷自偷免费一区调 | 日产精品99久久久久久 | 亚洲国产欧美在线成人 | 激情亚洲一区国产精品 | 18无码粉嫩小泬无套在线观看 | 久久精品视频在线看15 | 国产精品-区区久久久狼 | 牲欲强的熟妇农村老妇女视频 | 给我免费的视频在线观看 | 澳门永久av免费网站 | 色诱久久久久综合网ywww | 亚洲色欲久久久综合网东京热 | 久久久久亚洲精品中文字幕 | 日本熟妇人妻xxxxx人hd | 国産精品久久久久久久 | 无码国产色欲xxxxx视频 | 日韩欧美成人免费观看 | 欧美喷潮久久久xxxxx | 激情五月综合色婷婷一区二区 | 亚洲国精产品一二二线 | 狂野欧美性猛xxxx乱大交 | 久久人人爽人人人人片 | 久久精品女人天堂av免费观看 | 国产精品久久久久久亚洲毛片 | 国产国产精品人在线视 | 久久午夜无码鲁丝片午夜精品 | 欧美国产日韩久久mv | 香港三级日本三级妇三级 | 双乳奶水饱满少妇呻吟 | 国产午夜精品一区二区三区嫩草 | 熟女俱乐部五十路六十路av | 国产无av码在线观看 | 99精品国产综合久久久久五月天 | 97精品人妻一区二区三区香蕉 | 一本色道久久综合亚洲精品不卡 | 丰满少妇女裸体bbw | 亚洲人成人无码网www国产 | 日本又色又爽又黄的a片18禁 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 国产在线精品一区二区高清不卡 | 宝宝好涨水快流出来免费视频 | 欧美人与善在线com | 亚洲中文字幕乱码av波多ji | 兔费看少妇性l交大片免费 | 国产综合在线观看 | v一区无码内射国产 | 久久五月精品中文字幕 | 55夜色66夜色国产精品视频 | 荡女精品导航 | 亚洲精品成a人在线观看 | 伊在人天堂亚洲香蕉精品区 | 亚洲区小说区激情区图片区 | 国产成人久久精品流白浆 | 久久人人爽人人人人片 | 午夜福利一区二区三区在线观看 | 人妻少妇被猛烈进入中文字幕 | 狠狠色噜噜狠狠狠7777奇米 | 日日天干夜夜狠狠爱 | 性生交大片免费看l | 真人与拘做受免费视频一 | 国内精品一区二区三区不卡 | 无遮挡国产高潮视频免费观看 | 精品久久综合1区2区3区激情 | 国产精品亚洲专区无码不卡 | 久久国产精品_国产精品 | 亚洲aⅴ无码成人网站国产app | 岛国片人妻三上悠亚 | 4hu四虎永久在线观看 | 国产精品亚洲lv粉色 | 国产在线精品一区二区高清不卡 | 亚洲熟妇色xxxxx亚洲 | 亚洲日本在线电影 | 国产人妻精品午夜福利免费 | 日日天日日夜日日摸 | 亚洲精品成人av在线 | 欧美精品在线观看 | 青草视频在线播放 | 少妇无码吹潮 | 啦啦啦www在线观看免费视频 | 亚洲欧美日韩国产精品一区二区 | 无码一区二区三区在线观看 | 九九久久精品国产免费看小说 | 性欧美牲交在线视频 | 四虎影视成人永久免费观看视频 | 日日躁夜夜躁狠狠躁 | 伊人久久大香线焦av综合影院 | 国产成人无码av一区二区 | 日韩精品a片一区二区三区妖精 | 国产精品香蕉在线观看 | 欧美丰满熟妇xxxx性ppx人交 | 精品国产青草久久久久福利 | 国产精品久久久久9999小说 | 欧美肥老太牲交大战 | 大乳丰满人妻中文字幕日本 | 国产熟女一区二区三区四区五区 | 亚洲国产成人av在线观看 | 人人妻人人藻人人爽欧美一区 | 日韩精品无码一区二区中文字幕 | 色综合久久网 | 麻豆国产人妻欲求不满 | 人人妻人人澡人人爽欧美一区九九 | 亚洲国产高清在线观看视频 | 嫩b人妻精品一区二区三区 | 麻豆国产97在线 | 欧洲 | 人妻有码中文字幕在线 | 久久精品国产大片免费观看 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产一区二区三区日韩精品 | 影音先锋中文字幕无码 | 欧美性猛交xxxx富婆 | 无码人妻精品一区二区三区不卡 | 欧美性色19p | 波多野结衣一区二区三区av免费 | 国产精品无套呻吟在线 | 久久亚洲精品中文字幕无男同 | 欧美 日韩 人妻 高清 中文 | 伊在人天堂亚洲香蕉精品区 | 亚洲欧洲日本综合aⅴ在线 | 在线观看国产一区二区三区 | 色老头在线一区二区三区 | 中文字幕av伊人av无码av | 成人无码精品一区二区三区 | 久久zyz资源站无码中文动漫 | 福利一区二区三区视频在线观看 | 少妇被黑人到高潮喷出白浆 | 樱花草在线播放免费中文 | 国产精品自产拍在线观看 | 我要看www免费看插插视频 | 狠狠噜狠狠狠狠丁香五月 | 人人妻人人藻人人爽欧美一区 | 扒开双腿疯狂进出爽爽爽视频 | 亚洲日韩一区二区 | 欧美猛少妇色xxxxx | 中文字幕乱码人妻二区三区 | 久热国产vs视频在线观看 | 日本www一道久久久免费榴莲 | 国产在线无码精品电影网 | 亚洲成av人片天堂网无码】 | 亚洲狠狠婷婷综合久久 | 色婷婷久久一区二区三区麻豆 | 国产麻豆精品一区二区三区v视界 | 中文字幕av日韩精品一区二区 | www成人国产高清内射 | 国产成人精品无码播放 | 纯爱无遮挡h肉动漫在线播放 | 国产成人无码午夜视频在线观看 | 久久五月精品中文字幕 | 男女作爱免费网站 | 永久黄网站色视频免费直播 | 日日摸夜夜摸狠狠摸婷婷 | 精品 日韩 国产 欧美 视频 | 日本又色又爽又黄的a片18禁 | 精品国产一区二区三区四区在线看 | 日本欧美一区二区三区乱码 | 色婷婷av一区二区三区之红樱桃 | 97人妻精品一区二区三区 | 中文字幕无码免费久久9一区9 | 中文字幕av伊人av无码av | 国产区女主播在线观看 | 一本精品99久久精品77 | 亚洲成av人片天堂网无码】 | 日韩人妻无码中文字幕视频 | 爆乳一区二区三区无码 | 国产精品免费大片 | 国产超级va在线观看视频 | 女人被爽到呻吟gif动态图视看 | 男人的天堂av网站 | 麻豆国产人妻欲求不满 | 成人欧美一区二区三区黑人 | 无码精品人妻一区二区三区av | 在线天堂新版最新版在线8 | 日本www一道久久久免费榴莲 | 国产97人人超碰caoprom | 人妻无码αv中文字幕久久琪琪布 | 少妇被粗大的猛进出69影院 | 亚洲精品中文字幕乱码 | 少妇性l交大片欧洲热妇乱xxx | 久久久久久a亚洲欧洲av冫 | 少女韩国电视剧在线观看完整 | 最近免费中文字幕中文高清百度 | 国产人妻人伦精品1国产丝袜 | 在线视频网站www色 | 亚洲大尺度无码无码专区 | 国产精品沙发午睡系列 | 亚洲人交乣女bbw | 中文字幕无码热在线视频 | 久久精品视频在线看15 | 性做久久久久久久久 | 久久国产精品_国产精品 | 亚洲七七久久桃花影院 | 一个人免费观看的www视频 | 久久亚洲日韩精品一区二区三区 | 鲁一鲁av2019在线 | 在线精品亚洲一区二区 | 久久人人爽人人爽人人片ⅴ | 亚洲精品美女久久久久久久 | 国产区女主播在线观看 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 丰满人妻精品国产99aⅴ | 性啪啪chinese东北女人 | 国内揄拍国内精品少妇国语 | 欧美人与善在线com | 亚洲精品一区国产 | 日韩 欧美 动漫 国产 制服 | 99久久人妻精品免费一区 | 久久久久免费看成人影片 | 日韩精品无码免费一区二区三区 | 俺去俺来也在线www色官网 | 色婷婷av一区二区三区之红樱桃 | 伊人久久大香线焦av综合影院 | 99re在线播放 | 亚洲成a人片在线观看无码3d | 55夜色66夜色国产精品视频 | 亚洲精品一区二区三区婷婷月 | 丰满岳乱妇在线观看中字无码 | 久久久国产精品无码免费专区 | 好男人社区资源 | 无码人中文字幕 | 精品久久久久久亚洲精品 | 久久精品人人做人人综合试看 | 久久成人a毛片免费观看网站 | 妺妺窝人体色www在线小说 | 国产亚洲精品久久久久久久久动漫 | 亚洲国产av精品一区二区蜜芽 | 久久久久成人精品免费播放动漫 | 99精品视频在线观看免费 | 一本无码人妻在中文字幕免费 | 男人的天堂av网站 | 欧美真人作爱免费视频 | 午夜精品久久久内射近拍高清 | 中国女人内谢69xxxx | 丰满护士巨好爽好大乳 | 免费观看又污又黄的网站 | 国产精品美女久久久 | 中文精品久久久久人妻不卡 | 在线精品亚洲一区二区 | 精品无码一区二区三区爱欲 | 中文字幕无码av波多野吉衣 | 国产激情无码一区二区 | 国产亚洲视频中文字幕97精品 | av无码电影一区二区三区 | 67194成是人免费无码 | 欧美喷潮久久久xxxxx | 福利一区二区三区视频在线观看 | 天天燥日日燥 | 国产精品.xx视频.xxtv | 美女毛片一区二区三区四区 | 免费国产黄网站在线观看 | 亚洲 高清 成人 动漫 | 国产亚洲人成在线播放 | 亚洲性无码av中文字幕 | 无码播放一区二区三区 | 久久久精品人妻久久影视 | 国产成人精品一区二区在线小狼 | 日本乱人伦片中文三区 | 无码国产乱人伦偷精品视频 | 熟妇女人妻丰满少妇中文字幕 | 日日天日日夜日日摸 | 无码人妻出轨黑人中文字幕 | 四十如虎的丰满熟妇啪啪 | 亚洲日本在线电影 | 日韩av无码中文无码电影 | 亚洲精品综合一区二区三区在线 | 久久无码专区国产精品s | 亚洲精品中文字幕久久久久 | 精品人妻中文字幕有码在线 | 久久久精品欧美一区二区免费 | 真人与拘做受免费视频 | av香港经典三级级 在线 | 亚洲日韩av片在线观看 | 日日摸天天摸爽爽狠狠97 | 成在人线av无码免费 | 欧洲欧美人成视频在线 | 精品国产精品久久一区免费式 | 欧美喷潮久久久xxxxx | 亚洲人成网站免费播放 | 久久99精品久久久久婷婷 | 精品夜夜澡人妻无码av蜜桃 | 超碰97人人做人人爱少妇 | 欧美野外疯狂做受xxxx高潮 | 在线播放无码字幕亚洲 | 欧美老妇交乱视频在线观看 | 国产激情精品一区二区三区 | 日韩欧美成人免费观看 | 无码人妻久久一区二区三区不卡 | 奇米影视7777久久精品 | 亚洲 日韩 欧美 成人 在线观看 | 国产偷抇久久精品a片69 | 久久亚洲精品成人无码 | 三级4级全黄60分钟 | 日韩精品成人一区二区三区 | 久久综合狠狠综合久久综合88 | 免费人成在线视频无码 | 国产乱码精品一品二品 | 欧美人与禽zoz0性伦交 | 亚洲熟悉妇女xxx妇女av | www国产亚洲精品久久网站 | 2020久久超碰国产精品最新 | 婷婷综合久久中文字幕蜜桃三电影 | 精品一区二区三区无码免费视频 | 久久亚洲精品中文字幕无男同 | 色一情一乱一伦一区二区三欧美 | 无码精品人妻一区二区三区av | 国产精品手机免费 | 日日噜噜噜噜夜夜爽亚洲精品 | 亚洲成a人片在线观看无码3d | 国产精品怡红院永久免费 | 在线 国产 欧美 亚洲 天堂 | 欧美性生交活xxxxxdddd | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 久久亚洲中文字幕无码 | 女人被男人躁得好爽免费视频 | 久热国产vs视频在线观看 | 久久无码中文字幕免费影院蜜桃 | 国产综合色产在线精品 | 国产精品久久久久无码av色戒 | 亚洲区欧美区综合区自拍区 | 亚洲国产精品一区二区第一页 | 又色又爽又黄的美女裸体网站 | 亚洲国产成人av在线观看 | 亚洲成a人片在线观看无码 | 人人妻人人澡人人爽人人精品浪潮 | 久久久久久九九精品久 | 亚洲精品国产a久久久久久 | 国产内射老熟女aaaa | 露脸叫床粗话东北少妇 | 亚洲精品一区二区三区在线观看 | 久久精品成人欧美大片 | 99久久久无码国产精品免费 | 国产乱人伦av在线无码 | 我要看www免费看插插视频 | 久久精品人妻少妇一区二区三区 | 久久99精品久久久久久动态图 | 中文字幕日韩精品一区二区三区 | 精品夜夜澡人妻无码av蜜桃 | 东北女人啪啪对白 | 欧美亚洲国产一区二区三区 | 美女极度色诱视频国产 | 亚洲成a人片在线观看无码3d | 乱人伦人妻中文字幕无码久久网 | 亚洲欧洲无卡二区视頻 | 免费网站看v片在线18禁无码 | 亚洲gv猛男gv无码男同 | 少妇太爽了在线观看 | 四虎国产精品免费久久 | 东北女人啪啪对白 | 国产一区二区不卡老阿姨 | 精品国产成人一区二区三区 | 中文字幕无码日韩欧毛 | 国产绳艺sm调教室论坛 | 少妇一晚三次一区二区三区 | 在教室伦流澡到高潮hnp视频 | 夫妻免费无码v看片 | 999久久久国产精品消防器材 | 亚洲色在线无码国产精品不卡 | 成人一在线视频日韩国产 | 亚洲一区二区三区国产精华液 | 成年女人永久免费看片 | 精品一区二区三区无码免费视频 | 人妻尝试又大又粗久久 | 欧美xxxxx精品 | 丝袜足控一区二区三区 | 国产三级久久久精品麻豆三级 | 亚洲a无码综合a国产av中文 | 久久 国产 尿 小便 嘘嘘 | 在线观看国产一区二区三区 | 人人妻人人澡人人爽欧美一区 | 99久久久无码国产精品免费 | 日本乱偷人妻中文字幕 | 欧美老妇与禽交 | 国产精品第一国产精品 | 内射老妇bbwx0c0ck | 天天做天天爱天天爽综合网 | 大乳丰满人妻中文字幕日本 | 无码人妻丰满熟妇区毛片18 | 亚洲熟妇色xxxxx亚洲 | 精品夜夜澡人妻无码av蜜桃 | 色一情一乱一伦一区二区三欧美 | 亚洲爆乳精品无码一区二区三区 | 精品少妇爆乳无码av无码专区 | 国产超级va在线观看视频 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 欧美刺激性大交 | 精品人妻中文字幕有码在线 | 伊人久久大香线焦av综合影院 | 午夜福利试看120秒体验区 | 亚洲色无码一区二区三区 | 欧美 日韩 人妻 高清 中文 | 夜先锋av资源网站 | 中文字幕无码日韩欧毛 | 国产精品嫩草久久久久 | 日本精品高清一区二区 | 内射白嫩少妇超碰 | 亚洲中文字幕在线无码一区二区 | 亚洲精品无码人妻无码 | 亚洲精品成a人在线观看 | 亚洲成av人综合在线观看 | 欧美精品无码一区二区三区 | 国产人成高清在线视频99最全资源 | 人妻少妇精品视频专区 | 国产性生大片免费观看性 | 欧美肥老太牲交大战 | 四虎国产精品一区二区 | 真人与拘做受免费视频 | 18禁止看的免费污网站 | 无码人妻黑人中文字幕 | 日日躁夜夜躁狠狠躁 | 久久精品中文字幕一区 | 丝袜足控一区二区三区 | 亚洲一区av无码专区在线观看 | 国产午夜亚洲精品不卡下载 | 300部国产真实乱 | 成人试看120秒体验区 | 久久99热只有频精品8 | 少女韩国电视剧在线观看完整 | www国产亚洲精品久久久日本 | 日产精品99久久久久久 | 精品无人区无码乱码毛片国产 | 欧美喷潮久久久xxxxx | 日日鲁鲁鲁夜夜爽爽狠狠 | 成人精品一区二区三区中文字幕 | 强伦人妻一区二区三区视频18 | 无码精品人妻一区二区三区av | 亚洲区欧美区综合区自拍区 | 国产人成高清在线视频99最全资源 | 国产偷自视频区视频 | 国产精品亚洲а∨无码播放麻豆 | 99久久人妻精品免费一区 | 少妇久久久久久人妻无码 | 国产综合在线观看 | 亚洲日韩一区二区三区 | 久久久久免费看成人影片 | 东京热男人av天堂 | 老司机亚洲精品影院无码 | 丰满人妻翻云覆雨呻吟视频 | 久久综合狠狠综合久久综合88 | 欧美日本免费一区二区三区 | 欧美日韩在线亚洲综合国产人 | 国产后入清纯学生妹 | 久久久久人妻一区精品色欧美 | 亚洲成a人片在线观看无码 | 亚洲色成人中文字幕网站 | 少妇高潮喷潮久久久影院 | 99视频精品全部免费免费观看 | 无人区乱码一区二区三区 | 久久综合激激的五月天 | 东京一本一道一二三区 | 久久综合给久久狠狠97色 | 日本肉体xxxx裸交 | 国产成人人人97超碰超爽8 | 中文字幕人成乱码熟女app | 无遮无挡爽爽免费视频 | 大肉大捧一进一出好爽视频 | 日本又色又爽又黄的a片18禁 | 亚洲a无码综合a国产av中文 | aⅴ亚洲 日韩 色 图网站 播放 | 性史性农村dvd毛片 | 免费视频欧美无人区码 | 色综合久久久无码中文字幕 | 国产亚洲视频中文字幕97精品 | 亚洲欧美国产精品专区久久 | 色婷婷综合中文久久一本 | 99久久99久久免费精品蜜桃 | 国产色xx群视频射精 | 黑人粗大猛烈进出高潮视频 | 任你躁国产自任一区二区三区 | 在线观看国产午夜福利片 | 日韩精品久久久肉伦网站 | 亚洲日韩一区二区三区 | 欧美老人巨大xxxx做受 | 国产精品a成v人在线播放 | 精品aⅴ一区二区三区 | 久久国内精品自在自线 | 久久婷婷五月综合色国产香蕉 | 亚洲中文字幕无码中字 | 国产精品久久国产三级国 | 人妻无码久久精品人妻 | 国产片av国语在线观看 | 午夜男女很黄的视频 | 好爽又高潮了毛片免费下载 | 免费男性肉肉影院 | 精品国精品国产自在久国产87 | 欧美人与物videos另类 | 婷婷五月综合激情中文字幕 | 亚洲小说图区综合在线 | 精品国产av色一区二区深夜久久 | 无码午夜成人1000部免费视频 | 男女性色大片免费网站 | 激情亚洲一区国产精品 | 中文字幕色婷婷在线视频 | 日韩无套无码精品 | 亚洲国产精品无码一区二区三区 | 乱人伦中文视频在线观看 | 久久久久se色偷偷亚洲精品av | 亚洲国产精品一区二区美利坚 | 九一九色国产 | 亚洲 a v无 码免 费 成 人 a v | 国产办公室秘书无码精品99 | 午夜精品久久久久久久 | 亚洲乱亚洲乱妇50p | 国产成人无码av在线影院 | 人妻插b视频一区二区三区 | 99久久无码一区人妻 | 国产综合色产在线精品 | 欧美丰满熟妇xxxx性ppx人交 | 久久久久成人精品免费播放动漫 | 无码人妻丰满熟妇区毛片18 | 国产午夜无码视频在线观看 | 亚洲 欧美 激情 小说 另类 | 丁香花在线影院观看在线播放 | 日韩av无码中文无码电影 | 2020久久香蕉国产线看观看 | 天天拍夜夜添久久精品 | 4hu四虎永久在线观看 | 亚洲精品一区二区三区大桥未久 | 丰满少妇弄高潮了www | 久久午夜无码鲁丝片 | 精品亚洲韩国一区二区三区 | 久久99热只有频精品8 | 国产性生交xxxxx无码 | 人人妻人人藻人人爽欧美一区 | 永久免费观看美女裸体的网站 | 国产精品成人av在线观看 | 色欲av亚洲一区无码少妇 | а√天堂www在线天堂小说 | 亚洲色在线无码国产精品不卡 | 自拍偷自拍亚洲精品10p | 亚洲一区二区三区在线观看网站 | 人妻尝试又大又粗久久 | 无码人妻黑人中文字幕 | 色偷偷人人澡人人爽人人模 | 国产精品a成v人在线播放 | 一个人看的www免费视频在线观看 | 国产午夜无码视频在线观看 | 欧美人与动性行为视频 | 少女韩国电视剧在线观看完整 | 国产精品久久久久影院嫩草 | 国产凸凹视频一区二区 | 色欲久久久天天天综合网精品 | 天堂а√在线中文在线 | 最新国产麻豆aⅴ精品无码 | 最新版天堂资源中文官网 | 色综合久久久久综合一本到桃花网 | 粗大的内捧猛烈进出视频 | 久久精品国产一区二区三区肥胖 | 久久zyz资源站无码中文动漫 | 人人妻人人澡人人爽欧美一区 | 图片区 小说区 区 亚洲五月 | 国产熟妇高潮叫床视频播放 | 无码精品人妻一区二区三区av | 亚洲精品综合一区二区三区在线 | 强开小婷嫩苞又嫩又紧视频 | 国产成人人人97超碰超爽8 | 女人被男人爽到呻吟的视频 | 无码人妻久久一区二区三区不卡 | 久久国产精品二国产精品 | 天天摸天天碰天天添 | 亚洲精品成a人在线观看 | 久久综合色之久久综合 | 免费播放一区二区三区 | 国产成人无码av一区二区 | 国产深夜福利视频在线 | 老太婆性杂交欧美肥老太 | 久久精品国产一区二区三区 | 麻豆md0077饥渴少妇 | 亚洲成av人片在线观看无码不卡 | 国产suv精品一区二区五 | 老头边吃奶边弄进去呻吟 | 鲁大师影院在线观看 | 人妻有码中文字幕在线 | 性生交片免费无码看人 | 久久精品国产一区二区三区 | 久久久久免费看成人影片 | 欧美亚洲日韩国产人成在线播放 | 少妇高潮喷潮久久久影院 | 亚洲日韩中文字幕在线播放 | 色婷婷av一区二区三区之红樱桃 | 人人爽人人爽人人片av亚洲 | 奇米影视7777久久精品 | 激情爆乳一区二区三区 | 99在线 | 亚洲 | 熟妇人妻无码xxx视频 | 精品无码av一区二区三区 | 四虎4hu永久免费 | 久久国内精品自在自线 | 国产精品久久久久无码av色戒 | 国产婷婷色一区二区三区在线 | 久久99精品国产麻豆蜜芽 | 精品午夜福利在线观看 | 久久精品人人做人人综合 | 好屌草这里只有精品 | 国产内射老熟女aaaa | 麻花豆传媒剧国产免费mv在线 | 少妇人妻大乳在线视频 | 99久久久国产精品无码免费 | 高中生自慰www网站 | 亚洲狠狠婷婷综合久久 | 一区二区传媒有限公司 | 国产一区二区三区影院 | 国内精品人妻无码久久久影院 | 亚洲午夜无码久久 | 精品厕所偷拍各类美女tp嘘嘘 | 久久无码专区国产精品s | 国产艳妇av在线观看果冻传媒 | 人人妻人人澡人人爽欧美一区 | 日本乱人伦片中文三区 | 精品无码国产自产拍在线观看蜜 | 影音先锋中文字幕无码 | 国产熟妇另类久久久久 | 狠狠亚洲超碰狼人久久 | 天堂亚洲免费视频 | 日日橹狠狠爱欧美视频 | 国产精品无码永久免费888 | 日韩精品无码一本二本三本色 | 图片区 小说区 区 亚洲五月 | 纯爱无遮挡h肉动漫在线播放 | 久久久久久久女国产乱让韩 | 欧美兽交xxxx×视频 | 最近的中文字幕在线看视频 | 亚洲va中文字幕无码久久不卡 | 亚洲精品国产精品乱码视色 | 亚洲精品午夜国产va久久成人 | 午夜精品久久久内射近拍高清 | 国产成人午夜福利在线播放 | 日本一区二区更新不卡 | 国产人妻久久精品二区三区老狼 | 成人欧美一区二区三区黑人 | 欧美三级不卡在线观看 | 久久久中文字幕日本无吗 | 国产无av码在线观看 | 国产精品无套呻吟在线 | 国产成人无码午夜视频在线观看 | 欧美自拍另类欧美综合图片区 | 国产麻豆精品一区二区三区v视界 | 久久综合网欧美色妞网 | 亚洲中文字幕av在天堂 | 免费播放一区二区三区 | 特大黑人娇小亚洲女 | 99久久婷婷国产综合精品青草免费 | 久久综合网欧美色妞网 | 超碰97人人射妻 | 日本大香伊一区二区三区 | 日韩亚洲欧美中文高清在线 | 东京热无码av男人的天堂 | 人妻少妇精品无码专区二区 | 国产午夜视频在线观看 | av香港经典三级级 在线 | 国产麻豆精品精东影业av网站 | 国产成人精品久久亚洲高清不卡 | 蜜桃av抽搐高潮一区二区 | 国产免费久久久久久无码 | 久久精品国产亚洲精品 | 日韩欧美成人免费观看 | 国产精品久久久久久亚洲影视内衣 | 乱码av麻豆丝袜熟女系列 | 男女作爱免费网站 | 帮老师解开蕾丝奶罩吸乳网站 | 老太婆性杂交欧美肥老太 | 亚洲欧洲日本综合aⅴ在线 | 国产亚洲人成a在线v网站 | 精品日本一区二区三区在线观看 | 一本久久伊人热热精品中文字幕 | 亚洲毛片av日韩av无码 | 波多野结衣av一区二区全免费观看 | 99久久久无码国产精品免费 | 国产精品igao视频网 | 亚洲欧洲日本无在线码 | 久久久久免费看成人影片 | 国产农村乱对白刺激视频 | 久久无码中文字幕免费影院蜜桃 | a片在线免费观看 | 国产亚洲精品久久久久久久 | 中文字幕久久久久人妻 | 久久99国产综合精品 | 亚洲aⅴ无码成人网站国产app | 国产精品亚洲lv粉色 | 中文字幕乱妇无码av在线 | 中文字幕乱码人妻无码久久 | 日韩精品无码免费一区二区三区 | 三上悠亚人妻中文字幕在线 | 77777熟女视频在线观看 а天堂中文在线官网 | 亚洲s码欧洲m码国产av | 天天躁日日躁狠狠躁免费麻豆 | 久精品国产欧美亚洲色aⅴ大片 | 亚洲第一网站男人都懂 | 国产农村妇女高潮大叫 | 国产成人无码av一区二区 | 亚洲精品鲁一鲁一区二区三区 | 丰满肥臀大屁股熟妇激情视频 | 午夜理论片yy44880影院 | v一区无码内射国产 | 国产精品久久精品三级 | 东京热无码av男人的天堂 | 四虎永久在线精品免费网址 | 97精品人妻一区二区三区香蕉 | 国产两女互慰高潮视频在线观看 | 日韩亚洲欧美精品综合 | 国产午夜精品一区二区三区嫩草 | 伊人久久婷婷五月综合97色 | 无码一区二区三区在线 | 中文字幕无码热在线视频 | 蜜桃视频韩日免费播放 | 亚洲中文字幕无码中文字在线 | 亚洲精品成人av在线 | 黑人玩弄人妻中文在线 | 亚洲国产精品一区二区第一页 | 国产熟妇另类久久久久 | 国产亚洲精品精品国产亚洲综合 | 午夜精品久久久久久久久 | 奇米影视7777久久精品 | 无遮无挡爽爽免费视频 | 日韩精品乱码av一区二区 | 日韩少妇白浆无码系列 | 一二三四在线观看免费视频 | 18黄暴禁片在线观看 | 亚洲欧美精品伊人久久 | 曰本女人与公拘交酡免费视频 | a在线观看免费网站大全 | 无码一区二区三区在线观看 | 无码人妻久久一区二区三区不卡 | 国产特级毛片aaaaaa高潮流水 | 女高中生第一次破苞av | 性欧美videos高清精品 | 中文字幕中文有码在线 | 久久精品国产亚洲精品 | 青草青草久热国产精品 | 少妇高潮一区二区三区99 | 欧美日韩视频无码一区二区三 | 国产人妻人伦精品1国产丝袜 | 国内揄拍国内精品少妇国语 | 偷窥村妇洗澡毛毛多 | 娇妻被黑人粗大高潮白浆 | 亚洲色欲久久久综合网东京热 | 国产69精品久久久久app下载 | 亚洲精品午夜国产va久久成人 | 国内精品九九久久久精品 | 久久久久成人精品免费播放动漫 | 性生交大片免费看l | 亚洲精品一区二区三区四区五区 | 国产 浪潮av性色四虎 | 丰满岳乱妇在线观看中字无码 | 亚洲国产欧美在线成人 | 18精品久久久无码午夜福利 | 免费国产黄网站在线观看 | 一本无码人妻在中文字幕免费 | 又色又爽又黄的美女裸体网站 | 强伦人妻一区二区三区视频18 | 初尝人妻少妇中文字幕 | 国产成人一区二区三区在线观看 | 三上悠亚人妻中文字幕在线 | 亚洲伊人久久精品影院 | 妺妺窝人体色www婷婷 | 成人动漫在线观看 | 亚洲精品久久久久avwww潮水 | 国产精品无码永久免费888 | 日韩少妇内射免费播放 | 亚洲大尺度无码无码专区 | 亚洲国产精品美女久久久久 | 300部国产真实乱 | 国产成人综合在线女婷五月99播放 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 亚洲精品一区二区三区婷婷月 | 久久精品国产精品国产精品污 | 久久国产精品精品国产色婷婷 | 国产精品久久久久久久9999 | 亚洲中文字幕在线无码一区二区 | 色情久久久av熟女人妻网站 | 成人无码影片精品久久久 | 国产精品久久久久久久9999 | 日日干夜夜干 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲一区二区三区在线观看网站 | 国产精品美女久久久久av爽李琼 | 日韩精品无码一本二本三本色 | 国产精品鲁鲁鲁 | 午夜精品久久久久久久 | 国产成人无码av片在线观看不卡 | 国产成人无码av在线影院 | 国产九九九九九九九a片 | 日韩 欧美 动漫 国产 制服 | 亚洲中文字幕无码一久久区 | 国产成人综合在线女婷五月99播放 | 天天综合网天天综合色 | 亚洲熟悉妇女xxx妇女av | 国产激情艳情在线看视频 | 人人妻人人澡人人爽欧美一区 | av人摸人人人澡人人超碰下载 | 亚洲精品国偷拍自产在线观看蜜桃 | 天天拍夜夜添久久精品 | 成人片黄网站色大片免费观看 | 麻豆国产人妻欲求不满谁演的 | 国产av人人夜夜澡人人爽麻豆 | 55夜色66夜色国产精品视频 | 精品aⅴ一区二区三区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 夜夜夜高潮夜夜爽夜夜爰爰 | 亚洲综合另类小说色区 | 天堂在线观看www | 性欧美videos高清精品 | 伊人久久大香线蕉av一区二区 | 日本一区二区三区免费高清 | 亚洲精品美女久久久久久久 | 2019nv天堂香蕉在线观看 | 日韩精品无码一区二区中文字幕 | 国产女主播喷水视频在线观看 | 久久国内精品自在自线 | 国产欧美亚洲精品a | 人妻少妇被猛烈进入中文字幕 | 人妻少妇被猛烈进入中文字幕 | 国产亚洲日韩欧美另类第八页 | 国产在线aaa片一区二区99 | 四虎永久在线精品免费网址 | 日韩人妻无码一区二区三区久久99 | 美女张开腿让人桶 | 色狠狠av一区二区三区 | 国产情侣作爱视频免费观看 | 日韩精品久久久肉伦网站 | 精品乱码久久久久久久 | 国产熟妇高潮叫床视频播放 | 一个人免费观看的www视频 | 日韩av无码中文无码电影 | 欧美老人巨大xxxx做受 | 六十路熟妇乱子伦 | 极品尤物被啪到呻吟喷水 | 中文字幕 人妻熟女 | 骚片av蜜桃精品一区 | 熟妇女人妻丰满少妇中文字幕 | 欧美丰满老熟妇xxxxx性 | 中文字幕亚洲情99在线 | 九九在线中文字幕无码 | 99久久久无码国产aaa精品 | 色综合天天综合狠狠爱 | 亚洲熟妇自偷自拍另类 | 55夜色66夜色国产精品视频 | 牲欲强的熟妇农村老妇女视频 | 中文字幕乱码亚洲无线三区 | 人人澡人人透人人爽 | 成年女人永久免费看片 | 亚洲成在人网站无码天堂 | 精品国产一区二区三区四区 | 精品无人区无码乱码毛片国产 | 久精品国产欧美亚洲色aⅴ大片 | 日本高清一区免费中文视频 | 亚洲狠狠色丁香婷婷综合 | 精品国产成人一区二区三区 | 国产激情一区二区三区 | 在线精品亚洲一区二区 | 国产亚洲精品久久久久久大师 | 性开放的女人aaa片 | 97久久国产亚洲精品超碰热 | 国产成人无码av片在线观看不卡 | 永久免费观看国产裸体美女 | 国产成人一区二区三区别 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 无码国产乱人伦偷精品视频 | 性做久久久久久久久 | 欧美日韩精品 | 国产成人无码区免费内射一片色欲 | 婷婷五月综合激情中文字幕 | 久久国产精品精品国产色婷婷 | 老熟妇仑乱视频一区二区 | 99久久99久久免费精品蜜桃 | 九月婷婷人人澡人人添人人爽 | 成 人 免费观看网站 | 国产亚洲精品久久久闺蜜 | 狂野欧美性猛交免费视频 | 一区二区三区高清视频一 | 国产在线aaa片一区二区99 | 亚洲日韩一区二区三区 | 久久久国产精品无码免费专区 | 欧美日本免费一区二区三区 | 2020最新国产自产精品 | 久久精品99久久香蕉国产色戒 | 玩弄少妇高潮ⅹxxxyw | 日日噜噜噜噜夜夜爽亚洲精品 | 欧美日本精品一区二区三区 | 日本大乳高潮视频在线观看 | 欧美日本精品一区二区三区 | 又大又紧又粉嫩18p少妇 | 熟女少妇在线视频播放 | 男女爱爱好爽视频免费看 | 俺去俺来也在线www色官网 | 精品国产福利一区二区 | 亚洲色偷偷偷综合网 | 国产精品久久久久7777 | 精品偷自拍另类在线观看 | 亚洲人成网站在线播放942 | 丰满少妇女裸体bbw | 欧美 日韩 人妻 高清 中文 | 欧美老妇交乱视频在线观看 | 图片小说视频一区二区 | 日产精品高潮呻吟av久久 | 乱码av麻豆丝袜熟女系列 | 中文字幕乱码中文乱码51精品 | 久热国产vs视频在线观看 | 亚洲成av人片天堂网无码】 | 日本xxxx色视频在线观看免费 | 国产偷抇久久精品a片69 | 99国产精品白浆在线观看免费 | 亚洲国产精品成人久久蜜臀 | av人摸人人人澡人人超碰下载 | 人妻少妇精品无码专区动漫 | a在线亚洲男人的天堂 | 国产精品久久国产三级国 | 1000部夫妻午夜免费 | 奇米影视7777久久精品人人爽 | 国精品人妻无码一区二区三区蜜柚 | 欧美日韩色另类综合 | 色 综合 欧美 亚洲 国产 | 亚洲va中文字幕无码久久不卡 | 无码国内精品人妻少妇 | 丝袜美腿亚洲一区二区 | 国产精品久久国产精品99 | 国产av久久久久精东av | 国内精品九九久久久精品 | 国产手机在线αⅴ片无码观看 | 人人爽人人澡人人人妻 | 中文字幕久久久久人妻 | 日韩av无码一区二区三区不卡 | 97夜夜澡人人双人人人喊 | 亚洲精品鲁一鲁一区二区三区 | 蜜臀aⅴ国产精品久久久国产老师 | 国产小呦泬泬99精品 | 麻豆蜜桃av蜜臀av色欲av | 国产激情无码一区二区 | 久久久久久久女国产乱让韩 | 国产亚洲精品久久久久久 | 98国产精品综合一区二区三区 | 熟女少妇人妻中文字幕 | 中文无码精品a∨在线观看不卡 | 亚洲一区av无码专区在线观看 | 成人无码视频免费播放 | 中国女人内谢69xxxxxa片 | 国产熟妇高潮叫床视频播放 | 无套内谢的新婚少妇国语播放 | 一本久久伊人热热精品中文字幕 | 欧美国产亚洲日韩在线二区 | 沈阳熟女露脸对白视频 | 亚洲色成人中文字幕网站 | 中文字幕日产无线码一区 | 日日摸日日碰夜夜爽av | 色五月丁香五月综合五月 | 亚洲热妇无码av在线播放 | 亚洲va中文字幕无码久久不卡 | 欧美日韩一区二区三区自拍 | 久久这里只有精品视频9 | 久久久精品成人免费观看 | 欧美阿v高清资源不卡在线播放 | 夜先锋av资源网站 | 人妻aⅴ无码一区二区三区 | 国产精品久久久久7777 | 久久无码专区国产精品s | 狠狠色色综合网站 | 国产成人一区二区三区别 | 亚洲日韩中文字幕在线播放 | 色狠狠av一区二区三区 | 亚洲无人区午夜福利码高清完整版 | 东京热无码av男人的天堂 | 色婷婷香蕉在线一区二区 | 无码av中文字幕免费放 | 日韩精品久久久肉伦网站 | 丰满少妇弄高潮了www | 亚洲爆乳无码专区 | 久9re热视频这里只有精品 | 国产免费久久久久久无码 | 国产精品久久久久久亚洲毛片 | 国产无遮挡又黄又爽免费视频 | 无码国产激情在线观看 | 日韩欧美成人免费观看 | 无码人妻av免费一区二区三区 | 99久久精品午夜一区二区 | 国产精品久久久久无码av色戒 | 亚洲国产精品久久久天堂 | 午夜精品一区二区三区在线观看 | 欧美成人免费全部网站 | 国产超级va在线观看视频 | 人妻体内射精一区二区三四 | 亚洲天堂2017无码 | 国产极品视觉盛宴 | 国产精品视频免费播放 | 中文字幕亚洲情99在线 | 色综合久久中文娱乐网 | 久久亚洲日韩精品一区二区三区 | 国产精品对白交换视频 | 亚洲色在线无码国产精品不卡 | 亚洲 a v无 码免 费 成 人 a v | 好爽又高潮了毛片免费下载 | 亚洲精品国产第一综合99久久 | 国产成人无码av一区二区 | 亚无码乱人伦一区二区 | 国产精品沙发午睡系列 | 久久精品人人做人人综合试看 | 国产精品久久久久久久影院 | 亚洲精品国产精品乱码视色 | 久久综合久久自在自线精品自 | 天堂无码人妻精品一区二区三区 | 18无码粉嫩小泬无套在线观看 | 国内精品人妻无码久久久影院 | 西西人体www44rt大胆高清 | 俺去俺来也在线www色官网 | 亚洲精品鲁一鲁一区二区三区 | 亚洲精品综合五月久久小说 | 精品久久8x国产免费观看 | 狠狠色丁香久久婷婷综合五月 | 精品人妻人人做人人爽 | 午夜时刻免费入口 | 老熟女乱子伦 | 秋霞特色aa大片 | 亚洲熟妇色xxxxx欧美老妇y | 日韩在线不卡免费视频一区 | 熟妇女人妻丰满少妇中文字幕 | 国产深夜福利视频在线 | 女高中生第一次破苞av | 99久久精品午夜一区二区 | 亚洲欧洲中文日韩av乱码 | 亚洲狠狠色丁香婷婷综合 | 国产成人精品必看 | 亚洲日韩一区二区 | 特大黑人娇小亚洲女 | 久久国产自偷自偷免费一区调 | 精品厕所偷拍各类美女tp嘘嘘 | 啦啦啦www在线观看免费视频 | 国产精品久久久久久无码 | 欧美自拍另类欧美综合图片区 | 一本色道久久综合亚洲精品不卡 | 久久国产精品偷任你爽任你 | 久久人妻内射无码一区三区 | 久久五月精品中文字幕 | 人人妻人人澡人人爽人人精品 | 激情亚洲一区国产精品 | 亚洲另类伦春色综合小说 | 欧美兽交xxxx×视频 | 久久成人a毛片免费观看网站 | 小鲜肉自慰网站xnxx | 东京一本一道一二三区 | 乱码av麻豆丝袜熟女系列 | 国产精品-区区久久久狼 | 日韩av无码一区二区三区 | 欧美xxxxx精品 | 亚洲自偷自拍另类第1页 | 午夜精品一区二区三区在线观看 | 东京一本一道一二三区 | 51国偷自产一区二区三区 | 97色伦图片97综合影院 | 国产情侣作爱视频免费观看 | 美女扒开屁股让男人桶 | 国产口爆吞精在线视频 | 又大又黄又粗又爽的免费视频 | 中文字幕无码日韩专区 | 欧美第一黄网免费网站 | 国产色视频一区二区三区 | 亚洲gv猛男gv无码男同 | 精品日本一区二区三区在线观看 | 国产午夜无码视频在线观看 | 曰韩少妇内射免费播放 | 乌克兰少妇性做爰 | 久久久久人妻一区精品色欧美 | 久久人人爽人人人人片 | 国产做国产爱免费视频 | 无码国内精品人妻少妇 | 久久熟妇人妻午夜寂寞影院 | 国产精品久久精品三级 | 国产精品va在线观看无码 | 99久久99久久免费精品蜜桃 | 宝宝好涨水快流出来免费视频 | 精品久久久久久亚洲精品 | 日本精品人妻无码免费大全 | 亚洲中文字幕在线无码一区二区 | 国产精品久久久久久亚洲影视内衣 | 午夜男女很黄的视频 | 色婷婷欧美在线播放内射 | 欧美亚洲国产一区二区三区 | 青草青草久热国产精品 | 麻豆国产人妻欲求不满 | 亚洲综合无码久久精品综合 | 久久精品女人天堂av免费观看 | 中文字幕 人妻熟女 | 欧美成人高清在线播放 | 国产精品久久久久无码av色戒 | 98国产精品综合一区二区三区 | 特大黑人娇小亚洲女 | 丰满少妇高潮惨叫视频 | 亚洲爆乳大丰满无码专区 | 国产精品久久久久久亚洲影视内衣 | 久久久久国色av免费观看性色 | 久久精品人人做人人综合试看 | 女人被男人爽到呻吟的视频 | 亚洲色在线无码国产精品不卡 | 午夜福利试看120秒体验区 | 最近免费中文字幕中文高清百度 | 国产国产精品人在线视 | 乱人伦中文视频在线观看 | 一个人看的www免费视频在线观看 | 中文亚洲成a人片在线观看 | 色综合久久中文娱乐网 | 亚洲国产精华液网站w | 一本色道久久综合狠狠躁 | 国产精品办公室沙发 | 国产va免费精品观看 | 免费中文字幕日韩欧美 | 亚洲欧美日韩成人高清在线一区 | 成人一区二区免费视频 | 色妞www精品免费视频 | 人人爽人人爽人人片av亚洲 | 狠狠色欧美亚洲狠狠色www | 日韩少妇内射免费播放 | 国产综合久久久久鬼色 | www一区二区www免费 | 国内丰满熟女出轨videos | 粗大的内捧猛烈进出视频 | 国产精品a成v人在线播放 | 又大又硬又爽免费视频 | 99精品国产综合久久久久五月天 | 午夜熟女插插xx免费视频 | 久久久精品欧美一区二区免费 | 九月婷婷人人澡人人添人人爽 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲自偷自拍另类第1页 | 国产99久久精品一区二区 | 人妻体内射精一区二区三四 | 亚洲爆乳无码专区 | 国产乱子伦视频在线播放 | 日本又色又爽又黄的a片18禁 | 欧美丰满少妇xxxx性 | 丰满少妇女裸体bbw | 国语自产偷拍精品视频偷 | 精品无码国产自产拍在线观看蜜 | 精品无码av一区二区三区 | 国产亚洲精品久久久久久国模美 | 精品少妇爆乳无码av无码专区 | 亚洲七七久久桃花影院 | 精品久久久无码人妻字幂 | 又大又紧又粉嫩18p少妇 | 精品久久久久久人妻无码中文字幕 | 国产真实夫妇视频 | 亚洲中文字幕无码中文字在线 | 无码av免费一区二区三区试看 | 国产香蕉尹人视频在线 | 亚洲中文字幕成人无码 | 亚洲人亚洲人成电影网站色 | 色婷婷综合中文久久一本 | 97夜夜澡人人双人人人喊 | 在线观看欧美一区二区三区 | 又大又硬又黄的免费视频 | 国产后入清纯学生妹 | 亚洲色偷偷男人的天堂 | 亚洲日韩av一区二区三区四区 | 波多野结衣aⅴ在线 | 熟女体下毛毛黑森林 | 国产av剧情md精品麻豆 | 欧美放荡的少妇 | 国产综合在线观看 | 欧洲精品码一区二区三区免费看 | 日本精品久久久久中文字幕 | 色婷婷久久一区二区三区麻豆 | 日日摸天天摸爽爽狠狠97 | 性色欲网站人妻丰满中文久久不卡 | 激情爆乳一区二区三区 | 亚洲色欲色欲天天天www | 国产精品亚洲а∨无码播放麻豆 | 亚洲爆乳精品无码一区二区三区 | 帮老师解开蕾丝奶罩吸乳网站 | 麻豆果冻传媒2021精品传媒一区下载 | 久久久久久av无码免费看大片 | 久久综合给久久狠狠97色 | 在线成人www免费观看视频 | 亚洲狠狠色丁香婷婷综合 | 国产亚洲人成在线播放 | 精品厕所偷拍各类美女tp嘘嘘 | 亚洲中文字幕无码中文字在线 | 色欲综合久久中文字幕网 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 |