久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

詳解從Linux源碼看Socket(TCP)的bind

瀏覽:183日期:2024-04-08 18:22:01
目錄一、一個最簡單的Server端例子二、bind系統調用2.1、inet_bind2.2、inet_csk_get_port三、判斷端口號是否沖突四、SO_REUSEADDR和SO_REUSEPORT五、SO_REUSEADDR六、SO_REUSEPORT七、總結一、一個最簡單的Server端例子

眾所周知,一個Server端Socket的建立,需要socket、bind、listen、accept四個步驟。

詳解從Linux源碼看Socket(TCP)的bind

代碼如下:

void start_server(){ // server fd int sockfd_server; // accept fd int sockfd; int call_err; struct sockaddr_in sock_addr; sockfd_server = socket(AF_INET,SOCK_STREAM,0); memset(&sock_addr,0,sizeof(sock_addr)); sock_addr.sin_family = AF_INET; sock_addr.sin_addr.s_addr = htonl(INADDR_ANY); sock_addr.sin_port = htons(SERVER_PORT); // 這邊就是我們今天的聚焦點bind call_err=bind(sockfd_server,(struct sockaddr*)(&sock_addr),sizeof(sock_addr)); if(call_err == -1){fprintf(stdout,'bind error!n');exit(1); } // listen call_err=listen(sockfd_server,MAX_BACK_LOG); if(call_err == -1){fprintf(stdout,'listen error!n');exit(1); }}

首先我們通過socket系統調用創建了一個socket,其中指定了SOCK_STREAM,而且最后一個參數為0,也就是建立了一個通常所有的TCP Socket。在這里,我們直接給出TCP Socket所對應的ops也就是操作函數。

詳解從Linux源碼看Socket(TCP)的bind

二、bind系統調用

bind將一個本地協議地址(protocol:ip:port)賦予一個套接字。例如32位的ipv4地址或128位的ipv6地址+16位的TCP活UDP端口號。

#include <sys/socket.h>// 返回,若成功則為0,若出錯則為-1int bind(int sockfd, const struct sockaddr *myaddr, socklen_t addrlen);

好了,我們直接進入Linux源碼調用棧吧。

bind

// 這邊由系統調用的返回值會被glibc的INLINE_SYSCALL包一層

// 若有錯誤,則設置返回值為-1,同時將系統調用的返回值的絕對值設置給errno

|->INLINE_SYSCALL (bind......);

|->SYSCALL_DEFINE3(bind......);

/* 檢測對應的描述符fd是否存在,不存在,返回-BADF

|->sockfd_lookup_light

|->sock->ops->bind(inet_stream_ops)

|->inet_bind

|->AF_INET兼容性檢查

|-><1024端口權限檢查

/* bind端口號校驗or選擇(在bind為0的時候)

|->sk->sk_prot->get_port(inet_csk_get_port)

2.1、inet_bind

inet_bind這個函數主要做了兩個操作,一是檢測是否允許bind,而是獲取可用的端口號。這邊值得注意的是。如果我們設置需要bind的端口號為0,那么Kernel會幫我們隨機選擇一個可用的端口號來進行bind!

// 讓系統隨機選擇可用端口號sock_addr.sin_port = 0;call_err=bind(sockfd_server,(struct sockaddr*)(&sock_addr),sizeof(sock_addr));

讓我們看下inet_bind的流程

詳解從Linux源碼看Socket(TCP)的bind

值得注意的是,由于對于<1024的端口號需要CAP_NET_BIND_SERVICE,我們在監聽80端口號(例如啟動nginx時候),需要使用root用戶或者賦予這個可執行文件CAP_NET_BIND_SERVICE權限。

use root 

 or

setcap cap_net_bind_service=+eip ./nginx 

我們的bind允許綁定到0.0.0.0即INADDR_ANY這個地址上(一般都用這個),它意味著內核去選擇IP地址。對我們最直接的影響如下圖所示:

詳解從Linux源碼看Socket(TCP)的bind

然后,我們看下一個比較復雜的函數,即可用端口號的選擇過程inet_csk_get_port(sk->sk_prot->get_port)

2.2、inet_csk_get_port

第一段,如果bind port為0,隨機搜索可用端口號

直接上源碼,第一段代碼為端口號為0的搜索過程

// 這邊如果snum指定為0,則隨機選擇端口int inet_csk_get_port(struct sock *sk, unsigned short snum){......// 這邊net_random()采用prandom_u32,是偽(pseudo)隨機數smallest_rover = rover = net_random() % remaining + low;smallest_size = -1;// snum=0,隨機選擇端口的分支if(!sum){// 獲取內核設置的端口號范圍,對應內核參數/proc/sys/net/ipv4/ip_local_port_range inet_get_local_port_range(&low,&high);......do{if(inet_is_reserved_local_port(rover)goto next_nonlock; // 不選擇保留端口號......inet_bind_bucket_for_each(tb, &head->chain)// 在同一個網絡命名空間下存在和當前希望選擇的port rover一樣的portif (net_eq(ib_net(tb), net) && tb->port == rover) {// 已經存在的sock和當前新sock都開啟了SO_REUSEADDR,且當前sock狀態不為listen// 或者// 已經存在的sock和當前新sock都開啟了SO_REUSEPORT,而且兩者都是同一個用戶if (((tb->fastreuse > 0 && sk->sk_reuse && sk->sk_state != TCP_LISTEN) || (tb->fastreuseport > 0 && sk->sk_reuseport && uid_eq(tb->fastuid, uid))) && (tb->num_owners < smallest_size || smallest_size == -1)) { // 這邊是選擇一個最小的num_owners的port,即同時bind或者listen最小個數的port // 因為一個端口號(port)在開啟了so_reuseaddr/so_reuseport之后,是可以多個進程同時使用的smallest_size = tb->num_owners;smallest_rover = rover;if (atomic_read(&hashinfo->bsockets) > (high - low) + 1 && !inet_csk(sk)->icsk_af_ops->bind_conflict(sk, tb, false)) { // 進入這個分支,表明可用端口號已經不夠了,同時綁定當前端口號和之前已經使用此port的不沖突,則我們選擇這個端口號(最小的)snum = smallest_rover;goto tb_found;}}// 若端口號不沖突,則選擇這個端口if (!inet_csk(sk)->icsk_af_ops->bind_conflict(sk, tb, false)) {snum = rover;goto tb_found;}goto next;}break;// 直至遍歷完所有的可用port} while (--remaining > 0);}.......}

由于,我們在使用bind的時候很少隨機端口號(在TCP服務器來說尤其如此),這段代碼筆者就注釋一下。一般只有一些特殊的遠程過程調用(RPC)中會使用隨機Server端隨機端口號。

第二段,找到端口號或已經指定

have_snum:inet_bind_bucket_for_each(tb, &head->chain)if (net_eq(ib_net(tb), net) && tb->port == snum)goto tb_found;}tb = NULL;goto tb_not_foundtb_found:// 如果此port已被bindif (!hlist_empty(&tb->owners)) {// 如果設置為強制重用,則直接成功if (sk->sk_reuse == SK_FORCE_REUSE)goto success;}if (((tb->fastreuse > 0 && sk->sk_reuse && sk->sk_state != TCP_LISTEN) || (tb->fastreuseport > 0 && sk->sk_reuseport && uid_eq(tb->fastuid, uid))) && smallest_size == -1) { // 這個分支表明之前bind的port和當前sock都設置了reuse同時當前sock狀態不為listen// 或者同時設置了reuseport而且是同一個uid(注意,設置了reuseport后,可以同時listen同一個port了)goto success;} else {ret = 1;// 檢查端口是否沖突if (inet_csk(sk)->icsk_af_ops->bind_conflict(sk, tb, true)) {if (((sk->sk_reuse && sk->sk_state != TCP_LISTEN) || (tb->fastreuseport > 0 && sk->sk_reuseport && uid_eq(tb->fastuid, uid))) && smallest_size != -1 && --attempts >= 0) { // 若沖突,但是設置了reuse非listen狀態或者設置了reuseport且出在同一個用戶下 // 則可以進行重試spin_unlock(&head->lock);goto again;}goto fail_unlock;}// 不沖突,走下面的邏輯}tb_not_found:if (!tb && (tb = inet_bind_bucket_create(hashinfo->bind_bucket_cachep,net, head, snum)) == NULL)goto fail_unlock;// 設置fastreuse// 設置fastreuseportsuccess:......// 將當前sock鏈入tb->owner,同時tb->num_owners++inet_bind_hash(sk, tb, snum);ret = 0;// 返回bind(綁定)成功return ret;三、判斷端口號是否沖突

在上述源碼中,判斷端口號時否沖突的代碼為

inet_csk(sk)->icsk_af_ops->bind_conflict 也即 inet_csk_bind_conflictint inet_csk_bind_conflict(const struct sock *sk, const struct inet_bind_bucket *tb, bool relax){......sk_for_each_bound(sk2, &tb->owners) {// 這邊判斷表明,必須同一個接口(dev_if)才進入下內部分支,也就是說不在同一個接口端口的不沖突if (sk != sk2 && !inet_v6_ipv6only(sk2) && (!sk->sk_bound_dev_if || !sk2->sk_bound_dev_if || sk->sk_bound_dev_if == sk2->sk_bound_dev_if)) { if ((!reuse || !sk2->sk_reuse || sk2->sk_state == TCP_LISTEN) && (!reuseport || !sk2->sk_reuseport || (sk2->sk_state != TCP_TIME_WAIT && !uid_eq(uid, sock_i_uid(sk2))))) { // 在有一方沒設置reuse且sock2狀態為listen 同時 // 有一方沒設置reuseport且sock2狀態不為time_wait同時兩者的uid不一樣的時候const __be32 sk2_rcv_saddr = sk_rcv_saddr(sk2);if (!sk2_rcv_saddr || !sk_rcv_saddr(sk) || // ip地址一樣,才算沖突 sk2_rcv_saddr == sk_rcv_saddr(sk))break;}// 非放松模式,ip地址一樣,才算沖突...... return sk2 != NULL;}......}

上面代碼的邏輯如下圖所示:

詳解從Linux源碼看Socket(TCP)的bind

四、SO_REUSEADDR和SO_REUSEPORT

上面的代碼有點繞,筆者就講一下,對于我們日常開發要關心什么。

我們在上面的bind里面經常見到sk_reuse和sk_reuseport這兩個socket的Flag。這兩個Flag能夠決定是否能夠bind(綁定)成功。這兩個Flag的設置在C語言里面如下代碼所示:

setsockopt(sockfd_server, SOL_SOCKET, SO_REUSEADDR, &(int){ 1 }, sizeof(int)); setsockopt(sockfd_server, SOL_SOCKET, SO_REUSEPORT, &(int){ 1 }, sizeof(int));

在原生JAVA中

// java8中,原生的socket并不支持so_reuseport ServerSocket server = new ServerSocket(port); server.setReuseAddress(true);

在Netty(Netty版本 >= 4.0.16且Linux內核版本>=3.9以上)中,可以使用SO_REUSEPORT。

五、SO_REUSEADDR

在之前的源碼里面,我們看到判斷bind是否沖突的時候,有這么一個分支

(!reuse || !sk2->sk_reuse || sk2->sk_state == TCP_LISTEN) /* 暫忽略reuseport */){// 即有一方沒有設置}

如果sk2(即已bind的socket)是TCP_LISTEN狀態或者,sk2和新sk兩者都沒有設置_REUSEADDR的時候,可以判斷為沖突。

我們可以得出,如果原sock和新sock都設置了SO_REUSEADDR的時候,只要原sock不是Listen狀態,都可以綁定成功,甚至ESTABLISHED狀態也可以!

詳解從Linux源碼看Socket(TCP)的bind

這個在我們平常工作中,最常見的就是原sock處于TIME_WAIT狀態,這通常在我們關閉Server的時候出現,如果不設置SO_REUSEADDR,則會綁定失敗,進而啟動不來服務。而設置了SO_REUSEADDR,由于不是TCP_LISTEN,所以可以成功。

詳解從Linux源碼看Socket(TCP)的bind

這個特性在緊急重啟以及線下調試的非常有用,建議開啟。

六、SO_REUSEPORT

SO_REUSEPORT是Linux在3.9版本引入的新功能。

1.在海量高并發連接的創建時候,由于正常的模型是單線程listener分發,無法利用多核優勢,這就會成為瓶頸。

2.CPU緩存行丟失

我們看下一般的Reactor線程模型,

詳解從Linux源碼看Socket(TCP)的bind

明顯的其單線程listen/accept會存在瓶頸(如果采用多線程epoll accept,則會驚群,加WQ_FLAG_EXCLUSIVE可以解決一部分),尤其是在采用短鏈接的情況下。鑒于此,Linux增加了SO_REUSEPORT,而之前bind中判斷是否沖突的下面代碼也是為這個參數而添加的邏輯:

if(!reuseport || !sk2->sk_reuseport || (sk2->sk_state != TCP_TIME_WAIT && !uid_eq(uid, sock_i_uid(sk2))

這段代碼讓我們在多次bind的時候,如果設置了SO_REUSEPORT的時候不會報錯,也就是讓我們有個多線程(進程)bind/listen的能力。如下圖所示:

詳解從Linux源碼看Socket(TCP)的bind

而開啟了SO_REUSEPORT后,代碼棧如下:

tcp_v4_rcv|->__inet_lookup_skb |->__inet_lookup|->__inet_lookup_listener /* 用打分和偽隨機數等挑選出一個listen的sock */struct sock *__inet_lookup_listener(......){......if (score > hiscore) {result = sk;hiscore = score;reuseport = sk->sk_reuseport;if (reuseport) {phash = inet_ehashfn(net, daddr, hnum, saddr, sport);matches = 1;}} else if (score == hiscore && reuseport) {matches++;if (((u64)phash * matches) >> 32 == 0)result = sk;phash = next_pseudo_random32(phash);}......}

直接在內核層面做負載均衡,將accept的任務分散到不同的線程的不同socket上(Sharding),毫無疑問可以多核能力,大幅提升連接成功后的socket分發能力。

Nginx已經采用SO_REUSEPORT

Nginx在1.9.1版本的時候引入了SO_REUSEPORT,配置如下:

http { server { listen 80 reuseport; server_name localhost; # ... }}stream { server { listen 12345 reuseport; # ... }}

詳解從Linux源碼看Socket(TCP)的bind

詳解從Linux源碼看Socket(TCP)的bind

七、總結

Linux內核源碼博大精深,一個看起來簡單的bind系統調用竟然牽涉這么多,在里面可以挖掘出各種細節。在此分享出來,希望對讀者有所幫助。

以上就是詳解從Linux源碼看Socket(TCP)的bind的詳細內容,更多關于從Linux Socket(TCP) bind的資料請關注好吧啦網其它相關文章!

標簽: Linux系統
相關文章:
主站蜘蛛池模板: 不卡成人| 国产免费一区二区三区 | 亚洲啊v在线 | 韩日视频在线观看 | 欧美视频网站 | 国产精品无码永久免费888 | 韩日在线视频 | 国产成人一区二区三区 | av天天干| 国产欧美精品一区二区 | 亚洲成人一区二区三区 | 九九热免费看 | 91麻豆产精品久久久久久 | 一区二区免费在线观看 | 一区在线免费观看 | 欧美精品在线一区二区三区 | 91免费观看 | 国产99久久久久久免费看农村 | 午夜视频网址 | 久久久国产一区 | 久久久精彩视频 | 久久久久国产精品 | 国产传媒在线视频 | 自拍视频网站 | 国产不卡免费视频 | 成人av观看 | av中文字幕网 | 亚洲一区二区三区高清 | 欧美乱轮| 一区二区国产精品 | 中文字幕精品一区久久久久 | 亚洲国产一区二 | 久久y| 亚洲一区二区在线 | 国产97久久| 亚洲综合国产 | 亚洲精品视频免费 | 日韩视频欧美视频 | 亚洲久久久久久 | av性色| 福利视频一区 | 国产高清美女一级a毛片久久 | 久久网日本 | 亚洲精品视频在线观看免费 | 精品日韩一区二区三区 | 国产激情 | 本道综合精品 | 欧美在线观看视频 | 91成人在线免费视频 | 黄a在线观看| 美女福利网站 | 日本黄色大片免费观看 | 91夜夜| 亚洲第一黄 | 亚洲精品在线网站 | 日韩亚洲欧美综合 | 欧美午夜影院 | 欧美.com| 亚洲免费婷婷 | 99伊人| 97人人超碰 | 久热久热 | 成人午夜啪啪好大 | 亚洲国产精品一区二区三区 | 国产高清一区二区 | 91免费版在线观看 | 日韩三级电影免费观看 | 一区免费看 | 中文一区 | 日韩午夜在线 | 国产人妖视频 | 国产精品香蕉 | 成人在线网站 | 国产一区二区三区久久 | 最近的中文字幕在线看视频 | 久久精品a级毛片 | 国产一区中文字幕 | 国产精品久久久久久一区二区三区 | 久久久久久亚洲精品视频 | 欧美精品欧美精品系列 | 国产精品69毛片高清亚洲 | 中午字幕在线观看 | 欧美精品在线视频 | 亚洲国产精品久久久久 | 一区二区亚洲 | 日韩国产一区二区三区 | 久久噜噜噜精品国产亚洲综合 | 久久精品欧美一区二区三区不卡 | 日韩av电影免费 | 一级一片免费看 | h视频在线免费 | 91久久久久久久久 | 人人看超碰 | 黄色a级网站 | 午夜合集 | 成人国产精品久久久 | 中国黄色毛片 大片 | 在线成人www免费观看视频 | 亚洲欧美国产精品久久久久 | 黄色电影在线免费观看 | 欧美日韩精品一区二区三区在线观看 | 麻豆久久久9性大片 | 一级在线观看 | 天天色av | 在线国产视频 | 日韩欧美成人影院 | 久久亚洲一区二区 | 777色狠狠一区二区三区 | 91美女在线观看 | 国产精品无码久久久久 | 国产亚洲一区二区三区在线观看 | 视频一区在线播放 | 91社影院在线观看 | 亚洲www啪成人一区二区 | 欧美一区不卡 | 午夜精品网站 | 国产精品久久久久久一区二区三区 | 欧美视频在线播放 | 欧美一级片在线观看 | 九一视频在线免费观看 | 亚洲乱码二区 | 亚洲一区免费视频 | 又黄又爽的网站 | 欧美性受 | 性视频一区二区 | aaa级片| 欧美顶级毛片在线播放 | 看黄色.com| 97久久久 | 久久久久网站 | 精品视频成人 | 亚洲资源站 | 亚洲国产精品一区二区第一页 | 成人在线视频网站 | a在线看| 亚洲麻豆精品 | 亚洲精品不卡 | 久久久网 | 国产在线91 | 奇米av | 美女视频黄又黄又免费 | 国产精品久久久久久久久久免费 | 99久久精品一区二区成人 | 亚洲天堂成人 | 欧美日本精品 | 精品免费视频一区二区 | 人人干操 | 国产在线播 | 高清av在线 | 久久久久久极品 | 精品国产乱码久久久久久1区2区 | 成人av网站在线观看 | 欧美一区永久视频免费观看 | 亚洲免费视频一区 | 99热69 | 国产成人一区二区 | 欧美一级免费在线观看 | 狠狠操一区二区三区 | 狠狠干av | 午夜国产视频 | 在线播放中文字幕 | 一本大道久久a久久精二百 国产精品片aa在线观看 | 亚洲精品国产精品国自产 | av综合站 | 成人午夜免费视频 | 亚洲最大的黄色网 | 国产婷婷精品av在线 | 在线色网| 91视频专区 | 久久av网 | 国产精品99久久免费观看 | 一级黄色录像免费观看 | 日韩成人在线播放 | 久久久精品一区 | 国产成人涩涩涩视频在线观看 | 在线精品亚洲 | 日本不卡免费新一二三区 | 亚洲日本中文 | 精品在线播放 | 免费av在线网站 | 日韩精品区 | 欧美性影院 | 国产久| 欧美精品一区在线 | 久久综合九色综合欧美狠狠 | www.日韩在线观看 | 成人免费一区二区三区视频软件 | 国产成人高清 | 欧美一二三区在线 | 欧美一区不卡 | 免费的色网站 | 国产高清视频在线观看 | 欧美精品一区二区三区四区 | 亚洲人成在线播放 | 99精品福利视频 | 精品无人乱码一区二区三区的优势 | 国产一区二 | 成人欧美一区二区三区黑人孕妇 | 久久久久久久久一区二区 | 欧美成亚洲 | 色综合视频 | 天天澡天天狠天天天做 | 久久久精品一区二区三区 | 另类二区 | 亚洲精品免费在线观看 | 婷婷毛片 | 欧美中文在线观看 | 91麻豆精品国产91久久久久久 | 色九九 | 在线观看精品视频网站 | 色精品| 亚洲精品日韩激情在线电影 | 国产精品永久免费自在线观看 | 色一情一乱一伦一区二区三区 | 国产精品久久久久久久久久99 | 天堂在线www| 久久国产电影 | 天天躁日日躁性色aⅴ电影 免费在线观看成年人视频 国产欧美精品 | 亚洲在线视频 | 国产精品a久久久久 | 国产激情一区二区三区 | 国产成人精品免高潮在线观看 | 草久在线视频 | 亚洲色图p | 国产综合亚洲精品一区二 | 91社影院在线观看 | 欧美精产国品一二三区 | 成人一区二区三区 | 九九在线视频 | 中文字幕网在线 | 久草在线在线精品观看 | 一级毛片中国 | jlzzjlzz亚洲日本少妇 | 成人精品久久久 | av网站有哪些 | 欧美在线视频一区二区 | 欧美激情精品久久久久 | 成人激情视频在线观看 | 国产超碰人人爽人人做人人爱 | 亚洲一区av| 国产精品久久久久久久久免费桃花 | 国产精品免费一区二区三区四区 | 久久福利电影 | 亚洲精品乱码久久久久久金桔影视 | 日韩在线精品 | 日韩中文字幕在线视频 | 亚洲精品成人av | 欧美成人综合在线 | 国产一级黄片毛片 | 亚洲国产欧美一区二区三区久久 | 国产精品12 | 久久精品黄 | 日韩视频一 | 日韩成人tv | 欧美日韩成人一区 | 一级视频毛片 | 黑人巨大精品欧美一区二区小视频 | 欧美一级二级三级视频 | 国产一区二 | 亚洲精品乱码久久久久久蜜桃图片 | 日韩亚洲在线 | 精品一区二区三区在线视频 | 国产一级网站 | 成人免费激情视频 | 亚洲一区二区三区观看 | 精品欧美一区二区精品久久久 | 国产精品成人观看视频国产奇米 | 国产一级黄色av | www日韩| 日韩三区视频 | 日本不卡一区 | 亚洲天堂一区 | 色www精品视频在线观看 | 亚洲午夜视频在线观看 | 成人亚洲精品 | 伊人狠狠干 | 性视频网站免费 | 亚洲国产成人精品女人 | 亚洲网在线 | 一区二区精品视频 | 国产视频一区二区三区四区 | 久久se精品一区精品二区 | 成人在线观看免费 | 欧美99 | 国产欧美精品一区二区色综合朱莉 | 一级免费黄视频 | 免费观看欧美一级 | 国产免费av网站 | 成人影院av | 九九热九九 | 午夜欧美一区二区三区在线播放 | 成人免费视频网站在线观看 | 欧洲精品一区 | 久久久精品日本 | 日韩中文字幕在线观看 | 久久婷婷欧美 | 国产传媒毛片精品视频第一次 | 日本精品一区二区在线观看 | 黄色片在线| 黄色av网站在线免费观看 | 成人在线一区二区 | 国产成人黄色 | 91视频免费看 | 国产综合精品 | 欧美久久精品 | 看a网址| 日韩中出| 噜噜噜在线观看免费视频日本 | 久久久久久综合 | 四虎成人在线播放 | 国产精品久久久久久久久久久久久久 | h色视频在线观看 | 蜜桃视频成人m3u8 | 精品国产一区二区三区在线观看 | 亚洲国产成人av好男人在线观看 | 欧美日韩一区二区在线播放 | 日韩欧美中文在线 | 国产一区二区日韩 | 久久伊人精品视频 | 自拍亚洲 | 国产精品成人3p一区二区三区 | 亚洲风情在线观看 | 天堂伊人网 | 国产亚洲欧美精品永久 | 日本一级在线观看 | www.亚洲精品 | 欧美精品一区二区三区在线 | 1000部羞羞视频在线看视频 | 激情91 | 亚洲不卡免费视频 | 成人在线免费观看 | 精品在线一区二区 | 欧美aaaaa| 亚洲一区精品在线 | 国产精品毛片久久久久久久 | 久久久精品免费观看 | 成人欧美一区二区三区在线播放 | sese综合| 伊人久久爱| 99视频精品 | 综合一区二区三区 | 最近免费中文字幕大全免费版视频 | 欧美国产一区二区 | 天天操网址 | 国产日韩精品一区二区在线观看播放 | 亚洲一区二区在线视频 | 成人在线不卡 | 亚洲精品久久久久久一区二区 | 精品日韩中文字幕 | 日韩超碰在线观看 | www.亚洲区 | 在线观看免费视频黄 | 国产高潮在线观看 | 亚洲激情久久 | www.国产欧美| 日韩欧美三区 | 久久久一 | 欧美成年黄网站色视频 | 国产精品亲子伦av一区二区三区 | 91麻豆产精品久久久久久 | 一区二区中文字幕 | 亚洲综合二区 | 精品人成 | 日本私人网站在线观看 | 亚洲一区二区黄 | 国产高清视频一区二区 | 欧美成亚洲 | 羞羞视频在线免费 | 夜夜夜久久久 | 久久人人爽人人爽 | 欧美全黄 | 日韩在线二区 | 青青久草在线 | 亚洲一区二区三区四区在线观看 | 国产精品乱码久久 | 亚洲一区中文字幕 | 久久在线视频 | a中文在线视频 | 欧美一级二级片 | 超碰综合 | 欧美福利二区 | 久久一 | 久久草在线视频 | 亚洲伊人精品酒店 | 国产精品爱久久久久久久 | 免费观看一级视频 | 视色视频在线观看 | 国产在线精品一区 | 91九色视频 | 久久1区 | 日韩精品极品视频在线 | 欧美亚洲日本 | 精品国产一区二区三区久久影院 | 成人婷婷 | 69性欧美高清影院 | 国产精品久久久久久久久久大牛 | 99精品久久| 黄色片免费在线观看 | av77| 亚洲一区不卡 | 精品久久久久久久久久久久 | 亚洲国产成人久久 | 成年人精品视频在线观看 | 国产精品视频导航 | 成人免费激情视频 | 91中文字幕在线观看 | 国产成人jvid在线播放 | 黄色国产精品 | 91久久国产综合久久 | 国产成人精品免费视频大全 | 欧美日本韩国一区二区 | 国产精品久久久久久网站 | 日韩av电影网 | 国产精品久久久久久妇女6080 | 欧美1314 | 亚洲91 | 香蕉久久一区二区不卡无毒影院 | 一区二区在线看 | 国产精品久久久久久久午夜片 | 国产精品一区二区三区在线播放 | 91看片在线观看 | 夜夜草av | 成人福利网站 | 一级电影免费看 | 毛片免费观看 | 综合婷婷 | 国产精品久久久一区 | 福利网址 | 午夜激情在线 | 欧美一级h| 奇米精品一区二区三区在线观看 | 91亚洲精品乱码久久久久久蜜桃 | 中文字幕视频在线免费 | 一区二区在线视频 | 黄色一级片免费播放 | 一级做a爰片性色毛片2021 | 日韩免费 | 亚洲一区二区三区爽爽爽爽爽 | 爱爱精品 | 久久午夜影院 | 日韩欧美一区二区三区久久婷婷 | 国产激情在线视频 | 成人精品国产 | 午夜av成人 | 亚洲嫩草| 精品久久久久久久 | 伊人网国产 | 男人的天堂视频网站 | 不用播放器的毛片 | 国产精品久久777777 | 亚洲午夜精品一区二区三区他趣 | 欧美精品一区二区三区手机在线 | 久久伊人精品视频 | 日日操夜夜操天天操 | 国产日韩精品入口 | 亚洲一区二区三区四区 | 色综合天天天天做夜夜夜夜做 | 精品一区二区在线观看 | 在线观看理论电影 | 欧美激情欧美激情在线五月 | 国产一区二区在线视频 | 三级网站视频 | 亚洲精品视频在线免费 | 亚洲国产成人久久综合一区,久久久国产99 | 欧美日韩高清一区 | 久久精品欧美一区二区三区不卡 | 国产中文在线 | 久久伊人一区 | 欧美在线视频一区 | 国产精品久久久久一区二区三区 | 精品久久不卡 | 亚洲视频中文字幕 | 91精品久久久久久 | 日韩精品免费在线观看 | 中文字幕在线免费看 | 久久久久国产亚洲日本 | 91精品久久久久久综合五月天 | 久久久网 | 免费成人小视频 | 欧美在线视频三区 | 国产激情综合五月久久 | 久久伊| 欧美在线视频网 | 久久三区 | 夜夜操天天干, | 犬夜叉在线观看 | 国产女人免费看a级丨片 | 欧美日本精品 | 亚洲热在线视频 | 日韩视频二区 | 亚洲激情一区 | 欧美在线观看一区 | 亚洲国产精品成人 | 欧美一区二区三 | 国产精品永久免费自在线观看 | 桃花久久| 免费成人av在线 | 亚洲一区二区免费 | 久久久麻豆 | 欧美区 日韩区 | 少妇无套高潮一二三区 | 日本高清视频网站www | 国产成人综合视频 | 欧美日韩精品一二区 | 日韩视频一区二区三区 | 剑来在线观看 | 国产午夜一区二区三区 | 欧洲精品视频在线观看 | 欧美极品一区 | 天天色影视综合 | 男女羞羞视频在线免费观看 | 亚洲欧美日韩另类一区二区 | 久久99国产精品 | 午夜精品一区二区三区在线观看 | 久久二 | 在线视频一区二区 | 欧美国产精品一区二区 | 青青久久| 日韩一区精品 | 草樱av| 久久黄网 | 99视频在线看 | 久久久久国产精品一区二区三区 | 日韩精品av一区二区三区 | 黄色一级视频 | 亚洲国产精品久久久久久 | 国产情侣激情 | 一级做a爰片性色毛片2021 | 中文字幕在线观看免费视频 | 国产成人精品高清久久 | 犬夜叉在线观看 | 色5月婷婷丁香六月 | 禁果av一区二区三区 | 久久久精品一区 | 国产成人精品免高潮在线观看 | 在线精品亚洲欧美日韩国产 | 精品午夜久久久 | 国产精品欧美一区二区三区不卡 | 欧美激情综合色综合啪啪五月 | 热久久这里只有精品 | 久久久精品免费视频 | 狠狠撸在线视频 | 亚洲欧洲精品在线 | 精品一区二区av | 精品无人乱码一区二区三区的优势 | 国产91久久精品 | 羞羞视频网站 | 国产大片在线观看 | 青青久久av北条麻妃海外网 | 亚洲精品中文字幕 | 日韩av福利| 青青久久 | 亚洲免费视频观看 | 久久e久久| 亚洲精品中文字幕中文字幕 | 美女视频一区二区三区 | 在线久草 | 亚洲欧美激情另类 | 午夜欧美| 色视频免费在线观看 | 亚洲精品一区二区三区 | 色婷婷网 | 99pao成人国产永久免费视频 | 精品久久一级片 | 久久久精品一区 | www.成人在线视频 | 精品一区二区三区免费视频 | 国产一区二区三区在线免费观看 | 日韩一二三 | 99视频精品 | 亚洲精品中文字幕在线观看 | 久久韩剧网 | 中文二区| 久久久久久成人 | 日本久久www成人免 成人久久久久 | 欧美国产精品一区 | 国产精品成人在线 | 久久久一区二区三区 | 国产精品久久久久久久久久久久午夜片 | 成人黄色在线观看 | www.一区| 成人片免费看 | 久草视频在线播放 | 欧美片网站免费 | 久久国产精彩视频 | 中文精品在线 | 国产精品一区一区三区 | 久久精品一区二区三区四区 | 久热精品在线视频 | 二区视频 | 日韩国产 | 久草视| 国产乱人伦av在线a jizz久久久 www.亚洲 | 最近的中文字幕在线看视频 | a久久久 | 国产精品久久久久久久久久妞妞 | 欧美久久成人 | 在线成人国产 | 午夜视频网 | 国产高清久久久 | 免费国产成人 | 最新中文字幕在线资源 | 国产精品视频一区二区三区 | 久久综合久久综合久久 | 日韩在线你懂的 | 国产精品毛片一区二区三区 | 国产一区二区三区免费视频 | 国产欧美精品区一区二区三区 | 欧美一区二区三区免费 | 国产精品高清在线 | 亚洲第一免费看片 | 三a毛片 | 午夜激情影院 | 精品99在线 | 国产精品日本欧美一区二区三区 |