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

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

詳解linux里的backlog參數

瀏覽:291日期:2023-03-07 14:40:03

問題

我們在linux上服務器起了一個serversocket,并且設置了backlog為2,并沒有讓serversock.accept()

在客戶端上,我們一個一個的啟動了連接socket, 當連接數目超過3的時候,客戶端依然可以繼續新建連接。

什么是backlog

說起backlog, 都會想起socket編程中的listen backlog 參數,而這個backlog 是linux內核中處理的backlog么?

int listen(int sockfd, int backlog)

listen 中的backlog解釋

The backlog argument defines the maximum length to which the queue of pending connections for sockfd may grow. If a connection request arrives when the queue is full, the client may receive an error with an indication of ECONNREFUSED or, if the underlying protocol supports retransmission, the request may be ignored so that a later reattempt at connection succeeds.

實際上在linux內核2.2版本以后,backlog參數控制的是已經握手成功的還在accept queue的大小。

握手過程中的結構體

struct request_sock_queue {
/*Points to the request_sock accept queue, when after 3 handshake will add the request_sock from syn_table to here*/
    struct request_sock    *rskq_accept_head;
    struct request_sock    *rskq_accept_tail;
    rwlock_tsyn_wait_lock;
    u8    rskq_defer_accept;
    /* 3 bytes hole, try to pack */
    struct listen_sock    *listen_opt;
};
struct listen_sock {
    u8    max_qlen_log; /*2^max_qlen_log is the length of the accpet queue, max of max_qlen_log is 10. (2^10=1024)*/
    /* 3 bytes hole, try to use */
    int    qlen; /* qlen is the current length of the accpet queue*/
    int    qlen_young;
    int    clock_hand;
    u32    hash_rnd;
    u32    nr_table_entries; /*nr_table_entries is the number of the syn_table,max is 512*/
    struct request_sock    *syn_table[0];
};
struct request_sock {
	struct request_sock		*dl_next; /* Must be first member! */
	u16				mss;
	u8				retrans;
	u8				cookie_ts; /* syncookie: encode tcpopts in timestamp */
	/* The following two fields can be easily recomputed I think -AK */
	u32				window_clamp; /* window clamp at creation time */
	u32				rcv_wnd;	  /* rcv_wnd offered first time */
	u32				ts_recent;
	unsigned long			expires;
	const struct request_sock_ops	*rsk_ops;
	struct sock			*sk;
	u32				secid;
	u32				peer_secid;
};
struct sock{
	unsigned short		sk_ack_backlog;
	unsigned short		sk_max_ack_backlog;
}

首先在linux里可以簡單的認為有2個隊列,一個就是在握手過程中的隊列,而另一個就是握手成功的隊列

簡單的描述一下3個結構體

request_sock

 是每一個client的連接(無論是握手成功,還是不成功) 里面的 expires代表的是這個request在隊列里的存活時間,而 *sk 就是連接成功的socket的數目

request_sock_queue

rskq_accept_head 隊列,也就是握手成功的隊列,*listen_opt 是指listen過程中的sock

listen_sock

*syn_table 是指握手沒有成功的隊列,而qlen,qlen_young 分別指的是隊列的長度和隊列新成員的個數

在結構體中,我們已經清楚的看到了一個listen_sock中的syn_table,另一個是request_sock_queue中的rskq_accept_head,這就是我們剛才說的兩個隊列,一個是為正在握手的隊列,另一個是已經握手成功的隊列。

我們在上面都看到了結構體中只是看到了未握手的隊列的長度,并沒有看到握手的隊列長度統計,實際上握手成功的隊列長度是在sock 結構中

sock

當握手成功后每一個client就是一個sock, sk_ack_backlog 是隊列長度,而sk_max_ack_backlog是指最大的隊列長度

在這里我們會有疑問,難道是沒個連接上的 sock都會保留隊列的長度么?實際上在此時的sock 代表的是server端listen 的sock而不是客戶端的sock,也就是在握手沒有成功的過程中,在linux使用的sock都是server的listen的sock, 對客戶端只是保留成request_sock

TCP握手的幾個階段

收到客戶端的syn請求 ->將這個請求放入syn_table中去->服務器端回復syn-ack->收到客戶端的ack->放入accept queue中

我們把整個過程分為5個部分,其中將請求放入syn_table和accept queue中的過程也是backlog相關的,在下面我們會詳細闡述。

我們先簡單的描述一下幾個tcp的操作函數,下面針對的也是ip4協議的

const struct inet_connection_sock_af_ops ipv4_specific = {
	.queue_xmit	   = ip_queue_xmit,
	.send_check	   = tcp_v4_send_check,
	.rebuild_header	   = inet_sk_rebuild_header,
	.conn_request	   = tcp_v4_conn_request,
	.syn_recv_sock	   = tcp_v4_syn_recv_sock,
	.remember_stamp	   = tcp_v4_remember_stamp,
	.net_header_len	   = sizeof(struct iphdr),
	.setsockopt	   = ip_setsockopt,
	.getsockopt	   = ip_getsockopt,
	.addr2sockaddr	   = inet_csk_addr2sockaddr,
	.sockaddr_len	   = sizeof(struct sockaddr_in),
	.bind_conflict	   = inet_csk_bind_conflict,
#ifdef CONFIG_COMPAT
	.compat_setsockopt = compat_ip_setsockopt,
	.compat_getsockopt = compat_ip_getsockopt,
#endif
};

在剛才所說的兩個步驟,也就是結構體中的 conn_request 和 syn_recv_sock,  所對應的函數是 tcp_v4_conn_request 和 tcp_v4_syn_recv_sock

我們所重點關注的主要是方法中的drop邏輯

tcp_v4_conn_request 函數

int tcp_v4_conn_request(struct sock *sk, struct sk_buff *skb)
{
	/* Never answer to SYNs send to broadcast or multicast */
	if (skb_rtable(skb)->rt_flags & (RTCF_BROADCAST | RTCF_MULTICAST))
		goto drop;

	/* TW buckets are converted to open requests without
	 * limitations, they conserve resources and peer is
	 * evidently real one.
	 */
	if (inet_csk_reqsk_queue_is_full(sk) && !isn) {
#ifdef CONFIG_SYN_COOKIES
		if (sysctl_tcp_syncookies) {
			want_cookie = 1;
		} else
#endif
		goto drop;
	}

	/* Accept backlog is full. If we have already queued enough
	 * of warm entries in syn queue, drop request. It is better than
	 * clogging syn queue with openreqs with exponentially increasing
	 * timeout.
	 */
	if (sk_acceptq_is_full(sk) && inet_csk_reqsk_queue_young(sk) > 1)
		goto drop;
....
}
1. inet_csk_reqsk_queue_is_full(sk)

判斷的是  queue->listen_opt->qlen >> queue->listen_opt->max_qlen_log;

這里有個 qlen 代表的是listen_opt的 syn_table的長度,那什么是max_qlen_log呢?

nr_table_entries = min_t(u32, nr_table_entries, sysctl_max_syn_backlog);
nr_table_entries = max_t(u32, nr_table_entries, 8);
nr_table_entries = roundup_pow_of_two(nr_table_entries + 1);
for (lopt->max_qlen_log = 3;
	     (1 << lopt->max_qlen_log) < nr_table_entries;
	     lopt->max_qlen_log++);

也就是max_qlen 是listen 傳入的backlog和sysctl_max_syn_backlog最小值,并且一定大于16 , roudup_pow_of_two 代表著找最靠近nr_table_entries+1的2的倍數 sysctl_max_syn_backlog 就是我們熟悉的

/proc/sys/net/ipv4/tcp_max_syn_backlog

我們看一下listen 函數在kernel的實現

SYSCALL_DEFINE2(listen, int, fd, int, backlog)
{
	struct socket *sock;
	int err, fput_needed;
	int somaxconn;
 
	sock = sockfd_lookup_light(fd, &err, &fput_needed);
	if (sock) {
		<span>somaxconn = sock_net(sock->sk)->core.sysctl_somaxconn;
		if ((unsigned)backlog > somaxconn)
			backlog = somaxconn;</span>
 
		err = security_socket_listen(sock, backlog);
		if (!err)
			err = sock->ops->listen(sock, backlog);
 
		fput_light(sock->file, fput_needed);
	}
	return err;
}

我們清楚的看到backlog 并不是按照你調用listen的所設置的backlog大小,實際上取的是backlog和somaxconn的最小值

somaxconn的值定義在

/proc/sys/net/core/somaxconn

2.sk_acceptq_is_full

static inline int sk_acceptq_is_full(struct sock *sk)
{
	return sk->sk_ack_backlog > sk->sk_max_ack_backlog;
}
int inet_listen(struct socket *sock, int backlog)
{
    sk->sk_max_ack_backlog = backlog;
}

就是等于我們剛才在前面部分看到的listen中的值

3.inet_csk_reqsk_queue_young

在判斷sk_acceptq_is_full 的情況下,同是也要求了判斷inet_csk_reqsk_queue_young>1,也就是剛才的結構體listen_sock的qlen_young

qlen_young 是對syn_table的計數,進入 syn_table 加1,出了syn_table  -1

有的人可能會有疑問了

如果accept queue滿了,那么qlen_young不就是一直增加,而新來的客戶端都會被條件if (sk_acceptq_is_full(sk) && inet_csk_reqsk_queue_young(sk) > 1) 而drop syn的ack包,那么客戶端會出現connected timeout, 而實際上你在測試linux的環境中會發現并沒有出現這樣的情況。

實際上linux在server起socket的時候會調用tcp_keepalive_timer啟動tcp_synack_timer,會調用函數inet_csk_reqsk_queue_prune

 if (sk->sk_state == TCP_LISTEN) {
		tcp_synack_timer(sk);
		goto out;
}
static void tcp_synack_timer(struct sock *sk)
{
	inet_csk_reqsk_queue_prune(sk, TCP_SYNQ_INTERVAL,
				   TCP_TIMEOUT_INIT, TCP_RTO_MAX);
}

而inet_csk_reqsk_queue_prune會在去檢查syn的table, 而刪除一些這個request 過期后并且完成retry 的syn ack包的請求

為了提高inet_csk_reqsk_queue_prune的效率,在request_sock 里加入了 expires(才前面的結構體中已經提到過) , 這個expires初始值是hardcode的3HZ 時間, inet_csk_reqsk_queue_prune會輪訓syn_table里的已經exprie request, 發現如果還沒有到到retry的次數,那么會增加expire的時間直到重試結束,而expire的時間為剩余retry 次數*3HZ ,并且不大于120HZ

關于retry, retry的參數可以通過設置 

/proc/sys/net/ipv4/tcp_syn_retries

當然你可以通過設置

/proc/sys/net/ipv4/tcp_abort_on_overflow 為1 不允許syn ack 重試

因為被inet_csk_reqsk_queue_prune函數清除了syn_table,在沒有并發的前提下基本上不會出現inet_csk_reqsk_queue_young>1的情況,也就是說不會出現drop sync的情況,在客戶端表現,不會出現connect timeout 的情況(這里的實現linux和mac的實現有很大的不同)而剛開始的問題也能得到合理的解釋了

通過函數tcp_v4_conn_request的分析,在linux的設計初衷是盡力的允許新的連接握手,而期望服務器端能更快的響應accept.

我們也許會問,剛才的服務器syn ack回去后,如果客戶端也回復了ack的話,而此時accept的queue滿了,將會如何處理

我們回到前面提到的步驟,處理客戶端的ack 函數也就是

tcp_v4_syn_recv_sock 函數

struct sock *tcp_v4_syn_recv_sock(struct sock *sk, struct sk_buff *skb,
				  struct request_sock *req,
				  struct dst_entry *dst)
{
	struct inet_request_sock *ireq;
	struct inet_sock *newinet;
	struct tcp_sock *newtp;
	struct sock *newsk;
#ifdef CONFIG_TCP_MD5SIG
	struct tcp_md5sig_key *key;
#endif
 
	if (sk_acceptq_is_full(sk))
		goto exit_overflow;
 
	if (!dst && (dst = inet_csk_route_req(sk, req)) == NULL)
		goto exit;
 
	newsk = tcp_create_openreq_child(sk, req, skb);
	if (!newsk)
		goto exit;
 
	newsk->sk_gso_type = SKB_GSO_TCPV4;
	sk_setup_caps(newsk, dst);
 
	newtp		      = tcp_sk(newsk);
	newinet		      = inet_sk(newsk);
	ireq		      = inet_rsk(req);
	newinet->inet_daddr   = ireq->rmt_addr;
	newinet->inet_rcv_saddr = ireq->loc_addr;
	newinet->inet_saddr	      = ireq->loc_addr;
	newinet->opt	      = ireq->opt;
	ireq->opt	      = NULL;
	newinet->mc_index     = inet_iif(skb);
	newinet->mc_ttl	      = ip_hdr(skb)->ttl;
	inet_csk(newsk)->icsk_ext_hdr_len = 0;
	if (newinet->opt)
		inet_csk(newsk)->icsk_ext_hdr_len = newinet->opt->optlen;
	newinet->inet_id = newtp->write_seq ^ jiffies;
 
	tcp_mtup_init(newsk);
	tcp_sync_mss(newsk, dst_mtu(dst));
	newtp->advmss = dst_metric(dst, RTAX_ADVMSS);
	if (tcp_sk(sk)->rx_opt.user_mss &&
	    tcp_sk(sk)->rx_opt.user_mss < newtp->advmss)
		newtp->advmss = tcp_sk(sk)->rx_opt.user_mss;
 
	tcp_initialize_rcv_mss(newsk);
 
#ifdef CONFIG_TCP_MD5SIG
	/* Copy over the MD5 key from the original socket */
	key = tcp_v4_md5_do_lookup(sk, newinet->inet_daddr);
	if (key != NULL) {
		/*
		 * We"re using one, so create a matching key
		 * on the newsk structure. If we fail to get
		 * memory, then we end up not copying the key
		 * across. Shucks.
		 */
		char *newkey = kmemdup(key->key, key->keylen, GFP_ATOMIC);
		if (newkey != NULL)
			tcp_v4_md5_do_add(newsk, newinet->inet_daddr,
					  newkey, key->keylen);
		newsk->sk_route_caps &= ~NETIF_F_GSO_MASK;
	}
#endif
 
	__inet_hash_nolisten(newsk, NULL);
	__inet_inherit_port(sk, newsk);
 
	return newsk;
 
exit_overflow:
	NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_LISTENOVERFLOWS);
exit:
	NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_LISTENDROPS);
	dst_release(dst);
	return NULL;
}

我們看到了熟悉的函數 sk_acceptq_is_full, 而在此時在無函數inet_csk_reqsk_queue_young>1來保護,也就是說在此時如果發現queue是滿的,將直接丟棄只是統計了參數LINUX_MIB_LISTENOVERFLOWSLINUX_MIB_LISTENDROPS而這些參數的值可以通過

netstat -s 來查看到

在函數tcp_v4_syn_recv_sock中我們看到tcp_create_openreq_child,此時才clone出一個新的socket ,也就是只有通過了3次握手后,linux才會產生新的socket, 而在3次握手中所傳的socket 實際上是server的listen的 socket, 那也就是說這個socket 只有一個狀態TCP_LISTEN

netstat的狀態

通過在tcp_rcv_state_process可以置socket 的狀態,而我們通常使用netstat 中看到這些socket的狀態

case TCP_SYN_RECV:
			if (acceptable) {
				tp->copied_seq = tp->rcv_nxt;
				smp_mb();
				tcp_set_state(sk, TCP_ESTABLISHED);

我們看到從 SYN_RECV的狀態直接設置成ESTABLISHED,也就是當server收到client的ack回來,狀態置為 TCP_SYN_RECV,而馬上進入tcp_rcv_state_process函數置為狀態ESTABLISHED,基本沒有TCP_SYN_RECV 的狀態期,但我們通過netstat  的使用,還是會發現有部分socket 還是會處于SYN_RECV狀態,實際上這通常是在syn_table的request, 為了顯示還沒有通過三次握手的連接的狀態,這時候request 還在syn table里,并且還沒有屬于自己的socket對象,linux 把這些信息寫到了

/proc/net/tcp

而在TCP_SEQ_STATE_OPENREQ 的情況下(就是 syn synack ack)的3個狀態下都顯示成TCP_SYN_RECV

static void get_openreq4(struct sock *sk, struct request_sock *req,
			 struct seq_file *f, int i, int uid, int *len)
{
	const struct inet_request_sock *ireq = inet_rsk(req);
	int ttd = req->expires - jiffies;
 
	seq_printf(f, "%4d: %08X:%04X %08X:%04X"
		" %02X %08X:%08X %02X:%08lX %08X %5d %8d %u %d %p%n",
		i,
		ireq->loc_addr,
		ntohs(inet_sk(sk)->inet_sport),
		ireq->rmt_addr,
		ntohs(ireq->rmt_port),
		TCP_SYN_RECV,
		0, 0, /* could print option size, but that is af dependent. */
		1,    /* timers active (only the expire timer) */
		jiffies_to_clock_t(ttd),
		req->retrans,
		uid,
		0,  /* non standard timer */
		0, /* open_requests have no inode */
		atomic_read(&sk->sk_refcnt),
		req,
		len);
}

而對ESTABLISHED狀態,并不需要server.accept,只要在accept queue里就已經變成狀態ESTABLISHED

到此這篇關于詳解linux里的backlog參數的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持。

標簽: Linux Apache
相關文章:
主站蜘蛛池模板: 国产1区2区精品 | 亚洲视频在线观看 | 欧美午夜精品久久久 | 欧美一区二区三区 | 日韩在线精品视频 | 久久草视频 | 精品久久网站 | 午夜影院在线观看版 | 久久久精品 | 午夜成人免费电影 | 久久精品久久久久久 | 欧美精品一二区 | 免费黄色在线视频网址 | 天天精品视频免费观看 | 91视频在线免费观看 | 亚洲欧美日韩精品久久亚洲区 | 日韩一区精品 | 欧美大片在线看免费观看 | 精品国产精品三级精品av网址 | 精品视频在线观看一区二区三区 | 国产最新精品视频 | 午夜精品一区二区三区在线播放 | av免费在线观看网站 | 91成人在线视频 | 在线视频成人 | 欧美国产综合一区 | 亚洲毛片网站 | 久久精品视频免费 | 国产深夜视频在线观看 | 久久久精品网站 | 亚洲精品日本 | 精品免费av| www.国产在线| 国内精品在线视频 | 日韩精品视频在线观看免费 | 亚洲一区中文 | 99久久综合精品五月天 | av黄色一级片 | 久久国产精品视频 | 91久久久久久久久久久久久久久久 | 国产欧美精选 | 久久久国产视频 | 伊人一区二区三区 | av网站观看 | 国产日韩av在线 | 亚洲国产精品99久久久久久久久 | 蜜臀影院 | 欧美久久久精品 | www.99精品 | 在线看一区二区 | 午夜视频在线观看网站 | 99这里只有精品 | 一级一片免费看 | 国产不卡在线 | 亚洲+变态+欧美+另类+精品 | 一区二区三区视频免费在线观看 | 亚洲视频一区二区三区四区 | 久久99精品久久久久久琪琪 | 成人精品视频 | 美女久久久 | 精品国产伦一区二区三区观看说明 | 亚洲精品麻豆 | 久久久久国产一区二区三区四区 | 看亚洲a级一级毛片 | 日韩欧美国产一区二区 | 古风h啪肉1v1摄政王 | 色婷婷在线视频观看 | 日本做暖暖视频高清观看 | 成人a在线 | 久久国产一区二区 | 麻豆亚洲 | 亚洲va中文字幕 | 狠狠人人| www.黄色片视频 | 久久久久久久久久一区二区 | 蜜桃视频成人m3u8 | 欧美精品欧美激情 | www.se天堂 | 91精品久久久久久久久 | 日韩福利一区二区 | 福利视频网址导航 | 91.com在线观看 | 国产一区二区视频在线播放 | 欧美一级片免费在线观看 | 亚洲动漫在线观看 | 欧美高清视频一区二区三区 | 亚洲美女一区二区三区 | 亚洲一二三区在线观看 | 久久99精品久久久噜噜最新章节 | 欧美一区二区三区精品 | 久久国产精品久久久久久电车 | 天天插天天射天天干 | 欧美中文在线 | 国产成人亚洲精品 | 日韩在线免费观看网站 | 国产精品久久久久久亚洲调教 | 最新伦理片 | 亚洲h| 精品国产99 | 91精品久久久久久久 | 日本视频在线 | 国产精品国色综合久久 | 中文字幕日韩一区 | 欧美日韩国产在线看 | 最新国产视频 | 精品一二三区 | 三级网站在线播放 | 在线观看你懂的视频 | 久久一 | 综合网亚洲 | 99re视频在线观看 | 中文无码久久精品 | 午夜视频福利在线观看 | 黄色在线免费 | 天天操操 | 久久国内精品 | 欧美日韩在线一区 | 午夜成人在线视频 | 国产精品18久久久久久久久久久久 | 99国产精品视频免费观看一公开 | 午夜激情视频免费 | 亚洲精品18 | 亚洲精品一区二区三区 | 欧美成人精品一区二区男人看 | 成人午夜毛片 | 国产一区二区在线免费观看 | 国产欧美精品一区二区 | 91精品久久久久久久久 | 精品免费 | 天天草天天色 | 日韩视频区 | 中文字字幕一区二区三区四区五区 | 黄色成人免费看 | 亚洲区一区二 | 欧美精品欧美精品系列 | hitomi一区二区三区精品 | 999精品在线 | 欧美黄色激情 | 高清国产一区二区三区四区五区 | 青青草一区二区 | 欧美一级在线观看 | 一级篇 | 亚洲欧美电影 | 男女午夜 | 精品亚洲永久免费精品 | 欧美一级日韩 | 天天爽夜夜爽夜夜爽精品视频 | 精品一区二区不卡 | 噜噜噜噜狠狠狠7777视频 | 亚洲一区精品在线 | 亚洲精品一区二区三区蜜桃久 | 欧美综合久久 | 欧美日韩大陆 | 日韩在线精品视频 | 91精品国产自产91精品 | 美女黄在线观看 | 日韩欧美中文字幕在线视频 | 国产精品久久久久久久久久东京 | 亚洲精彩视频 | 黄色一级大片在线免费看产 | 日韩国产一区二区 | 欧美亚洲性视频 | 亚洲精品成人久久久 | 久久久久a | 欧美日韩精品一区 | 国产一区 | 人人种亚洲 | 亚洲国产成人久久一区二区三区 | 欧美二区精品 | 午夜午夜精品一区二区三区文 | 91精品国产综合久久久久久丝袜 | 国产精品视频一区二区三区不卡 | 日韩欧美网址 | 亚洲一区二区三区视频 | 久久精品国产久精国产 | 国产精品久久久久久久娇妻 | 91在线看片| 亚洲三级av| 久久99精品久久久久久琪琪 | 污色视频在线观看 | 日本免费视频 | 在线观看国产视频 | 亚洲成人自拍 | 激情图区在线观看 | 欧美日韩中文字幕在线 | 日韩免费网站 | 亚洲国产精品视频 | 日产精品久久久一区二区 | 国产精品久久九九 | 成人av播放| 国产精品久久久久久久久久久免费看 | 9999国产精品欧美久久久久久 | 国产成人精品久久二区二区 | 欧美 日韩 国产 在线 | 欧美激情综合色综合啪啪五月 | 国产福利在线视频 | 久久精品久久久 | 亚洲精品电影在线观看 | 日韩成人国产 | 国产午夜精品一区二区 | 波多野结衣一区二区三区中文字幕 | 国产精品成人在线观看 | 成人av片在线观看 | 久久久精品区 | 一区二区在线视频 | 婷婷丁香五 | 香蕉久久一区二区不卡无毒影院 | 黄色免费一级 | 爱爱视频免费 | 午夜国产羞羞视频免费网站 | 亚洲精品系列 | 亚洲一区二区三区高清 | 日韩中文字幕 | 国产丝袜一区二区三区免费视频 | 国精品一区 | 久久男人天堂 | 精品福利在线视频 | 国产精品99久久久久久大便 | 999在线观看精品免费不卡网站 | 欧美亚洲三级 | www.亚洲成人网 | 天天操天天干天天插 | 欧美性猛交一区二区三区精品 | 一级特黄色大片 | 成人九色| 伊人久久精品久久亚洲一区 | 久久久精品一区二区 | 在线免费观看激情视频 | 激情网页 | 日韩一级电影在线 | 男人亚洲天堂网 | 日韩在线观看三区 | 国产成人毛片 | 国产高清一二三区 | 91在线观看视频 | 色婷婷久久久久swag精品 | 国产精品久久国产精麻豆99网站 | 九色av| 日韩在线观看网站 | 一级性视频 | 亚洲一区二区三区蜜桃 | 亚洲福利二区 | 日本成人在线视频网站 | 日韩欧美在线看 | 精品一二三四区 | 国产一区二区免费 | 蜜臀久久99精品久久久无需会员 | 亚洲男人av | 国产在线一区二区三区 | 欧美成人a∨高清免费观看 在线视频成人 | 天天干狠狠干 | 国产精品亚洲a | 99久久精品国产毛片 | 天天操天天草 | 国产在线第一页 | 国产精品久久久久影院色老大 | 插插射啊爱视频日a级 | 99色资源 | 一区免费视频 | 欧美久久不卡 | 日日摸夜夜添夜夜添亚洲女人 | 在线看免费的a | 国产1页 | 国产区福利 | 欧美黄色一区 | 在线观看欧美成人 | 亚洲成人二区 | 亚洲欧美成人影院 | 精品久久久久久久久久久久久久 | 伊人网综合在线 | 91av国产视频 | www.久草| 国产极品视频在线观看 | av一级毛片 | 国外成人在线视频网站 | 国产综合视频在线观看 | 日韩在线不卡 | 午夜成年人 | 99久久久国产精品 | 国产精品伦理 | 中文在线一区 | 日韩中文字幕在线观看 | 国产成人片 | 国产三区四区 | www.久久 | 欧美日韩亚洲在线 | 最新黄色网页 | 欧美一区二区三区视频 | 欧美一区二区三 | 欧美一区二区黄色片 | 狠狠插狠狠操 | 国产精品成人国产乱一区 | 一级黄色片aaa | 97成人在线 | 日韩免费视频中文字幕 | 国产日韩一区二区 | 国产性网 | 在线精品国产 | 国产在视频一区二区三区吞精 | 日本一区二区精品视频 | 日韩欧美在线视频 | 亚洲精品一区二区三区在线播放 | 久久综合九九 | 日韩一二三区视频 | 精品一区二区久久久久久久网站 | 99视频在线 | 一级一级黄色片 | 成人欧美一区二区 | 亚洲高清在线观看 | 久久久久久亚洲 | 国产一级黄色大片 | 天天操网 | 亚洲视频观看 | 91一区二区三区 | 日韩在线视频在线观看 | www.国产精品.com | 99色播| 久久精品久久久久久久久久16 | 色综合天天综合网国产成人网 | 中文字幕视频三区 | 国产精品久久久久久吹潮 | 久久电影国产 | 狠狠操狠狠摸 | 日本精品视频网站 | 日韩在线播放视频 | 精品亚洲一区二区三区 | 美女中文字幕视频 | 亚洲精品视频免费 | 日本69视频 | 欧美成人一区二区三区片免费 | 婷婷午夜激情网 | 欧美激情视频一区二区三区 | 欧美一区二区大片 | 91在线免费视频 | 亚洲天堂久久 | 国产毛片毛片 | 自拍视频在线观看 | 国产精品久久久久久亚洲调教 | 在线观看免费毛片视频 | 欧美日韩国产在线播放 | 久久久精彩视频 | 在线不卡视频 | 97久久久 | 天堂av中文在线 | 欧美综合视频在线观看 | 午夜av成人 | 成人免费淫片aa视频免费 | 在线观看你懂的视频 | 亚洲午夜免费视频 | 成人av观看| 亚洲精品乱码久久久久久久久 | 国产情品 | 国产精品自产av一区二区三区 | 在线观看免费视频91 | 中文字幕亚洲一区二区三区 | 国产精品久久久久久久午夜 | 一区二区视频在线观看 | 国产高清精品一区二区三区 | 成人毛片在线观看 | 国产福利片在线观看 | 国产一区二区精品在线观看 | 国产剧情一区二区 | 久久88| 亚洲电影在线观看 | 亚洲国产字幕 | 亚洲欧美一区二区三区在线 | 免费黄看片 | 久久av网 | 三级色网站| 一级片在线观看视频 | 一区二区三区四区视频 | 大象视频成人在线观看 | 91视频国产网站 | 亚洲精品久久久久久久久久久 | 欧美大片一区 | 粉嫩高清一区二区三区精品视频 | 美女福利视频网站 | 亚洲综合一区二区三区 | 日韩性猛交 | 99热在线观看免费 | 国产精品久久精品 | 亚洲国产精品久久久久久女王 | www婷婷| 免费av在线网站 | 亚洲精品久久 | 中文字幕在线免费看 | 精品国产一区二区三区四区 | 亚洲成人免费视频在线观看 | 激情欧美一区二区三区中文字幕 | 男人天堂视频网 | 你懂的在线视频播放 | 久久综合入口 | 亚洲另类视频 | 国产一区在线观看视频 | 国产精久久一区二区三区 | 精品一区二区国产 | 午夜精品视频在线观看 | 日产精品久久 | 成人在线观看网 | 国产aⅴ一区二区 | 不卡的毛片| 亚洲不卡视频在线 | 噜噜噜在线视频 | 这里有精品视频 | 日日操操 | 成人一区视频 | 麻豆国产免费 | 日韩中文字幕av | 国产精品视频一二三区 | 一级欧美在线 | 国产精品久久久久久久久久三级 | 国产乱码精品1区2区3区 | 中文字幕在线网址 | 免费观看黄色一级大片 | 国产一区二区在线观看视频 | 狠狠躁夜夜躁人人爽天天高潮 | 久久久久国产精品视频 | 亚洲国产精品一区 | 久久99国产精品久久99大师 | 成人在线网址 | 欧美日韩精品综合 | 一区二区三区四区不卡视频 | 看毛片网站 | 综合久久久久久久 | 日韩中文字幕在线免费 | 午夜精品一区 | 高清成人| 狠狠操操 | 精品日韩在线观看 | 91久久精品日日躁夜夜躁欧美 | 男女18免费网站视频 | 天天天干天天射天天天操 | 色欧美片视频在线观看 | 精品成人一区 | 91精品电影 | 羞羞视频在线观免费观看 | www国产在线观看 | 色视频www在线播放国产人成 | 免费一区二区三区 | 久久精品伊人 | 日韩一区二区在线免费观看 | 国产精品久久久久久久久久久久久 | 夜夜夜久久久 | 亚洲精品一区二区三区精华液 | 99国产精品99久久久久久 | 日本亚洲欧美 | 久久www免费人成看片高清 | 日本污视频在线观看 | 欧美在线国产 | 欧美亚洲激情 | www.福利视频| 国产青青草 | 在线免费国产 | 亚洲高清视频一区 | 狠狠综合久久av一区二区小说 | 一级黄色av片 | 欧美激情精品久久久久 | 在线免费观看黄色 | 中文字幕爱爱视频 | 国产wwwcom| 欧美区国产区 | 中文字幕日韩欧美 | 美女黄网站视频免费 | 欧美国产一区二区 | 电影午夜精品一区二区三区 | 手机看片国产精品 | 99精品欧美一区二区三区综合在线 | 国产99久久 | 国产精品久久久久一区二区三区 | 91麻豆精品国产91久久久资源速度 | 欧美午夜在线观看 | 手机在线观看av | 亚洲欧美在线免费观看 | 久草视频在线观 | 能免费看av的网站 | 成人欧美亚洲 | 亚洲精品在线播放 | 日韩欧美黄色 | 久久久国产精品视频 | 久久精品 | 亚洲精品视 | 国产成人jvid在线播放 | 国产91亚洲精品 | 99国产精品视频免费观看一公开 | 一区二区三区精品 | 成人在线免费视频 | 日韩三区| 欧美精品区 | 91亚洲精| 天天插天天操 | www,99热| 97伦理网 | 中文字幕在线欧美 | 成人av片在线观看 | 国产视频第一页 | 午夜色电影 | www.久久99 | 亚洲乱码一区二区三区在线观看 | 中文字幕日韩在线 | 久久午夜精品 | 久久国产精品久久久久久久久久 | 日本三级电影免费 | 亚洲电影免费 | 亚洲成人免费在线 | 欧美一区视频 | 欧洲美女7788成人免费视频 | 国产超碰人人爽人人做人人爱 | 久久久99精品免费观看 | 欧美日本一区 | 91精品国产色综合久久不卡98 | 国产在线不卡一区 | 欧美日韩在线视频观看 | 97色婷婷成人综合在线观看 | 亚洲综合日韩 | 在线免费观看黄 | 日韩精品一区二区三区老鸭窝 | 青青久久久 | 国产精品久久久久久一区二区三区 | 三级视频在线观看 | 国产精品久久久久久久久久久久久久 | 成人国产精品视频 | 成人在线视频免费观看 | 免费亚洲精品 | 国产成人免费视频 | 91久久夜色精品国产九色 | 91精品久久久久久久久中文字幕 | 久久亚洲国产精品 | 99精品欧美一区二区三区综合在线 | 天堂av一区 | 日韩激情综合网 | 99精品一区二区 | 久久国产精品99久久久久久牛牛 | 久久人人爽人人爽人人片av不 | 日韩成人在线影院 | 国产区第一页 | 91精品久久久久久久久中文字幕 | 久草视频免费看 | 精品一区二区三区三区 | 国产精彩视频 | 精品一区二区电影 | 在线亚洲一区 | 亚洲视频在线观看网址 | 欧美中文日韩 | 亚洲国产成人91精品 | 无毒黄网 | 草草网| 91精品久久久久久久久久 | 亚洲国产一区二区三区 | 可以在线观看的黄色 | 亚洲男人天堂网 | 免费欧美一级 | 成人免费视频视频在线观看 免费 | 偷拍做爰吃奶视频免费看 | 欧美极品视频 | 久草视频在线播放 | 一区二区三区免费在线观看 | 欧美一区二区精品 | 国产免费一区二区三区四区五区 | 日本在线播放 | 亚洲大片69999 | 自拍视频在线观看 | 亚洲精品在线国产 | 亚洲成人一 | 欧美中文字幕 | 久久成人在线视频 | 久久噜噜噜精品国产亚洲综合 | 成人午夜精品久久久久久久蜜臀 | www.国产.com | 懂色一区二区三区av片 | 久久亚洲国产视频 | 成人免费视频视频在线观看 免费 | 欧美国产一区二区三区 | 国产欧美在线观看 | 成人天堂666 | 九九精品视频在线 | 国产高清美女一级a毛片久久 | 亚洲成人精品一区二区三区 | 日韩精品一二三区 | 国产一级视频免费观看 | 日韩成人免费 | 日韩欧美精品一区二区三区 | 午夜激情在线播放 | 香蕉大人久久国产成人av | 黄色一级片看看 | 亚洲精品一区国产精品 | 国产精品色综合 | 久久99一区 | 国产精品成人国产乱一区 | 日本黄色片免费看 | 在线视频亚洲 | 91亚洲国产精品 | 精品一区二区三区中文字幕 | 日韩一区电影 | 亚洲成a | 国偷自产av一区二区三区 | 国产男女爽爽爽免费视频 | 91成人免费在线观看 | 午夜精品久久久久久久星辰影院 | 91视在线国内在线播放酒店 | 国产玖玖 | 一区二区三区视频在线免费观看 | 另类a v | 国产大学生一区 | 午夜精品在线 | 精品不卡 | 在线观看亚洲一区二区三区 | 成年人黄色免费视频 | 性瘾调教校园h | 日日摸天天做天天添天天欢 | 无码日韩精品一区二区免费 | 久久91| 色婷综合网 | 久久午夜影院 | 精品国产精品 | 日韩成人一区二区 |