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

Micro-PaaS典型代表:Kubernetes技術分析入門

云計算 PaaS
Docker的流行激活了一直不溫不火的PaaS,隨著而來的是各類Micro-PaaS的出現,Kubernetes是其中最具代表性的一員,它是Google多年大規模容器管理技術的開源版本。本系列文章將逐一分析Kubernetes,本文通過一個例子進行入門,介紹Kubernetes的基本概念和功能。

概述

Docker的流行激活了一直不溫不火的PaaS,隨著而來的是各類Micro-PaaS的出現,Kubernetes是其中最具代表性的一員,它是Google多年大規模容器管理技術的開源版本。本系列文章將逐一分析Kubernetes,本文通過一個例子進行入門,介紹Kubernetes的基本概念和功能。

1. Kubernetes介紹

基本概念

- Pod

Pod是Kubernetes的基本操作單元,把相關的一個或多個容器構成一個Pod,通常Pod里的容器運行相同的應用。Pod包含的容器運行在同一個Node(Host)上,看作一個統一管理單元,共享相同的volumes和network namespace/IP和Port空間。

- Replication Controller

Replication Controller確保任何時候Kubernetes集群中有指定數量的pod副本(replicas)在運行, 如果少于指定數量的pod副本(replicas),Replication Controller會啟動新的Container,反之會殺死多余的以保證數量不變。Replication Controller使用預先定義的pod模板創建pods,一旦創建成功,pod 模板和創建的pods沒有任何關聯,可以修改pod 模板而不會對已創建pods有任何影響,也可以直接更新通過Replication Controller創建的pods。對于利用pod 模板創建的pods,Replication Controller根據label selector來關聯,通過修改pods的label可以刪除對應的pods。

- Service

Service也是Kubernetes的基本操作單元,是真實應用服務的抽象,每一個服務后面都有很多對應的容器來支持,通過Proxy的port和服務selector決定服務請求傳遞給后端提供服務的容器,對外表現為一個單一訪問接口,外部不需要了解后端如何運行,這給擴展或維護后端帶來很大的好處。

- Label

Label是用于區分Pod、Service、Replication Controller的key/value鍵值對,Pod、Service、 Replication Controller可以有多個label,但是每個label的key只能對應一個value。Labels是Service和Replication Controller運行的基礎,為了將訪問Service的請求轉發給后端提供服務的多個容器,正是通過標識容器的labels來選擇正確的容器。同樣,Replication Controller也使用labels來管理通過pod 模板創建的一組容器,這樣Replication Controller可以更加容易,方便地管理多個容器,無論有多少容器。

架構

Kubernets屬于主從的分布式集群架構,包含Master和Node:

1. Master作為控制節點,調度管理整個系統,包含以下組件:

- API Server作為kubernetes系統的入口,封裝了核心對象的增刪改查操作,以RESTFul接口方式提供給外部客戶和內部組件調用。它維護的REST對象將持久化到etcd(一個分布式強一致性的key/value存儲)。

- Scheduler:負責集群的資源調度,為新建的pod分配機器。這部分工作分出來變成一個組件,意味著可以很方便地替換成其他的調度器。

- Controller Manager:負責執行各種控制器,目前有兩類:(1)Endpoint Controller:定期關聯service和pod(關聯信息由endpoint對象維護),保證service到pod的映射總是最新的。(2)Replication Controller:定期關聯replicationController和pod,保證replicationController定義的復制數量與實際運行pod的數量總是一致的。

Node是運行節點,運行業務容器,包含以下組件:

Kubelet:責管控docker容器,如啟動/停止、監控運行狀態等。它會定期從etcd獲取分配到本機的pod,并根據pod信息啟動或停止相應的容器。同時,它也會接收apiserver的HTTP請求,匯報pod的運行狀態。

Kube Proxy:負責為pod提供代理。它會定期從etcd獲取所有的service,并根據service信息創建代理。當某個客戶pod要訪問其他pod時,訪問請求會經過本機proxy做轉發。

Kubernets使用Etcd作為存儲和通信中間件,實現Master和Node的一致性,這是目前比較常見的做法,典型的SOA架構,解耦Master和Node。

#p#

2. Guestbook示例

Guestbook示例將會展示如何運行一個應用到Kubernetes上,應用包含

- Web前端

- Redis集群(一個master,2個slave)

Micro-PaaS典型代表:Kubernetes技術分析入門

1) 部署Kubernetes

如果你熟悉Bosh/Bosh Lite的話,可以使用kubernetes-release.本文使用Kubernetes環境:

- master:192.168.3.146

- node1:192.168.3.147

- node2:192.168.3.148

- node3:192.168.3.149

2)啟動Redis Master

需要準備配置文件redis-master-controller.yaml,用于描述pod如何運行服務容器:

apiVersion: v1
kind: ReplicationController
metadata:
name: redis-master
labels:
name: redis-master
spec:
replicas: 1
selector:
name: redis-master
template:
metadata:
  labels:
    name: redis-master
spec:
  containers:
  - name: master
    image: redis
    ports:
    - containerPort: 6379

即使只有一個Redis Master Pod實例,這里也使用ReplicationController保證Pod持續運行,否則Node掛掉的話,Pod將停止運行。

創建Pod:

  1. $ kubectl create -f redis-master-controller.yaml 

查看ReplicationController:

 

  1. $ kubectl get rc  
  2. CONTROLLER   CONTAINER(S)  IMAGE(S)  SELECTOR            REPLICAS 
  3. redis-master master        redis     name=redis-master   1 

查看Pod:

 

  1. $ kubectl get pods -o wide 
  2. NAME                READY    STATUS    RESTARTS   AGE       NODE 
  3. redis-master-u3fup   1/1     Running   0          2m        node1 

可以看到Pod運行在Node1節點,在Node1查看docker容器:

  1. $ docker ps 
  2. CONTAINER ID  IMAGE                                ...     
  3. feb393fbe42b  redis:latestminute ago               ...          
  4. d9e934ee55ae  gcr.io/google_containers/pause:0.8.0 ...   

總共有2個容器正在運行,其中一個Redis Master,另外一個是google_containers/pause,它是Netowrk Container, 每啟動一個Pod都會附加啟動這樣一個容器,它的作用就只是簡單的等待,設置Pod的網絡。

如果docker rm -f feb393fbe42b,刪掉Redis Master Container,過一會兒就會有新的容器啟動,這說明Kubernetes會保證Pod的容器運行。

 

  1. $ docker ps 
  2. CONTAINER ID  IMAGE                                ...     
  3. fc3b458d333a  redis:latestminute ago               ...          
  4. d9e934ee55ae  gcr.io/google_containers/pause:0.8.0 ...  

如果把Node1關掉,Pod會遷移到其他Node上,這是ReplicationController保證Pod運行。

 

  1. $ kubectl get pods -o wide 
  2. NAME               READY STATUS   RESTARTS  AGE       NODE 
  3. redis-master-x5kjp 0/1   Running  0         7s        node3 

上一步已經運行起了一個Redis Master Pod, 即使只有一個Pod,也是有必要使用Service。Kubernetes中Service中起到了負載均衡器的作用,通過Proxy和Selector決定服務請求傳遞給后端提供服務的Pod,對外提供固定的IP,這樣的話Redis Master Pod遷移變化也不會影響。

需要redis-master-service.yaml來描述redis master service:

 

apiVersion: v1
kind: Service
metadata:
name: redis-master
labels:
name: redis-master
spec:
ports:
# the port that this service should serve on
- port: 6379
targetPort: 6379
selector:
name: redis-master #和redis-master的Label對應

創建Service:

  1. $ kubectl create -f redis-master-service.yaml 

查看Service:

$ kubectl get service

 

  1. NAME            LABELS              SELECTOR            IP(S)            PORT(S) 
  2. redis-master    name=redis-master   name=redis-master   10.254.189.63    6379/TCP 

Kubernetes會分配IP(10.254.189.63)給Redis Master Service,這個就是Redis Master Service對外暴露的IP,可以通過redis-cli訪問:

  1. $ redis-cli -h 10.254.189.63 info 

#p#

Kubernetes同時提供2種了發現Service的方法:

- 環境變量

當Pod運行的時候,Kubernetes會將之前存在的Service的信息通過環境變量寫到Pod里面,以Redis Master Service為例,它的信息會被寫到新的Pod里面:

 

"REDIS_MASTER_PORT_6379_TCP=tcp://10.254.189.63:6379",
"REDIS_MASTER_PORT_6379_TCP_PROTO=tcp",
"REDIS_MASTER_PORT_6379_TCP_ADDR=10.254.189.63",
"REDIS_MASTER_SERVICE_PORT=6379",
"REDIS_MASTER_SERVICE_HOST=10.254.189.63",
"REDIS_MASTER_PORT=tcp://10.254.189.63:6379",
"REDIS_MASTER_PORT_6379_TCP_PORT=6379",

這種方法有個比較明顯的缺陷,Pod必須在Service之后啟動,之前啟動的Pod將沒有這些環境變量。那么下一種方法就沒有這個限制。

- DNS

當有新的Service創建,就會自動生成一條DNS記錄,比如在Kubernetes的Namespace "my-ns"中有個Service叫"my-service",那么就有條DNS記錄"my-service.my-ns"對應Service的IP。以Redis Master Service為例, 就有條DNS記錄:

  1. redis-master => 10.254.189.63 

3)啟動Redis Slave

apiVersion: v1
kind: ReplicationController
metadata:
name: redis-slave
labels:
name: redis-slave
spec:
replicas: 2
selector:
name: redis-slave
template:
metadata:
  labels:
    name: redis-slave
spec:
  containers:
  - name: worker
    image: kubernetes/redis-slave:v2
    ports:
    - containerPort: 6379

創建Pod:

 

$ kubectl create -f redis-slave-controller.yaml

$ kubectl get rc
CONTROLLER     CONTAINER(S)   IMAGE(S)                    SELECTOR            REPLICAS
redis-master   master         redis                       name=redis-master   1
redis-slave    worker         kubernetes/redis-slave:v2   name=redis-slave    2

$ kubectl get pods -o wide
NAME                 READY     STATUS    RESTARTS   AGE       NODE
redis-master-x5kjp   1/1       Running   0          1h        node3
redis-slave-04o8g    1/1       Running   0          5m        node1
redis-slave-llxpk    1/1       Running   0          5m        node1

redis-slave-service.yaml:

apiVersion: v1
kind: Service
metadata:
name: redis-slave
labels:
name: redis-slave
spec:
ports:
# the port that this service should serve on
- port: 6379
selector:
name: redis-slave

創建Service:

$ kubectl create -f redis-slave-service.yaml

$ kubectl get service

NAME LABELS SELECTOR IP(S) PORT(S)

redis-master name=redis-master name=redis-master 10.254.189.63 6379/TCP

redis-slave name=redis-slave name=redis-slave 10.254.70.184 6379/TCP

4)啟動Web Frontend

$ kubectl create -f redis-slave-service.yaml 

$ kubectl get service
NAME            LABELS            SELECTOR           IP(S)           PORT(S)
redis-master   name=redis-master  name=redis-master  10.254.189.63   6379/TCP
redis-slave    name=redis-slave   name=redis-slave   10.254.70.184   6379/TCP

創建Pod:

 

$ kubectl create -f frontend-controller.yaml

$ kubectl get rc
CONTROLLER     CONTAINER(S)   IMAGE(S)                                    SELECTOR            REPLICAS
frontend       php-redis      kubernetes/example-guestbook-php-redis:v2   name=frontend       3
redis-master   master         redis                                       name=redis-master   1
redis-slave    worker         kubernetes/redis-slave:v2                   name=redis-slave    2

$ kubectl get pods
NAME                 READY     STATUS    RESTARTS   AGE
frontend-7ukb6       1/1       Running   0          45s
frontend-8ch4l       1/1       Running   0          45s
frontend-n8l7w       1/1       Running   0          45s
redis-master-x5kjp   1/1       Running   0          3h
redis-slave-04o8g    1/1       Running   0          2h
redis-slave-llxpk    1/1       Running   0          2h
apiVersion: v1
kind: Service
metadata:
name: frontend
labels:
name: frontend
spec:
ports:
# the port that this service should serve on
- port: 80
selector:
name: frontend

創建Service:

 

$ kubectl create -f frontend-service.yaml

$ kubectl get service
NAME            LABELS            SELECTOR            IP(S)            PORT(S)
frontend        name=frontend     name=frontend       10.254.58.118    80/TCP
redis-master    name=redis-master name=redis-master   10.254.189.63    6379/TCP
redis-slave     name=redis-slave  name=redis-slave    10.254.70.184    6379/TCP

Web Frontend是需要對外暴露的,這樣外部網絡才能真正訪問該應用,Kubernetes提供了2種方式暴露Service到外部網絡:

- NodePort

Kubernetes將會在每個Node上設置一個Port,訪問該Port會被轉發到對應的Service。這支持開發者設置自己的LoadBalancer。

- LoadBalancer

Kubernetes會設置LoadBalancer給Service。

本文采用NodePort方式, 更改frontend-service.yaml:

 

apiVersion: v1
kind: Service
metadata:
name: frontend
labels:
name: frontend
spec:
type: NodePort
ports:
# the port that this service should serve on
- port: 80
nodePort: 30061
selector:
name: frontend

那么就可以通過任意節點訪問該應用:

參考

http://kubernetes.io/v1.0/docs

https://github.com/GoogleCloud ... es.md

https://github.com/GoogleCloud ... tbook

作者簡介

吳龍輝,現任網宿科技高級運營工程師,致力于云計算PaaS的研究和實踐,活躍于CloudFoundry、Docker、Kubernetes等開源社區,貢獻代碼和撰寫技術文檔。

郵箱:wulh@chinanetcenter.com/wlh6666@qq.com

原文鏈接:http://www.dockone.io/article/542

 

責任編輯:Ophira 來源: dockone
相關推薦

2015-09-06 10:29:20

PaaS云計算開源

2015-08-10 14:41:39

Kubernetes監控開源容器管理

2019-03-01 10:46:36

PaaSSaaS技術

2009-07-09 09:28:19

.Net Micro

2015-05-26 09:15:14

開源PaaS 云平臺Cloud Found

2012-02-17 10:04:06

JavaPlay!

2015-10-15 14:32:34

2010-02-04 11:50:18

ibmdwCognosBI

2016-06-21 10:02:11

云計算

2017-09-30 10:17:24

云計算PaaS容器云

2022-04-17 10:04:32

HerokuPaaSPorter

2015-08-31 14:12:12

DockerKubernetesPaaS

2016-07-21 10:16:51

云計算

2015-03-30 20:56:55

SaaS云計算企業級應用

2023-09-27 12:35:39

2024-08-06 09:54:20

2011-01-27 09:40:53

PaaS

2011-08-10 10:39:47

路由器路由器故障

2009-03-26 10:12:00

WCDMA網絡建設

2023-05-04 16:03:50

KubernetesCI/CD集成
點贊
收藏

51CTO技術棧公眾號

亚洲欧洲日韩女同| 巨乳诱惑日韩免费av| 日韩免费电影一区| www.一区二区.com| 偷拍自拍在线| 精品一区二区三区影院在线午夜| 久久久久久美女| 91蝌蚪国产九色| 久久久之久亚州精品露出| 一出一进一爽一粗一大视频| 久久av影院| 天天色天天操综合| 亚洲欧美日韩不卡| 日本又骚又刺激的视频在线观看| 久久精品国产99国产精品| 久久久久亚洲精品成人网小说| 色婷婷精品久久二区二区密| 久久人人视频| 欧美日韩亚洲精品一区二区三区| 青春草在线视频免费观看| 激情小说 在线视频| 国产ts人妖一区二区| 国产精品视频永久免费播放| 男人的天堂一区| 亚洲xxx拳头交| 亚洲人成在线观看| 成人在线电影网站| 成人综合日日夜夜| 在线观看亚洲一区| 人妻少妇被粗大爽9797pw| 欧美14一18处毛片| 国产精品久久久久影视| 蜜桃臀一区二区三区| 亚洲黄色在线观看视频| 国产一区二区伦理片| 国产精品国产自产拍高清av水多| 亚洲精品77777| 好看的日韩av电影| 成年无码av片在线| 亚洲熟女毛茸茸| 狠狠做六月爱婷婷综合aⅴ| 亚洲精品98久久久久久中文字幕| 香蕉网在线视频| 国产精一区二区| 欧美美女bb生活片| av污在线观看| av在线不卡精品| 在线观看三级视频欧美| 国产一级片黄色| 中文字幕在线官网| 欧美特级www| www.99热这里只有精品| 成年人视频免费在线播放| 亚洲自拍与偷拍| 免费网站永久免费观看| 91精选在线| 一区二区三区四区高清精品免费观看| 三年中文高清在线观看第6集| 色网站在线看| 亚洲视频在线一区二区| 日本高清xxxx| 日韩三级电影视频| 亚洲福中文字幕伊人影院| 日韩一级免费看| 国产蜜臀一区二区打屁股调教| 一区二区三区在线观看视频| 久久99久久久久久| 精精国产xxxx视频在线野外| 黑人巨大精品欧美一区二区三区| 男人揉女人奶房视频60分| 校园春色亚洲色图| 欧美日韩激情一区二区三区| 中文 日韩 欧美| 成人爽a毛片| 亚洲免费一在线| 欧美老女人性生活视频| 91成人观看| 欧美激情精品久久久久久大尺度| 国产第100页| 美女视频一区免费观看| 国产精品三级网站| 亚洲毛片欧洲毛片国产一品色| 波多野洁衣一区| 日本不卡二区| 1区2区3区在线视频| 亚洲成人黄色影院| 美女黄色片视频| 国产精品一站二站| 亚洲精品在线视频| 在线观看天堂av| 韩国一区二区三区在线观看| 国产97在线|亚洲| 99国产精品一区二区三区| 成人看片黄a免费看在线| 欧美亚洲另类在线一区二区三区| 午夜视频在线看| 精品二区三区线观看| 高清一区在线观看| 国产精品毛片av| 色妞一区二区三区| 日产精品久久久久| 精品无码三级在线观看视频| 国产偷国产偷亚洲高清97cao| 成人免费在线观看| 精品久久久久久久久久国产 | 欧美成人一区二免费视频软件| 久久久久久久久久久人体| 波多野结衣家庭主妇| 国产盗摄精品一区二区三区在线 | 国产精品国产一区| 欧美做爰性生交视频| 国产强伦人妻毛片| 久久精品人人做人人综合| 免费看欧美黑人毛片| 亚洲狼人综合| 国产亚洲一区精品| 西西44rtwww国产精品| 国产一区二区三区在线观看免费视频 | 亚洲一区二区三区网站| 久久人人爽爽爽人久久久| 无码日本精品xxxxxxxxx| 日韩免费在线电影| 亚洲精选中文字幕| 日韩经典在线观看| 国产盗摄一区二区三区| 黄色www在线观看| 国产韩日精品| 亚洲精品一区二区久| 久久精品国产亚洲av麻豆色欲 | 野战少妇38p| 亚洲成人日韩| 成人久久一区二区| 在线激情小视频| 色婷婷亚洲精品| 毛片网站免费观看| 中日韩男男gay无套| 99中文视频在线| 国产鲁鲁视频在线观看特色| 欧美探花视频资源| 亚洲女优在线观看| 日本女人一区二区三区| 欧美一区观看| yw.尤物在线精品视频| 亚洲男人天堂2023| 天堂在线免费观看视频| 99re亚洲国产精品| 国产中文字幕在线免费观看| 国产一区二区在线视频你懂的| 久久影视电视剧免费网站清宫辞电视 | 爱草tv视频在线观看992| 精品黑人一区二区三区久久| 免费网站观看www在线观| 国产a区久久久| av在线播放天堂| 美女av一区| 91av在线免费观看| 九九在线视频| 欧美丝袜丝交足nylons| 国产传媒在线看| 国产一区二区视频在线播放| 亚洲中文字幕无码一区二区三区| 秋霞午夜一区二区三区视频| 欧美日韩国产二区| 欧美视频一二区| 欧美午夜片在线免费观看| 中文字幕一二三四区| 秋霞午夜鲁丝一区二区老狼| 在线国产伦理一区| 天堂精品久久久久| 2019中文字幕在线| 91porn在线观看| 欧美一区二区三区啪啪| 日本免费在线播放| 国产日韩亚洲欧美综合| 男女污污的视频| 亚洲影视一区| 久久av二区| 岛国一区二区| 精品视频9999| 免费资源在线观看| 欧美高清精品3d| 日韩欧美亚洲国产| 国产精品污污网站在线观看| 1314成人网| 亚洲高清久久| 香蕉久久免费影视| 日韩欧美中文字幕在线视频| 日本不卡免费高清视频| 日本中文字幕在线观看| 精品av综合导航| 波多野结衣理论片| 亚洲最色的网站| 免费黄在线观看| 丁香亚洲综合激情啪啪综合| 成人亚洲视频在线观看| 欧美日韩 国产精品| 欧美深深色噜噜狠狠yyy| 欧美一区在线观看视频| 国产999在线| 牛牛精品在线视频| 一个色综合导航| 婷婷久久久久久| 制服丝袜在线91| 日本中文字幕久久| 亚洲综合清纯丝袜自拍| 欧美大波大乳巨大乳| 成人深夜福利app| www.成年人| 久久不射网站| 欧美无砖专区免费| 国产精品毛片久久| 欧美资源一区| 欧美大胆a级| 2022国产精品| 性欧美video另类hd尤物| 欧美专区日韩视频| 免费在线播放电影| 欧美成人一区二区三区电影| av在线免费观看网站| 亚洲毛片在线看| 欧美一级性视频| 欧美一区二区三区性视频| 中文字幕精品无码亚| 色久综合一二码| 中文字幕在线观看视频网站| 亚洲国产va精品久久久不卡综合 | 精品国产福利视频| 麻豆一区产品精品蜜桃的特点 | 欧美日韩视频免费在线观看| 精品日本12videosex| 久久综合久久久| 欧美成人专区| 久久99热只有频精品91密拍| 国产成人一二片| 国产a一区二区| 午夜视频一区二区在线观看| 999久久久| 国产亚洲高清一区| 91日本在线观看| 国产精品高清一区二区 | 牛牛视频精品一区二区不卡| 成人欧美一区二区三区在线观看| 日本成人手机在线| 超碰97在线播放| 日韩精品一区二区三区中文| 99热国产免费| 精品一区二区男人吃奶| 国产精品日韩一区二区| 国产厕拍一区| 国产日韩欧美二区| 日本成人7777| 欧美一级爽aaaaa大片| 欧美日韩播放| 水蜜桃一区二区三区| 日韩欧美中文| 在线观看欧美激情| 欧美 日韩 国产精品免费观看| 国产精品av免费| 伊人久久大香线| 亚洲色婷婷久久精品av蜜桃| 亚洲小说区图片区| 日韩精品一区二区三区久久| 日本欧美一区二区三区| 911福利视频| 成人综合婷婷国产精品久久免费| 亚洲男人在线天堂| 久久久噜噜噜久久人人看| 无码人中文字幕| 亚洲精品国产精华液| 国产精品6666| 色综合色综合色综合色综合色综合 | 91国产免费观看| 一区二区日韩在线观看| 日韩亚洲欧美成人一区| 免费观看成年人视频| 亚洲欧洲日本专区| gogo在线观看| 欧美性视频精品| 男人亚洲天堂| 国产精品久久亚洲| 欧美呦呦网站| 蜜臀av.com| 99亚洲精品| 高清av免费看| 99精品欧美一区二区三区综合在线| av中文字幕免费观看| 亚洲免费观看高清完整版在线| 久久久久久91亚洲精品中文字幕| 欧美日韩卡一卡二| 无码国产色欲xxxx视频| 在线精品91av| 青青青草视频在线| 国产精品美乳在线观看| 久久91在线| 最新视频 - x88av| 裸体一区二区| 少妇欧美激情一区二区三区| 久久久久国产精品麻豆ai换脸| 极品盗摄国产盗摄合集| 在线观看精品一区| 欧美特黄一级视频| 日韩中文字幕在线免费观看| 玖玖在线播放| 91在线免费看片| 欧美一区二区三| 大肉大捧一进一出好爽视频| 国产一区二区精品久久91| 成人免费网站黄| 亚洲国产aⅴ成人精品无吗| 亚洲视频中文字幕在线观看| 日韩大陆欧美高清视频区| a级毛片免费观看在线| 国产97在线视频| 日韩系列在线| 久久久亚洲国产精品| 狠狠狠色丁香婷婷综合激情| 中文字幕第二区| 色呦呦国产精品| 人人妻人人澡人人爽久久av| 两个人的视频www国产精品| 韩国三级一区| 免费电影一区| 亚洲免费影视| 三级电影在线看| 精品成人av一区| 国 产 黄 色 大 片| 久久国产精品久久精品| 24小时成人在线视频| 亚洲一区二区在| 蜜臀av一区二区在线免费观看| 久久久视频6r| 色悠悠久久综合| 免费在线一级视频| 日本精品久久久久影院| 日韩欧美在线精品| aa在线观看视频| av动漫一区二区| 国产成人无码精品| 日韩av资源在线播放| 国产乱码精品一区二三赶尸艳谈| 国产伦精品一区二区三区在线| 外国成人免费视频| 一级 黄 色 片一| 亚洲精品ww久久久久久p站| 91中文字幕在线播放| 久久精品国产电影| 国产精品一区二区美女视频免费看| 黄频视频在线观看| 国产乱人伦偷精品视频免下载| 澳门黄色一级片| 欧美哺乳videos| 97超碰在线免费| 开心色怡人综合网站| 日韩精品国产精品| 亚洲色图第四色| 欧美高清激情brazzers| 午夜激情在线| 好看的日韩精品| 久久国产欧美| 色撸撸在线视频| 555www色欧美视频| 青青在线视频| 欧美一级日本a级v片| 美女视频第一区二区三区免费观看网站| 林心如三级全黄裸体| 91精品国产美女浴室洗澡无遮挡| 50度灰在线| 久久久久久久久久久久久久久久av | 欧美日韩国产传媒| 狠狠干狠狠操视频| 夜夜爽夜夜爽精品视频| 亚洲欧美一区二区三| 国产精品久久久av| 小处雏高清一区二区三区| 18禁一区二区三区| 色综合久久天天综合网| 一区二区三区视频在线观看视频| 2020国产精品久久精品不卡| 国产精品毛片在线| 超碰人人人人人人人| 欧美哺乳videos| 日韩精品99| 日本一道在线观看| 久久综合中文字幕| 国产成人免费看一级大黄| 97超碰国产精品女人人人爽 | 日韩区欧美区| 欧美成人xxxxx| 国产精品国产三级国产a| 人妻91麻豆一区二区三区| 国产精品69久久久久| 国产综合欧美| 国产视频123区| 日韩大陆欧美高清视频区| 超碰国产精品一区二页| 欧美一区二区三区爽大粗免费| 亚洲欧洲一区二区三区| 午夜视频免费看| 亚洲最大福利网| 日韩影院精彩在线|