日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

epoll模型之服务器设计

發布時間:2023/12/20 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 epoll模型之服务器设计 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Linux ?2.6內核中提高網絡I/O性能的新方法-epoll I/O多路復用技術在比較多的TCP網絡服務器中有使用,即比較多的用到select函數。

1、為什么select落后
??? 首先,在Linux內核中,select所用到的FD_SET是有限的,即內核中有個參數__FD_SETSIZE定義了每個FD_SET的句柄個數,在我用的2.6.15-25-386內核中,該值是1024,搜索內核源代碼得到:
include/linux/posix_types.h:
#define __FD_SETSIZE???????? 1024
也就是說,如果想要同時檢測1025個句柄的可讀狀態是不可能用select實現的。或者同時檢測1025個句柄的可寫狀態也是不可能的。其次,內核中實現 select是用輪詢方法,即每次檢測都會遍歷所有FD_SET中的句柄,顯然,select函數執行時間與FD_SET中的句柄個數有一個比例關系,即 select要檢測的句柄數越多就會越費時。當然,在前文中我并沒有提及poll方法,事實上用select的朋友一定也試過poll,我個人覺得 select和poll大同小異,個人偏好于用select而已。

2、內核中提高I/O性能的新方法epoll
??? epoll是什么?按照man手冊的說法:是為處理大批量句柄而作了改進的poll。要使用epoll只需要這三個系統調用:epoll_create(2), epoll_ctl(2), epoll_wait(2)。
當然,這不是2.6內核才有的,它是在2.5.44內核中被引進的(epoll(4) is a new API introduced in Linux kernel 2.5.44)

Linux2.6內核epoll介紹
??? 先介紹2本書《The Linux Networking Architecture--Design and Implementation of Network Protocols in the Linux Kernel》,以2.4內核講解Linux TCP/IP實現,相當不錯.作為一個現實世界中的實現,很多時候你必須作很多權衡,這時候參考一個久經考驗的系統更有實際意義。舉個例子,linux內核中sk_buff結構為了追求速度和安全,犧牲了部分內存,所以在發送TCP包的時候,無論應用層數據多大,sk_buff最小也有272的字節.其實對于socket應用層程序來說,另外一本書《UNIX Network Programming Volume 1》意義更大一點.2003年的時候,這本書出了最新的第3版本,不過主要還是修訂第2版本。其中第6章《I/O Multiplexing》是最重要的。Stevens給出了網絡IO的基本模型。在這里最重要的莫過于select模型和Asynchronous I/O模型.從理論上說,AIO似乎是最高效的,你的IO操作可以立即返回,然后等待os告訴你IO操作完成。但是一直以來,如何實現就沒有一個完美的方案。最著名的windows完成端口實現的AIO,實際上也是內部用線程池實現的罷了,最后的結果是IO有個線程池,你應用也需要一個線程池...... 很多文檔其實已經指出了這帶來的線程context-switch帶來的代價。在linux 平臺上,關于網絡AIO一直是改動最多的地方,2.4的年代就有很多AIO內核patch,最著名的應該算是SGI那個。但是一直到2.6內核發布,網絡模塊的AIO一直沒有進入穩定內核版本(大部分都是使用用戶線程模擬方法,在使用了NPTL的linux上面其實和windows的完成端口基本上差不多了)。2.6內核所支持的AIO特指磁盤的AIO---支持io_submit(),io_getevents()以及對Direct IO的支持(就是繞過VFS系統buffer直接寫硬盤,對于流服務器在內存平穩性上有相當幫助)。
??? 所以,剩下的select模型基本上就是我們在linux上面的唯一選擇,其實,如果加上no-block socket的配置,可以完成一個"偽"AIO的實現,只不過推動力在于你而不是os而已。不過傳統的select/poll函數有著一些無法忍受的缺點,所以改進一直是2.4-2.5開發版本內核的任務,包括/dev/poll,realtime signal等等。最終,Davide Libenzi開發的epoll進入2.6內核成為正式的解決方案

3、epoll的優點
<1>支持一個進程打開大數目的socket描述符(FD)
??? select 最不能忍受的是一個進程所打開的FD是有一定限制的,由FD_SETSIZE設置,默認值是2048。對于那些需要支持的上萬連接數目的IM服務器來說顯然太少了。這時候你一是可以選擇修改這個宏然后重新編譯內核,不過資料也同時指出這樣會帶來網絡效率的下降,二是可以選擇多進程的解決方案(傳統的 Apache方案),不過雖然linux上面創建進程的代價比較小,但仍舊是不可忽視的,加上進程間數據同步遠比不上線程間同步的高效,所以也不是一種完美的方案。不過 epoll則沒有這個限制,它所支持的FD上限是最大可以打開文件的數目,這個數字一般遠大于2048,舉個例子,在1GB內存的機器上大約是10萬左右,具體數目可以cat /proc/sys/fs/file-max察看,一般來說這個數目和系統內存關系很大。

<2>IO效率不隨FD數目增加而線性下降
??? 傳統的select/poll另一個致命弱點就是當你擁有一個很大的socket集合,不過由于網絡延時,任一時間只有部分的socket是"活躍"的,但是select/poll每次調用都會線性掃描全部的集合,導致效率呈現線性下降。但是epoll不存在這個問題,它只會對"活躍"的socket進行操作---這是因為在內核實現中epoll是根據每個fd上面的callback函數實現的。那么,只有"活躍"的socket才會主動的去調用 callback函數,其他idle狀態socket則不會,在這點上,epoll實現了一個"偽"AIO,因為這時候推動力在os內核。在一些 benchmark中,如果所有的socket基本上都是活躍的---比如一個高速LAN環境,epoll并不比select/poll有什么效率,相反,如果過多使用epoll_ctl,效率相比還有稍微的下降。但是一旦使用idle connections模擬WAN環境,epoll的效率就遠在select/poll之上了。

<3>使用mmap加速內核與用戶空間的消息傳遞。
??? 這點實際上涉及到epoll的具體實現了。無論是select,poll還是epoll都需要內核把FD消息通知給用戶空間,如何避免不必要的內存拷貝就很重要,在這點上,epoll是通過內核于用戶空間mmap同一塊內存實現的。而如果你想我一樣從2.5內核就關注epoll的話,一定不會忘記手工 mmap這一步的。

<4>內核微調
??? 這一點其實不算epoll的優點了,而是整個linux平臺的優點。也許你可以懷疑 linux平臺,但是你無法回避linux平臺賦予你微調內核的能力。比如,內核TCP/IP協議棧使用內存池管理sk_buff結構,那么可以在運行時期動態調整這個內存pool(skb_head_pool)的大小--- 通過echo XXXX>/proc/sys/net/core/hot_list_length完成。再比如listen函數的第2個參數(TCP完成3次握手的數據包隊列長度),也可以根據你平臺內存大小動態調整。更甚至在一個數據包面數目巨大但同時每個數據包本身大小卻很小的特殊系統上嘗試最新的NAPI網卡驅動 架構

4、epoll的工作模式
??? 令人高興的是,2.6內核的epoll比其2.5開發版本的/dev/epoll簡潔了許多,所以,大部分情況下,強大的東西往往是簡單的。唯一有點麻煩是epoll有2種工作方式:LT和ET。
LT(level triggered)是缺省的工作方式,并且同時支持block和no-block socket.在這種做法中,內核告訴你一個文件描述符是否就緒了,然后你可以對這個就緒的fd進行IO操作。如果你不作任何操作,內核還是會繼續通知你的,所以,這種模式編程出錯誤可能性要小一點。傳統的select/poll都是這種模型的代表.
??? ET (edge-triggered)是高速工作方式,只支持no-block socket。在這種模式下,當描述符從未就緒變為就緒時,內核通過epoll告訴你。然后它會假設你知道文件描述符已經就緒,并且不會再為那個文件描述符發送更多的就緒通知,直到你做了某些操作導致那個文件描述符不再為就緒狀態了(比如,你在發送,接收或者接收請求,或者發送接收的數據少于一定量時導致了一個EWOULDBLOCK 錯誤)。但是請注意,如果一直不對這個fd作IO操作(從而導致它再次變成未就緒),內核不會發送更多的通知(only once),不過在TCP協議中,ET模式的加速效用仍需要更多的benchmark確認。
??? epoll只有epoll_create,epoll_ctl,epoll_wait 3個系統調用,具體用法請參考http://www.xmailserver.org/linux-patches/nio-improve.html ,在http://www.kegel.com/rn/也有一個完整的例子,大家一看就知道如何使用了
Leader/follower模式線程pool實現,以及和epoll的配合。

5、 epoll的使用方法
??? 首先通過create_epoll(int maxfds)來創建一個epoll的句柄,其中maxfds為你epoll所支持的最大句柄數。這個函數會返回一個新的epoll句柄,之后的所有操作將通過這個句柄來進行操作。在用完之后,記得用close()來關閉這個創建出來的epoll句柄。之后在你的網絡主循環里面,每一幀的調用epoll_wait(int epfd, epoll_event events, int max events, int timeout)來查詢所有的網絡接口,看哪一個可以讀,哪一個可以寫了。基本的語法為:
nfds = epoll_wait(kdpfd, events, maxevents, -1);
其中kdpfd為用epoll_create創建之后的句柄,events是一個epoll_event*的指針,當epoll_wait這個函數操作成功之后,epoll_events里面將儲存所有的讀寫事件。max_events是當前需要監聽的所有socket句柄數。最后一個timeout是 epoll_wait的超時,為0的時候表示馬上返回,為-1的時候表示一直等下去,直到有事件范圍,為任意正整數的時候表示等這么長的時間,如果一直沒有事件,則范圍。一般如果網絡主循環是單獨的線程的話,可以用-1來等,這樣可以保證一些效率,如果是和主邏輯在同一個線程的話,則可以用0來保證主循環的效率。

epoll_wait范圍之后應該是一個循環,遍利所有的事件:
for(n = 0; n < nfds; ++n) {
? if(events[n].data.fd == listener) { //如果是主socket的事件的話,則表示有新連接進入了,進行新連接的處理。
??? client = accept(listener, (struct sockaddr *) &local,? &addrlen);
??? if(client < 0){
????? perror("accept");
????? continue;
??? }
??? setnonblocking(client); // 將新連接置于非阻塞模式
??? ev.events = EPOLLIN | EPOLLET; // 并且將新連接也加入EPOLL的監聽隊列。
?????????????????????????????????? //注意,這里的參數EPOLLIN | EPOLLET并沒有設置對寫socket的監聽,
?????????????????????????????????? //如果有寫操作的話,這個時候epoll是不會返回事件的,
?????????????????????????????????? //如果要對寫操作也監聽的話,應該是EPOLLIN | EPOLLOUT | EPOLLET
??? ev.data.fd = client;
??? if (epoll_ctl(kdpfd, EPOLL_CTL_ADD, client, &ev) < 0) {? // 設置好event之后,將這個新的event通過epoll_ctl
???????????????????????????????????????????????????????????? //加入到epoll的監聽隊列里面,這里用EPOLL_CTL_ADD
???????????????????????????????????????????????????????????? //來加一個新的 epoll事件,通過EPOLL_CTL_DEL來減少
???????????????????????????????????????????????????????????? //一個epoll事件,通過EPOLL_CTL_MOD來改變一個事件的
???????????????????????????????????????????????????????????? //監聽方式。
????? fprintf(stderr, "epoll set insertion error: fd=%d0, client);
????? return -1;
??? }
? }? else // 如果不是主socket的事件的話,則代表是一個用戶socket的事件,

????????? //則來處理這個用戶socket的事情,比如說read(fd,xxx)之類的,或者一些其他的處理。
??? do_use_fd(events[n].data.fd);
}

對,epoll的操作就這么簡單,總共不過4個API:epoll_create, epoll_ctl, epoll_wait和close。
如果您對epoll的效率還不太了解,請參考我之前關于網絡游戲的網絡編程等相關的文章。


??? 以前公司的服務器都是使用HTTP連接,但是這樣的話,在手機目前的網絡情況下不但顯得速度較慢,而且不穩定。因此大家一致同意用 SOCKET來進行連接。雖然使用SOCKET之后,對于用戶的費用可能會增加(由于是用了CMNET而非CMWAP),但是,秉著用戶體驗至上的原則,相信大家還是能夠接受的(希望那些玩家月末收到帳單不后能夠保持克制...)。
這次的服務器設計中,最重要的一個突破,是使用了EPOLL模型,雖然對之也是一知半解,但是既然在各大PC網游中已經經過了如此嚴酷的考驗,相信他不會讓我們失望,使用后的結果,確實也是表現相當不錯。在這里,我還是主要大致介紹一下這個模型的結構。
6、Linux下EPOll編程實例
EPOLL模型似乎只有一種格式,所以大家只要參考我下面的代碼,就能夠對EPOLL有所了解了,代碼的解釋都已經在注釋中:

while (TRUE) {
? int nfds = epoll_wait (m_epoll_fd, m_events, MAX_EVENTS, EPOLL_TIME_OUT);//等待EPOLL時間的發生,相當于監聽,
???????????????????????????????????????????????????????????????????????????? //至于相關的端口,需要在初始化EPOLL的時候綁定。
? if (nfds <= 0)
??? continue;
? m_bOnTimeChecking = FALSE;
? G_CurTime = time(NULL);
? for (int i=0; i<nfds; i++) {
??? try {
????? if (m_events[i].data.fd == m_listen_http_fd)//如果新監測到一個HTTP用戶連接到綁定的HTTP端口,
????????????????????????????????????????????????? //建立新的連接。由于我們新采用了SOCKET連接,所以基本沒用。
????? {
??????? OnAcceptHttpEpoll ();
????? } else if (m_events[i].data.fd == m_listen_sock_fd)//如果新監測到一個SOCKET用戶連接到了綁定的SOCKET端口,
??????????????????????????????????????????????????????? //建立新的連接。
????? {
??????? OnAcceptSockEpoll ();
????? } else if (m_events[i].events & EPOLLIN)//如果是已經連接的用戶,并且收到數據,那么進行讀入。
????? {
??????? OnReadEpoll (i);
????? }

????? OnWriteEpoll (i);//查看當前的活動連接是否有需要寫出的數據。
??? } catch (int) {
????? PRINTF ("CATCH捕獲錯誤/n");
????? continue;
??? }
? }
? m_bOnTimeChecking = TRUE;
? OnTimer ();//進行一些定時的操作,主要就是刪除一些短線用戶等。
}
 其實EPOLL的精華,也就是上述的幾段短短的代碼,看來時代真的不同了,以前如何接受大量用戶連接的問題,現在卻被如此輕松的搞定,真是讓人不得不感嘆,對哪。





Epoll模型主要負責對大量并發用戶的請求進行及時處理,完成服務器與客戶端的數據交互。其具體的實現步驟如下:
(a) 使用epoll_create()函數創建文件描述,設定將可管理的最大socket描述符數目。
(b) 創建與epoll關聯的接收線程,應用程序可以創建多個接收線程來處理epoll上的讀通知事件,線程的數量依賴于程序的具體需要。
(c) 創建一個偵聽socket描述符ListenSock;將該描述符設定為非阻塞模式,調用Listen()函數在套接字上偵聽有無新的連接請求,在epoll_event結構中設置要處理的事件類型EPOLLIN,工作方式為 epoll_ET,以提高工作效率,同時使用epoll_ctl()注冊事件,最后啟動網絡監視線程。
(d) 網絡監視線程啟動循環,epoll_wait()等待epoll事件發生。
(e) 如果epoll事件表明有新的連接請求,則調用accept()函數,將用戶socket描述符添加到epoll_data聯合體,同時設定該描述符為非阻塞,并在epoll_event結構中設置要處理的事件類型為讀和寫,工作方式為epoll_ET.
(f) 如果epoll事件表明socket描述符上有數據可讀,則將該socket描述符加入可讀隊列,通知接收線程讀入數據,并將接收到的數據放入到接收數據的鏈表中,經邏輯處理后,將反饋的數據包放入到發送數據鏈表中,等待由發送線程發送。

總結

以上是生活随笔為你收集整理的epoll模型之服务器设计的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产一区二区在线免费视频 | 激情网五月 | 成人三级网址 | 特级毛片网| 92国产精品久久久久首页 | 97超碰.com| 欧美夫妻生活视频 | 天天综合天天做 | 久草久草在线 | 91精品电影 | 欧美夫妻生活视频 | 黄a网 | 日韩精品免费在线播放 | 亚洲人成在线观看 | 99日精品| 91最新地址永久入口 | 国产精品人人做人人爽人人添 | 中文字幕在线视频一区二区 | 亚洲欧美乱综合图片区小说区 | www视频在线观看 | 国产99久久九九精品免费 | 久久av电影 | 最近2019年日本中文免费字幕 | 亚洲免费av一区二区 | 99热在线网站| 国产美女免费观看 | 日本公乱妇视频 | 色婷婷福利 | 欧洲性视频 | 日韩精品一区二区三区免费观看视频 | 久久国产精品免费看 | 日日夜夜天天综合 | 国产在线不卡 | 国产成人1区 | 天天天天天天天天操 | 成人免费视频a | 日日插日日干 | 天天爱av导航 | 久久久精品免费观看 | 97超级碰碰碰视频在线观看 | 天天操天天弄 | 国产丝袜一区二区三区 | 午夜精品婷婷 | 精品视频区 | 国产精品久久久久久模特 | 青青河边草观看完整版高清 | 日日爱av | 成片免费 | 中文字幕在线免费播放 | 99精品免费观看 | 天天草av| 精品国产伦一区二区三区观看方式 | 在线视频日韩一区 | 欧美精品亚州精品 | 久久久免费看 | 欧美日韩久久不卡 | 九九久久影院 | 精品国产诱惑 | 日日爱影视 | 久草视频在线看 | 在线观看免费福利 | 久久久精品欧美一区二区免费 | 亚洲资源网 | 精品视频国产 | 国产精品都在这里 | 九9热这里真品2 | 91精品一区国产高清在线gif | 国产精品 亚洲精品 | 亚洲开心色 | 国产黄大片 | 国产在线永久 | av免费看av | 婷婷精品国产一区二区三区日韩 | 91精品国产综合久久福利 | 亚洲日本va中文字幕 | 国产字幕在线看 | 最近免费中文字幕mv在线视频3 | 国内精品美女在线观看 | 亚洲人在线 | 激情网站免费观看 | 97在线视频免费观看 | 91原创在线观看 | 国产区在线视频 | 日韩综合第一页 | www.天天干.com | 日韩超碰| 激情深爱五月 | 成人欧美日韩国产 | 国产在线久草 | 中文字幕影片免费在线观看 | 九九亚洲视频 | 四虎影视8848dvd | 国产一级二级av | 国产成人精品亚洲精品 | 一区二区三区高清不卡 | www.97色.com | 三级午夜片 | 日韩字幕 | 成年人免费电影在线观看 | 亚洲国产精品第一区二区 | 天天操夜夜曰 | 99久久国产免费免费 | 国产69久久精品成人看 | 伊人色综合久久天天 | 久久久久草 | 天天艹日日干 | 91在线色 | 精品一区精品二区高清 | 性色xxxxhd | 日韩在线中文字幕 | 午夜精品电影 | 91精品秘密在线观看 | 日日摸日日添夜夜爽97 | 狠狠色丁香婷婷综合久小说久 | 91精品视频在线 | 欧美做受高潮 | 最新成人在线 | 亚洲精区二区三区四区麻豆 | 日日躁夜夜躁aaaaxxxx | 亚洲综合色丁香婷婷六月图片 | 亚洲 欧美 综合 在线 精品 | 国产一区福利 | 国产亚洲婷婷免费 | 成人va视频 | 国产亚洲资源 | 国产中的精品av小宝探花 | 国产精品成人一区二区 | 成人一级电影在线观看 | 国产中年夫妇高潮精品视频 | 999免费视频 | 日韩精品国产一区 | 久久国产精品免费观看 | 婷婷久操 | 国产在线精品区 | 四虎成人精品 | 亚洲精品视频一 | 97精品国产aⅴ | 日日干天夜夜 | 91高清免费观看 | 亚洲精品视频免费在线观看 | 日b视频国产 | a在线免费| 久久精品免费电影 | 91日韩在线视频 | 婷婷丁香六月天 | 国产精品日韩高清 | 激情五月综合网 | 天天综合网天天 | 国产精品久久久久久久久大全 | 国产精品美 | www.久久久久 | 亚洲国产成人av网 | 黄p在线播放 | 一级性视频 | 日韩在线视频一区 | 日韩大片免费观看 | 久久久久在线观看 | 国产永久网站 | 欧美电影黄色 | 黄色软件视频大全免费下载 | 三级av黄色| 亚洲精品美女免费 | 国产999| 成人av一区二区兰花在线播放 | 日本精品久久久久中文字幕 | 日韩videos | 亚洲欧洲日韩在线观看 | 蜜臀av麻豆| 国产一区观看 | 国产一卡二卡在线 | 91麻豆精品国产91久久久无限制版 | 天天插狠狠干 | 久久国产精品99久久久久久丝袜 | 久久久久久国产精品美女 | 黄在线免费观看 | 国产专区日韩专区 | а中文在线天堂 | 欧美性脚交 | 超碰公开在线 | 国产专区一 | 96av在线视频 | 国产一二三区av | 中文字幕在线观看一区二区 | 免费av福利 | 97夜夜澡人人爽人人免费 | 一区二区丝袜 | 欧美亚洲一级片 | 国产小视频在线免费观看视频 | 国产二区精品 | 99一区二区三区 | 激情欧美一区二区三区免费看 | 国产精品免费观看视频 | 国产免费一区二区三区最新6 | 999国产 | 色婷在线| 91你懂的| 久久精品视频在线看 | 国内视频在线 | 综合伊人久久 | 在线视频一二区 | 午夜国产福利在线 | 久草在线这里只有精品 | 久久久资源 | 国产在线91精品 | 婷婷综合成人 | 亚洲三级在线免费观看 | 91爱看片 | 国产 欧美 日产久久 | 日本一区二区免费在线观看 | 亚洲精品国产麻豆 | 久久国产精品99久久久久久丝袜 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 国产高清视频免费观看 | 精品国产一区二区久久 | 日日干美女 | 91精品少妇偷拍99 | 黄色网址中文字幕 | 欧洲色吧 | 国产最新精品视频 | 人人玩人人添人人澡97 | 亚洲手机天堂 | 成人国产精品久久久 | 成人黄在线 | 国产视频一区在线免费观看 | 欧美日韩国产一区二区三区 | 欧美精品在线观看一区 | 免费看黄色91 | 午夜电影 电影 | 亚洲黄色片在线 | 免费中文字幕在线观看 | 天天精品视频 | 成人99免费视频 | 成人综合免费 | 国内精品久久久久久久久久久久 | 日韩精品亚洲专区在线观看 | 国产一级片观看 | 久久精品99视频 | 亚洲精品日韩在线观看 | 国产精品久久久久久999 | 国产在线播放观看 | 亚洲国产中文字幕在线观看 | 91麻豆免费看 | 人人爽人人射 | 久久久96| 国产免费人成xvideos视频 | 久久久久久久国产精品视频 | 人人插人人| 96精品高清视频在线观看软件特色 | 亚洲黄色一级大片 | 欧美一级免费 | 日韩av黄| 国产精品一区二区62 | 婷婷黄色片 | 97福利在线观看 | 亚洲精品免费在线视频 | 97国产大学生情侣白嫩酒店 | 欧美成人aa | 国产精品3 | 深夜福利视频在线观看 | 欧美中文字幕第一页 | 又紧又大又爽精品一区二区 | 9999亚洲| 人人干人人爽 | 国产福利在线 | 午夜国产福利在线 | 久草在线最新免费 | 国产一区在线观看免费 | 亚洲精品99久久久久中文字幕 | 99国产在线视频 | 午夜国产一区二区三区四区 | www.久久久久| 91禁看片 | 亚洲一区二区观看 | 免费在线观看视频a | 欧美日韩p片 | 亚洲精品一区二区在线观看 | 中文字幕二区 | 免费看国产曰批40分钟 | 天天综合网 天天综合色 | 亚洲精品一区二区三区新线路 | 日本精品久久久久久 | 日韩精品一区二区不卡 | 日韩欧美在线一区 | 欧美伦理一区二区 | 奇米7777狠狠狠琪琪视频 | 九九精品在线观看 | 在线观看香蕉视频 | 色婷婷亚洲精品 | 日韩在线色 | 欧美人人爱| 97人人射 | 狠狠色丁香婷婷综合 | 一区二区三区播放 | 国产无遮挡又黄又爽在线观看 | 欧美日韩在线视频一区二区 | 青草视频免费观看 | 国产黄 | 麻豆国产在线播放 | 国产亚洲精品福利 | 69av在线视频 | 麻豆视频免费入口 | 不卡日韩av | 亚洲国产中文在线观看 | 97视频入口免费观看 | 免费视频区 | 天天天色综合a | 在线看国产日韩 | 午夜精品成人一区二区三区 | 国产视频美女 | 99精品视频网 | 日韩视频免费在线观看 | 在线视频免费观看 | 91视频久久久久久 | 久久66热这里只有精品 | 亚洲春色成人 | 国产亚洲精品中文字幕 | 久久国内精品视频 | 国产精品一区二区吃奶在线观看 | 婷婷中文字幕综合 | 高清av中文在线字幕观看1 | 日韩在线中文字幕 | 亚洲一区二区精品 | www.夜夜草 | 成人黄色中文字幕 | 久久久久久久久久久久亚洲 | 97超碰在线免费观看 | 五月综合激情网 | 99精品国产在热久久 | 欧美精品中文字幕亚洲专区 | 91免费观看国产 | 国内精品久久影院 | 欧美极度另类 | 国产理伦在线 | 欧美精品一区二区三区四区在线 | 91av久久| 精品国产成人在线影院 | 高清一区二区三区 | 日韩高清免费电影 | 久插视频 | 黄色三几片 | 六月色婷 | 久久久精品免费观看 | 久久精品系列 | 亚洲综合成人专区片 | 成人不用播放器 | www.婷婷色| 97国产超碰 | 69绿帽绿奴3pvideos | 91网站免费观看 | 欧美精品一级视频 | 成人黄色在线看 | 日日干干| 91av原创| 欧美一级片在线播放 | 在线视频欧美日韩 | 国产一区欧美一区 | 青春草视频在线播放 | 欧美精品久久久久久久亚洲调教 | 在线看中文字幕 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 国产精品一区二区白浆 | 中文字幕 国产 一区 | 日韩久久久久久 | 久久国产精品99久久久久久进口 | 国产无遮挡又黄又爽在线观看 | 婷婷黄色片 | 久久色亚洲 | 欧美激情视频一二区 | 亚洲精品玖玖玖av在线看 | 久久一区91 | 久草精品视频在线播放 | 日本动漫做毛片一区二区 | 色天天综合久久久久综合片 | 天天爽天天搞 | 在线国产日本 | 国产午夜精品免费一区二区三区视频 | 日韩有码中文字幕在线 | 在线观看视频一区二区三区 | 久久午夜影院 | 国产高清一 | 中国老女人日b | 日日夜夜免费精品 | 亚洲精品国产精品久久99 | 精品久久久久久综合 | 黄色录像av | 国产精品久久久av久久久 | 国产成人免费高清 | 欧美国产精品一区二区 | 亚洲国产视频网站 | 婷婷六月天天 | 久久国产免费视频 | 亚洲免费av网站 | 国产成人精品一区二区三区在线 | 91热精品视频 | 亚洲成人精品av | 国产一区在线看 | 91视频在线网址 | 国产精品美女久久久免费 | 特级黄录像视频 | 美女黄频免费 | 三级午夜片 | 国产精品a久久久久 | 成 人 黄 色视频免费播放 | 黄色aa久久 | 99 精品 在线 | 综合网天天色 | 中文久草 | 国产一级黄大片 | 丰满少妇一级片 | 国产欧美最新羞羞视频在线观看 | 久久久久久久精 | 四虎最新入口 | 制服丝袜亚洲 | 日一日干一干 | 婷婷在线视频观看 | av动图| 成人小视频在线观看免费 | 国产精品大全 | 丁香六月激情 | 亚洲国产精品久久久久婷婷884 | 久久福利剧场 | 91精品麻豆 | 日韩乱色精品一区二区 | 2021国产精品视频 | 成人久久18免费网站图片 | 国产一区二区免费 | 久艹视频在线免费观看 | 日韩欧美一区二区不卡 | 在线观看国产区 | 日韩欧美精品在线观看 | 一区二区三区四区久久 | 国产一区二区在线精品 | 欧美久久久久 | 婷婷激情五月 | 午夜影院一级片 | 在线看中文字幕 | 免费在线国产黄色 | 国产综合精品一区二区三区 | 日韩在线 一区二区 | 在线观看爱爱视频 | 99久久日韩精品视频免费在线观看 | 手机av看片 | 天天操天天干天天爽 | bbbb操bbbb | 久久永久免费视频 | 欧美日韩观看 | 91在线九色| 亚洲精品一区二区三区高潮 | 欧美精品久久久久久久久久久 | 日韩欧美综合视频 | 五月激情六月丁香 | 在线 欧美 日韩 | 国产日产欧美在线观看 | 99久热在线精品视频 | 精品a在线 | 黄色特一级| 久久精品999 | 欧美日韩xx | 一区二区三区精品在线视频 | 亚洲精品视频久久 | 久久福利综合 | 日韩欧美电影 | 久久一区二区三区日韩 | 97免费在线观看视频 | 日韩理论片中文字幕 | 探花视频免费观看高清视频 | 蜜桃av久久久亚洲精品 | 国产aa免费视频 | 福利一区二区三区四区 | 欧美一二区视频 | 人九九精品| 国产精品丝袜 | 久久国产热视频 | 国产成人黄色 | 在线天堂中文www视软件 | av丁香花 | 美女视频a美女大全免费下载蜜臀 | 欧美性生活大片 | 涩涩网站在线播放 | 在线视频麻豆 | 国产一卡久久电影永久 | 成人精品福利 | 免费观看mv大片高清 | 国产不卡一二三区 | 精品欧美小视频在线观看 | 中文字幕在线观看三区 | 免费污片| 美女视频网站久久 | 欧美日韩国产精品一区 | av一级片在线观看 | 久久国产二区 | 精品国产亚洲日本 | 日韩欧美高清 | 国产高清视频在线免费观看 | 日精品| 一区二区不卡视频在线观看 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 日批视频 | 国产黄色在线 | 日本韩国中文字幕 | 激情网站| 黄色在线免费观看网址 | 狠狠狠狠狠狠狠狠干 | 国产黄色大全 | 国产午夜三级一区二区三 | 国产在线永久 | 国产在线观看 | 99精品国产成人一区二区 | 91精品啪 | 一区av在线播放 | 一本一道波多野毛片中文在线 | 午夜免费在线观看 | 亚洲精品久久久久久中文传媒 | 日韩一级电影在线 | 久久精品网址 | 毛片无卡免费无播放器 | 色综合天天视频在线观看 | 五月婷婷在线综合 | 日韩日韩日韩日韩 | 久久久国产一区二区三区四区小说 | 中文字幕丝袜一区二区 | 91av视屏 | 在线之家官网 | 国产成人精品av在线观 | 亚洲综合激情小说 | 99精品视频免费在线观看 | 丰满少妇在线观看网站 | 午夜精品三区 | 久久精品伊人 | 色福利网 | 久久五月情影视 | 女人魂免费观看 | 五月婷婷综合激情网 | 日本精品一区二区三区在线播放视频 | 亚洲涩涩色| 99精品国产一区二区 | 国产精品2区 | 91高清视频在线 | 日韩欧美一区二区不卡 | 国产精品久久久久高潮 | 狠狠色婷婷丁香六月 | 日本精品一区二区在线观看 | 欧美一二三区播放 | 美女黄频在线观看 | 久久久久久久久久久免费视频 | 欧美a级免费视频 | 国产精品第二十页 | 久久人91精品久久久久久不卡 | 久久精品亚洲综合专区 | 国产一区免费在线观看 | 亚洲成人av片 | 99久久99久久精品 | 中文字幕av影院 | 日本中文字幕网 | 国产97视频| 欧美一级免费黄色片 | 激情久久久久久久久久久久久久久久 | 99国产精品视频免费观看一公开 | 九九色视频 | 丰满少妇高潮在线观看 | 日日干美女 | 久久久夜色| 日韩免费电影一区二区 | 亚洲激情精品 | 天天综合日日夜夜 | 成年人在线免费看片 | 国产精品日韩在线观看 | 在线观看蜜桃视频 | 在线观看欧美成人 | 亚洲精品久久视频 | 国产日韩欧美在线一区 | 亚洲资源片 | 久久99国产精品自在自在app | 免费观看高清 | 99精品热| 国产高清在线免费观看 | 97精品国自产拍在线观看 | 色爽网站 | 日韩久久久久久久久久 | 亚洲最新视频在线播放 | 久久婷婷一区二区三区 | 99精品久久99久久久久 | 国产91粉嫩白浆在线观看 | 久久精品久久久精品美女 | 国产91精品一区二区绿帽 | 久久999精品 | 久久国产视频网 | 一区二区伦理电影 | 五月激情视频 | 免费在线色电影 | 成人黄色片在线播放 | 亚洲精品www. | 夜夜操狠狠操 | 亚洲午夜大片 | 精品久久久成人 | 日韩精品视频在线免费观看 | 韩国在线一区 | 久久免费成人精品视频 | 韩国一区二区三区在线观看 | 88av视频 | 西西大胆免费视频 | 97成人精品| 中文字幕亚洲欧美日韩2019 | 在线免费观看麻豆视频 | 蜜臀久久99精品久久久久久网站 | 亚洲h色精品 | 国产免费av一区二区三区 | 午夜性生活片 | 正在播放一区 | 久久av电影 | 久久精品观看 | 国产精彩在线视频 | 日本三级久久久 | 国产精品美女久久久久久2018 | 国产日韩精品在线观看 | 国产精品一区免费看8c0m | 天天舔天天射天天操 | 日韩中文在线观看 | 天海冀一区二区三区 | 久久网址| 99色免费| 欧美极度另类性三渗透 | 中国成人一区 | 成人毛片在线观看视频 | 久久九九精品 | 狠狠操夜夜操 | 四虎国产精品免费观看视频优播 | 中文字幕在线免费播放 | 国产1区2区| 精品综合久久久 | 国产精品自产拍在线观看 | 久久久久女人精品毛片九一 | 久久韩国免费视频 | 久久理论电影 | 91免费观看视频网站 | 国产免费又粗又猛又爽 | 亚洲精品视频在线观看免费视频 | 免费视频色 | 黄色在线观看www | 在线国产欧美 | 欧美日韩亚洲第一 | 夜夜嗨av色一区二区不卡 | 国产视频一区二区三区在线 | 久久精品国产精品 | 国产乱对白刺激视频在线观看女王 | av免费片| www.夜色321.com | av黄色免费看 | 久久中文字幕视频 | 在线免费观看黄色av | 五月婷在线播放 | 中文字幕 国产视频 | 欧美另类美少妇69xxxx | 久久久91精品国产一区二区三区 | 色婷婷丁香 | 夜夜躁日日躁狠狠躁 | 午夜精品久久久久久久久久久久 | 亚洲国产天堂av | 久久8精品| 欧美一级性生活 | 国产精品视频99 | 国内精品久久久久久久久久久久 | 99视频网址| 四虎影视成人永久免费观看亚洲欧美 | 久久久久久久综合色一本 | 日韩欧在线 | 91污视频在线观看 | 亚洲成人av电影在线 | 久久久久成人精品亚洲国产 | 国产黄在线免费观看 | 一二三久久久 | 色妞色视频一区二区三区四区 | 欧美日本在线观看视频 | 国产福利资源 | 92国产精品久久久久首页 | 91人人人 | 玖玖视频国产 | 999久久a精品合区久久久 | av免费电影网站 | 天天操天天干天天干 | 99久热在线精品视频 | 天天干夜夜爱 | 中文字幕久久精品 | 色多多污污在线观看 | 亚洲精品男女 | 亚洲国产精品激情在线观看 | 国产在线观看免费观看 | 久久婷婷精品视频 | 亚州精品在线视频 | 精品国产一区二区三区久久 | 手机在线观看国产精品 | 国产亚洲欧美日韩高清 | 97精品一区二区三区 | 国产视频 久久久 | 久久不射影院 | 国产一区二区日本 | 婷婷激情av | 97超碰在线人人 | 国产精品视频区 | 在线你懂| 最新av网址在线观看 | 欧美ⅹxxxxxx | 中文字幕一区二区三区久久蜜桃 | avsex| 日韩黄色免费在线观看 | 久久久久久久久电影 | 久草在线免费资源站 | 国产一级黄色免费看 | 日韩精品免费一区二区三区 | 日韩激情影院 | 手机看片99 | 国产黄视频在线观看 | 韩国精品福利一区二区三区 | 亚洲精品日韩一区二区电影 | 天天操天天摸天天干 | 国产成人精品免高潮在线观看 | 欧美成人xxxxx| 六月丁香在线视频 | 深夜免费网站 | 精品国产一区二区三区在线观看 | 伊人导航| 亚洲aⅴ在线观看 | 国产视频在线免费 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 97在线观看免费高清 | 欧美 日韩 性 | 五月天免费网站 | 四虎成人av| 日本公妇在线观看 | 欧美日韩国产精品一区二区 | 美女搞黄国产视频网站 | 国产中文视 | 18久久久 | 最近中文字幕视频网 | 最新av电影网址 | 黄色网址国产 | 日韩videos高潮hd| 国产美女黄网站免费 | 久久超级碰 | 久久精品免费观看 | 免费能看的av | 午夜影院一级片 | 伊人天堂网 | 成人午夜网 | 激情丁香婷婷 | 久久99久久99精品免观看粉嫩 | 国产成人精品一区二三区 | 66av99精品福利视频在线 | 麻豆视频观看 | 99精品一区二区三区 | 美女视频黄免费网站 | 久久久人人爽 | 久久免费黄色大片 | 久久一区二区三区国产精品 | 久久99精品国产麻豆婷婷 | 丰满少妇久久久 | 黄色一级大片免费看 | 国产成人精品国内自产拍免费看 | 国内视频 | 久久看片 | 在线看免费 | 国内精品亚洲 | 一区二区三区在线电影 | 91中文视频 | 毛片网站免费 | 国产精品系列在线 | 亚洲一区二区三区精品在线观看 | 欧美一区二区视频97 | 精品色综合| 亚洲精品播放 | 亚洲精选视频在线 | 国产视频2 | 午夜av免费| 亚洲免费永久精品国产 | 久久午夜色播影院免费高清 | 国产一区在线免费观看视频 | 久久视频在线观看 | 久久丁香 | 亚洲成人中文在线 | 91av九色 | 欧美精选一区二区三区 | 黄色小说免费观看 | 国产精品一区久久久久 | 色婷婷综合久久久中文字幕 | 国产最新视频在线观看 | 国产精品综合久久久 | 久久久久久久网 | 在线视频免费观看 | 麻豆视频一区 | 九热在线| 欧美另类交在线观看 | 亚洲精品一区二区久 | 在线一区二区三区 | 午夜精品一区二区三区在线视频 | 在线观看免费色 | 伊人久在线 | 国产在线精品一区二区 | 狠狠狠狠干 | ,午夜性刺激免费看视频 | 超碰在线亚洲 | 天天av在线播放 | www色,com| 绯色av一区| 日韩va亚洲va欧美va久久 | 中文字幕色婷婷在线视频 | 国产男女无遮挡猛进猛出在线观看 | 亚洲毛片一区二区三区 | 好看av在线| 久久久黄色免费网站 | 91免费观看国产 | 久久超碰在线 | 日韩com| 99久久网站 | 久久任你操 | 久久精品日产第一区二区三区乱码 | 91香蕉视频在线下载 | 国产亚洲精品中文字幕 | 91热这里只有精品 | 四虎影视欧美 | 亚洲精品国产区 | 在线观看国产www | 中文字幕4 | 欧洲色吧 | 国产成人久久精品77777综合 | 亚洲专区 国产精品 | 日本一区二区高清不卡 | 香蕉视频在线观看免费 | 国产成人精品一区二区三区福利 | 国产成人三级在线观看 | 精品久久久久国产免费第一页 | 麻豆久久久久 | 99国产精品免费网站 | 黄色国产高清 | 成人av一二三区 | 麻豆一区在线观看 | 99久久99久久精品国产片果冰 | 国产自制av | 国内精品毛片 | 日韩精品在线免费播放 | 色婷婷综合久久久中文字幕 | 亚洲精品午夜视频 | 亚洲男男gⅴgay双龙 | 99精品国产福利在线观看免费 | 久久人人爽人人爽人人片av软件 | 狠狠狠狠狠狠狠 | www在线免费观看 | 欧美另类重口 | 欧美一级看片 | 久久精品日本啪啪涩涩 | 日本在线观看黄色 | 人人爽人人射 | 天天操天天射天天操 | 中文字幕一区二区在线播放 | 亚洲国产精品电影在线观看 | 亚洲精选在线观看 | 久久免费99精品久久久久久 | 91大片网站 | 亚洲国产大片 | 国产精品久久嫩一区二区免费 | 久久精品之 | 日韩二区在线观看 | a视频免费看 | 日韩电影在线一区 | 中文字幕在线免费看线人 | 国产一区观看 | 国产成人精品久久久久蜜臀 | 91大神精品视频在线观看 | 成人免费看黄 | 在线欧美最极品的av | 开心丁香婷婷深爱五月 | 日韩免费在线观看网站 | 亚洲精品在线观看中文字幕 | 日韩一区二区三区免费视频 | 国产日韩精品一区二区在线观看播放 | 在线观看一区 | 欧美日韩中文在线 | 五月天中文字幕 | 毛片永久新网址首页 | 黄色大片入口 | 天天插天天干天天操 | 中文字幕在线免费观看视频 | 亚洲精品在线一区二区三区 | 亚洲精品网址在线观看 | 日韩中文字幕a | 韩日精品在线观看 | 99热亚洲精品 | 伊人精品在线 | 久久福利在线 | 五月婷婷在线播放 | 久久精品一区二区国产 | 亚洲另类视频在线观看 | 日一日干一干 | 精品无人国产偷自产在线 | 黄在线免费观看 | 毛片网站免费 | 国产在线中文 | 国产色视频网站2 | 国内精品视频免费 | 久久午夜精品影院一区 | 婷婷五情天综123 | 欧美日韩中文另类 | 亚洲黄色免费在线看 | 久久久精品国产免费观看一区二区 | 国产a级免费 | 久久精品一区二区国产 | 久久综合九色综合97婷婷女人 | 97精品免费视频 | 久久99亚洲热视 | 国产视频一区在线 | 91免费看黄| 亚洲高清在线视频 | 成人永久视频 | 69av视频在线观看 | 黄色小网站在线 | 黄色影院在线免费观看 | 欧美有色 | 欧美午夜性 | 婷婷激情网站 | 色狠狠狠 | 99久久婷婷国产 | 国产黄免费在线观看 | 最近高清中文在线字幕在线观看 | 国产高清中文字幕 | 国产精品18久久久久久首页狼 | 一区二区视频免费在线观看 | 欧美性生活免费 | 久久久影院一区二区三区 | 欧美大片aaa | 亚洲国产资源 | 亚洲精品www. | 日韩免费在线看 | 懂色av一区二区三区蜜臀 | 91| 久久精品一区二区国产 | 国产91精品一区二区麻豆亚洲 | 色综合久久五月 | 欧美午夜精品久久久久 | 91看片看淫黄大片 | 亚洲欧洲国产视频 | 亚洲精品中文在线资源 | 日韩久久久久久久 | 精品少妇一区二区三区在线 | 91三级视频 | 成人教育av | 免费看的黄色的网站 | 看黄色.com | 国产精品系列在线 | 日韩精品免费一区 | 久久精品播放 | 日韩视频1 | 国产精品久久婷婷六月丁香 | 99久久久久国产精品免费 | 国产精品国产自产拍高清av | 国产一级黄 | 天天亚洲 | 国产日韩精品一区二区在线观看播放 | 字幕网av| 婷婷久久综合九色综合 | 香蕉视频日本 | 日韩草比 | 午夜精品视频一区二区三区在线看 | 亚洲91中文字幕无线码三区 | 国产亚洲视频中文字幕视频 | 久久精品综合 | 亚洲黄色av网址 | 久久国产精品99久久人人澡 | 中文字幕制服丝袜av久久 | 日韩精品中文字幕在线 | 成人av在线影视 | 在线观看成人福利 | 亚洲视频第一页 | 国产精品久久久久久超碰 | 国产一级a毛片视频爆浆 | av夜夜操 | www欧美日韩 | 在线免费观看视频a | 中文字幕色站 | 久艹视频免费观看 | 日韩欧美精品一区二区 | 中文乱码视频在线观看 | 国产精品久久久久久久久久直播 | 国产亚洲资源 | 中文字幕国产精品 | 在线国产高清 | 久久九九影视 | 国产1区2| 午夜黄色大片 | 色婷婷亚洲 | 五月天丁香亚洲 | 五月天丁香视频 | 99热国产在线中文 | 久久久www成人免费毛片麻豆 | 中文字幕文字幕一区二区 | 国产人免费人成免费视频 | 国产精品美女视频 | 国产精品久久久久久99 | 黄视频色网站 | 亚洲综合小说 |