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

Docker容器網(wǎng)絡(luò)下UDP協(xié)議的一個(gè)問題

開發(fā) 前端
最近在工作中遇到一個(gè)docker容器下UDP協(xié)議網(wǎng)絡(luò)不通的問題,困擾了很久,也比較有意思,所以想寫下來和大家分享。

最近在工作中遇到一個(gè) docker 容器下 UDP 協(xié)議網(wǎng)絡(luò)不通的問題,困擾了很久,也比較有意思,所以想寫下來和大家分享。

我們有個(gè)應(yīng)用是 UDP 協(xié)議的,部署上去發(fā)現(xiàn)無法工作,但是換成 TCP 協(xié)議是可以的(應(yīng)用同時(shí)支持 UDP、TCP 協(xié)議,切換成 TCP 模式發(fā)現(xiàn)一切正常)。雖然換成 TCP 能解決問題,但是我們還是想知道到底 UDP 協(xié)議在網(wǎng)絡(luò)模式下為什么會出現(xiàn)這個(gè)問題,以防止后面其他 UDP 應(yīng)用會有異常。

這個(gè)問題抽象出來是這樣的:如果有 UDP 服務(wù)運(yùn)行在主機(jī)上(或者運(yùn)行在網(wǎng)絡(luò)模型為 Host 的容器里),并且監(jiān)聽在 0.0.0.0 地址(也就是所有的 ip 地址),從運(yùn)行在 docker bridge 網(wǎng)絡(luò)的容器運(yùn)行客戶端訪問服務(wù),兩者通信有問題。

注意以上的的限制條件,通過測試,我們發(fā)現(xiàn)下來幾種情況都是正常的:

  • 使用 TCP 協(xié)議沒有這個(gè)問題,這個(gè)已經(jīng)說過了
  • 如果 UDP 服務(wù)器監(jiān)聽在 eth0 IP 地址上也不會出現(xiàn)這個(gè)問題
  • 并不是所有的應(yīng)用都有這個(gè)問題,我們的 DNS(dnsmasq + kubeDNS) 也是同樣的部署方式,但是功能都正常

這個(gè)問題在 docker 上也有 issue 記錄:https://github.com/moby/moby/issues/15127,但是目前并沒有合理的解決方案。

這篇文章就分析一下出現(xiàn)這個(gè)問題的原因,希望給同樣遇到這個(gè)問題的讀者提供些幫助。

問題重現(xiàn)

這個(gè)問題很容易重現(xiàn),我的實(shí)驗(yàn)是在 ubuntu16.04 下用 netcat 命令完成的,其他系統(tǒng)應(yīng)該類似。在主機(jī)上通過 nc 監(jiān)聽 56789 端口,然后在容器里使用 nc 發(fā)數(shù)據(jù)。***個(gè)報(bào)文是能發(fā)送出去的,但是以后的報(bào)文雖然在網(wǎng)絡(luò)上能看到,但是對方無法接收。

在主機(jī)上運(yùn)行 nc UDP 服務(wù)器( -u 表示 UDP 協(xié)議, -l 表示監(jiān)聽的端口)

  1. $ nc -ul 56789 

然后啟動一個(gè)容器,運(yùn)行客戶端:

 

  1. $ docker run -it apline sh 
  2. / # nc -u 172.16.13.13 56789 

nc 的通信是雙方的,不管對方輸入什么字符,回車后對方就能立即收到。但是在這個(gè)模式下,客戶端***次輸入對方能夠收到,后續(xù)的報(bào)文對方都收不到。

在這個(gè)實(shí)驗(yàn)中,容器使用的是 docker 的默認(rèn)網(wǎng)絡(luò),容器的 ip 是 172.17.0.3,通過 veth pair(圖中沒有顯示)連接到虛擬網(wǎng)橋 docker0(ip 地址為 172.17.0.1),主機(jī)本身的網(wǎng)絡(luò)為 eth0,其 ip 地址為 172.16.13.13。

 

  1. 172.17.0.3 
  2. +----------+ 
  3. |   eth0   | 
  4. +----+-----+ 
  5.      | 
  6.      | 
  7.      | 
  8.      | 
  9. +----+-----+          +----------+ 
  10. | docker0  |          |  eth0    | 
  11. +----------+          +----------+ 
  12. 172.17.0.1            172.16.13.13 

tcpdump 抓包

遇到這種疑難雜癥,***個(gè)想到的抓包,我們需要在 docker0 上抓包,因?yàn)檫@是報(bào)文必經(jīng)過的地方。通過過濾容器的 ip 地址,很容器找到感興趣的報(bào)文:

  1. $ tcpdump -i docker0 -nn host 172.17.0.3 

為了模擬多數(shù)應(yīng)用一問一答的通信方式,我們一共發(fā)送三個(gè)報(bào)文,并用 tcpdump 抓取 docker0 接口上的報(bào)文:

  1. 客戶端先向服務(wù)器端發(fā)送 hello 字符串
  2. 服務(wù)器端回復(fù) world
  3. 客戶端繼續(xù)發(fā)送 hi 消息

抓包的結(jié)果如下,可以發(fā)現(xiàn)***個(gè)報(bào)文發(fā)送出去沒有任何問題(因?yàn)?UDP 是沒有 ACK 報(bào)文的,所以客戶端無法知道對方有沒有收到,這里說的沒有問題是值沒有對應(yīng)的 ICMP 報(bào)文),但是第二個(gè)報(bào)文從服務(wù)端發(fā)送的報(bào)文,對方會返回一個(gè) ICMP 告訴端口 38908 不可達(dá);第三個(gè)報(bào)文從客戶端發(fā)送的報(bào)文也是如此。以后的報(bào)文情況類似,雙方再也無法進(jìn)行通信了。

 

  1. 11:20:43.973286 IP 172.17.0.3.38908 > 172.16.13.13.56789: UDP, length 6 
  2. 11:20:50.102018 IP 172.17.0.1.56789 > 172.17.0.3.38908: UDP, length 6 
  3. 11:20:50.102129 IP 172.17.0.3 > 172.17.0.1: ICMP 172.17.0.3 udp port 38908 unreachable, length 42 
  4. 11:20:54.503198 IP 172.17.0.3.38908 > 172.16.13.13.56789: UDP, length 3 
  5. 11:20:54.503242 IP 172.16.13.13 > 172.17.0.3: ICMP 172.16.13.13 udp port 56789 unreachable, length 39 

而此時(shí)主機(jī)上 UDP nc 服務(wù)器并沒有退出,使用 lsof -i :56789 可能看到它仍然在監(jiān)聽著該端口。

問題原因

從網(wǎng)絡(luò)報(bào)文的分析中可以看到服務(wù)端返回的報(bào)文源地址不是我們預(yù)想的 eth0 地址,而是 docker0 的地址,而客戶端直接認(rèn)為該報(bào)文是非法的,返回了 ICMP 的報(bào)文給對方。

那么問題的原因也可以分為兩個(gè)部分:

  1. 為什么應(yīng)答報(bào)文源地址是 錯(cuò)誤的 ?
  2. 既然 UDP 是無狀態(tài)的,內(nèi)核怎么判斷源地址不正確呢?

主機(jī)多網(wǎng)絡(luò)接口 UDP 源地址選擇問題

***個(gè)問題的關(guān)鍵詞是:UDP 和多網(wǎng)絡(luò)接口。因?yàn)槿绻鳈C(jī)上只有一個(gè)網(wǎng)絡(luò)接口,發(fā)出去的報(bào)文源地址一定不會有錯(cuò);而我們也測試過 TCP 協(xié)議是能夠處理這個(gè)問題的。

通過搜索,發(fā)現(xiàn)這確實(shí)是個(gè)已知的問題。在 UNP() 這本書中,已經(jīng)描述過這個(gè)問題,下面是對應(yīng)的內(nèi)容:

Docker容器網(wǎng)絡(luò)下UDP協(xié)議的一個(gè)問題

這個(gè)問題可以歸結(jié)為一句話:UDP 在多網(wǎng)卡的情況下,可能會發(fā)生服務(wù)器端源地址不對的情況,這是內(nèi)核選路的結(jié)果。 為什么 UDP 和 TCP 有不同的選路邏輯呢?因?yàn)?UDP 是無狀態(tài)的協(xié)議,內(nèi)核不會保存連接雙方的信息,因此每次發(fā)送的報(bào)文都認(rèn)為是獨(dú)立的,socket 層每次發(fā)送報(bào)文默認(rèn)情況不會指明要使用的源地址,只是說明對方地址。因此,內(nèi)核會為要發(fā)出去的報(bào)文選擇一個(gè) ip,這通常都是報(bào)文路由要經(jīng)過的設(shè)備 ip 地址。

有了這個(gè)原因,還要解釋一下問題: 為什么 dnsmasq 服務(wù)沒有這個(gè)問題呢 ?因此我使用 strace 工具抓取了 dnsmasq 和出問題應(yīng)用的網(wǎng)絡(luò) socket 系統(tǒng)調(diào)用,來查看它們兩個(gè)到底有什么區(qū)別。

dnsmasq 在啟動階段監(jiān)聽了 UDP 和 TCP 的 54 端口(因?yàn)槭窃诒镜貦C(jī)器上測試的,為了防止和本地 DNS 監(jiān)聽的 DNS端口沖突,我選擇了 54 而不是標(biāo)準(zhǔn)的 53 端口):

 

  1. socket(PF_INET, SOCK_DGRAM, IPPROTO_IP) = 4 
  2. setsockopt(4, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0 
  3. bind(4, {sa_family=AF_INET, sin_port=htons(54), sin_addr=inet_addr("0.0.0.0")}, 16) = 0 
  4. setsockopt(4, SOL_IP, IP_PKTINFO, [1], 4) = 0 
  5.  
  6. socket(PF_INET, SOCK_STREAM, IPPROTO_IP) = 5 
  7. setsockopt(5, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0 
  8. bind(5, {sa_family=AF_INET, sin_port=htons(54), sin_addr=inet_addr("0.0.0.0")}, 16) = 0 
  9. listen(5, 5)                            = 0 

比起 TCP,UDP 部分少了 listen ,但是多個(gè) setsockopt(4, SOL_IP, IP_PKTINFO, [1], 4) 這句。到底這兩點(diǎn)和我們的問題是否有關(guān),先暫時(shí)放著,繼續(xù)看傳輸報(bào)文的部分。

dnsmasq 收包和發(fā)包的系統(tǒng)調(diào)用,直接使用 recvmsg 和 sendmsg 系統(tǒng)調(diào)用:

 

  1. recvmsg(4, {msg_name(16)={sa_family=AF_INET, sin_port=htons(52072), sin_addr=inet_addr("10.111.59.4")}, msg_iov(1)=[{"\315\n\1 \0\1\0\0\0\0\0\1\fterminal19-0\5u5016\3"..., 4096}], msg_controllen=32, {cmsg_len=28, cmsg_level=SOL_IP, cmsg_type=, ...}, msg_flags=0}, 0) = 67  
  2. sendmsg(4, {msg_name(16)={sa_family=AF_INET, sin_port=htons(52072), sin_addr=inet_addr("10.111.59.4")}, msg_iov(1)=[{"\315\n\201\200\0\1\0\1\0\0\0\1\fterminal19-0\5u5016\3"..., 83}], msg_controllen=28, {cmsg_len=28, cmsg_level=SOL_IP, cmsg_type=, ...}, msg_flags=0}, 0) = 83 

而出問題的應(yīng)用 strace 結(jié)果如下:

 

  1. [pid   477] socket(PF_INET6, SOCK_DGRAM, IPPROTO_IP) = 124 
  2. [pid   477] setsockopt(124, SOL_IPV6, IPV6_V6ONLY, [0], 4) = 0 
  3. [pid   477] setsockopt(124, SOL_IPV6, IPV6_MULTICAST_HOPS, [1], 4) = 0 
  4. [pid   477] bind(124, {sa_family=AF_INET6, sin6_port=htons(6088), inet_pton(AF_INET6, "::", &sin6_addr), sin6_flowinfo=0, sin6_scope_id=0}, 28) = 0 
  5.  
  6. [pid   477] getsockname(124, {sa_family=AF_INET6, sin6_port=htons(6088), inet_pton(AF_INET6, "::", &sin6_addr), sin6_flowinfo=0, sin6_scope_id=0}, [28]) = 0 
  7. [pid   477] getsockname(124, {sa_family=AF_INET6, sin6_port=htons(6088), inet_pton(AF_INET6, "::", &sin6_addr), sin6_flowinfo=0, sin6_scope_id=0}, [28]) = 0 
  8.  
  9. [pid   477] recvfrom(124, "j\201\2450\201\242\241\3\2\1\5\242\3\2\1\n\243\0160\f0\n\241\4\2\2\0\225\242\2\4\0"..., 2048, 0, {sa_family=AF_INET6, sin6_port=htons(38790), inet_pton(AF_INET6, "::ffff:172.17.0.3", &sin6_addr), sin6_flowinfo=0, sin6_scope_id=0}, [28]) = 168 
  10.  
  11. [pid   477] sendto(124, "k\202\2\0210\202\2\r\240\3\2\1\5\241\3\2\1\v\243\5\33\3TDH\244\0220\20\240\3\2"..., 533, 0, {sa_family=AF_INET6, sin6_port=htons(38790), inet_pton(AF_INET6, "::ffff:172.17.0.3", &sin6_addr), sin6_flowinfo=0, sin6_scope_id=0}, 28) = 533 

其對應(yīng)的邏輯是這樣的:使用 ipv6 綁定在 0.0.0.0 和 6088 端口,調(diào)用 getsockname 獲取當(dāng)前 socket 綁定的端口信息,數(shù)據(jù)傳輸過程使用的是 recvfrom 和 sendto 。

對比下來,兩者的不同有幾點(diǎn):

  • 后者使用的是 ipv6,而前者是 ipv4
  • 后者使用 recvfrom 和 sendto 傳輸數(shù)據(jù),而前者是 sendmsg 和 recvmsg
  • 前者有調(diào)用 setsockopt 設(shè)置 IP_PKTINFO 的值,而后者沒有

因?yàn)槭窃趥鬏敂?shù)據(jù)的時(shí)候出錯(cuò)的,因此***個(gè)疑點(diǎn)是 sendmsg 和 sendto 的某些區(qū)別導(dǎo)致選擇源地址有不同,通過 man sendto 可以知道 sendmsg 包含了更多的控制信息在 msghdr 。一個(gè)合理的猜測是 msghdr 中包含了內(nèi)核選擇源地址的信息!

通過查找,發(fā)現(xiàn) IP_PKTINFO 這個(gè)選項(xiàng)就是讓內(nèi)核在 socket 中保存 IP 報(bào)文的信息,當(dāng)然也包括了報(bào)文的源地址和目的地址。 IP_PKTINFO 和 msghdr 的關(guān)系可以在這個(gè) stackoverflow 中找到:https://stackoverflow.com/questions/3062205/setting-the-source-ip-for-a-udp-socket。

而 man 7 ip 文檔中也說明了 IP_PKTINFO 是怎么控制源地址選擇的:

 

  1. IP_PKTINFO (since Linux 2.2) 
  2.               Pass  an  IP_PKTINFO  ancillary message that contains a pktinfo structure that supplies some information about the incoming packet.  This only works for datagram ori‐ 
  3.               ented sockets.  The argument is a flag that tells the socket whether the IP_PKTINFO message should be passed or not.  The message itself can only be sent/retrieved as 
  4.               control message with a packet using recvmsg(2) or sendmsg(2). 
  5.  
  6.                   struct in_pktinfo { 
  7.                       unsigned int   ipi_ifindex;  /* Interface index */ 
  8.                       struct in_addr ipi_spec_dst; /* Local address */ 
  9.                       struct in_addr ipi_addr;     /* Header Destination 
  10.                                                       address */ 
  11.                   }; 
  12.  
  13.               ipi_ifindex  is the unique index of the interface the packet was received on.  ipi_spec_dst is the local address of the packet and ipi_addr is the destination address 
  14.               in the packet header.  If IP_PKTINFO is passed to sendmsg(2) and ipi_spec_dst is not zero, then it is used as the local source address for the  routing  table  lookup 
  15.               and  for  setting up IP source route options.  When ipi_ifindex is not zero, the primary local address of the interface specified by the index overwrites ipi_spec_dst 
  16.               for the routing table lookup. 

如果 ipi_spec_dst 和 ipi_ifindex 不為空,它們都能作為源地址選擇的依據(jù),而不是讓內(nèi)核通過路由決定。

也就是說,通過設(shè)置 IP_PKTINFO socket 選項(xiàng)為 1,然后使用 recvmsg 和 sendmsg 傳輸數(shù)據(jù)就能保證源地址選擇符合我們的期望。這也是 dnsmasq 使用的方案,而出問題的應(yīng)用是因?yàn)槭褂昧四J(rèn)的 recvfrom 和 sendto 。

關(guān)于 UDP 連接的疑惑

另外一個(gè)疑惑是:為什么內(nèi)核會把源地址和之前不同的報(bào)文丟棄?認(rèn)為它是非法的?因?yàn)槲覀兦懊嬉呀?jīng)說過,UDP 協(xié)議是無連接的,默認(rèn)情況下 socket 也不會保存雙方連接的信息。即使服務(wù)端發(fā)送報(bào)文的源地址有誤,只要對方能正常接收并處理,也不會導(dǎo)致網(wǎng)絡(luò)不通。

因?yàn)?conntrack,內(nèi)核的 netfilter 模塊會保存連接的狀態(tài),并作為防火墻設(shè)置的依據(jù)。它保存的 UDP 連接,只是簡單記錄了主機(jī)上本地 ip 和端口,和對端 ip 和端口,并不會保存更多的內(nèi)容。

可以參考 intables info 網(wǎng)站的文章:http://www.iptables.info/en/connection-state.html#UDPCONNECTIONS。

在找到根源之前,我們曾經(jīng)嘗試過用 SNAT 來修改服務(wù)端應(yīng)答報(bào)文的源地址,期望能夠修復(fù)該問題。但是卻發(fā)現(xiàn)這種方法行不通,為什么呢?

因?yàn)?SNAT 是在 netfilter ***做的,在之前 netfilter 的 conntrack 因?yàn)椴徽J(rèn)識該 connection,直接丟棄了,所以即使添加了 SNAT 也是無法工作的。

那能不能把 conntrack 功能去掉呢?比如解決方案:

 

  1. iptables -I OUTPUT -t raw -p udp --sport 5060 -j CT --notrack 
  2. iptables -I PREROUTING -t raw -p udp --dport 5060 -j CT --notrack 

答案也是否定的,因?yàn)?NAT 需要 conntrack 來做翻譯工作,如果去掉 conntrack 等于 SNAT 完全沒用。

解決方案

知道了問題的原因,解決方案也就很容易找到。

使用 TCP 協(xié)議

如果服務(wù)端和客戶端使用 TCP 協(xié)議進(jìn)行通信,它們之間的網(wǎng)絡(luò)是正常的。

  1. $ nc -l 56789 

監(jiān)聽在特定端口

使用 nc 啟動一個(gè) udp 服務(wù)器,監(jiān)聽在 eth0 上:

  1. ➜ ~ nc -ul 172.16.13.13 56789 

nc 可以跟兩個(gè)參數(shù),分別代表 ip 和 端口,表示服務(wù)端監(jiān)聽在某個(gè)特定 ip 上。如果接收到的報(bào)文目的地址不是 172.16.13.13,也會被內(nèi)核直接丟棄。

這種情況下,服務(wù)端和客戶端也能正常通信。

改動應(yīng)用程序?qū)崿F(xiàn)

修改應(yīng)用程序的邏輯,在 UDP socket 上設(shè)置 IP_PKTIFO ,并通過 recvmsg 和 sendmsg 函數(shù)傳輸數(shù)據(jù)。

責(zé)任編輯:未麗燕 來源: Cizixs Writes Here
相關(guān)推薦

2014-06-13 13:47:31

UDP

2010-07-09 11:12:09

UDP協(xié)議

2010-07-07 10:45:22

TCP UDP協(xié)議

2015-05-12 10:26:56

iptraf運(yùn)維工具

2010-06-29 12:42:05

UDP協(xié)議Java

2024-08-20 21:27:04

docker部署容器

2020-07-28 08:38:10

TCPUDP協(xié)議

2020-11-20 10:50:01

Docker容器

2010-07-06 15:16:34

UDP協(xié)議

2024-02-26 18:11:08

Docker容器鏡像

2025-02-13 07:00:00

Dubbo-goJava服務(wù)端

2010-08-03 22:09:16

2013-08-01 10:01:02

網(wǎng)絡(luò)協(xié)議TCP協(xié)議UDP協(xié)議

2010-06-28 15:45:07

UDP協(xié)議

2020-01-03 07:57:39

UDPTCP網(wǎng)絡(luò)協(xié)議

2010-07-05 16:17:18

UDP協(xié)議

2010-07-08 12:42:34

UDP協(xié)議

2010-07-12 21:14:09

UDP協(xié)議

2010-07-01 16:55:03

UDP協(xié)議

2010-07-07 11:17:01

UDP協(xié)議應(yīng)用
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

国产专区综合网| heyzo久久| 性做久久久久久| 久久国产精品一区二区三区| 日日夜夜狠狠操| 不卡在线一区二区| 精品少妇一区二区| 大肉大捧一进一出好爽视频| 色综合久久影院| 国产ts人妖一区二区| 欧洲亚洲免费视频| 国产高潮国产高潮久久久91| 天堂av一区二区三区在线播放| 欧美亚洲国产bt| 日本人体一区二区| 亚乱亚乱亚洲乱妇| 99久久精品一区| 91精品久久久久久久久青青| 国产午夜小视频| 久久在线免费| 日韩毛片在线观看| 在线免费观看av网| 超碰国产一区| 亚洲一区二区视频在线观看| 午夜精品一区二区在线观看的 | 国产成人精品一区二区三区福利| 国产一区免费看| 亚洲久久一区二区| 久久视频中文字幕| 成人一级片免费看| 欧美精美视频| 日韩精品免费在线视频| 四虎国产精品永久免费观看视频| 国产成人精品123区免费视频| 亚洲午夜久久久久久久久久久| 亚洲一区二区三区乱码| 噜噜噜噜噜在线视频| 播五月开心婷婷综合| 1卡2卡3卡精品视频| 特级西西444www高清大视频| 国产精品日韩久久久| 色综合天天狠天天透天天伊人 | 深夜福利久久| 日韩电影大片中文字幕| 精品伦一区二区三区| 精品一区视频| 欧美一区二区三区在线看| 午夜激情av在线| 456成人影院在线观看| 欧美丝袜一区二区| 久久这里只有精品18| av网站导航在线观看免费| 国产精品成人一区二区艾草| 日韩精品福利视频| 国产最新视频在线| 国产欧美日韩一区二区三区在线观看 | 亚洲一区欧美在线| 999在线观看精品免费不卡网站| 欧美激情第99页| 久久精品国产av一区二区三区| 亚洲欧美文学| 久久男人的天堂| 可以在线观看av的网站| 欧美亚洲一区二区三区| 国产国语刺激对白av不卡| 亚洲第一网站在线观看| 日韩国产精品久久久久久亚洲| 国产精品极品美女在线观看免费 | 精品女同一区二区| 中文字幕乱视频| 秋霞影院一区二区三区| 亚洲天堂成人在线| 国产精品夜夜夜爽阿娇| 亚洲精品一区二区妖精| 欧美理论电影在线播放| 国产午夜精品无码一区二区| 亚洲在线国产日韩欧美| 国产精品久久久精品| 97超视频在线观看| 国产在线精品国自产拍免费| 国产精品日韩欧美一区二区三区| 女人18毛片一区二区三区| 99视频精品在线| 色女人综合av| 青青青国内视频在线观看软件| 亚洲国产日日夜夜| 五月天婷婷激情视频| 91亚洲精品在看在线观看高清| 日韩一区二区三区观看| 日韩av一二区| 国产精品国产一区| 国外成人免费在线播放| 国语对白做受69按摩| 国模无码大尺度一区二区三区| 国产精品一区二区不卡视频| 国产视频精选在线| 一区二区三区在线免费观看 | 欧美被狂躁喷白浆精品| 久久精品国产清高在天天线| 成人午夜高潮视频| 日韩欧美在线观看一区二区| 综合av第一页| 欧美黄色免费影院| 日本精品在线播放 | 国产一区二区精品在线| av影片免费在线观看| 亚洲一级二级在线| 奇米影音第四色| 久久久亚洲欧洲日产| 精品精品国产国产自在线| 中文字幕亚洲精品一区| 国内精品久久久久影院一蜜桃| 免费一区二区三区| 欧美性受ⅹ╳╳╳黑人a性爽| 在线免费观看一区| 人妻 日韩 欧美 综合 制服| 久久综合电影| 欧美在线视频一区二区| 亚洲精品久久久蜜桃动漫| 中文字幕二三区不卡| 欧美变态另类刺激| 亚洲国产高清在线观看| 中文字幕亚洲一区在线观看| www.中文字幕在线观看| 国产91在线看| 天堂av在线中文| 九九久久国产| 亚洲全黄一级网站| 国产又大又黄又粗| jlzzjlzz亚洲日本少妇| 日韩一级免费看| 成人51免费| 波霸ol色综合久久| a片在线免费观看| 久久久久久亚洲综合影院红桃| 日韩精品一区二区免费| 久久综合偷偷噜噜噜色| 日韩在线视频国产| 中文字幕丰满人伦在线| 久久久www成人免费无遮挡大片| 欧美不卡在线播放| 国产精品任我爽爆在线播放| 欧美大片第1页| h狠狠躁死你h高h| 亚洲丝袜精品丝袜在线| 日本美女久久久| 欧美激情777| 91精品久久久久久久久中文字幕| 欧洲日本在线| 4438x成人网最大色成网站| 操她视频在线观看| 精品一区免费av| 人人妻人人澡人人爽精品欧美一区| 成人黄色在线| 久久精品国产清自在天天线| 国产精品久久久久久久免费| 综合久久给合久久狠狠狠97色| 中文字幕中文在线| 欧美日韩ab| 国产精品久久亚洲7777| 理论片午夜视频在线观看| 亚洲国产精品999| 五月激情六月丁香| 国产欧美日本一区二区三区| 日本中文字幕精品—区二区| 伊人久久大香线蕉综合四虎小说| 亚洲自拍小视频| av中文字幕在线观看第一页 | avtt亚洲| 日韩午夜中文字幕| 精品在线播放视频| 欧美国产一区在线| 午夜啪啪小视频| 欧美精品国产一区| 蜜桃传媒视频麻豆第一区免费观看 | 国产成人av网| 男人在线资源站| 亚洲第一精品电影| 亚洲精品一区二三区| 国产精品大尺度| 免费黄色三级网站| 麻豆久久久久久| 人妻互换免费中文字幕| 国产探花一区在线观看| 91久久精品久久国产性色也91| 后进极品白嫩翘臀在线播放| 亚洲毛片在线观看.| 97人妻精品一区二区三区视频 | 日韩免费毛片视频| 亚洲精品一区二区妖精| 麻豆视频成人| 精品国产第一国产综合精品| 97视频人免费观看| 日本高清中文字幕在线| 亚洲国产黄色片| 91亚洲国产成人久久精品麻豆| 污片在线观看一区二区 | 夜夜嗨av一区二区三区四季av| 亚洲天堂视频一区| 国产精品1区2区| 免费一级特黄录像| 亚洲日产国产精品| 中文字幕乱码免费| 欧美日本成人| 国产欧美日韩一区| 国产精品**亚洲精品| 浅井舞香一区二区| 美女日批视频在线观看| 日韩视频免费大全中文字幕| 亚洲区小说区图片区| 日韩欧美国产小视频| 色老头一区二区| 婷婷国产v国产偷v亚洲高清| 男人的午夜天堂| 久久久精品天堂| 97精品人人妻人人| 国产老肥熟一区二区三区| 日韩av一二三四| 国产午夜精品一区二区三区欧美| 9l视频自拍9l视频自拍| 日本一区二区免费高清| 欧美人与性禽动交精品| 国产一区二区三区亚洲| 7777精品伊久久久大香线蕉语言| 精品176极品一区| 日本韩国在线不卡| 中文字幕在线看片| 国外成人性视频| 超碰在线中文字幕| 欧美激情喷水视频| 直接在线观看的三级网址| 久久九九国产精品怡红院 | 欧美中文字幕视频| 日韩理论视频| 97婷婷涩涩精品一区| 丁香花在线电影小说观看| 美日韩精品免费视频| 在线中文字幕视频观看| 蜜月aⅴ免费一区二区三区 | 天堂在线视频免费观看| 精品sm在线观看| 黄频在线免费观看| 精品999久久久| 人妻一区二区三区| 欧美精品一区二| 亚洲 欧美 激情 另类| 亚洲国产97在线精品一区| 欧美 中文字幕| 日韩av网站在线| 青青草在线免费观看| 亚洲欧美日韩爽爽影院| 国产在线观看免费网站| 在线成人激情视频| 精品视频在线一区二区| 久久综合免费视频| 黄网站在线观| 97超碰国产精品女人人人爽| av资源亚洲| 国产噜噜噜噜噜久久久久久久久 | 欧美精品丝袜中出| 精品国产无码一区二区三区| 日韩欧美卡一卡二| 污污的视频网站在线观看| 亚洲欧美国产精品va在线观看| 黄色av免费在线观看| 综合欧美国产视频二区| 国内精品久久久久久野外| 欧美人与性动交| caoprom在线| 国产精品成人在线| 国色天香久久精品国产一区| 国产精品国产一区二区 | 亚洲精品久久在线| 国产永久免费高清在线观看| 中文字幕亚洲二区| 在线播放免费av| 91精品国产乱码久久久久久久久| 欧美××××黑人××性爽| 成人国产在线视频| 国产精品自在线拍| 亚洲国产精品123| 欧美午夜一区二区福利视频| 黄色影院一级片| 久久超级碰视频| 精品无码国产一区二区三区51安| 欧美经典一区二区| 国产无码精品视频| 欧美日本一区二区三区四区| 亚洲乱码精品久久久久.. | a视频在线免费看| 欧美孕妇性xx| 亚洲国产天堂| 久久久婷婷一区二区三区不卡| 色999国产精品| 三上悠亚久久精品| 久久激情五月激情| jizz日本免费| 亚洲乱码国产乱码精品精可以看| 91精品国产高清一区二区三密臀| 在线成人av影院| 免费一级在线观看播放网址| 欧美精品一区二区三区国产精品| 欧美日韩免费看片| 国产精品久久7| 婷婷综合久久| 国产免费人做人爱午夜视频| 国产91露脸合集magnet| 超碰人人人人人人人| 欧美性猛交xxxx免费看| 精品人妻少妇AV无码专区| 中文字幕精品www乱入免费视频| av资源中文在线天堂| 91免费精品视频| jlzzjlzz亚洲女人| 中国丰满人妻videoshd| 国产suv精品一区二区6| 欧美手机在线观看| 色域天天综合网| 欧美在线 | 亚洲| 日韩资源在线观看| 亚洲综合在线电影| 久久av一区二区三区亚洲| 最新亚洲精品| 国产成人无码精品久久久性色| 国产寡妇亲子伦一区二区| 三级黄色片在线观看| 一本在线高清不卡dvd| 日本免费一区视频| 久久久久免费精品国产| 精品国产亚洲日本| 中文字幕在线观看一区二区三区| 久久精品亚洲一区二区| 亚洲av成人无码一二三在线观看| 亚洲宅男天堂在线观看无病毒 | 亚洲免费一在线| 欧美日韩国产观看视频| 国内视频一区二区| 影音先锋亚洲精品| 精品影片一区二区入口| 亚洲电影中文字幕在线观看| 丰满大乳国产精品| 久久久中文字幕| 久久夜色电影| 久久国产亚洲精品无码| 97se亚洲国产综合自在线| 国产精品久久久久久99| 日韩国产一区三区| 性感美女一区二区在线观看| 日本在线高清视频一区| 日本欧美大码aⅴ在线播放| 正在播放国产对白害羞| 欧美日韩精品一区二区三区四区 | 午夜精品蜜臀一区二区三区免费 | 久久久久亚洲av成人毛片韩| 日韩成人在线视频| 欧美日韩成人影院| 亚洲欧洲一区二区在线观看| 久久精品久久综合| 久久久久亚洲AV| 亚洲激情小视频| 成人线上视频| 亚洲精蜜桃久在线| 国产精品一区二区在线看| 久草国产在线观看| 亚洲欧美日韩中文在线制服| 草民电影神马电影一区二区| 一区二区三区四区免费视频| 激情综合色丁香一区二区| 亚洲欧美小视频| 亚洲国产高清福利视频| 中文在线资源| 中文字幕欧美人与畜| 国产黄色91视频| 日韩精品在线不卡| 国产一区二区三区免费视频| 国产成人免费视频网站视频社区 | 精精国产xxx在线视频app| 日本一区二区三区www| 狠狠色丁香婷婷综合| 国产在线一二区| 中文字幕精品网| 成人中文字幕视频| 欧美精品aaaa| 亚洲一区二区偷拍精品| 国产一区二区三区福利| 91久久爱成人| 丝袜亚洲另类丝袜在线| 91视频综合网| 亚洲人成五月天| 日本成人手机在线| 天天爽天天爽夜夜爽| 亚洲最快最全在线视频| av网站无病毒在线| 国产日韩精品久久| 久久黄色级2电影| 中文字幕精品无码一区二区| 久久影视电视剧免费网站| 妖精一区二区三区精品视频 | 欧美日韩精品一区二区三区在线观看| 538任你躁在线精品免费|