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

Docker 網(wǎng)絡(luò)基礎(chǔ) | 虛擬網(wǎng)絡(luò)設(shè)備對(duì)(Veth)原理

云計(jì)算 虛擬化
在容器化大行其道的今天,Docker 可謂是容器界的寵兒。比起笨重的虛擬機(jī),Docker 可謂是身輕如燕。

 [[402397]]

本文轉(zhuǎn)載自微信公眾號(hào)「Linux內(nèi)核那些事」,作者songsong001。轉(zhuǎn)載本文請(qǐng)聯(lián)系Linux內(nèi)核那些事公眾號(hào)。

在容器化大行其道的今天,Docker 可謂是容器界的寵兒。比起笨重的虛擬機(jī),Docker 可謂是身輕如燕。當(dāng)然,本文不是介紹虛擬機(jī)與 Docker 之間的優(yōu)缺點(diǎn),而是介紹 Docker 網(wǎng)絡(luò)中重要的組成部分之一:

虛擬網(wǎng)絡(luò)設(shè)備對(duì):veth

在介紹 veth 前,我們先來(lái)介紹一下 網(wǎng)絡(luò)命名空間(network namespace)。

網(wǎng)絡(luò)命名空間

網(wǎng)絡(luò)命名空間 是 Linux 內(nèi)核用來(lái)隔離不同容器間的網(wǎng)絡(luò)資源(每個(gè) Docker 容器都擁有一個(gè)獨(dú)立的網(wǎng)絡(luò)命名空間),網(wǎng)絡(luò)命名空間主要隔離的資源包括:

  • iptables規(guī)則表
  • 路由規(guī)則表
  • 網(wǎng)絡(luò)設(shè)備列表

如下圖所示,當(dāng)系統(tǒng)中擁有 3 個(gè)網(wǎng)絡(luò)命名空間:

由于不同的網(wǎng)絡(luò)命名空間之間是相互隔離的,所以不同的網(wǎng)絡(luò)命名空間之間并不能直接通信。比如在 網(wǎng)絡(luò)命名空間A 配置了一個(gè) IP 地址為 172.17.42.1 的設(shè)備,但在 網(wǎng)絡(luò)命名空間B 里卻不能訪問(wèn),如下圖所示:

就好比兩臺(tái)電腦,如果沒(méi)有任何網(wǎng)線連接,它們之間是不能通信的。所以,Linux 內(nèi)核提供了 虛擬網(wǎng)絡(luò)設(shè)備對(duì)(veth) 這個(gè)功能,用于解決不同網(wǎng)絡(luò)命名空間之間的通信。

虛擬網(wǎng)絡(luò)設(shè)備對(duì)(veth)

虛擬網(wǎng)絡(luò)設(shè)備對(duì) 用于解決不同網(wǎng)絡(luò)命名空間之間的通信,可以將其看成是兩塊有網(wǎng)線連接的網(wǎng)卡。只要將其中一塊網(wǎng)卡放置到網(wǎng)絡(luò)命名空間A,另外一塊網(wǎng)卡放置到網(wǎng)絡(luò)命名空間B,那么兩個(gè)不同的網(wǎng)絡(luò)命名空間就能夠通信,如下圖所示:

如上圖所示,veth0 與 veth1 組成一個(gè)虛擬網(wǎng)絡(luò)設(shè)備對(duì)。虛擬網(wǎng)絡(luò)設(shè)備對(duì) 就像管道一樣,只要向其中一端發(fā)送數(shù)據(jù),就可以從另外一端接收到數(shù)據(jù)。

Docker 就是使用 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 來(lái)實(shí)現(xiàn)不同容器之間的通信,其原理如下圖:

從上圖可以看出,每個(gè)容器之間并不是直接通過(guò) 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 來(lái)進(jìn)行連接的,而是在主機(jī)上創(chuàng)建一個(gè)名為 docker0 的 網(wǎng)橋,然后通過(guò) 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 來(lái)將各個(gè)容器連接到 網(wǎng)橋 上。網(wǎng)橋 有將多個(gè) 網(wǎng)絡(luò)設(shè)備 連接起來(lái)的能力,就如現(xiàn)實(shí)中的 交換機(jī) 一樣。

當(dāng)然,本文的主題是 veth 的實(shí)現(xiàn),而不是 網(wǎng)橋 的現(xiàn)實(shí),所以對(duì) 網(wǎng)橋 的介紹就此結(jié)束,有興趣可以參考《Linux網(wǎng)橋工作原理與實(shí)現(xiàn)》一文。

虛擬網(wǎng)絡(luò)設(shè)備對(duì)實(shí)現(xiàn)

在 Linux 內(nèi)核中,使用 net_device 對(duì)象來(lái)表示一個(gè)網(wǎng)絡(luò)設(shè)備。由于 veth 提供雙向通信的功能,所以需要使用兩個(gè) net_device 對(duì)象來(lái)實(shí)現(xiàn)。由于 net_device 對(duì)象比較龐大,所以這里只列出本文相關(guān)的字段:

  1. struct net_device 
  2.     char name[IFNAMSIZ]; 
  3.     ... 
  4.     const struct net_device_ops *netdev_ops; 
  5.     ... 

下面介紹一下這兩個(gè)字段的作用:

  • name:用來(lái)存儲(chǔ)設(shè)備的名稱(chēng),如 eth0。
  • netdev_ops:設(shè)備相關(guān)的操作接口列表,如初始化設(shè)備的接口、關(guān)閉設(shè)備的接口和發(fā)送數(shù)據(jù)的接口等。

由于 veth 由兩個(gè) net_device 對(duì)象組成的,所以這兩個(gè) net_device 對(duì)象應(yīng)該有指向?qū)Ψ降闹羔槨5ㄟ^(guò)查閱代碼,并沒(méi)發(fā)現(xiàn)有指向?qū)Ψ降闹羔槪敲磧?nèi)核是怎么實(shí)現(xiàn) veth 的呢?

雖然 Linux 內(nèi)核使用 net_device 對(duì)象來(lái)表示一個(gè)網(wǎng)絡(luò)設(shè)備,但由于不同廠商的網(wǎng)絡(luò)設(shè)備可能存在各種差異,所以為了讓 Linux 內(nèi)核能夠適應(yīng)各種網(wǎng)絡(luò)設(shè)備,故為不同的網(wǎng)絡(luò)設(shè)備提供私有數(shù)據(jù)的存儲(chǔ)空間。

也就是說(shuō),一個(gè)網(wǎng)絡(luò)設(shè)備除了擁有 net_device 部分外,還有其私有數(shù)據(jù)部分。不同的網(wǎng)絡(luò)設(shè)備其私有數(shù)據(jù)部分不同,而網(wǎng)絡(luò)設(shè)備的私有數(shù)據(jù)部分存一般放在 net_device 對(duì)象的結(jié)束位置,如下圖所示:

上圖展示了 PCMCIA網(wǎng)卡 和 RTL-8139網(wǎng)卡 對(duì)應(yīng)的私有數(shù)據(jù)部分存儲(chǔ)的位置,PCMCIA網(wǎng)卡 的私有數(shù)據(jù)部分對(duì)應(yīng)的是 pcnet_dev_t 結(jié)構(gòu),而 RTL-8139網(wǎng)卡 的私有數(shù)據(jù)部分對(duì)應(yīng)的是 rtl8139_private 結(jié)構(gòu)。

回到我們的主題,虛擬網(wǎng)絡(luò)設(shè)備對(duì) 的私有數(shù)據(jù)部分由 veth_priv 結(jié)構(gòu)表示,其定義如下:

  1. struct veth_priv { 
  2.     struct net_device *peer; 
  3.     struct veth_net_stats *stats; 
  4.     ... 
  5. }; 

下面介紹一下 veth_priv 結(jié)構(gòu)各個(gè)字段的作用:

  • peer:由于 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 是由一對(duì)網(wǎng)絡(luò)設(shè)備組成,所以此字段用于指向設(shè)備對(duì)的另外一個(gè)設(shè)備。
  • stats:用于保存統(tǒng)計(jì)信息。

從 veth_priv 結(jié)構(gòu)可以看出,虛擬網(wǎng)絡(luò)設(shè)備對(duì) 所屬的兩個(gè)設(shè)備對(duì)象是由 peer 字段來(lái)關(guān)聯(lián)起來(lái)的,如下圖所示:

1. 創(chuàng)建虛擬網(wǎng)絡(luò)設(shè)備對(duì)

當(dāng)使用 ip 命令創(chuàng)建一對(duì) 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 時(shí),會(huì)觸發(fā)調(diào)用 veth_newlink 函數(shù)來(lái)完成創(chuàng)建工作,其實(shí)現(xiàn)如下:

  1. static int 
  2. veth_newlink(struct net_device *dev, struct nlattr *tb[], struct nlattr *data[]) 
  3.     int err; 
  4.     struct net_device *peer; 
  5.     struct veth_priv *priv; 
  6.     char ifname[IFNAMSIZ]; 
  7.     ... 
  8.  
  9.     // 由于虛擬網(wǎng)絡(luò)設(shè)備對(duì)是由兩個(gè)網(wǎng)絡(luò)設(shè)備組成, 
  10.     // dev 是虛擬網(wǎng)絡(luò)設(shè)備對(duì)的其中一個(gè)網(wǎng)絡(luò)設(shè)備, 
  11.     // 所以需要調(diào)用 rtnl_create_link() 函數(shù)創(chuàng)建的另外一個(gè)網(wǎng)絡(luò)設(shè)備并保存到 peer 變量中. 
  12.     peer = rtnl_create_link(dev_net(dev), ifname, &veth_link_ops, tbp); 
  13.     ... 
  14.  
  15.     priv = netdev_priv(dev);  // 獲取 dev 的私有數(shù)據(jù)部分 
  16.     priv->peer = peer;        // 將其 peer 字段指向 peer 
  17.  
  18.     priv = netdev_priv(peer); // 獲取 peer 的私有數(shù)據(jù)部分 
  19.     priv->peer = dev;         // 將其 peer 字段指向 dev 
  20.  
  21.     return 0; 

上面代碼經(jīng)過(guò)精簡(jiǎn)后,保留了主要邏輯,所以 veth_newlink 主要完成以下工作:

  • 由于虛擬網(wǎng)絡(luò)設(shè)備對(duì)是由兩個(gè)網(wǎng)絡(luò)設(shè)備組成,而 dev 是虛擬網(wǎng)絡(luò)設(shè)備對(duì)的其中一個(gè)網(wǎng)絡(luò)設(shè)備,所以需要調(diào)用 rtnl_create_link 函數(shù)創(chuàng)建的另外一個(gè)網(wǎng)絡(luò)設(shè)備,并保存到 peer 變量中。
  • 將其 dev 設(shè)備對(duì)象的 peer 字段指向 peer 設(shè)備對(duì)象。
  • 將其 peer 設(shè)備對(duì)象的 peer 字段指向 dev 設(shè)備對(duì)象。

就這樣,一對(duì) 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 的創(chuàng)建就完成了。

2. 初始化虛擬網(wǎng)絡(luò)設(shè)備對(duì)

當(dāng)然,在創(chuàng)建 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 時(shí)還需要對(duì)其進(jìn)行初始化,初始化過(guò)程由 veth_setup 函數(shù)完成,其實(shí)現(xiàn)如下:

  1. static const struct net_device_ops veth_netdev_ops = { 
  2.     ... 
  3.     .ndo_start_xmit = veth_xmit, 
  4.     ... 
  5. }; 
  6.  
  7. static void veth_setup(struct net_device *dev) 
  8.     ... 
  9.     dev->netdev_ops = &veth_netdev_ops; 
  10.     ... 

在初始化 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 時(shí),最重要的是設(shè)置其操作函數(shù)集。而 net_device_ops 結(jié)構(gòu)是網(wǎng)絡(luò)設(shè)備的操作函數(shù)集結(jié)構(gòu),當(dāng)向設(shè)備發(fā)送數(shù)據(jù)時(shí),將會(huì)觸發(fā)調(diào)用設(shè)備操作函數(shù)集的 ndo_start_xmit 方法。

而 veth_setup 函數(shù)將此方法設(shè)置為 veth_xmit,也就是說(shuō),當(dāng)向 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 的其中一端發(fā)送數(shù)據(jù)時(shí),將會(huì)調(diào)用 veth_xmit 函數(shù)來(lái)發(fā)送數(shù)據(jù)。

3. 向虛擬網(wǎng)絡(luò)設(shè)備對(duì)發(fā)送數(shù)據(jù)

當(dāng)向 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 的其中一端發(fā)送數(shù)據(jù)時(shí),將會(huì)調(diào)用 veth_xmit 函數(shù)來(lái)完成發(fā)送過(guò)程,其實(shí)現(xiàn)如下:

  1. static netdev_tx_t veth_xmit(struct sk_buff *skb, struct net_device *dev) 
  2.     struct net_device *rcv = NULL
  3.     struct veth_priv *priv, *rcv_priv; 
  4.     ... 
  5.  
  6.     // 獲取發(fā)送數(shù)據(jù)設(shè)備的對(duì)端設(shè)備 
  7.     priv = netdev_priv(dev);  
  8.     rcv = priv->peer; 
  9.     ... 
  10.  
  11.     skb->tstamp.tv64 = 0; 
  12.     skb->pkt_type = PACKET_HOST; 
  13.     // 將數(shù)據(jù)包的接收設(shè)備設(shè)置為對(duì)端設(shè)備 
  14.     skb->protocol = eth_type_trans(skb, rcv); 
  15.     ... 
  16.  
  17.     // 將數(shù)據(jù)包上送給內(nèi)核協(xié)議棧 
  18.     netif_rx(skb); 
  19.  
  20.     return NETDEV_TX_OK; 

我們先來(lái)介紹一下 veth_xmit 函數(shù)各個(gè)參數(shù)的意義:

  • skb:要發(fā)送的數(shù)據(jù)包對(duì)象。
  • dev:發(fā)送數(shù)據(jù)的設(shè)備。

veth_xmit 函數(shù)的實(shí)現(xiàn)比較簡(jiǎn)單,主要完成以下工作:

  • 獲取發(fā)送數(shù)據(jù)設(shè)備的對(duì)端設(shè)備。
  • 將數(shù)據(jù)包的接收設(shè)備設(shè)置為對(duì)端設(shè)備。
  • 將數(shù)據(jù)包上送給內(nèi)核協(xié)議棧。

我們通過(guò)下圖來(lái)展示發(fā)送數(shù)據(jù)的過(guò)程:

如上圖所示,當(dāng)一個(gè)數(shù)據(jù)包從 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 的一端發(fā)送出去,會(huì)從其另外一端被接收,并上送到內(nèi)核協(xié)議棧處理。

總結(jié)

由于 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 的出現(xiàn),解決了容器間的通信問(wèn)題。而本文主要分析了 虛擬網(wǎng)絡(luò)設(shè)備對(duì) 的實(shí)現(xiàn)原理,但是有些細(xì)節(jié)并沒(méi)有詳細(xì)分析,如果有不懂的地方可以加我微信一起探討。

 

責(zé)任編輯:武曉燕 來(lái)源: Linux內(nèi)核那些事
相關(guān)推薦

2021-09-09 14:54:10

Linuxbridge網(wǎng)絡(luò)設(shè)備

2011-05-13 17:49:56

2013-10-30 11:27:25

Linux基礎(chǔ)網(wǎng)絡(luò)設(shè)備

2010-08-23 09:06:14

路由器配置

2011-06-30 09:43:53

虛擬設(shè)備虛擬網(wǎng)絡(luò)

2012-12-27 15:59:56

網(wǎng)絡(luò)設(shè)備網(wǎng)絡(luò)虛擬化MDC

2022-07-12 10:01:33

網(wǎng)絡(luò)設(shè)備供應(yīng)鏈

2020-04-20 21:22:50

網(wǎng)絡(luò)設(shè)備網(wǎng)絡(luò)協(xié)議計(jì)算機(jī)網(wǎng)絡(luò)

2013-05-02 10:03:59

網(wǎng)絡(luò)管理網(wǎng)絡(luò)設(shè)備交換機(jī)

2009-11-19 08:55:44

Windows 7網(wǎng)絡(luò)兼容性

2010-01-05 15:27:19

Ubuntu Virt

2019-03-21 14:03:29

Wi-Fi 6Wi-Fi網(wǎng)絡(luò)

2018-07-31 10:56:28

2021-04-13 09:12:45

網(wǎng)絡(luò)設(shè)備無(wú)線路由器交換機(jī)

2022-04-07 08:34:46

網(wǎng)絡(luò)設(shè)備路由器WiFi

2022-12-29 08:00:26

Loki網(wǎng)絡(luò)設(shè)備

2012-02-14 13:56:01

ibmdw

2023-05-12 07:27:24

Linux內(nèi)核網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)

2021-07-13 07:12:04

Zabbix監(jiān)控網(wǎng)絡(luò)設(shè)備

2012-02-29 16:41:30

MWC網(wǎng)絡(luò)設(shè)備Mozilla
點(diǎn)贊
收藏

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

国产视频123区| 国产中文一区二区| 超碰人人人人人人人| vam成人资源在线观看| 亚洲男同1069视频| 麻豆传媒一区| 国产精品久久影视| 日韩午夜电影| 中文字幕亚洲天堂| 在线播放av网址| 欧美人体一区二区三区| 亚洲人成亚洲人成在线观看图片| 国产精品国色综合久久| 性色av免费观看| 欧美激情综合| 国产亚洲精品91在线| 国产裸体视频网站| 巨胸喷奶水www久久久免费动漫| 亚洲欧洲综合另类| 午夜国产精品一区| 啪啪亚洲精品| 国产成人久久精品77777综合| 欧美一区二区三区在线免费观看| 丁香五六月婷婷久久激情| 欧美激情久久久久久久久久久| 在线观看免费av片| 国产精品免费视频一区二区| 国产成人在线电影| 手机av在线免费观看| 中文字幕超清在线免费观看| 亚洲一级二级三级| 国产不卡精品在线| 国产熟女一区二区三区五月婷 | 欧美美女性生活视频| 国产日韩欧美在线视频观看| 一区二区三区精品视频| 红桃成人av在线播放| 香蕉精品999视频一区二区| 成人97在线观看视频| 欧美大波大乳巨大乳| 日韩黄色网络| 亚洲国产成人久久综合| 中文字幕在线观看视频www| 深夜成人影院| 欧美性xxxx18| 男女高潮又爽又黄又无遮挡| heyzo在线欧美播放| 亚洲男人电影天堂| 亚洲国产精品久久久久久女王| 色在线免费视频| av不卡免费在线观看| 爱情岛论坛亚洲入口| 99精品在线视频观看| 激情另类小说区图片区视频区| 日本一区视频在线播放| 国产人妻精品一区二区三区不卡| 国产va免费精品观看精品视频| 亚洲国产美女精品久久久久∴| 久久久久久穴| 亚洲精品视频免费在线观看| 国产精品麻豆入口| 国产精品一线| 亚洲激情视频在线| 在线观看av中文字幕| 欧美一级色片| 亚洲乱码av中文一区二区| 人妻少妇精品视频一区二区三区| 奇米777国产一区国产二区| 日韩成人网免费视频| 中文在线一区二区三区| 免费电影一区二区三区| 国产亚洲xxx| 国产精品视频一区二区在线观看 | 国产区二精品视| 午夜影院免费视频| 久久精品亚洲乱码伦伦中文 | 欧美极品一区二区三区| 久久久久久91| 免费av网站在线| 日韩电影网1区2区| 亚洲一区二区久久久久久| 精品国产18久久久久久| 青草国产精品| 色天天综合色天天久久| www.涩涩涩| 国产aⅴ精品一区二区四区| 人妻激情偷乱频一区二区三区| 一区二区三区在线资源| 日韩hd视频在线观看| 国产成人无码精品久久二区三| 国产一区二区三区四区二区| 日韩在线视频导航| 国产小视频在线观看免费| 中文字幕人成人乱码| 97视频在线观看视频免费视频 | 亚洲一区在线观看免费 | 奇米影视7777精品一区二区| 成人女保姆的销魂服务| 日本激情一区二区三区| 欧美国产丝袜视频| a天堂资源在线观看| 欧美日韩激情电影| 精品日韩在线观看| 公肉吊粗大爽色翁浪妇视频| 欧美激情视频一区二区三区在线播放 | 亚洲综合小说区| 日韩亚洲视频在线观看| 亚洲视频一区二区在线观看| 久久视频这里有精品| 国外成人福利视频| 亚洲国产三级网| 午夜爽爽爽男女免费观看| 国产亚洲精品bv在线观看| 成人午夜在线影院| 国产午夜精品一区理论片| 一区二区三区日韩精品视频| 欧在线一二三四区| 99re热精品视频| 色偷偷88888欧美精品久久久 | 久久激情婷婷| 国产精品成人观看视频免费| av免费观看一区二区| 欧美日韩免费在线观看| 被黑人猛躁10次高潮视频| 国产剧情一区| 91sa在线看| 高潮毛片7777777毛片| 国产精品激情偷乱一区二区∴| 青青艹视频在线| 日韩中文一区二区| 久久精品青青大伊人av| 亚洲av人无码激艳猛片服务器| 成人av在线播放网站| 青青草影院在线观看| 成人国产精选| 在线精品国产成人综合| 在线精品免费视| 99re8在线精品视频免费播放| 99中文字幕在线观看| 伊人久久大香| jizz国产在线| 夜夜爽av福利精品导航| 91黄色国产视频| 黄视频网站在线看| 欧美人妇做爰xxxⅹ性高电影| 久久精品视频导航| 在线看成人av| 成人国产精品免费网站| 91动漫在线看| 麻豆成人入口| 97视频com| 天天爽天天狠久久久| 96av在线| 亚洲国产成人爱av在线播放| 久久久www成人免费毛片| 国产麻豆精品视频| 欧美一级爱爱视频| 91大神精品| 久久久久久久久久久网站| 亚洲成人久久精品| 亚洲一区二区综合| chinese麻豆新拍video| 国产欧美亚洲一区| 欧美午夜视频在线| 电影久久久久久| 色系列之999| 国产免费av电影| 一区二区三区在线看| 久久性爱视频网站| 嫩草成人www欧美| 五月天色一区| 精品亚洲二区| 午夜精品视频在线| 欧美zzoo| 欧美另类变人与禽xxxxx| 波多野结衣亚洲色图| 成人黄色av电影| www.四虎成人| 久久久久免费av| 国产精品夜夜夜一区二区三区尤| 日本乱码一区二区三区不卡| 亚洲人成毛片在线播放| 中文字幕一区二区免费| 亚洲欧美区自拍先锋| 三级视频网站在线观看| 日韩国产精品91| 精品国产三级a∨在线| 欧美一区二区三区红桃小说| 国产精品美女无圣光视频| 国产高清一区二区三区视频 | 亚洲区小说区图片区qvod| 国产精品久久中文| 久久五月精品中文字幕| 亚洲欧洲在线看| 成人av免费播放| 在线一区二区视频| 亚洲熟女www一区二区三区| 91视频国产观看| 深夜福利国产精品| 亚洲综合五月天婷婷丁香| 亚洲乱码中文字幕综合| 精品久久久久久中文字幕人妻最新| 日韩电影一区二区三区四区| 男人天堂手机在线视频| av一区二区在线播放| 成人黄色在线免费观看| 国模一区二区| 欧美极品少妇xxxxⅹ喷水| 大乳在线免费观看| 亚洲精品电影在线| 国产精品区在线观看| 日韩欧美亚洲成人| 国产亚洲精品久久777777| 欧美国产成人在线| 黄色录像a级片| 国产激情视频一区二区三区欧美 | 日本大胆欧美人术艺术动态| 免费高清一区二区三区| 久久一区二区三区喷水| 精品国产乱码久久久久久88av| 日本一区二区中文字幕| 欧美做爰性生交视频| 亚洲91av| 久久精品视频导航| 99青草视频在线播放视| 亚洲乱码国产乱码精品精| 你懂的网站在线| 91精品欧美久久久久久动漫| 中文字幕 人妻熟女| 黑人巨大精品欧美一区二区| 国产小视频在线观看免费| 亚洲美女屁股眼交| 四虎地址8848| 亚洲电影第三页| 日本 欧美 国产| 国产日产欧美一区| 亚洲精品乱码久久久久久久| 国产成人在线看| 国产美女www爽爽爽| 亚洲精品写真福利| 国产精品麻豆免费版现看视频| 91美女在线视频| 欧美一级黄色录像片| 国产在线一区不卡| 国产精品欧美日韩| 韩国精品主播一区二区在线观看 | 99热免费精品在线观看| 国产成年精品| 国产精品十八以下禁看| 免费看av不卡| 欧美一级片免费在线| 暧暧视频在线免费观看| 欧美成人剧情片在线观看| 男人影院在线观看| 色狠狠av一区二区三区香蕉蜜桃| av在线日韩国产精品| 在线播放日韩欧美| 91精品大全| www.日韩av.com| av免费在线免费观看| 久久6精品影院| 国产乱码在线| 91超碰中文字幕久久精品| 蜜桃麻豆影像在线观看| 欧美有码在线观看| 高清电影一区| 成人亲热视频网站| 亚洲专区**| 久久av一区二区| 国产永久精品大片wwwapp| 视频一区三区| 91tv官网精品成人亚洲| www.国产亚洲| 亚洲在线观看| 视色视频在线观看| 国产.精品.日韩.另类.中文.在线.播放| 国产原创剧情av| 国产午夜精品久久| 青青青免费视频在线2| 欧美在线看片a免费观看| 成人免费一区二区三区| 欧美日韩国产不卡| 亚洲成人精品女人久久久| 久久精品国产99国产| 九色91popny| 国产麻豆精品久久一二三| 亚洲一区二区三区无码久久| 欧美国产欧美亚州国产日韩mv天天看完整 | 欧美精品一区二区蜜桃| 欧美日韩一区二区免费在线观看| 中文字幕理论片| 精品久久久久久无| 电影在线一区| 久久久久久噜噜噜久久久精品| 日韩三级影视| av一本久道久久波多野结衣| 九色精品国产蝌蚪| 米仓穗香在线观看| 日韩成人精品在线| 成人欧美精品一区二区| 国产欧美中文在线| 成人午夜视频精品一区| 91麻豆精品国产无毒不卡在线观看| 欧美天堂在线视频| www.欧美精品| 中文在线中文资源| 成人欧美一区二区三区黑人孕妇| 小说区图片区色综合区| 国产精品波多野结衣| 久久久久.com| 免费观看黄网站| 日韩精品91亚洲二区在线观看| 丰满人妻一区二区三区大胸| 91丝袜国产在线播放| 欧美午夜激情影院| 午夜精品视频一区| 91免费视频播放| 亚洲日韩中文字幕| 免费影视亚洲| 国产91精品青草社区| 亚洲天堂中文字幕在线观看| 欧美lavv| 99精品在线| 亚洲 欧美 综合 另类 中字| 噜噜噜91成人网| 少妇愉情理伦片bd| 国产精品久久久久久久久图文区| 日韩污视频在线观看| 在线成人小视频| 求av网址在线观看| 国产成+人+综合+亚洲欧美丁香花| 99re8这里有精品热视频免费| 神马影院我不卡午夜| 一本色道88久久加勒比精品| 五月天丁香社区| 亚洲欧美一区二区久久 | 狠狠做深爱婷婷久久综合一区 | 天堂av一区二区三区在线播放| 天天在线免费视频| 欧美第一页浮力影院| 国产亚洲精品bv在线观看| 九九久久久久久| 国产农村妇女精品| 99久久久无码国产精品免费蜜柚 | 日本欧美视频在线观看| 麻豆精品在线播放| 亚洲一级理论片| 在线视频国产一区| 国产调教在线| 一区二区三区欧美久久| 男人午夜免费视频| 欧美成人乱码一区二区三区| 在线看免费av| 国产成人午夜视频网址| 亚州综合一区| 国产二级片在线观看| 福利电影一区二区| 国产黄在线免费观看| 欧美一级夜夜爽| 麻豆网站视频在线观看| 91久久伊人青青碰碰婷婷| 中文乱码免费一区二区三区下载| 午夜天堂在线视频| 亚洲一区影音先锋| 日韩中文字幕综合| 国产成人亚洲综合91| 国内成人自拍| 手机在线看福利| 亚洲同性gay激情无套| 97成人在线观看| 久久精品国产久精国产思思| 91久久精品无嫩草影院 | 亚洲精品久久久久久动漫器材一区| 久久99视频免费| 国产伦乱精品| 欧美日韩亚洲一| 国产精品日韩精品欧美在线| 91在线公开视频| 97在线视频一区| 九色成人国产蝌蚪91| 日本三区在线观看| 亚洲男女毛片无遮挡| 免费观看国产视频| 国产精品第一第二| 国产精品久久久久蜜臀| 国产黑丝一区二区| 91福利社在线观看| 免费大片黄在线| 久久99精品国产一区二区三区| 丝袜美腿一区二区三区| 欧美色图亚洲视频| 日韩精品视频观看| 国产精品igao视频网网址不卡日韩| 欧美精品在欧美一区二区| 久久精品亚洲麻豆av一区二区| 一区不卡在线观看| 久久久中文字幕| 婷婷综合亚洲| 可以直接看的无码av| 欧美一区二区三区性视频|