3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

zookeeper中展示所有节点_分布式协调服务之Zookeeper

發布時間:2025/3/12 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 zookeeper中展示所有节点_分布式协调服务之Zookeeper 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

??理論篇

一、基礎概念

ZooKeeper是開源分布式協調服務,提供高可用、高性能、穩定的分布式數據一致性解決方案,通常被用于實現諸如數據發布/訂閱、負載均衡、命名服務、分布式協調/通知、集群管理、Master選舉、分布式鎖和分布式隊列等功能。

二、ZooKeeper數據模型

image.png

2.1 znode(數據節點)

Zookeeper中所有存儲的數據由znode組成,節點也成為znode,并以key value鍵值對形式存儲數據。整體結構類似linux文件系統,根路徑以/開頭。

znode中數據的讀寫都是原子的,而且每一個znode都有一個Access Control List(ACL)用來限制誰可以做什么。每一個znode的數據大小不能超過1M

2.1.1 znode數據節點名稱規范
  • null 字符(即\u0000)不能組成znode節點path的命名
  • \ud800 - uF8FF, \uFFF0 - uFFFF, \u0001 - \u001F 以及 \u007F、\u009F 這些玩意無法很好地進行展示,看起來像亂碼
  • "."可以構成命名的一部分,但是不能單獨作為path的命名
  • "zookeeper"是保留字
2.1.2 znode數據節點組成:
  • stat 狀態屬性組成:
屬性名稱屬性描述
czxid創建節點的事務ID
mzxid節點最后一次修改的事務ID
pzxid子節點列表最后的一次修改(子節點列表的增加或刪除)的事務ID
ctime創建節點的時間,單位:毫秒
mtime節點最后一次修改的時間,單位:毫秒
version節點數據變更的次數
cversion子節點變更的次數
aversion節點ACL變更的次數
ephemeralOwner如果節點是臨時節點, 則此值為創建該節點的session的id,否則為0
dataLength節點數據長度
numChildren子節點個數
  • data
  • children
2.1.3 znode數據節點類型:
  • 持久節點(Persistent Nodes)

  • 臨時節點(Ephemeral Nodes) 臨時節點的生命周期即為創建這些節點的會話生命周期,即會話結束,則這些節點就會被刪除。所以臨時節點不允許創建子節點。

  • 順序節點(Sequence Nodes ) 順序節點可以是持久的,也可以是臨時的。在創建節點時,可為節點路徑添加一個單調遞增計數器,Zookeeper將通過將10位的序列號附加到原始節點名稱后來設置節點路徑。

  • 容器節點(Container Nodes) 此類型節點是3.6.0版本之后添加,容器節點是一種有特殊用途的節點,可用于leader選舉和分布式鎖等,當容器中最后一個子節點被刪除,此容器節點將會在未來某個時刻被刪除。

  • 超時過期節點(TTL Nodes) 此類型節點是3.6.0版本之后添加,當創建一個持久節點或者順序持久節點時,可以為其設置一個毫秒級的超時過期時間,如果在設置時間內,此節點沒又被修改過而且也沒有子節點,則此節點將作為候選項,在未來某個時刻被刪除。當然TTL Nodes默認是禁用狀態的。

三、Zookeeper Time

Zookeeper中時間有很多表示時間的方式。

  • Zxid 事務ID。Zookeeper狀態的每次變化都會收到這樣一個事務ID

  • Version numbers

  • Ticks

  • Real time

四、ZooKeeper Sessions (會話)

Zookeeper客戶端通過

五、ZooKeeper Watches (監聽)

5.1 watch基本概念

Zookeeper所有讀相關操作:getData()、getChildren()、 exists()等都有一個參數boolean watch用來設置watche。按照讀的內容不同,有兩種watch:Data WatchChild Watch,像getData()和exists()這種屬于讀取znode數據,所以屬于Data Watch,所以當znode數據發生變更,將觸發znode的Data Watch;getChildren()對應的就是Child Watch。創建子節點將觸發父節點的Child Watch,而節點的刪除將同時觸發Data Watch和Child Watch。

Watch是一個一次性觸發器,比如當調用 getData("/znode1", true) 后--true代表設置監聽,該節點被刪除或者數據發生變更,將會觸發客戶端注冊的watch,觸發之后,將被刪除,也就是往后數據再變化就不會再觸發此watch了。

5.2 watch 事件類型

那么當觸發watch的時候有因為數據發生變化的,有因為節點創建或刪除的等等,客戶端如何判斷服務端觸發的watch是各種類型呢?zookeeper提供了EventType的枚舉,服務端觸發watch時,會告訴客戶端是何種類型。

一共有如下這么多事件類型:

  • None
  • NodeCreated
  • NodeDeleted
  • NodeDataChanged
  • NodeChildrenChanged
  • DataWatchRemoved
  • ChildWatchRemoved
  • PersistentWatchRemoved

其中最后三個事件類型:DataWatchRemoved、ChildWatchRemoved、PersistentWatchRemoved分別是刪除不同類型的watch的時候事件類型,從單詞字面意思也應該能夠理解。

5.3 永久遞歸watch

3.6.0之后(包括3.6.0) 客戶端可以通過addWatch()為znode設置永久遞歸的watch,這意味著watch不再是一次性的了,可以多次觸發不會被刪除,并且還會遞歸觸發。當然也有移除永久watch的機制:removeWatches()

watch是維護在zookeeper服務端的,所有當客戶端與服務端斷鏈,將不會接受到watch的觸發,而當重連后都將恢復可以重新觸發。

5.3 關于watch的一些注意事項?

1.標準watch是一次性的,如果當客戶端接收到watch的回調通知,那么此watch將被刪除,如果客戶端還想接收到通知,則需要注冊另一個watch

2.正如第一條所講,在客戶端接收到watch回調通知時,可能會繼續設置一個watch以監聽znode的下次變更,但是假如在接收到watch和發送請求設置新watch的中間,znode發生了多次變化,這個可能客戶端會接收不到此變更通知。

3.如果為比如exist、getData注冊了同一個watch,那么當watch被刪除的時候,僅會觸發一次delete watch事件

六、ZooKeeper access control using ACLs(權限控制器)

ACL全稱Access Control List,即訪問控制列表。Zookeeper的ACL實現很類似與UNIX的文件系統權限控制。每一個ACL針對指定的znode,但是并不針對指定znode的子節點,也就是ACL并不遞歸生效。假如給/app設置了一個ACL,那么/app/childtest將不受此ACL控制。

權限的表達式為scheme:id, permissions

6.1 scheme-->授權策略

授權策略一共有4種

授權策略含義
world默認策略。任何人都可以訪問
auth即已經認證通過的用戶
digest通過使用MD5進行哈希 username:password格式生成的字符串來進行身份驗證,當進行身份驗證時,是使用usename:password明文形式字符串,當用做ACL驗證時,會先經過base64編碼,然后使用SHA1加密
ip使用客戶端IP作為ACL身份標識。其格式為addr/bits,bits代表客戶端的IP地址要至少匹配ACL中IP地址的多少位
x509

6.2 id-->授權對象

6.3 permissions-->權限點

權限點含義
CREATE可以創建子節點
READ可以獲取znode數據,以及znode的子節點列表
WRITE可以為znode設置數據
DELETE可以刪除znode的子節點
ADMIN可以為znode設置ACL,ADMIN就像是znode的owner

六、ZooKeeper ?Consistency Guarantees(一致性保障)

Zookeeper是高性能、可擴展的服務,它的讀操作和寫操作都非常的快

6.1 Sequential Consistency(順序一致性)

來自客戶端的更新將會按照順序進行處理

6.2 Atomicity (原子性)

6.3 Single System Image(單一系統鏡像)

無論客戶端連接到哪一個服務器上,其看到的服務端數據模型都是一致的

6.4Reliability(可靠性)

一旦更新請求被處理,更改的結果將會持久化

6.5 Timeliness (及時性)


??實戰篇

一、下載安裝

1.1 下載

下載地址:https://zookeeper.apache.org/releases.html#download [apache-zookeeper-3.6.2-bin.tar.gz](https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.6.2/apache-zookeeper-3.6.2-bin.tar.gz)

1.2 單機模式

1.2.1 設置配置文件

在conf目錄下會有一個zoo_sample.cfg文件,這里提供了樣例配置信息,我們只需要將此文件改名為zoo.cfg,這樣才會被zookeeper識別。該配置文件中的配置項說明:

  • tickTime 單位:毫秒。是服務器之間或客戶端與服務器之間維持心跳的時間間隔;且最小會話超時時間將是tickTime的兩倍

  • dataDir zookeeper保存的數據的目錄地址,默認情況下,事務log也會記在這里(除非另外指定)

  • clientPort 客戶端連接服務端的端口 zoo.cfg示例

tickTime=2000
dataDir=/var/lib/zookeeper
clientPort=2181
1.2.2 啟動zookeeper服務端(前提是需要保證安裝機器上有JDK)
./zkServer.sh?start
1.2.3 客戶端連接服務器
./zkCli.sh?-server?127.0.0.1:2181

1.3 集群模式

zookeeper集群部署可以獲得高可靠性,要想實現高可靠容錯好集群,至少需要3臺服務器,且集群數量最好為奇數。

1.3.1 設置集群配置文件zoo.conf
tickTime=2000
dataDir=/var/lib/zookeeper/
clientPort=2181
initLimit=5
syncLimit=2
server.1=zoo1:2888:3888
server.2=zoo2:2888:3888
server.3=zoo3:2888:3888

除了單機模式中需要配置的那幾個參數外,需要配置和集群相關的參數

  • initLimit 表示集群中的followers服務器 在連接leader服務器時,經過最大initLimit個tickTime后,若leader還未接收到followers的信息,則認為連接失敗
  • syncLimit 表示集群中follower服務器與leader服務器在同步消息時最大syncLimit*tickTime時間間隔未收到響應,則此follower會被拋棄
  • server.id=host:port:port 配置文件中每行的server.id=host:port:port共同組成一個集群。這里有兩個端口,前面的端口用于與集群leader連接的端口,后面的端口用于leader選舉。如果想在同一臺機器上搭建偽集群,則第一個端口不同即可

1.3.2 設置myid文件

myid文件中只有一行內容,且這行內容就是上述配置server.id=host:port:port 中的id,在集群模式下該id不可重復,范圍為1-255,將此文件放在dataDir參數表示的目錄下

1.3.3 查看服務器狀態

./zkServer.sh?status
followerleader

1.3.4 搭建集群過程遇到的問題

在搭建集群的時候,啟動三臺機器都顯示啟動成功,但是使用客戶端命令也連接失敗,通過./zkServer.sh status 顯示Error contacting service. It is probably not running.查看logs下的日志,發現有這么一行:Exception when following the leader java.io.EOFException。查資料發現是我將客戶端端口和follower服務器與leader服務器通信的端口混到一起了,如下圖配置的相同,所以出現了這種錯誤,所以這兩個端口不可以相同

錯誤配置

二、zk客戶端 操作 Zookeeper及基礎命令

2.1 bin/zkServer.sh

./zkServer.sh [--config]startstart-foreground|stop|version|restart|status|print-cmd

用于操作zk服務器相關,不同的參數代表不同的操作

#啟動zk服務器
bin/zkServer.sh?start

#重啟zk服務器
bin/zkServer.sh?restart

#停止zk服務器
bin/zkServer.sh?stop

#查看zk運行狀態
bin/zkServer.sh?status

#查看zk版本信息
bin/zkServer.sh?version

2.2 bin/zkCli.sh

  • 啟動客戶端連接zk服務器
bin/zkCli.sh?-server?{host}:{port}

2.3 客戶端命令

  • ls列出指定路徑下所有子節點 ls [-s] [-w] [-R] path
#列出根路徑下所有節點
ls?/
#列出指定路徑節點下的子節點同時,輸出指定路徑節點狀態細膩些
ls?-s?/
  • get查看指定路徑節點信息 get [-s] [-w] path
#查看/node1節點信息
get?/node1
#?查看/node1節點信息及狀態信息
get?-s?/node1
  • create創建節點 create [-s] [-e] [-c] [-t ttl] path [data] [acl] 可選參數 -s 代表創建順序節點 可選參數 -e 代表創建臨時節點 可選參數 -c 代表創建容器節點 可選參數 -t 設置節點過期時間
#?創建路徑為/node1,數據為data的持久節點
create?/node1?data
  • set修改節點 set [-s] [-v version] path data 可選參數-s代表更新節點后,輸出節點狀態信息 可選參數-v用來表示根據版本號進行更新,低版本肯定是無法更新高版本節點的(樂觀鎖)
#創建/node2節點
[zk:?localhost:2181(CONNECTED)?27]?create?/node2?data
Created?/node2
#查看/node2節點狀態信息
[zk:?localhost:2181(CONNECTED)?28]?get?-s?/node2
data
#...省略其他信息
dataVersion?=?0
#...省略其他信息
#更新節點,此時版本號為1
[zk:?localhost:2181(CONNECTED)?29]?set?-s?/node2?data2
#...省略其他信息
dataVersion?=?1
#...省略其他信息
[zk:?localhost:2181(CONNECTED)?30]?set?-v?1?/node2?data3
#更新失敗
[zk:?localhost:2181(CONNECTED)?31]?set?-v?1?/node2?data3
version?No?is?not?valid?:?/node2
[zk:?localhost:2181(CONNECTED)?32]?
  • deletedelete [-v version] path 刪除節點 因為刪除本身也是更新的意思,-v參數同上set的-v參數
#刪除/node2節點
delete?/node2

三、Java 操作 Zookeeper

通過Java操作Zookeeper有兩種方式,一種就是通過Zookeeper提供的原生API(鏈接)進行操作,一種就是通過Apache Curator(官網) ---進行操作。

3.1 Apache Curator是什么

Apache Curator是比較完善的Zookeeper客戶端框架,針對Zookeeper原生API的封裝和擴展,降低了使用 Zookeeper的復雜性,使得使用Zookeeper更加可靠、更加簡單。Curator有很多不同的artifacts,可以根據我們的需要進行引入使用:

  • curator-recipes 該artifact包含了對Zookeeper的所有操作,大部分場景只需要使用該artifact即可滿足需求。

  • curator-framework 針對zookeeper的高級功能的簡化封裝,該artifact構建在整個客戶端之上,所有應該自動包含此模塊

  • curator-client 對于Zookeeper客戶端鏈接相關操作的封裝

3.2 使用apache-curator操作zookeeper

3.2.1 引入pom
org.apache.curatorcurator-recipes5.1.0

5.1.0版本對應的zookeeper客戶端版本為3.6.0

3.2.2 創建連接

創建鏈接需要zk host地址,需要重試策略,還可以設置一些諸如超時時間等等參數。創建客戶端連接的入口類是CuratorFrameworkFactory,該類中有一個內部靜態類Builder,用于設置連接的一些額外高級參數。重試策略則是RetryPolicy。

????public?static?CuratorFramework?createWithOptions(String?connectionString,?RetryPolicy?retryPolicy,?int?connectionTimeoutMs,?int?sessionTimeoutMs){
????????return?CuratorFrameworkFactory.builder()
????????????????.connectString(connectionString)
????????????????.retryPolicy(retryPolicy)
????????????????.connectionTimeoutMs(connectionTimeoutMs)
????????????????.sessionTimeoutMs(sessionTimeoutMs)
????????????????.build();
????}

3.2.3 創建節點,更新節點內容

????/**
?????*?創建持久性節點
?????*?@param?client?CuratorFramework
?????*?@param?path?節點路徑
?????*?@param?payload?節點內容
?????*?@throws?Exception
?????*/
????public?static?void?create(CuratorFramework?client,?String?path,?byte[]?payload)?throws?Exception?{
????????client.create().forPath(path,?payload);
????}

更多參考官方示例:https://github.com/apache/curator/tree/master/curator-examples/src/main/java/framework

??應用篇

一、應用場景

  • 命名服務:按名稱標識集群中的節點
  • 統一配置管理
  • 數據發布/訂閱
  • 分布式鎖
  • Leader 選舉

二、通過Zookeeper實現統一配置管理

三、通過Zookeeper實現分布式鎖

Apache Curator針對分布式鎖提供了多種實現

  • InterProcessMutex:分布式可重入排它鎖
  • InterProcessSemaphoreMutex:分布式排它鎖
  • InterProcessReadWriteLock:分布式可重入讀寫鎖
  • InterProcessMultiLock:將多個鎖作為單個實體管理的容器

3.1 代碼實戰

3.1.1 分布式可重入排它鎖
/**
?*?@author?miaomiao
?*?@date?2020/10/25?11:15
?*/
public?class?DistributReetrantLock?{

????private?final?InterProcessMutex?interProcessMutex;
????private?final?String?lockPath;

????public?DistributReetrantLock(CuratorFramework?client,?String?lockPath)?{
????????this.lockPath?=?lockPath;
????????//?此InterProcessMutex構造方法的maxLeases為1,表示為排他鎖
????????this.interProcessMutex?=?new?InterProcessMutex(client,?lockPath);
????}

????/**
?????*?阻塞式獲取
?????*/
????public?void?tryLock()?throws?Exception?{
????????this.interProcessMutex.acquire();
????}

????/**
?????*?超時未獲取到鎖則獲取鎖失敗
?????*?@param?time
?????*?@param?unit
?????*?@return?是否獲取到鎖
?????*?@throws?Exception
?????*/
????public?boolean?tryLock(long?time,?TimeUnit?unit)?throws?Exception?{
????????return?this.interProcessMutex.acquire(time,unit);
????}

????/**
?????*?釋放鎖
?????*?@throws?Exception
?????*/
????public?void?unLock()?throws?Exception?{
????????this.interProcessMutex.release();
????}
}

測試

?????public?static?void?main(String[]?args)?throws?InterruptedException?{

????????ExecutorService?executorService?=?Executors.newFixedThreadPool(5);

????????final?String?lockPath?=?"/lock";

????????for?(int?i?=?0;?i?????????????final?int?clientIndex?=?i;
????????????Callable?callable?=?new?Callable()?{
????????????????public?Void?call()?throws?Exception?{
????????????????????CuratorFramework?simpleClient?=?MyZookeeperClient.createSimpleClient("192.168.0.104:2181");
????????????????????try?{
????????????????????????simpleClient.start();
????????????????????????DistributReetrantLock?distributReetrantLock?=?new?DistributReetrantLock(simpleClient,?lockPath);
????????????????????????//?阻塞式獲取
????????????????????????distributReetrantLock.tryLock();
????????????????????????System.out.println("Client:"?+?clientIndex?+?"?get?lock!");
????????????????????????//?驗證是否是可重入的
????????????????????????distributReetrantLock.tryLock();
????????????????????????System.out.println("Client:"?+?clientIndex?+?"?get?lock?again!");
????????????????????????Thread.sleep(1000);
????????????????????????//?持有鎖一秒后釋放,以便其他客戶端獲取到鎖
????????????????????????System.out.println("Client:"?+?clientIndex?+?"?release?lock!");
????????????????????????distributReetrantLock.unLock();
????????????????????}?finally?{
????????????????????????CloseableUtils.closeQuietly(simpleClient);
????????????????????}return?null;
????????????????}
????????????};
????????????executorService.submit(callable);
????????}
????????executorService.awaitTermination(10,?TimeUnit.MINUTES);
????}

輸出結果

Client:4?get?lock!
Client:4?get?lock?again!
Client:4?release?lock!
Client:3?get?lock!
Client:3?get?lock?again!
Client:3?release?lock!
Client:0?get?lock!
Client:0?get?lock?again!
Client:0?release?lock!
Client:1?get?lock!
Client:1?get?lock?again!
Client:1?release?lock!
Client:2?get?lock!
Client:2?get?lock?again!
Client:2?release?lock!

3.1.2 分布式排它鎖
/**
?*?分布式排它鎖
?*?@author?miaomiao
?*?@date?2020/10/25?12:54
?*/
public?class?DistributeLock?{
????private?final?String?lockPath;
????private?InterProcessSemaphoreMutex?interProcessSemaphoreMutex;
????public?DistributeLock(CuratorFramework?client,String?lockPath){
????????this.lockPath?=?lockPath;
????????this.interProcessSemaphoreMutex?=?new?InterProcessSemaphoreMutex(client,lockPath);
????}
????/**
?????*?阻塞式獲取
?????*/
????public?void?tryLock()?throws?Exception?{
????????this.interProcessSemaphoreMutex.acquire();
????}

????/**
?????*?超時未獲取到鎖則獲取鎖失敗
?????*?@param?time
?????*?@param?unit
?????*?@return?是否獲取到鎖
?????*?@throws?Exception
?????*/
????public?boolean?tryLock(long?time,?TimeUnit?unit)?throws?Exception?{
????????return?this.interProcessSemaphoreMutex.acquire(time,unit);
????}

????/**
?????*?釋放鎖
?????*?@throws?Exception
?????*/
????public?void?unLock()?throws?Exception?{
????????this.interProcessSemaphoreMutex.release();
????}
}

3.1.3 分布式可重入讀寫鎖

獲取到寫鎖的進程可以繼續獲取讀鎖,當釋放掉寫鎖后,降級為讀鎖。

/**
?*?分布式可重入讀寫鎖
?*?@author?miaomiao
?*?@date?2020/10/25?13:07
?*/
public?class?DistributeReetrantReadWriteLock?{
????private?InterProcessReadWriteLock?interProcessReadWriteLock;
????private?String?lockPath;
????public?DistributeReetrantReadWriteLock(CuratorFramework?client,String?lockPath){
????????this.lockPath?=?lockPath;
????????this.interProcessReadWriteLock?=?new?InterProcessReadWriteLock(client,lockPath);
????}

????/**
?????*?阻塞式獲取讀鎖
?????*?@throws?Exception
?????*/
????public?void?tryReadLock()?throws?Exception?{
???????interProcessReadWriteLock.readLock().acquire();
????}

????/**
?????*?獲阻塞式獲取寫鎖
?????*?@throws?Exception
?????*/
????public?void?tryWriteLock()?throws?Exception?{
????????interProcessReadWriteLock.writeLock().acquire();
????}

????/**
?????*?釋放寫鎖
?????*?@throws?Exception
?????*/
????public?void?unlockWriteLock()?throws?Exception?{
????????interProcessReadWriteLock.writeLock().release();
????}

????/**
?????*?釋放讀鎖
?????*?@throws?Exception
?????*/
????public?void?unlockReadLock()?throws?Exception?{
????????interProcessReadWriteLock.readLock().release();
????}
}

3.2 分布式鎖原理

3.1 排它鎖原理

利用 zookeeper 的同級節點的唯一性特性,在需要獲取排他鎖時,所有的客戶端試圖通過調用 create() 接口,在 /指定 節點下創建相同臨時子節點 /exclusive_lock/lock,最終只有一個客戶端能創建成功,那么此客戶端就獲得了分布式鎖。同時,所有沒有獲取到鎖的客戶端可以在 /exclusive_lock 節點上注冊一個子節點變更的 watcher 監聽事件,以便重新爭取獲得鎖。

3.2 讀寫鎖原理

共享鎖需要實現共享讀,排他寫。實現原理:當多個客戶端請求共享鎖時,為指定節點創建臨時順序子節點,且子節點的path能夠區分是哪個客戶端以及當前該客戶端的操作(寫還是讀)就像這樣 [hostname]-請求類型W/R-序號。之后在判斷當前客戶端是否獲得鎖時,如果當前客戶端的操作為讀請求,則判斷如果存在小于自己節點序號的寫請求節點或者自己本身就是最小序列的節點,則獲取到鎖;如果當前客戶端的操作為寫請求時,則只有自己節點序號是最小的節點時,才可以獲取到鎖。如果沒有獲取到鎖,讀請求在比自己序號小的最后一個寫請求節點添加監聽器;寫請求在子節點列表比自己小的最后一個節點注冊watcher監聽。

四、通過Zookeeper實現Leader選舉

在分布式系統中,leader選舉是指指定一個進程(一個實例、一臺機器)作為分配給多臺服務器任務的組織者的過程。在任務開始之前,所有服務器節點都不知道哪個節點將作為任務的領導者或者說協調者,然后在leader選舉之后,每個節點都會識別出一個特定的、唯一的節點作為任務leader。

Apache Curator針對Leader 選舉提供了兩種方式:

4.1 利用順序臨時節點實現

最簡單的方式就是,當有一個"/election"節點,客戶端們為此節點創建一個順序、臨時節點,每個客戶端創建的子節點都會自動帶上一個序號后綴,并且最早創建的序號最小,只需要選舉序號最小的子節點對應的客戶端作為leader即可。

當然這些肯定是遠遠不夠的,還要有假如leader宕機出現故障,必須要重新推舉新的leader機制。一種解決辦法就是所有的應用客戶端都監聽序號最小的子節點來判斷自己是否可以成為leader,因為假如leader客戶端宕機,那么最小序號節點也會消失,所以會產生新的最小序號節點,也就是產生新的leader。但是這樣做會產生羊群效應(herd effect):所有的客戶端都接收到了最小序號子節點被刪除的通知,接下來所有客戶端都調用getChilrden()獲取"/election"的子節點列表,如果客戶端數量很大,將會給zookeeper服務器帶來一定的壓力。為了避免羊群效應,每個客戶端只需要監聽自己對應子節點的前一個節點就足夠了,這樣當leader客戶端宕機,最小子序列節點被刪除,那么最小序列子節點的下一個節點對應的客戶端就成為新的leader。

對應在Apache Curator中的相關實現類為

  • org.apache.curator.framework.recipes.leader.LeaderLatch

核心類,主入口

  • org.apache.curator.framework.recipes.leader.LeaderLatchListener leader latch監聽器,當leader狀態發生改變時回調,該接口有兩個方法
??//當稱為leader時調用
??public?void?isLeader();
??//當失去leader時調用
??public?void?notLeader();

示例

????????????????????????CuratorFramework?simpleClient?=?MyZookeeperClient.createSimpleClient("192.168.0.104:2181");

????????????????????????simpleClient.start();

????????????????????????MyLeaderLatch?leaderLatch?=?new?MyLeaderLatch(simpleClient,"/leader_election"?,new?LeaderLatchListener(){
????????????????????????????public?void?isLeader()?{
????????????????????????????????System.out.println("Client:"+clientIndex+"?is?leader");
????????????????????????????}

????????????????????????????public?void?notLeader()?{
????????????????????????????????System.out.println("Client:"+clientIndex+"?lose?leader");

????????????????????????????}
????????????????????????});
????????????????????????leaderLatch.start();

4.2 利用分布式鎖實現

相關類:

  • org.apache.curator.framework.recipes.leader.LeaderSelector

核心類,選舉主入口,構造LeaderSelector 必須傳入LeaderSelectorListener

  • org.apache.curator.framework.recipes.leader.LeaderSelectorListener

leader selector監聽器,當被選為leader時回調。當某節點被選舉為leader時,調用takeLeadership,當takeLeadership方法執行完畢后,則此節點就會放棄leader,從而致使重新選舉,即leader得生命周期等于takeLeadership方法得周期。

  • org.apache.curator.framework.recipes.leader.LeaderSelectorListenerAdapter

LeaderSelectorListenerAdapter是對LeaderSelectorListener的一個抽象實現,覆寫了stateChanged方法,并當選舉失敗時拋出CancelLeadershipException,官方推薦使用該監聽器

  • org.apache.curator.framework.recipes.leader.CancelLeadershipException示例:
?????????????CuratorFramework?simpleClient?=?MyZookeeperClient.createSimpleClient("192.168.0.104:2181");

????????????????simpleClient.start();

????????????????MyLeaderSelector?leaderSelector?=?new?MyLeaderSelector(simpleClient,?"/leader_selector",?new?LeaderSelectorListenerAdapter()?{

????????????????????public?void?takeLeadership(CuratorFramework?client)?throws?Exception?{
????????????????????????System.out.println("Client:"?+?clientIndex?+?"?get?leader!");
????????????????????}
????????????????});
????????????????//開始選舉
????????????????leaderSelector.start();

??參考文章

https://github.com/Snailclimb/JavaGuide/blob/master/docs/system-design/framework/zookeeper/

https://zookeeper.apache.org/doc/r3.6.2/zookeeperProgrammers.html

https://www.cnblogs.com/qlqwjy/p/10517231.html

ZooKeeper 的應用場景

分布式服務框架 Zookeeper —— 管理分布式環境中的數據

https://www.runoob.com/w3cnote_genre/zookeeper/page/2

http://curator.apache.org/

??理論篇

一、基礎概念

ZooKeeper是開源分布式協調服務,提供高可用、高性能、穩定的分布式數據一致性解決方案,通常被用于實現諸如數據發布/訂閱、負載均衡、命名服務、分布式協調/通知、集群管理、Master選舉、分布式鎖和分布式隊列等功能。

二、ZooKeeper數據模型

image.png

2.1 znode(數據節點)

Zookeeper中所有存儲的數據由znode組成,節點也成為znode,并以key value鍵值對形式存儲數據。整體結構類似linux文件系統,根路徑以/開頭。

znode中數據的讀寫都是原子的,而且每一個znode都有一個Access Control List(ACL)用來限制誰可以做什么。每一個znode的數據大小不能超過1M

2.1.1 znode數據節點名稱規范
  • null 字符(即\u0000)不能組成znode節點path的命名
  • \ud800 - uF8FF, \uFFF0 - uFFFF, \u0001 - \u001F 以及 \u007F、\u009F 這些玩意無法很好地進行展示,看起來像亂碼
  • "."可以構成命名的一部分,但是不能單獨作為path的命名
  • "zookeeper"是保留字
2.1.2 znode數據節點組成:
  • stat 狀態屬性組成:
屬性名稱屬性描述
czxid創建節點的事務ID
mzxid節點最后一次修改的事務ID
pzxid子節點列表最后的一次修改(子節點列表的增加或刪除)的事務ID
ctime創建節點的時間,單位:毫秒
mtime節點最后一次修改的時間,單位:毫秒
version節點數據變更的次數
cversion子節點變更的次數
aversion節點ACL變更的次數
ephemeralOwner如果節點是臨時節點, 則此值為創建該節點的session的id,否則為0
dataLength節點數據長度
numChildren子節點個數
  • data
  • children
2.1.3 znode數據節點類型:
  • 持久節點(Persistent Nodes)

  • 臨時節點(Ephemeral Nodes) 臨時節點的生命周期即為創建這些節點的會話生命周期,即會話結束,則這些節點就會被刪除。所以臨時節點不允許創建子節點。

  • 順序節點(Sequence Nodes ) 順序節點可以是持久的,也可以是臨時的。在創建節點時,可為節點路徑添加一個單調遞增計數器,Zookeeper將通過將10位的序列號附加到原始節點名稱后來設置節點路徑。

  • 容器節點(Container Nodes) 此類型節點是3.6.0版本之后添加,容器節點是一種有特殊用途的節點,可用于leader選舉和分布式鎖等,當容器中最后一個子節點被刪除,此容器節點將會在未來某個時刻被刪除。

  • 超時過期節點(TTL Nodes) 此類型節點是3.6.0版本之后添加,當創建一個持久節點或者順序持久節點時,可以為其設置一個毫秒級的超時過期時間,如果在設置時間內,此節點沒又被修改過而且也沒有子節點,則此節點將作為候選項,在未來某個時刻被刪除。當然TTL Nodes默認是禁用狀態的。

三、Zookeeper Time

Zookeeper中時間有很多表示時間的方式。

  • Zxid 事務ID。Zookeeper狀態的每次變化都會收到這樣一個事務ID

  • Version numbers

  • Ticks

  • Real time

四、ZooKeeper Sessions (會話)

Zookeeper客戶端通過

五、ZooKeeper Watches (監聽)

5.1 watch基本概念

Zookeeper所有讀相關操作:getData()、getChildren()、 exists()等都有一個參數boolean watch用來設置watche。按照讀的內容不同,有兩種watch:Data WatchChild Watch,像getData()和exists()這種屬于讀取znode數據,所以屬于Data Watch,所以當znode數據發生變更,將觸發znode的Data Watch;getChildren()對應的就是Child Watch。創建子節點將觸發父節點的Child Watch,而節點的刪除將同時觸發Data Watch和Child Watch。

Watch是一個一次性觸發器,比如當調用 getData("/znode1", true) 后--true代表設置監聽,該節點被刪除或者數據發生變更,將會觸發客戶端注冊的watch,觸發之后,將被刪除,也就是往后數據再變化就不會再觸發此watch了。

5.2 watch 事件類型

那么當觸發watch的時候有因為數據發生變化的,有因為節點創建或刪除的等等,客戶端如何判斷服務端觸發的watch是各種類型呢?zookeeper提供了EventType的枚舉,服務端觸發watch時,會告訴客戶端是何種類型。

一共有如下這么多事件類型:

  • None
  • NodeCreated
  • NodeDeleted
  • NodeDataChanged
  • NodeChildrenChanged
  • DataWatchRemoved
  • ChildWatchRemoved
  • PersistentWatchRemoved

其中最后三個事件類型:DataWatchRemoved、ChildWatchRemoved、PersistentWatchRemoved分別是刪除不同類型的watch的時候事件類型,從單詞字面意思也應該能夠理解。

5.3 永久遞歸watch

3.6.0之后(包括3.6.0) 客戶端可以通過addWatch()為znode設置永久遞歸的watch,這意味著watch不再是一次性的了,可以多次觸發不會被刪除,并且還會遞歸觸發。當然也有移除永久watch的機制:removeWatches()

watch是維護在zookeeper服務端的,所有當客戶端與服務端斷鏈,將不會接受到watch的觸發,而當重連后都將恢復可以重新觸發。

5.3 關于watch的一些注意事項?

1.標準watch是一次性的,如果當客戶端接收到watch的回調通知,那么此watch將被刪除,如果客戶端還想接收到通知,則需要注冊另一個watch

2.正如第一條所講,在客戶端接收到watch回調通知時,可能會繼續設置一個watch以監聽znode的下次變更,但是假如在接收到watch和發送請求設置新watch的中間,znode發生了多次變化,這個可能客戶端會接收不到此變更通知。

3.如果為比如exist、getData注冊了同一個watch,那么當watch被刪除的時候,僅會觸發一次delete watch事件

六、ZooKeeper access control using ACLs(權限控制器)

ACL全稱Access Control List,即訪問控制列表。Zookeeper的ACL實現很類似與UNIX的文件系統權限控制。每一個ACL針對指定的znode,但是并不針對指定znode的子節點,也就是ACL并不遞歸生效。假如給/app設置了一個ACL,那么/app/childtest將不受此ACL控制。

權限的表達式為scheme:id, permissions

6.1 scheme-->授權策略

授權策略一共有4種

授權策略含義
world默認策略。任何人都可以訪問
auth即已經認證通過的用戶
digest通過使用MD5進行哈希 username:password格式生成的字符串來進行身份驗證,當進行身份驗證時,是使用usename:password明文形式字符串,當用做ACL驗證時,會先經過base64編碼,然后使用SHA1加密
ip使用客戶端IP作為ACL身份標識。其格式為addr/bits,bits代表客戶端的IP地址要至少匹配ACL中IP地址的多少位
x509

6.2 id-->授權對象

6.3 permissions-->權限點

權限點含義
CREATE可以創建子節點
READ可以獲取znode數據,以及znode的子節點列表
WRITE可以為znode設置數據
DELETE可以刪除znode的子節點
ADMIN可以為znode設置ACL,ADMIN就像是znode的owner

六、ZooKeeper ?Consistency Guarantees(一致性保障)

Zookeeper是高性能、可擴展的服務,它的讀操作和寫操作都非常的快

6.1 Sequential Consistency(順序一致性)

來自客戶端的更新將會按照順序進行處理

6.2 Atomicity (原子性)

6.3 Single System Image(單一系統鏡像)

無論客戶端連接到哪一個服務器上,其看到的服務端數據模型都是一致的

6.4Reliability(可靠性)

一旦更新請求被處理,更改的結果將會持久化

6.5 Timeliness (及時性)


??實戰篇

一、下載安裝

1.1 下載

下載地址:https://zookeeper.apache.org/releases.html#download [apache-zookeeper-3.6.2-bin.tar.gz](https://mirrors.tuna.tsinghua.edu.cn/apache/zookeeper/zookeeper-3.6.2/apache-zookeeper-3.6.2-bin.tar.gz)

1.2 單機模式

1.2.1 設置配置文件

在conf目錄下會有一個zoo_sample.cfg文件,這里提供了樣例配置信息,我們只需要將此文件改名為zoo.cfg,這樣才會被zookeeper識別。該配置文件中的配置項說明:

  • tickTime 單位:毫秒。是服務器之間或客戶端與服務器之間維持心跳的時間間隔;且最小會話超時時間將是tickTime的兩倍

  • dataDir zookeeper保存的數據的目錄地址,默認情況下,事務log也會記在這里(除非另外指定)

  • clientPort 客戶端連接服務端的端口 zoo.cfg示例

tickTime=2000
dataDir=/var/lib/zookeeper
clientPort=2181
1.2.2 啟動zookeeper服務端(前提是需要保證安裝機器上有JDK)
./zkServer.sh?start
1.2.3 客戶端連接服務器
./zkCli.sh?-server?127.0.0.1:2181

1.3 集群模式

zookeeper集群部署可以獲得高可靠性,要想實現高可靠容錯好集群,至少需要3臺服務器,且集群數量最好為奇數。

1.3.1 設置集群配置文件zoo.conf
tickTime=2000
dataDir=/var/lib/zookeeper/
clientPort=2181
initLimit=5
syncLimit=2
server.1=zoo1:2888:3888
server.2=zoo2:2888:3888
server.3=zoo3:2888:3888

除了單機模式中需要配置的那幾個參數外,需要配置和集群相關的參數

  • initLimit 表示集群中的followers服務器 在連接leader服務器時,經過最大initLimit個tickTime后,若leader還未接收到followers的信息,則認為連接失敗
  • syncLimit 表示集群中follower服務器與leader服務器在同步消息時最大syncLimit*tickTime時間間隔未收到響應,則此follower會被拋棄
  • server.id=host:port:port 配置文件中每行的server.id=host:port:port共同組成一個集群。這里有兩個端口,前面的端口用于與集群leader連接的端口,后面的端口用于leader選舉。如果想在同一臺機器上搭建偽集群,則第一個端口不同即可

1.3.2 設置myid文件

myid文件中只有一行內容,且這行內容就是上述配置server.id=host:port:port 中的id,在集群模式下該id不可重復,范圍為1-255,將此文件放在dataDir參數表示的目錄下

1.3.3 查看服務器狀態

./zkServer.sh?status
followerleader

1.3.4 搭建集群過程遇到的問題

在搭建集群的時候,啟動三臺機器都顯示啟動成功,但是使用客戶端命令也連接失敗,通過./zkServer.sh status 顯示Error contacting service. It is probably not running.查看logs下的日志,發現有這么一行:Exception when following the leader java.io.EOFException。查資料發現是我將客戶端端口和follower服務器與leader服務器通信的端口混到一起了,如下圖配置的相同,所以出現了這種錯誤,所以這兩個端口不可以相同

錯誤配置

二、zk客戶端 操作 Zookeeper及基礎命令

2.1 bin/zkServer.sh

./zkServer.sh [--config]startstart-foreground|stop|version|restart|status|print-cmd

用于操作zk服務器相關,不同的參數代表不同的操作

#啟動zk服務器
bin/zkServer.sh?start

#重啟zk服務器
bin/zkServer.sh?restart

#停止zk服務器
bin/zkServer.sh?stop

#查看zk運行狀態
bin/zkServer.sh?status

#查看zk版本信息
bin/zkServer.sh?version

2.2 bin/zkCli.sh

  • 啟動客戶端連接zk服務器
bin/zkCli.sh?-server?{host}:{port}

2.3 客戶端命令

  • ls列出指定路徑下所有子節點 ls [-s] [-w] [-R] path
#列出根路徑下所有節點
ls?/
#列出指定路徑節點下的子節點同時,輸出指定路徑節點狀態細膩些
ls?-s?/
  • get查看指定路徑節點信息 get [-s] [-w] path
#查看/node1節點信息
get?/node1
#?查看/node1節點信息及狀態信息
get?-s?/node1
  • create創建節點 create [-s] [-e] [-c] [-t ttl] path [data] [acl] 可選參數 -s 代表創建順序節點 可選參數 -e 代表創建臨時節點 可選參數 -c 代表創建容器節點 可選參數 -t 設置節點過期時間
#?創建路徑為/node1,數據為data的持久節點
create?/node1?data
  • set修改節點 set [-s] [-v version] path data 可選參數-s代表更新節點后,輸出節點狀態信息 可選參數-v用來表示根據版本號進行更新,低版本肯定是無法更新高版本節點的(樂觀鎖)
#創建/node2節點
[zk:?localhost:2181(CONNECTED)?27]?create?/node2?data
Created?/node2
#查看/node2節點狀態信息
[zk:?localhost:2181(CONNECTED)?28]?get?-s?/node2
data
#...省略其他信息
dataVersion?=?0
#...省略其他信息
#更新節點,此時版本號為1
[zk:?localhost:2181(CONNECTED)?29]?set?-s?/node2?data2
#...省略其他信息
dataVersion?=?1
#...省略其他信息
[zk:?localhost:2181(CONNECTED)?30]?set?-v?1?/node2?data3
#更新失敗
[zk:?localhost:2181(CONNECTED)?31]?set?-v?1?/node2?data3
version?No?is?not?valid?:?/node2
[zk:?localhost:2181(CONNECTED)?32]?
  • deletedelete [-v version] path 刪除節點 因為刪除本身也是更新的意思,-v參數同上set的-v參數
#刪除/node2節點
delete?/node2

三、Java 操作 Zookeeper

通過Java操作Zookeeper有兩種方式,一種就是通過Zookeeper提供的原生API(鏈接)進行操作,一種就是通過Apache Curator(官網) ---進行操作。

3.1 Apache Curator是什么

Apache Curator是比較完善的Zookeeper客戶端框架,針對Zookeeper原生API的封裝和擴展,降低了使用 Zookeeper的復雜性,使得使用Zookeeper更加可靠、更加簡單。Curator有很多不同的artifacts,可以根據我們的需要進行引入使用:

  • curator-recipes 該artifact包含了對Zookeeper的所有操作,大部分場景只需要使用該artifact即可滿足需求。

  • curator-framework 針對zookeeper的高級功能的簡化封裝,該artifact構建在整個客戶端之上,所有應該自動包含此模塊

  • curator-client 對于Zookeeper客戶端鏈接相關操作的封裝

3.2 使用apache-curator操作zookeeper

3.2.1 引入pom
org.apache.curatorcurator-recipes5.1.0

5.1.0版本對應的zookeeper客戶端版本為3.6.0

3.2.2 創建連接

創建鏈接需要zk host地址,需要重試策略,還可以設置一些諸如超時時間等等參數。創建客戶端連接的入口類是CuratorFrameworkFactory,該類中有一個內部靜態類Builder,用于設置連接的一些額外高級參數。重試策略則是RetryPolicy。

????public?static?CuratorFramework?createWithOptions(String?connectionString,?RetryPolicy?retryPolicy,?int?connectionTimeoutMs,?int?sessionTimeoutMs){
????????return?CuratorFrameworkFactory.builder()
????????????????.connectString(connectionString)
????????????????.retryPolicy(retryPolicy)
????????????????.connectionTimeoutMs(connectionTimeoutMs)
????????????????.sessionTimeoutMs(sessionTimeoutMs)
????????????????.build();
????}

3.2.3 創建節點,更新節點內容

????/**
?????*?創建持久性節點
?????*?@param?client?CuratorFramework
?????*?@param?path?節點路徑
?????*?@param?payload?節點內容
?????*?@throws?Exception
?????*/
????public?static?void?create(CuratorFramework?client,?String?path,?byte[]?payload)?throws?Exception?{
????????client.create().forPath(path,?payload);
????}

更多參考官方示例:https://github.com/apache/curator/tree/master/curator-examples/src/main/java/framework

??應用篇

一、應用場景

  • 命名服務:按名稱標識集群中的節點
  • 統一配置管理
  • 數據發布/訂閱
  • 分布式鎖
  • Leader 選舉

二、通過Zookeeper實現統一配置管理

三、通過Zookeeper實現分布式鎖

Apache Curator針對分布式鎖提供了多種實現

  • InterProcessMutex:分布式可重入排它鎖
  • InterProcessSemaphoreMutex:分布式排它鎖
  • InterProcessReadWriteLock:分布式可重入讀寫鎖
  • InterProcessMultiLock:將多個鎖作為單個實體管理的容器

3.1 代碼實戰

3.1.1 分布式可重入排它鎖
/**
?*?@author?miaomiao
?*?@date?2020/10/25?11:15
?*/
public?class?DistributReetrantLock?{

????private?final?InterProcessMutex?interProcessMutex;
????private?final?String?lockPath;

????public?DistributReetrantLock(CuratorFramework?client,?String?lockPath)?{
????????this.lockPath?=?lockPath;
????????//?此InterProcessMutex構造方法的maxLeases為1,表示為排他鎖
????????this.interProcessMutex?=?new?InterProcessMutex(client,?lockPath);
????}

????/**
?????*?阻塞式獲取
?????*/
????public?void?tryLock()?throws?Exception?{
????????this.interProcessMutex.acquire();
????}

????/**
?????*?超時未獲取到鎖則獲取鎖失敗
?????*?@param?time
?????*?@param?unit
?????*?@return?是否獲取到鎖
?????*?@throws?Exception
?????*/
????public?boolean?tryLock(long?time,?TimeUnit?unit)?throws?Exception?{
????????return?this.interProcessMutex.acquire(time,unit);
????}

????/**
?????*?釋放鎖
?????*?@throws?Exception
?????*/
????public?void?unLock()?throws?Exception?{
????????this.interProcessMutex.release();
????}
}

測試

?????public?static?void?main(String[]?args)?throws?InterruptedException?{

????????ExecutorService?executorService?=?Executors.newFixedThreadPool(5);

????????final?String?lockPath?=?"/lock";

????????for?(int?i?=?0;?i?????????????final?int?clientIndex?=?i;
????????????Callable?callable?=?new?Callable()?{
????????????????public?Void?call()?throws?Exception?{
????????????????????CuratorFramework?simpleClient?=?MyZookeeperClient.createSimpleClient("192.168.0.104:2181");
????????????????????try?{
????????????????????????simpleClient.start();
????????????????????????DistributReetrantLock?distributReetrantLock?=?new?DistributReetrantLock(simpleClient,?lockPath);
????????????????????????//?阻塞式獲取
????????????????????????distributReetrantLock.tryLock();
????????????????????????System.out.println("Client:"?+?clientIndex?+?"?get?lock!");
????????????????????????//?驗證是否是可重入的
????????????????????????distributReetrantLock.tryLock();
????????????????????????System.out.println("Client:"?+?clientIndex?+?"?get?lock?again!");
????????????????????????Thread.sleep(1000);
????????????????????????//?持有鎖一秒后釋放,以便其他客戶端獲取到鎖
????????????????????????System.out.println("Client:"?+?clientIndex?+?"?release?lock!");
????????????????????????distributReetrantLock.unLock();
????????????????????}?finally?{
????????????????????????CloseableUtils.closeQuietly(simpleClient);
????????????????????}return?null;
????????????????}
????????????};
????????????executorService.submit(callable);
????????}
????????executorService.awaitTermination(10,?TimeUnit.MINUTES);
????}

輸出結果

Client:4?get?lock!
Client:4?get?lock?again!
Client:4?release?lock!
Client:3?get?lock!
Client:3?get?lock?again!
Client:3?release?lock!
Client:0?get?lock!
Client:0?get?lock?again!
Client:0?release?lock!
Client:1?get?lock!
Client:1?get?lock?again!
Client:1?release?lock!
Client:2?get?lock!
Client:2?get?lock?again!
Client:2?release?lock!

3.1.2 分布式排它鎖
/**
?*?分布式排它鎖
?*?@author?miaomiao
?*?@date?2020/10/25?12:54
?*/
public?class?DistributeLock?{
????private?final?String?lockPath;
????private?InterProcessSemaphoreMutex?interProcessSemaphoreMutex;
????public?DistributeLock(CuratorFramework?client,String?lockPath){
????????this.lockPath?=?lockPath;
????????this.interProcessSemaphoreMutex?=?new?InterProcessSemaphoreMutex(client,lockPath);
????}
????/**
?????*?阻塞式獲取
?????*/
????public?void?tryLock()?throws?Exception?{
????????this.interProcessSemaphoreMutex.acquire();
????}

????/**
?????*?超時未獲取到鎖則獲取鎖失敗
?????*?@param?time
?????*?@param?unit
?????*?@return?是否獲取到鎖
?????*?@throws?Exception
?????*/
????public?boolean?tryLock(long?time,?TimeUnit?unit)?throws?Exception?{
????????return?this.interProcessSemaphoreMutex.acquire(time,unit);
????}

????/**
?????*?釋放鎖
?????*?@throws?Exception
?????*/
????public?void?unLock()?throws?Exception?{
????????this.interProcessSemaphoreMutex.release();
????}
}

3.1.3 分布式可重入讀寫鎖

獲取到寫鎖的進程可以繼續獲取讀鎖,當釋放掉寫鎖后,降級為讀鎖。

/**
?*?分布式可重入讀寫鎖
?*?@author?miaomiao
?*?@date?2020/10/25?13:07
?*/
public?class?DistributeReetrantReadWriteLock?{
????private?InterProcessReadWriteLock?interProcessReadWriteLock;
????private?String?lockPath;
????public?DistributeReetrantReadWriteLock(CuratorFramework?client,String?lockPath){
????????this.lockPath?=?lockPath;
????????this.interProcessReadWriteLock?=?new?InterProcessReadWriteLock(client,lockPath);
????}

????/**
?????*?阻塞式獲取讀鎖
?????*?@throws?Exception
?????*/
????public?void?tryReadLock()?throws?Exception?{
???????interProcessReadWriteLock.readLock().acquire();
????}

????/**
?????*?獲阻塞式獲取寫鎖
?????*?@throws?Exception
?????*/
????public?void?tryWriteLock()?throws?Exception?{
????????interProcessReadWriteLock.writeLock().acquire();
????}

????/**
?????*?釋放寫鎖
?????*?@throws?Exception
?????*/
????public?void?unlockWriteLock()?throws?Exception?{
????????interProcessReadWriteLock.writeLock().release();
????}

????/**
?????*?釋放讀鎖
?????*?@throws?Exception
?????*/
????public?void?unlockReadLock()?throws?Exception?{
????????interProcessReadWriteLock.readLock().release();
????}
}

3.2 分布式鎖原理

3.1 排它鎖原理

利用 zookeeper 的同級節點的唯一性特性,在需要獲取排他鎖時,所有的客戶端試圖通過調用 create() 接口,在 /指定 節點下創建相同臨時子節點 /exclusive_lock/lock,最終只有一個客戶端能創建成功,那么此客戶端就獲得了分布式鎖。同時,所有沒有獲取到鎖的客戶端可以在 /exclusive_lock 節點上注冊一個子節點變更的 watcher 監聽事件,以便重新爭取獲得鎖。

3.2 讀寫鎖原理

共享鎖需要實現共享讀,排他寫。實現原理:當多個客戶端請求共享鎖時,為指定節點創建臨時順序子節點,且子節點的path能夠區分是哪個客戶端以及當前該客戶端的操作(寫還是讀)就像這樣 [hostname]-請求類型W/R-序號。之后在判斷當前客戶端是否獲得鎖時,如果當前客戶端的操作為讀請求,則判斷如果存在小于自己節點序號的寫請求節點或者自己本身就是最小序列的節點,則獲取到鎖;如果當前客戶端的操作為寫請求時,則只有自己節點序號是最小的節點時,才可以獲取到鎖。如果沒有獲取到鎖,讀請求在比自己序號小的最后一個寫請求節點添加監聽器;寫請求在子節點列表比自己小的最后一個節點注冊watcher監聽。

四、通過Zookeeper實現Leader選舉

在分布式系統中,leader選舉是指指定一個進程(一個實例、一臺機器)作為分配給多臺服務器任務的組織者的過程。在任務開始之前,所有服務器節點都不知道哪個節點將作為任務的領導者或者說協調者,然后在leader選舉之后,每個節點都會識別出一個特定的、唯一的節點作為任務leader。

Apache Curator針對Leader 選舉提供了兩種方式:

4.1 利用順序臨時節點實現

最簡單的方式就是,當有一個"/election"節點,客戶端們為此節點創建一個順序、臨時節點,每個客戶端創建的子節點都會自動帶上一個序號后綴,并且最早創建的序號最小,只需要選舉序號最小的子節點對應的客戶端作為leader即可。

當然這些肯定是遠遠不夠的,還要有假如leader宕機出現故障,必須要重新推舉新的leader機制。一種解決辦法就是所有的應用客戶端都監聽序號最小的子節點來判斷自己是否可以成為leader,因為假如leader客戶端宕機,那么最小序號節點也會消失,所以會產生新的最小序號節點,也就是產生新的leader。但是這樣做會產生羊群效應(herd effect):所有的客戶端都接收到了最小序號子節點被刪除的通知,接下來所有客戶端都調用getChilrden()獲取"/election"的子節點列表,如果客戶端數量很大,將會給zookeeper服務器帶來一定的壓力。為了避免羊群效應,每個客戶端只需要監聽自己對應子節點的前一個節點就足夠了,這樣當leader客戶端宕機,最小子序列節點被刪除,那么最小序列子節點的下一個節點對應的客戶端就成為新的leader。

對應在Apache Curator中的相關實現類為

  • org.apache.curator.framework.recipes.leader.LeaderLatch

核心類,主入口

  • org.apache.curator.framework.recipes.leader.LeaderLatchListener leader latch監聽器,當leader狀態發生改變時回調,該接口有兩個方法
??//當稱為leader時調用
??public?void?isLeader();
??//當失去leader時調用
??public?void?notLeader();

示例

????????????????????????CuratorFramework?simpleClient?=?MyZookeeperClient.createSimpleClient("192.168.0.104:2181");

????????????????????????simpleClient.start();

????????????????????????MyLeaderLatch?leaderLatch?=?new?MyLeaderLatch(simpleClient,"/leader_election"?,new?LeaderLatchListener(){
????????????????????????????public?void?isLeader()?{
????????????????????????????????System.out.println("Client:"+clientIndex+"?is?leader");
????????????????????????????}

????????????????????????????public?void?notLeader()?{
????????????????????????????????System.out.println("Client:"+clientIndex+"?lose?leader");

????????????????????????????}
????????????????????????});
????????????????????????leaderLatch.start();

4.2 利用分布式鎖實現

相關類:

  • org.apache.curator.framework.recipes.leader.LeaderSelector

核心類,選舉主入口,構造LeaderSelector 必須傳入LeaderSelectorListener

  • org.apache.curator.framework.recipes.leader.LeaderSelectorListener

leader selector監聽器,當被選為leader時回調。當某節點被選舉為leader時,調用takeLeadership,當takeLeadership方法執行完畢后,則此節點就會放棄leader,從而致使重新選舉,即leader得生命周期等于takeLeadership方法得周期。

  • org.apache.curator.framework.recipes.leader.LeaderSelectorListenerAdapter

LeaderSelectorListenerAdapter是對LeaderSelectorListener的一個抽象實現,覆寫了stateChanged方法,并當選舉失敗時拋出CancelLeadershipException,官方推薦使用該監聽器

  • org.apache.curator.framework.recipes.leader.CancelLeadershipException示例:
?????????????CuratorFramework?simpleClient?=?MyZookeeperClient.createSimpleClient("192.168.0.104:2181");

????????????????simpleClient.start();

????????????????MyLeaderSelector?leaderSelector?=?new?MyLeaderSelector(simpleClient,?"/leader_selector",?new?LeaderSelectorListenerAdapter()?{

????????????????????public?void?takeLeadership(CuratorFramework?client)?throws?Exception?{
????????????????????????System.out.println("Client:"?+?clientIndex?+?"?get?leader!");
????????????????????}
????????????????});
????????????????//開始選舉
????????????????leaderSelector.start();

??參考文章

https://github.com/Snailclimb/JavaGuide/blob/master/docs/system-design/framework/zookeeper/

https://zookeeper.apache.org/doc/r3.6.2/zookeeperProgrammers.html

https://www.cnblogs.com/qlqwjy/p/10517231.html

ZooKeeper 的應用場景

分布式服務框架 Zookeeper —— 管理分布式環境中的數據

https://www.runoob.com/w3cnote_genre/zookeeper/page/2

http://curator.apache.org/

總結

以上是生活随笔為你收集整理的zookeeper中展示所有节点_分布式协调服务之Zookeeper的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

三级4级全黄60分钟 | 精品一区二区不卡无码av | 亚洲性无码av中文字幕 | 久久国产精品萌白酱免费 | 少妇厨房愉情理9仑片视频 | 精品国产精品久久一区免费式 | 亚洲大尺度无码无码专区 | 狂野欧美性猛xxxx乱大交 | 中文字幕无码日韩欧毛 | 亚洲中文字幕无码中文字在线 | 精品乱码久久久久久久 | 国产人成高清在线视频99最全资源 | 免费无码的av片在线观看 | 亚洲精品中文字幕乱码 | 久久久中文字幕日本无吗 | 国内精品久久毛片一区二区 | 日韩av无码一区二区三区 | 成人av无码一区二区三区 | 亚洲の无码国产の无码影院 | 激情五月综合色婷婷一区二区 | 呦交小u女精品视频 | 亚洲综合无码久久精品综合 | 樱花草在线播放免费中文 | 特黄特色大片免费播放器图片 | 色欲av亚洲一区无码少妇 | 自拍偷自拍亚洲精品被多人伦好爽 | 亚洲国产精品久久久久久 | 欧美激情一区二区三区成人 | 亚洲国产高清在线观看视频 | 人人妻人人澡人人爽欧美一区 | 中文字幕无码免费久久99 | 国产精品亚洲专区无码不卡 | 国产真实伦对白全集 | 色情久久久av熟女人妻网站 | 日韩 欧美 动漫 国产 制服 | 国内老熟妇对白xxxxhd | 日韩 欧美 动漫 国产 制服 | 欧美国产日产一区二区 | 亚洲国产精品一区二区第一页 | 色欲人妻aaaaaaa无码 | 乌克兰少妇性做爰 | 亚洲日韩一区二区三区 | 中文无码伦av中文字幕 | 免费国产成人高清在线观看网站 | 国产精品欧美成人 | 少妇被粗大的猛进出69影院 | 偷窥村妇洗澡毛毛多 | 久久综合九色综合97网 | 精品国精品国产自在久国产87 | 日日摸日日碰夜夜爽av | 天堂亚洲2017在线观看 | 亚洲经典千人经典日产 | 国内丰满熟女出轨videos | 极品尤物被啪到呻吟喷水 | 任你躁在线精品免费 | 美女黄网站人色视频免费国产 | 国产精品美女久久久 | 亚洲欧美综合区丁香五月小说 | 国精产品一区二区三区 | 2020最新国产自产精品 | 国产成人无码一二三区视频 | 乱码午夜-极国产极内射 | 高潮毛片无遮挡高清免费 | 丁香花在线影院观看在线播放 | 国产特级毛片aaaaaa高潮流水 | 狠狠躁日日躁夜夜躁2020 | 成人一在线视频日韩国产 | 亚洲中文字幕无码一久久区 | 国产精品办公室沙发 | 成人动漫在线观看 | www一区二区www免费 | 色婷婷av一区二区三区之红樱桃 | 精品亚洲成av人在线观看 | 久久精品丝袜高跟鞋 | 精品欧洲av无码一区二区三区 | 日本护士毛茸茸高潮 | 无码av最新清无码专区吞精 | 成熟人妻av无码专区 | 精品久久久无码中文字幕 | 扒开双腿疯狂进出爽爽爽视频 | 国产特级毛片aaaaaaa高清 | 鲁一鲁av2019在线 | 国产精品香蕉在线观看 | 亚洲国产欧美国产综合一区 | 国产精品久久久 | 亚洲精品国产精品乱码视色 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲成a人一区二区三区 | 人妻互换免费中文字幕 | 国产精品久久久久久久影院 | 成在人线av无码免观看麻豆 | 国产精品第一区揄拍无码 | 久久久久免费精品国产 | 国产成人综合色在线观看网站 | 97人妻精品一区二区三区 | 久久精品国产日本波多野结衣 | 成人欧美一区二区三区黑人免费 | 波多野结衣乳巨码无在线观看 | 久久99精品久久久久久 | 377p欧洲日本亚洲大胆 | 色综合久久久无码网中文 | 一本久久a久久精品亚洲 | 欧洲欧美人成视频在线 | 一二三四社区在线中文视频 | 在线精品亚洲一区二区 | 久久无码中文字幕免费影院蜜桃 | 久久久久国色av免费观看性色 | 亚洲中文字幕va福利 | 亚洲国产精品成人久久蜜臀 | 亚洲熟妇色xxxxx欧美老妇y | 色老头在线一区二区三区 | 国产suv精品一区二区五 | 最新版天堂资源中文官网 | 日日摸夜夜摸狠狠摸婷婷 | 欧美自拍另类欧美综合图片区 | 欧美日韩在线亚洲综合国产人 | 97夜夜澡人人爽人人喊中国片 | 性欧美videos高清精品 | 亚洲精品一区二区三区四区五区 | 国产成人av免费观看 | 日本饥渴人妻欲求不满 | 性生交大片免费看l | 丰满人妻精品国产99aⅴ | 无码人妻久久一区二区三区不卡 | 国产性生大片免费观看性 | 日本精品人妻无码77777 天堂一区人妻无码 | 3d动漫精品啪啪一区二区中 | 中文字幕乱码人妻二区三区 | 麻豆成人精品国产免费 | 水蜜桃亚洲一二三四在线 | 亚洲乱码国产乱码精品精 | 久久国语露脸国产精品电影 | 亚洲熟女一区二区三区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 自拍偷自拍亚洲精品被多人伦好爽 | 精品久久久久久人妻无码中文字幕 | 日日夜夜撸啊撸 | 福利一区二区三区视频在线观看 | 久久久久亚洲精品男人的天堂 | 人妻aⅴ无码一区二区三区 | 18黄暴禁片在线观看 | 人妻人人添人妻人人爱 | 性色av无码免费一区二区三区 | 日本va欧美va欧美va精品 | 亚洲欧洲无卡二区视頻 | 免费乱码人妻系列无码专区 | 人妻少妇精品无码专区动漫 | 欧美日韩亚洲国产精品 | 亚洲天堂2017无码 | 欧美黑人巨大xxxxx | 中文字幕无线码免费人妻 | 色爱情人网站 | 中文字幕乱码人妻二区三区 | 四虎4hu永久免费 | 久久综合色之久久综合 | 一本久久伊人热热精品中文字幕 | √天堂中文官网8在线 | 无套内谢老熟女 | 中文字幕人妻无码一夲道 | 1000部啪啪未满十八勿入下载 | 扒开双腿吃奶呻吟做受视频 | 久久久精品欧美一区二区免费 | 少妇激情av一区二区 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产办公室秘书无码精品99 | 少妇性荡欲午夜性开放视频剧场 | 国产av无码专区亚洲a∨毛片 | 小泽玛莉亚一区二区视频在线 | 欧美刺激性大交 | 67194成是人免费无码 | 性生交片免费无码看人 | 国产精品久久国产精品99 | 日韩精品a片一区二区三区妖精 | 狂野欧美性猛交免费视频 | 亚洲熟妇色xxxxx欧美老妇 | 久在线观看福利视频 | 狠狠亚洲超碰狼人久久 | 亚洲精品中文字幕久久久久 | 国产日产欧产精品精品app | 国产精华av午夜在线观看 | 18黄暴禁片在线观看 | 夜夜躁日日躁狠狠久久av | 97久久精品无码一区二区 | 国产无遮挡又黄又爽免费视频 | 蜜桃臀无码内射一区二区三区 | 精品国偷自产在线 | 国产免费观看黄av片 | 日本在线高清不卡免费播放 | 理论片87福利理论电影 | 国产亚洲人成在线播放 | 无套内射视频囯产 | 欧美丰满少妇xxxx性 | 国产av人人夜夜澡人人爽麻豆 | 波多野42部无码喷潮在线 | 美女扒开屁股让男人桶 | 国产精品美女久久久 | 亚洲色无码一区二区三区 | 久久精品人妻少妇一区二区三区 | 欧美国产日产一区二区 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 精品 日韩 国产 欧美 视频 | 色欲综合久久中文字幕网 | 久久97精品久久久久久久不卡 | 亚洲日韩乱码中文无码蜜桃臀网站 | 99er热精品视频 | 国产成人亚洲综合无码 | 国产精品亚洲专区无码不卡 | 亚洲a无码综合a国产av中文 | 国产人妻久久精品二区三区老狼 | 男女猛烈xx00免费视频试看 | 丰满少妇人妻久久久久久 | 成人无码视频免费播放 | 国产网红无码精品视频 | 国产午夜亚洲精品不卡下载 | 欧美性猛交内射兽交老熟妇 | 日韩精品无码一本二本三本色 | 小鲜肉自慰网站xnxx | 中文字幕无码日韩专区 | 中文字幕av伊人av无码av | www国产亚洲精品久久网站 | 国产舌乚八伦偷品w中 | 国产情侣作爱视频免费观看 | 国产午夜精品一区二区三区嫩草 | 亚洲综合另类小说色区 | 亚洲自偷自拍另类第1页 | 四十如虎的丰满熟妇啪啪 | 日本一本二本三区免费 | 沈阳熟女露脸对白视频 | 欧美喷潮久久久xxxxx | 国产精品办公室沙发 | 国产精品亚洲一区二区三区喷水 | 欧美人与牲动交xxxx | 亚洲国产精品毛片av不卡在线 | 国产成人无码区免费内射一片色欲 | 男人的天堂2018无码 | 久久成人a毛片免费观看网站 | 午夜精品一区二区三区在线观看 | 亚洲男人av香蕉爽爽爽爽 | 亚洲人成无码网www | 国内揄拍国内精品少妇国语 | 精品一区二区三区波多野结衣 | 丰满少妇女裸体bbw | 无码国产乱人伦偷精品视频 | 男女下面进入的视频免费午夜 | 久久伊人色av天堂九九小黄鸭 | 精品少妇爆乳无码av无码专区 | 一本久道久久综合婷婷五月 | 久久久中文字幕日本无吗 | 欧美人与禽zoz0性伦交 | 丰满妇女强制高潮18xxxx | 无码人妻出轨黑人中文字幕 | 亚洲中文字幕在线无码一区二区 | 欧美人与牲动交xxxx | 国产亚洲欧美在线专区 | 无码任你躁久久久久久久 | 亚洲熟妇自偷自拍另类 | 丰满人妻精品国产99aⅴ | 乱人伦人妻中文字幕无码久久网 | 国内揄拍国内精品人妻 | 麻豆国产人妻欲求不满谁演的 | 久久久久99精品成人片 | 强奷人妻日本中文字幕 | 亚洲成a人片在线观看无码3d | 人人妻在人人 | 俺去俺来也在线www色官网 | 久久综合香蕉国产蜜臀av | 天堂а√在线地址中文在线 | 狠狠cao日日穞夜夜穞av | 亚洲日韩乱码中文无码蜜桃臀网站 | 日日摸天天摸爽爽狠狠97 | 少妇一晚三次一区二区三区 | 任你躁国产自任一区二区三区 | 欧美人与禽zoz0性伦交 | 乌克兰少妇性做爰 | 欧美喷潮久久久xxxxx | 精品久久久久久人妻无码中文字幕 | 国产口爆吞精在线视频 | 欧美人与动性行为视频 | 性色欲网站人妻丰满中文久久不卡 | 清纯唯美经典一区二区 | 四虎国产精品一区二区 | 久久久久99精品成人片 | 综合网日日天干夜夜久久 | 2019午夜福利不卡片在线 | 99久久99久久免费精品蜜桃 | 精品国产麻豆免费人成网站 | 欧美老人巨大xxxx做受 | 2019午夜福利不卡片在线 | 国产精品久久久久影院嫩草 | 人人妻人人澡人人爽欧美一区 | 国产免费久久精品国产传媒 | 18无码粉嫩小泬无套在线观看 | 亚洲一区二区三区播放 | 久久综合久久自在自线精品自 | 午夜精品一区二区三区在线观看 | 内射白嫩少妇超碰 | 国产成人综合色在线观看网站 | 免费人成在线视频无码 | 亚洲精品一区二区三区婷婷月 | 亚洲欧美中文字幕5发布 | 丰满少妇女裸体bbw | 1000部夫妻午夜免费 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 熟女少妇人妻中文字幕 | 中文字幕无码免费久久99 | 伊人久久大香线蕉av一区二区 | 无人区乱码一区二区三区 | 亚洲中文字幕久久无码 | 日韩精品无码一区二区中文字幕 | 特级做a爰片毛片免费69 | 中文字幕无码免费久久99 | 久久无码中文字幕免费影院蜜桃 | 中文字幕av日韩精品一区二区 | 97夜夜澡人人爽人人喊中国片 | 人人妻人人澡人人爽欧美一区九九 | 欧美精品无码一区二区三区 | 永久免费观看美女裸体的网站 | 强伦人妻一区二区三区视频18 | v一区无码内射国产 | 双乳奶水饱满少妇呻吟 | 中文字幕人成乱码熟女app | 精品国产av色一区二区深夜久久 | 国产亚洲欧美日韩亚洲中文色 | 亚洲人成无码网www | 少妇无码av无码专区在线观看 | 精品国产一区二区三区四区在线看 | 亚洲精品美女久久久久久久 | 动漫av网站免费观看 | 亚洲一区二区三区国产精华液 | 少妇高潮一区二区三区99 | 性欧美牲交在线视频 | 欧美日韩在线亚洲综合国产人 | 国精品人妻无码一区二区三区蜜柚 | 成人无码影片精品久久久 | 天天拍夜夜添久久精品大 | 婷婷五月综合激情中文字幕 | 久久五月精品中文字幕 | 亚洲一区二区三区在线观看网站 | 亚洲一区二区三区含羞草 | 无码福利日韩神码福利片 | 亚洲中文字幕无码一久久区 | 荫蒂添的好舒服视频囗交 | 少妇被粗大的猛进出69影院 | 欧美三级a做爰在线观看 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国内精品久久毛片一区二区 | 亚洲中文字幕无码中文字在线 | 国产明星裸体无码xxxx视频 | 国产午夜无码视频在线观看 | 色偷偷人人澡人人爽人人模 | 久久99久久99精品中文字幕 | 久久久久久久人妻无码中文字幕爆 | 国产精品美女久久久久av爽李琼 | 久久久久亚洲精品男人的天堂 | 久久久久久久女国产乱让韩 | www一区二区www免费 | 黑人粗大猛烈进出高潮视频 | 1000部啪啪未满十八勿入下载 | 亚洲中文字幕成人无码 | 亚洲综合另类小说色区 | 少妇一晚三次一区二区三区 | 国产精品第一区揄拍无码 | 丰满妇女强制高潮18xxxx | 国产精品高潮呻吟av久久 | 亚洲日本在线电影 | 欧美成人高清在线播放 | 欧美大屁股xxxxhd黑色 | 少妇无套内谢久久久久 | 乌克兰少妇xxxx做受 | 日韩精品一区二区av在线 | 久久国产精品二国产精品 | 亚洲呦女专区 | 人妻少妇精品无码专区动漫 | v一区无码内射国产 | 中文亚洲成a人片在线观看 | 亚洲中文字幕无码中文字在线 | 国产两女互慰高潮视频在线观看 | 乱码午夜-极国产极内射 | 久久婷婷五月综合色国产香蕉 | 中国大陆精品视频xxxx | 国产激情综合五月久久 | 国产精品99爱免费视频 | 天堂一区人妻无码 | 亚洲精品久久久久avwww潮水 | 国产午夜亚洲精品不卡 | 国产99久久精品一区二区 | 国产成人一区二区三区别 | www国产亚洲精品久久网站 | 爱做久久久久久 | 日韩在线不卡免费视频一区 | 波多野结衣一区二区三区av免费 | www国产亚洲精品久久网站 | 国产真实伦对白全集 | 亚洲一区av无码专区在线观看 | 国产欧美精品一区二区三区 | 动漫av一区二区在线观看 | 国产成人无码午夜视频在线观看 | 无码成人精品区在线观看 | 扒开双腿疯狂进出爽爽爽视频 | 无码任你躁久久久久久久 | 乱码午夜-极国产极内射 | 欧美猛少妇色xxxxx | 亚洲第一网站男人都懂 | 狠狠色噜噜狠狠狠7777奇米 | 日日摸天天摸爽爽狠狠97 | 国产精品久久久久久亚洲毛片 | 黑人巨大精品欧美一区二区 | 永久免费观看国产裸体美女 | 国产人妻久久精品二区三区老狼 | 欧美亚洲国产一区二区三区 | 又湿又紧又大又爽a视频国产 | 麻豆国产人妻欲求不满 | 美女黄网站人色视频免费国产 | 日韩人妻无码中文字幕视频 | 无码人妻av免费一区二区三区 | 波多野结衣一区二区三区av免费 | 无码人妻出轨黑人中文字幕 | 精品人妻av区 | 日韩精品一区二区av在线 | 欧美日韩精品 | 国产免费久久久久久无码 | 久久99精品国产.久久久久 | 丝袜人妻一区二区三区 | 国产亚洲精品久久久久久久久动漫 | 精品国产一区二区三区四区 | 久久精品丝袜高跟鞋 | 国精产品一品二品国精品69xx | 三上悠亚人妻中文字幕在线 | 欧美日韩亚洲国产精品 | 给我免费的视频在线观看 | 无码人妻av免费一区二区三区 | 男女猛烈xx00免费视频试看 | 国产成人无码av一区二区 | 久久国产劲爆∧v内射 | 欧美性猛交内射兽交老熟妇 | 亚洲 欧美 激情 小说 另类 | 98国产精品综合一区二区三区 | 精品久久久中文字幕人妻 | 国产精品美女久久久网av | 麻豆蜜桃av蜜臀av色欲av | 中文字幕无码日韩专区 | 无码人妻av免费一区二区三区 | 人人爽人人爽人人片av亚洲 | 激情内射亚州一区二区三区爱妻 | 国产国语老龄妇女a片 | 美女极度色诱视频国产 | 激情综合激情五月俺也去 | 国内精品一区二区三区不卡 | 久久人人爽人人爽人人片av高清 | 久久99精品久久久久婷婷 | 国产成人精品一区二区在线小狼 | 国产精品久久久久久久影院 | 久久久久人妻一区精品色欧美 | 国产香蕉尹人视频在线 | 无套内谢的新婚少妇国语播放 | 国产精品美女久久久 | 亚洲熟妇自偷自拍另类 | 国产精品无码久久av | 无遮挡啪啪摇乳动态图 | 色婷婷久久一区二区三区麻豆 | 午夜性刺激在线视频免费 | 波多野结衣一区二区三区av免费 | 最新版天堂资源中文官网 | 亚洲成在人网站无码天堂 | 亚洲精品久久久久中文第一幕 | 正在播放老肥熟妇露脸 | 九一九色国产 | 色婷婷综合激情综在线播放 | 久久综合狠狠综合久久综合88 | 欧美丰满少妇xxxx性 | 色综合久久88色综合天天 | 国内揄拍国内精品少妇国语 | 成人aaa片一区国产精品 | 成在人线av无码免费 | 丰满护士巨好爽好大乳 | 亚洲国产成人a精品不卡在线 | 亚洲第一无码av无码专区 | 国产精品资源一区二区 | 国产精品18久久久久久麻辣 | 欧美性黑人极品hd | 久久久亚洲欧洲日产国码αv | 亚洲中文字幕无码中文字在线 | 强伦人妻一区二区三区视频18 | 日日噜噜噜噜夜夜爽亚洲精品 | 亚洲精品久久久久avwww潮水 | 国产一区二区三区四区五区加勒比 | 国产亚洲人成在线播放 | 好男人www社区 | 欧美性猛交xxxx富婆 | 玩弄少妇高潮ⅹxxxyw | 国产无av码在线观看 | a在线亚洲男人的天堂 | 亚洲色偷偷男人的天堂 | 久久久久99精品国产片 | 无码人妻丰满熟妇区五十路百度 | 国产精品高潮呻吟av久久 | 精品日本一区二区三区在线观看 | 十八禁真人啪啪免费网站 | 波多野结衣av一区二区全免费观看 | 国产人成高清在线视频99最全资源 | 丰腴饱满的极品熟妇 | 98国产精品综合一区二区三区 | 一区二区三区乱码在线 | 欧洲 | 亚洲天堂2017无码中文 | 又大又紧又粉嫩18p少妇 | 澳门永久av免费网站 | 国产色xx群视频射精 | 无码免费一区二区三区 | 国内少妇偷人精品视频免费 | 亚洲精品一区二区三区婷婷月 | 18无码粉嫩小泬无套在线观看 | 国产极品美女高潮无套在线观看 | 人人妻人人澡人人爽精品欧美 | 妺妺窝人体色www在线小说 | 久久久久99精品国产片 | 少妇一晚三次一区二区三区 | 亚洲人成影院在线观看 | 水蜜桃av无码 | 精品久久久无码人妻字幂 | 亚洲天堂2017无码中文 | 性色欲网站人妻丰满中文久久不卡 | 亚洲成av人片在线观看无码不卡 | 国产 浪潮av性色四虎 | 少妇性俱乐部纵欲狂欢电影 | 久久人人97超碰a片精品 | 亚洲乱码国产乱码精品精 | 丰满人妻一区二区三区免费视频 | 久久久久久久久888 | 亚洲 欧美 激情 小说 另类 | 男女下面进入的视频免费午夜 | 2020最新国产自产精品 | 国产情侣作爱视频免费观看 | 欧美黑人巨大xxxxx | 亚洲日韩一区二区三区 | 亚洲爆乳精品无码一区二区三区 | 色欲综合久久中文字幕网 | 丝袜美腿亚洲一区二区 | av在线亚洲欧洲日产一区二区 | 国产成人无码a区在线观看视频app | 黑人巨大精品欧美黑寡妇 | 日日天干夜夜狠狠爱 | 国产凸凹视频一区二区 | 福利一区二区三区视频在线观看 | 日本精品少妇一区二区三区 | 免费网站看v片在线18禁无码 | 麻豆md0077饥渴少妇 | 色一情一乱一伦一视频免费看 | 国产熟妇高潮叫床视频播放 | 999久久久国产精品消防器材 | 国产午夜福利100集发布 | 在线观看免费人成视频 | 欧美 亚洲 国产 另类 | 亚洲国产精品久久人人爱 | 国产麻豆精品一区二区三区v视界 | 无码一区二区三区在线观看 | 日韩人妻少妇一区二区三区 | 香蕉久久久久久av成人 | 人人澡人人透人人爽 | 3d动漫精品啪啪一区二区中 | 中文字幕无码av波多野吉衣 | 色噜噜亚洲男人的天堂 | 成人免费视频一区二区 | 亚洲无人区午夜福利码高清完整版 | 国产精品福利视频导航 | 狠狠亚洲超碰狼人久久 | 中文字幕无码热在线视频 | 久久国产自偷自偷免费一区调 | 东京热无码av男人的天堂 | 天堂а√在线地址中文在线 | 欧美亚洲国产一区二区三区 | 色欲久久久天天天综合网精品 | 国内精品九九久久久精品 | 精品国产乱码久久久久乱码 | 在线观看免费人成视频 | 亚洲欧美日韩成人高清在线一区 | 无码人妻精品一区二区三区不卡 | 中文字幕日韩精品一区二区三区 | 精品人妻人人做人人爽夜夜爽 | 乱人伦中文视频在线观看 | 网友自拍区视频精品 | 亚洲色欲色欲欲www在线 | 色婷婷av一区二区三区之红樱桃 | 国产精品久久久一区二区三区 | 亚洲精品www久久久 | 色一情一乱一伦一区二区三欧美 | 人妻与老人中文字幕 | 白嫩日本少妇做爰 | 亚洲欧美日韩国产精品一区二区 | 国产国产精品人在线视 | 亚洲综合久久一区二区 | 免费人成在线观看网站 | 18无码粉嫩小泬无套在线观看 | 欧美高清在线精品一区 | 亚洲熟悉妇女xxx妇女av | 亚洲日韩中文字幕在线播放 | 国产精品成人av在线观看 | 久久国产精品_国产精品 | 成人精品视频一区二区三区尤物 | 久久精品国产日本波多野结衣 | 国产婷婷色一区二区三区在线 | 无人区乱码一区二区三区 | 永久免费精品精品永久-夜色 | 国产成人午夜福利在线播放 | 荫蒂添的好舒服视频囗交 | 四十如虎的丰满熟妇啪啪 | 日日麻批免费40分钟无码 | 亚洲中文字幕无码中文字在线 | 天天拍夜夜添久久精品 | 国产人妻精品一区二区三区不卡 | 色欲综合久久中文字幕网 | 澳门永久av免费网站 | 熟妇人妻无码xxx视频 | 亚洲a无码综合a国产av中文 | 日韩欧美中文字幕在线三区 | 东京热男人av天堂 | 少妇性俱乐部纵欲狂欢电影 | 丰满少妇熟乱xxxxx视频 | 在线a亚洲视频播放在线观看 | 亚洲精品一区二区三区四区五区 | 婷婷综合久久中文字幕蜜桃三电影 | 中文字幕无码av激情不卡 | 国产精品欧美成人 | 鲁鲁鲁爽爽爽在线视频观看 | 久久综合激激的五月天 | 131美女爱做视频 | 午夜精品久久久内射近拍高清 | 扒开双腿疯狂进出爽爽爽视频 | 奇米影视7777久久精品人人爽 | 国产性生交xxxxx无码 | 又大又紧又粉嫩18p少妇 | 最新国产麻豆aⅴ精品无码 | 亚洲综合久久一区二区 | 高清无码午夜福利视频 | 99久久婷婷国产综合精品青草免费 | 国产激情艳情在线看视频 | 国产免费观看黄av片 | 天干天干啦夜天干天2017 | 久久久久久久女国产乱让韩 | 999久久久国产精品消防器材 | 国产在线aaa片一区二区99 | 正在播放东北夫妻内射 | 亚洲天堂2017无码 | 亚洲最大成人网站 | 四虎影视成人永久免费观看视频 | 欧美兽交xxxx×视频 | 日韩欧美群交p片內射中文 | 野狼第一精品社区 | 亚洲中文字幕无码中文字在线 | 波多野结衣aⅴ在线 | 久久人人97超碰a片精品 | 欧美国产亚洲日韩在线二区 | 青青青手机频在线观看 | 亚洲精品久久久久中文第一幕 | 一本久道久久综合狠狠爱 | 熟妇人妻中文av无码 | 少妇久久久久久人妻无码 | 成人精品天堂一区二区三区 | 一本大道伊人av久久综合 | 日本又色又爽又黄的a片18禁 | 九九热爱视频精品 | 久久精品国产精品国产精品污 | 99精品视频在线观看免费 | 国产午夜亚洲精品不卡 | 粗大的内捧猛烈进出视频 | 久久久久成人精品免费播放动漫 | 中国女人内谢69xxxxxa片 | 九九综合va免费看 | 人妻少妇精品视频专区 | 久久熟妇人妻午夜寂寞影院 | 麻豆av传媒蜜桃天美传媒 | 亚洲另类伦春色综合小说 | 国产农村乱对白刺激视频 | 精品人妻人人做人人爽夜夜爽 | 在线 国产 欧美 亚洲 天堂 | 久久久久久九九精品久 | 国产亚洲精品久久久久久久久动漫 | 成人片黄网站色大片免费观看 | 国内精品人妻无码久久久影院 | 中国女人内谢69xxxxxa片 | 亚洲 日韩 欧美 成人 在线观看 | 成人动漫在线观看 | 亚洲欧美国产精品专区久久 | 日本成熟视频免费视频 | 亚洲欧洲日本综合aⅴ在线 | 人人爽人人澡人人人妻 | 噜噜噜亚洲色成人网站 | 久久无码中文字幕免费影院蜜桃 | 熟妇人妻无码xxx视频 | 免费无码午夜福利片69 | 97色伦图片97综合影院 | 精品一二三区久久aaa片 | 偷窥日本少妇撒尿chinese | 久久久精品人妻久久影视 | 久久zyz资源站无码中文动漫 | 国产精品久久久久影院嫩草 | а√资源新版在线天堂 | 性生交大片免费看女人按摩摩 | 中文字幕乱码亚洲无线三区 | 精品午夜福利在线观看 | 亚洲va中文字幕无码久久不卡 | 成人性做爰aaa片免费看不忠 | 免费乱码人妻系列无码专区 | 久久精品无码一区二区三区 | 国产精品igao视频网 | 啦啦啦www在线观看免费视频 | 性生交大片免费看l | 成人毛片一区二区 | 亚洲第一网站男人都懂 | www国产亚洲精品久久网站 | 国产精品对白交换视频 | 中国大陆精品视频xxxx | 国产一区二区三区影院 | 亚洲の无码国产の无码影院 | 亚洲一区二区三区含羞草 | 呦交小u女精品视频 | 日日橹狠狠爱欧美视频 | 精品国偷自产在线 | 国精产品一品二品国精品69xx | 国产一区二区不卡老阿姨 | 成人综合网亚洲伊人 | 午夜肉伦伦影院 | 中文亚洲成a人片在线观看 | 成人欧美一区二区三区黑人免费 | 精品午夜福利在线观看 | 亚洲色成人中文字幕网站 | 国产疯狂伦交大片 | 99久久无码一区人妻 | 国产97在线 | 亚洲 | 国产性生大片免费观看性 | 国产亚洲人成a在线v网站 | 国产福利视频一区二区 | 色狠狠av一区二区三区 | av小次郎收藏 | 亚洲综合无码一区二区三区 | 影音先锋中文字幕无码 | 国产麻豆精品一区二区三区v视界 | 国产尤物精品视频 | 黑人粗大猛烈进出高潮视频 | 亚洲熟妇色xxxxx欧美老妇 | 2020久久香蕉国产线看观看 | 久久99精品久久久久久动态图 | 水蜜桃色314在线观看 | 国产乱人伦av在线无码 | 骚片av蜜桃精品一区 | 亚洲va欧美va天堂v国产综合 | 鲁一鲁av2019在线 | 亚洲日韩中文字幕在线播放 | 亚洲精品一区国产 | 久久婷婷五月综合色国产香蕉 | 在教室伦流澡到高潮hnp视频 | 欧美zoozzooz性欧美 | 曰本女人与公拘交酡免费视频 | 少妇久久久久久人妻无码 | 中文字幕无码日韩专区 | 国产精品人人妻人人爽 | 夜夜影院未满十八勿进 | 三上悠亚人妻中文字幕在线 | 欧美精品一区二区精品久久 | 国产激情精品一区二区三区 | 婷婷丁香五月天综合东京热 | 男女作爱免费网站 | 一个人免费观看的www视频 | 国产精品毛多多水多 | 少妇人妻大乳在线视频 | 国产高清av在线播放 | 亚洲成色在线综合网站 | 久久国内精品自在自线 | 欧洲极品少妇 | 国产办公室秘书无码精品99 | 特黄特色大片免费播放器图片 | 少女韩国电视剧在线观看完整 | 强伦人妻一区二区三区视频18 | 无码一区二区三区在线 | 欧美丰满熟妇xxxx性ppx人交 | 免费人成网站视频在线观看 | 无套内谢老熟女 | 俺去俺来也在线www色官网 | 日韩精品无码一本二本三本色 | 中文无码伦av中文字幕 | 青青青爽视频在线观看 | 国产色精品久久人妻 | 亚洲欧洲日本综合aⅴ在线 | 强开小婷嫩苞又嫩又紧视频 | 丁香花在线影院观看在线播放 | 久久精品女人天堂av免费观看 | 欧美激情综合亚洲一二区 | 国产热a欧美热a在线视频 | 巨爆乳无码视频在线观看 | 久久精品国产日本波多野结衣 | 精品欧美一区二区三区久久久 | 又粗又大又硬毛片免费看 | 亚洲欧美日韩国产精品一区二区 | 国产精品无码一区二区三区不卡 | 亚洲欧美色中文字幕在线 | 天天av天天av天天透 | 日产精品高潮呻吟av久久 | 欧美日韩亚洲国产精品 | 中国大陆精品视频xxxx | 亚洲日本va中文字幕 | 少妇高潮一区二区三区99 | 午夜成人1000部免费视频 | 亚洲成a人片在线观看无码 | 综合人妻久久一区二区精品 | 精品国产麻豆免费人成网站 | 亚洲中文字幕久久无码 | 国产亚洲精品久久久ai换 | 丰满少妇弄高潮了www | 久在线观看福利视频 | 荡女精品导航 | 天天做天天爱天天爽综合网 | 少妇被粗大的猛进出69影院 | 无人区乱码一区二区三区 | 日本在线高清不卡免费播放 | 日日麻批免费40分钟无码 | 欧美日韩人成综合在线播放 | 国产色xx群视频射精 | 日本大乳高潮视频在线观看 | 九九在线中文字幕无码 | 成人影院yy111111在线观看 | 国产欧美熟妇另类久久久 | 欧美xxxx黑人又粗又长 | 亚洲成熟女人毛毛耸耸多 | 欧美老妇与禽交 | 沈阳熟女露脸对白视频 | 无码国产色欲xxxxx视频 | 熟妇人妻无码xxx视频 | 永久免费观看美女裸体的网站 | 国产一区二区三区四区五区加勒比 | 强辱丰满人妻hd中文字幕 | 国产办公室秘书无码精品99 | 欧美 日韩 亚洲 在线 | 在线a亚洲视频播放在线观看 | 亚洲精品一区二区三区大桥未久 | 精品 日韩 国产 欧美 视频 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 夜夜高潮次次欢爽av女 | 中文字幕人成乱码熟女app | 少妇高潮一区二区三区99 | 大胆欧美熟妇xx | 丰满肥臀大屁股熟妇激情视频 | 未满小14洗澡无码视频网站 | 亚洲精品国偷拍自产在线观看蜜桃 | 99精品国产综合久久久久五月天 | 熟妇人妻无乱码中文字幕 | 老熟女重囗味hdxx69 | 国产在线精品一区二区三区直播 | 免费视频欧美无人区码 | av香港经典三级级 在线 | 伊人久久大香线蕉av一区二区 | 鲁鲁鲁爽爽爽在线视频观看 | 国产精品人人妻人人爽 | 日日躁夜夜躁狠狠躁 | 日本丰满护士爆乳xxxx | 国产三级久久久精品麻豆三级 | 日本乱偷人妻中文字幕 | 正在播放老肥熟妇露脸 | 成人影院yy111111在线观看 | 久久国语露脸国产精品电影 | 四虎永久在线精品免费网址 | 免费无码一区二区三区蜜桃大 | 亚洲色在线无码国产精品不卡 | 人妻无码αv中文字幕久久琪琪布 | 国产香蕉尹人综合在线观看 | 国产人妻精品午夜福利免费 | 久久久久人妻一区精品色欧美 | 荫蒂被男人添的好舒服爽免费视频 | 久久久精品人妻久久影视 | 日韩少妇内射免费播放 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 正在播放东北夫妻内射 | 最新版天堂资源中文官网 | 精品国产精品久久一区免费式 | 国产成人无码av在线影院 | 99久久精品国产一区二区蜜芽 | 国产亲子乱弄免费视频 | 国产一区二区三区四区五区加勒比 | 在线欧美精品一区二区三区 | 亚洲欧美日韩国产精品一区二区 | 少妇人妻大乳在线视频 | 国产婷婷色一区二区三区在线 | 国产av无码专区亚洲awww | 国产成人亚洲综合无码 | 四虎4hu永久免费 | 67194成是人免费无码 | 午夜福利不卡在线视频 | 青青久在线视频免费观看 | 无码av免费一区二区三区试看 | 日本丰满护士爆乳xxxx | 欧洲精品码一区二区三区免费看 | 精品国产一区二区三区av 性色 | 国产超级va在线观看视频 | 内射后入在线观看一区 | 中文字幕日韩精品一区二区三区 | 国产真实伦对白全集 | 人人妻人人澡人人爽欧美精品 | 在线 国产 欧美 亚洲 天堂 | 99麻豆久久久国产精品免费 | 日日摸夜夜摸狠狠摸婷婷 | 国产sm调教视频在线观看 | 精品人妻人人做人人爽夜夜爽 | 日本欧美一区二区三区乱码 | 性色欲网站人妻丰满中文久久不卡 | 国产电影无码午夜在线播放 | 国产精品毛片一区二区 | 午夜精品一区二区三区的区别 | 国产精品久久久 | 性欧美熟妇videofreesex | 亚洲综合色区中文字幕 | 熟妇人妻无乱码中文字幕 | 天堂在线观看www | 曰韩少妇内射免费播放 | 亚洲精品国偷拍自产在线麻豆 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 国精品人妻无码一区二区三区蜜柚 | 美女毛片一区二区三区四区 | 久久亚洲精品成人无码 | 亚洲欧洲中文日韩av乱码 | 在线观看免费人成视频 | 麻豆精品国产精华精华液好用吗 | 精品国产福利一区二区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 十八禁真人啪啪免费网站 | 红桃av一区二区三区在线无码av | 人妻有码中文字幕在线 | 97夜夜澡人人爽人人喊中国片 | 日韩 欧美 动漫 国产 制服 | 无码成人精品区在线观看 | 无码人妻丰满熟妇区毛片18 | 亚洲国产精品一区二区美利坚 | 国产乱人伦av在线无码 | 精品国偷自产在线视频 | 一本精品99久久精品77 | 蜜桃av抽搐高潮一区二区 | 国产又爽又黄又刺激的视频 | 国产精品亚洲综合色区韩国 | 极品尤物被啪到呻吟喷水 | 国产亚洲tv在线观看 | 最近中文2019字幕第二页 | 人人妻人人澡人人爽人人精品浪潮 | 伊人久久婷婷五月综合97色 | 又大又紧又粉嫩18p少妇 | 永久免费观看国产裸体美女 | 国产深夜福利视频在线 | 精品成人av一区二区三区 | 99国产欧美久久久精品 | 国产精品无套呻吟在线 | 久久成人a毛片免费观看网站 | 熟女俱乐部五十路六十路av | 欧美人与善在线com | 久久综合网欧美色妞网 | 国产亲子乱弄免费视频 | 色婷婷久久一区二区三区麻豆 | 天海翼激烈高潮到腰振不止 | 1000部夫妻午夜免费 | 日本一区二区更新不卡 | 人人澡人摸人人添 | 中国大陆精品视频xxxx | 人妻天天爽夜夜爽一区二区 | 欧美日韩一区二区综合 | 国产熟妇高潮叫床视频播放 | 色狠狠av一区二区三区 | 国产三级久久久精品麻豆三级 | 欧美三级不卡在线观看 | 亚洲精品成人福利网站 | 国产人妻精品一区二区三区不卡 | 亚洲一区二区三区偷拍女厕 | 偷窥日本少妇撒尿chinese | 狠狠综合久久久久综合网 | 久久婷婷五月综合色国产香蕉 | 亚洲熟熟妇xxxx | 久久zyz资源站无码中文动漫 | 人人妻人人澡人人爽欧美一区 | 十八禁视频网站在线观看 | 中文字幕亚洲情99在线 | 扒开双腿吃奶呻吟做受视频 | 国内精品一区二区三区不卡 | 亚洲人亚洲人成电影网站色 | 欧美人与动性行为视频 | 亚洲精品一区二区三区在线观看 | 最近免费中文字幕中文高清百度 | 日日摸天天摸爽爽狠狠97 | 亚洲经典千人经典日产 | 夜夜高潮次次欢爽av女 | 娇妻被黑人粗大高潮白浆 | 日韩精品无码免费一区二区三区 | 久久久亚洲欧洲日产国码αv | 国产精品无码成人午夜电影 | 日韩精品无码一本二本三本色 | 无套内谢的新婚少妇国语播放 | 丰满人妻精品国产99aⅴ | 色欲av亚洲一区无码少妇 | 国产人妻精品午夜福利免费 | 欧美黑人乱大交 | 中文毛片无遮挡高清免费 | 国产麻豆精品一区二区三区v视界 | 亚欧洲精品在线视频免费观看 | 桃花色综合影院 | 午夜免费福利小电影 | 麻豆精品国产精华精华液好用吗 | 无码纯肉视频在线观看 | 精品厕所偷拍各类美女tp嘘嘘 | 国产av一区二区三区最新精品 | 国产午夜福利100集发布 | 夜夜高潮次次欢爽av女 | 国产精品久久久久无码av色戒 | 亚洲欧美中文字幕5发布 | 国产97人人超碰caoprom | 亚洲春色在线视频 | 久久久久久久久蜜桃 | 欧美精品一区二区精品久久 | 亚洲呦女专区 | 东京热无码av男人的天堂 | 无码av岛国片在线播放 | 国产av人人夜夜澡人人爽麻豆 | 亚洲欧洲中文日韩av乱码 | 欧美兽交xxxx×视频 | 国产精品内射视频免费 | 久久99热只有频精品8 | 大地资源中文第3页 | 日本肉体xxxx裸交 | 亚洲国产精品无码久久久久高潮 | 国产午夜福利100集发布 | 中文久久乱码一区二区 | 任你躁国产自任一区二区三区 | 国产人妻精品一区二区三区 | 日本一卡二卡不卡视频查询 | 色婷婷综合激情综在线播放 | av在线亚洲欧洲日产一区二区 | 动漫av一区二区在线观看 | 日本丰满护士爆乳xxxx | 亚洲码国产精品高潮在线 | 精品人妻av区 | 亚洲一区二区三区播放 | 亚洲 另类 在线 欧美 制服 | 亚洲小说春色综合另类 | 国色天香社区在线视频 | 男女超爽视频免费播放 | 无码人妻出轨黑人中文字幕 | 内射爽无广熟女亚洲 | 国产精品久免费的黄网站 | 亚洲欧美综合区丁香五月小说 | 亚洲无人区午夜福利码高清完整版 | 国产成人无码a区在线观看视频app | 亚洲精品国偷拍自产在线麻豆 | 精品偷自拍另类在线观看 | 狠狠色色综合网站 | 亚洲一区av无码专区在线观看 | 精品人人妻人人澡人人爽人人 | 亚洲人成无码网www | 免费国产成人高清在线观看网站 | 国产超级va在线观看视频 | 色 综合 欧美 亚洲 国产 | 久久97精品久久久久久久不卡 | 日本一卡2卡3卡四卡精品网站 | 国产色xx群视频射精 | 少妇高潮喷潮久久久影院 | 国产亚洲精品久久久久久国模美 | 综合人妻久久一区二区精品 | 成人免费视频一区二区 | 又粗又大又硬又长又爽 | 免费中文字幕日韩欧美 | 嫩b人妻精品一区二区三区 | 激情五月综合色婷婷一区二区 | 中文亚洲成a人片在线观看 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 久久精品人人做人人综合 | 老头边吃奶边弄进去呻吟 | 久久综合狠狠综合久久综合88 | 国产精品视频免费播放 | 扒开双腿吃奶呻吟做受视频 | 国产性生大片免费观看性 | 夜夜躁日日躁狠狠久久av | 亚洲大尺度无码无码专区 | 亚洲理论电影在线观看 | 麻豆成人精品国产免费 | 无码精品国产va在线观看dvd | 久久综合狠狠综合久久综合88 | 人妻中文无码久热丝袜 | 国产人妻大战黑人第1集 | 天天做天天爱天天爽综合网 | 在线看片无码永久免费视频 | 天堂а√在线中文在线 | 综合人妻久久一区二区精品 | 亚洲毛片av日韩av无码 | 无码国内精品人妻少妇 | 亚洲毛片av日韩av无码 | 久久久久亚洲精品男人的天堂 | 亚洲毛片av日韩av无码 | 久久人人爽人人爽人人片ⅴ | 久久精品国产99精品亚洲 | 亚洲爆乳精品无码一区二区三区 | 日韩无套无码精品 | 国产色视频一区二区三区 | 日本饥渴人妻欲求不满 | 鲁大师影院在线观看 | 久久国语露脸国产精品电影 | 两性色午夜视频免费播放 | 国产亚洲精品久久久久久久久动漫 | 国产乱码精品一品二品 | 亚洲自偷自拍另类第1页 | 亚洲乱码中文字幕在线 | 97精品国产97久久久久久免费 | 欧美老妇与禽交 | 亚洲国产精品成人久久蜜臀 | 国产综合在线观看 | 亚洲国产精品久久久久久 | 亚洲综合无码一区二区三区 | 亚洲自偷精品视频自拍 | 国产午夜亚洲精品不卡 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 国产欧美熟妇另类久久久 | 爽爽影院免费观看 | 亚洲国产精品毛片av不卡在线 | 99久久精品国产一区二区蜜芽 | 99精品久久毛片a片 | 无套内谢老熟女 | 欧美freesex黑人又粗又大 | 精品久久8x国产免费观看 | 久久精品无码一区二区三区 | 成人一区二区免费视频 | 亚洲日本va中文字幕 | 人妻熟女一区 | 日本乱人伦片中文三区 | 无码人妻精品一区二区三区不卡 | 六月丁香婷婷色狠狠久久 | 人人澡人人透人人爽 | 综合人妻久久一区二区精品 | 小泽玛莉亚一区二区视频在线 | 三上悠亚人妻中文字幕在线 | 日本精品人妻无码77777 天堂一区人妻无码 | 免费播放一区二区三区 | 欧美精品国产综合久久 | 久久www免费人成人片 | 色综合久久久久综合一本到桃花网 | 我要看www免费看插插视频 | 中文字幕无线码 | 国产熟妇另类久久久久 | 成年女人永久免费看片 | 亚洲一区二区三区在线观看网站 | 人人妻人人澡人人爽精品欧美 | 国产激情一区二区三区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国精产品一品二品国精品69xx | 国产极品美女高潮无套在线观看 | 亚洲自偷精品视频自拍 | 亚洲狠狠色丁香婷婷综合 | 国产无套内射久久久国产 | 激情爆乳一区二区三区 | 男人和女人高潮免费网站 | 久青草影院在线观看国产 | 波多野42部无码喷潮在线 | 成人免费视频一区二区 | 激情内射日本一区二区三区 | 激情人妻另类人妻伦 | 最新国产乱人伦偷精品免费网站 | 亚洲色偷偷偷综合网 | 国产办公室秘书无码精品99 | 日韩成人一区二区三区在线观看 | 一本大道久久东京热无码av | 亚洲欧美日韩综合久久久 | 日本丰满护士爆乳xxxx | 中文字幕无码日韩专区 | 粉嫩少妇内射浓精videos | 久久精品女人天堂av免费观看 | 捆绑白丝粉色jk震动捧喷白浆 | 国产精品欧美成人 | 性欧美熟妇videofreesex | 亚洲小说春色综合另类 | 国产人妖乱国产精品人妖 | 丰满少妇弄高潮了www | 亚洲 日韩 欧美 成人 在线观看 | 无码帝国www无码专区色综合 | 中文字幕乱妇无码av在线 | 久久视频在线观看精品 | 亚洲国产精品无码久久久久高潮 | 亚洲s色大片在线观看 | 亚洲无人区一区二区三区 | 亚洲日本va中文字幕 | av香港经典三级级 在线 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲精品www久久久 | 99久久精品午夜一区二区 | 97久久精品无码一区二区 | 久久无码人妻影院 | 日本精品久久久久中文字幕 | 国内少妇偷人精品视频 | 综合人妻久久一区二区精品 | av无码久久久久不卡免费网站 | 亚洲成色www久久网站 | 在线天堂新版最新版在线8 | 少妇人妻大乳在线视频 | 久久久久久久久蜜桃 | 中文字幕无码日韩专区 | 最近中文2019字幕第二页 | 日本肉体xxxx裸交 | 自拍偷自拍亚洲精品10p | 精品一区二区不卡无码av | 青青久在线视频免费观看 | 少妇无套内谢久久久久 | 亚无码乱人伦一区二区 | 亚洲精品国产精品乱码视色 | 久久久久成人片免费观看蜜芽 | 国产乱人偷精品人妻a片 | 精品偷自拍另类在线观看 | 亚洲精品午夜无码电影网 | 日韩人妻系列无码专区 | 人妻插b视频一区二区三区 | 亚洲国产精品久久人人爱 | 国产av一区二区精品久久凹凸 | 亚洲伊人久久精品影院 | 十八禁真人啪啪免费网站 | 中文字幕人妻无码一区二区三区 | 草草网站影院白丝内射 | 暴力强奷在线播放无码 | 中文字幕无码av波多野吉衣 | 又湿又紧又大又爽a视频国产 | 精品久久久久香蕉网 | 又大又紧又粉嫩18p少妇 | 女高中生第一次破苞av | 国产97在线 | 亚洲 | 草草网站影院白丝内射 | 欧美喷潮久久久xxxxx | 日韩在线不卡免费视频一区 | 黄网在线观看免费网站 | 乱人伦人妻中文字幕无码 | 天天躁夜夜躁狠狠是什么心态 | 久久久无码中文字幕久... | 色欲久久久天天天综合网精品 | 中文字幕无码免费久久9一区9 | 亚洲国产av精品一区二区蜜芽 | 亚洲乱码国产乱码精品精 | 综合网日日天干夜夜久久 | 大屁股大乳丰满人妻 | 乱人伦中文视频在线观看 | 国产女主播喷水视频在线观看 | 自拍偷自拍亚洲精品被多人伦好爽 | 一二三四社区在线中文视频 | 人人妻人人澡人人爽欧美精品 | 在线观看欧美一区二区三区 | 欧美日韩亚洲国产精品 | 青青青爽视频在线观看 | 奇米影视7777久久精品 | 国产做国产爱免费视频 | 午夜理论片yy44880影院 | 色五月丁香五月综合五月 | 亚洲男人av香蕉爽爽爽爽 | 亚洲综合另类小说色区 | 麻豆国产97在线 | 欧洲 | 无码乱肉视频免费大全合集 | 亚洲乱亚洲乱妇50p | 成人av无码一区二区三区 | 久久午夜无码鲁丝片秋霞 | 97久久超碰中文字幕 | 国产精品va在线观看无码 | 无码人妻丰满熟妇区五十路百度 | 麻豆md0077饥渴少妇 | 日韩人妻少妇一区二区三区 | 免费人成在线观看网站 | 少妇无码av无码专区在线观看 | 黑人巨大精品欧美黑寡妇 | 亚洲中文字幕无码中文字在线 | 国精产品一区二区三区 | 欧美精品国产综合久久 | 日本www一道久久久免费榴莲 | 乱人伦中文视频在线观看 | 丝袜 中出 制服 人妻 美腿 | 亚洲爆乳精品无码一区二区三区 | 曰韩少妇内射免费播放 | 丝袜美腿亚洲一区二区 | 欧美日韩一区二区综合 | 国产人妻精品午夜福利免费 | 我要看www免费看插插视频 | 国产在线一区二区三区四区五区 | 亚洲无人区午夜福利码高清完整版 | 国产办公室秘书无码精品99 | 国产高清不卡无码视频 | 国产高清av在线播放 | 久久久成人毛片无码 | 无码一区二区三区在线观看 | 欧美阿v高清资源不卡在线播放 | 免费无码av一区二区 | 天天燥日日燥 | 扒开双腿吃奶呻吟做受视频 | 亚洲精品一区二区三区在线观看 | 97资源共享在线视频 | 撕开奶罩揉吮奶头视频 | 图片小说视频一区二区 | 欧美亚洲日韩国产人成在线播放 | 日本爽爽爽爽爽爽在线观看免 | 东京无码熟妇人妻av在线网址 | 内射白嫩少妇超碰 | 国产真实乱对白精彩久久 | 日韩欧美中文字幕在线三区 | 国产人妻精品一区二区三区不卡 | 亚洲小说图区综合在线 | 亚洲中文字幕无码中文字在线 | 日韩人妻少妇一区二区三区 | 亚洲中文字幕成人无码 | 日本大香伊一区二区三区 | 偷窥村妇洗澡毛毛多 | 天下第一社区视频www日本 | 欧美变态另类xxxx | 少妇被粗大的猛进出69影院 | 国产av剧情md精品麻豆 | 久久精品国产精品国产精品污 | 亚洲精品午夜国产va久久成人 | 俄罗斯老熟妇色xxxx | 国产手机在线αⅴ片无码观看 | 扒开双腿吃奶呻吟做受视频 | 免费看少妇作爱视频 | 欧美人与物videos另类 | 亚洲精品欧美二区三区中文字幕 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲国精产品一二二线 | 国产亚洲美女精品久久久2020 | 国产精品久久久av久久久 | 强伦人妻一区二区三区视频18 | 国产凸凹视频一区二区 | 欧美高清在线精品一区 | 成人影院yy111111在线观看 | 在线 国产 欧美 亚洲 天堂 | 国产人妖乱国产精品人妖 | 亚洲精品www久久久 | 亚洲 激情 小说 另类 欧美 | 欧美精品在线观看 | 国产香蕉尹人视频在线 | 久久无码专区国产精品s | 99久久人妻精品免费一区 | 欧美精品在线观看 | 2019nv天堂香蕉在线观看 | av小次郎收藏 | 亚洲精品中文字幕久久久久 | 久久久久久a亚洲欧洲av冫 | av香港经典三级级 在线 | 久久天天躁狠狠躁夜夜免费观看 | 三上悠亚人妻中文字幕在线 | 学生妹亚洲一区二区 | 国内精品久久久久久中文字幕 | 欧美激情内射喷水高潮 | 免费人成网站视频在线观看 | 色婷婷欧美在线播放内射 | 老熟妇乱子伦牲交视频 | 99精品国产综合久久久久五月天 | 精品夜夜澡人妻无码av蜜桃 | 亚洲色欲色欲天天天www | 日本一卡2卡3卡四卡精品网站 | 久久亚洲中文字幕无码 | 国产精品无套呻吟在线 | 在线精品亚洲一区二区 | 人人爽人人澡人人人妻 | 天堂在线观看www | 蜜臀av无码人妻精品 | 无码国产激情在线观看 | 一本精品99久久精品77 | 国产成人精品三级麻豆 | 久久久久久国产精品无码下载 | 精品成在人线av无码免费看 | 无套内射视频囯产 | 亚洲娇小与黑人巨大交 | 亚洲а∨天堂久久精品2021 | 黑人玩弄人妻中文在线 | 亚洲乱码中文字幕在线 | 中文字幕日韩精品一区二区三区 | 国产sm调教视频在线观看 | 性史性农村dvd毛片 | 亚洲精品一区二区三区婷婷月 | 欧美freesex黑人又粗又大 | 伊人久久大香线蕉亚洲 | 亚洲色偷偷偷综合网 | 国内精品人妻无码久久久影院蜜桃 | 亚洲中文字幕无码一久久区 | 国产精品第一区揄拍无码 | 99精品国产综合久久久久五月天 | 国产精品久久久久久亚洲影视内衣 | 亚洲国产欧美在线成人 | 国产莉萝无码av在线播放 | 麻花豆传媒剧国产免费mv在线 | 少女韩国电视剧在线观看完整 | 欧美xxxxx精品 | 人人妻人人藻人人爽欧美一区 | 欧美日韩人成综合在线播放 | 搡女人真爽免费视频大全 | 国产精品无套呻吟在线 | 中文字幕精品av一区二区五区 | 97色伦图片97综合影院 | 国产精品a成v人在线播放 | 人人妻人人澡人人爽人人精品浪潮 | 久久精品中文字幕大胸 | 在线播放免费人成毛片乱码 | 国产成人无码一二三区视频 | 宝宝好涨水快流出来免费视频 | 国产精品亚洲综合色区韩国 | 99精品久久毛片a片 | 精品亚洲韩国一区二区三区 | 美女黄网站人色视频免费国产 | 影音先锋中文字幕无码 | 亚洲精品久久久久久久久久久 | 亚洲精品鲁一鲁一区二区三区 | 丰满诱人的人妻3 | 性生交大片免费看l | 国产成人精品一区二区在线小狼 | 国产一区二区三区精品视频 | 国产亚洲日韩欧美另类第八页 | 六月丁香婷婷色狠狠久久 | 亚洲一区二区三区 | 成人影院yy111111在线观看 | 国产亚洲精品久久久久久久 | 久久精品丝袜高跟鞋 | 无码国产乱人伦偷精品视频 | 亚洲中文字幕成人无码 | 人妻少妇精品视频专区 | 天堂а√在线地址中文在线 | 蜜桃臀无码内射一区二区三区 | 性欧美牲交xxxxx视频 | 日本大香伊一区二区三区 | 国模大胆一区二区三区 | 一个人看的视频www在线 | 亚洲一区二区三区国产精华液 | 无码人妻黑人中文字幕 | 色偷偷人人澡人人爽人人模 | 性做久久久久久久免费看 | 人人澡人人透人人爽 | 最新版天堂资源中文官网 | 无码人妻精品一区二区三区下载 | 午夜精品一区二区三区的区别 | 成人片黄网站色大片免费观看 | 亚洲热妇无码av在线播放 | 亚洲精品久久久久avwww潮水 | 未满小14洗澡无码视频网站 | 99久久精品日本一区二区免费 | 色综合久久88色综合天天 | 欧美xxxx黑人又粗又长 | 亚洲爆乳无码专区 | 88国产精品欧美一区二区三区 | 亚洲中文字幕av在天堂 | 国产亚洲精品久久久久久 | 亚洲自偷自偷在线制服 | 女高中生第一次破苞av | 亚洲一区二区三区国产精华液 | 久久无码中文字幕免费影院蜜桃 | 撕开奶罩揉吮奶头视频 | 中文无码成人免费视频在线观看 | 免费中文字幕日韩欧美 | 粗大的内捧猛烈进出视频 | 狠狠色欧美亚洲狠狠色www | 草草网站影院白丝内射 | 亚洲国产成人a精品不卡在线 | 色婷婷香蕉在线一区二区 | av小次郎收藏 | 欧美第一黄网免费网站 | 亚欧洲精品在线视频免费观看 | 亚洲一区二区三区偷拍女厕 | 十八禁视频网站在线观看 | 日韩欧美中文字幕在线三区 | 精品久久8x国产免费观看 | 国产艳妇av在线观看果冻传媒 | 露脸叫床粗话东北少妇 | 免费观看激色视频网站 | 偷窥日本少妇撒尿chinese | 最近的中文字幕在线看视频 | 久久久久久av无码免费看大片 | av无码久久久久不卡免费网站 | 老司机亚洲精品影院无码 | 精品久久久久久人妻无码中文字幕 | 亚洲精品一区三区三区在线观看 | 国产性生交xxxxx无码 | 亚洲精品国产a久久久久久 | 国产麻豆精品精东影业av网站 | 亚洲一区二区三区无码久久 | 永久免费精品精品永久-夜色 | 国产在线aaa片一区二区99 | 国内精品久久毛片一区二区 | 黑人大群体交免费视频 | 人人妻人人澡人人爽人人精品浪潮 | 国产精品久久久午夜夜伦鲁鲁 | 综合网日日天干夜夜久久 | 国产无套粉嫩白浆在线 | 黑人巨大精品欧美黑寡妇 | 日韩少妇白浆无码系列 | 亚洲综合无码一区二区三区 | 中文无码精品a∨在线观看不卡 | 乱码午夜-极国产极内射 | 国产色xx群视频射精 | 乱码午夜-极国产极内射 | 丝袜美腿亚洲一区二区 | 亚洲区欧美区综合区自拍区 | 亚洲熟妇色xxxxx欧美老妇 | 美女张开腿让人桶 | 六十路熟妇乱子伦 | 亚洲小说图区综合在线 | 中文字幕无码av波多野吉衣 | 亚洲精品成a人在线观看 | 波多野结衣av一区二区全免费观看 | 我要看www免费看插插视频 | 又湿又紧又大又爽a视频国产 | 性做久久久久久久免费看 | 国产激情艳情在线看视频 | 性生交片免费无码看人 | 日本在线高清不卡免费播放 | 中文字幕无码日韩欧毛 | 全球成人中文在线 | 亚洲综合色区中文字幕 | 亚洲国产成人a精品不卡在线 | 久久久中文久久久无码 | 欧美午夜特黄aaaaaa片 | 国产午夜无码视频在线观看 | 粗大的内捧猛烈进出视频 | 嫩b人妻精品一区二区三区 | 亚洲七七久久桃花影院 | 亚洲人成人无码网www国产 | 狠狠躁日日躁夜夜躁2020 | 久久综合网欧美色妞网 | 午夜无码区在线观看 | 任你躁国产自任一区二区三区 | 亚洲熟熟妇xxxx | 亚洲码国产精品高潮在线 | 美女黄网站人色视频免费国产 | 东京热男人av天堂 | 99久久亚洲精品无码毛片 | 欧美阿v高清资源不卡在线播放 | 欧美人与禽猛交狂配 | 男女超爽视频免费播放 | 亚洲国产精品一区二区美利坚 | 伊人久久大香线蕉亚洲 | 国产成人一区二区三区别 | 精品国产麻豆免费人成网站 | 国产热a欧美热a在线视频 | 特黄特色大片免费播放器图片 | 又紧又大又爽精品一区二区 | 久久精品一区二区三区四区 | 麻豆国产人妻欲求不满谁演的 | aⅴ亚洲 日韩 色 图网站 播放 | 久久亚洲日韩精品一区二区三区 | 亚洲天堂2017无码 | 久久久精品成人免费观看 | 三级4级全黄60分钟 | 国产成人无码一二三区视频 | 国产精品永久免费视频 | 久久久久久a亚洲欧洲av冫 | 日本在线高清不卡免费播放 | 久久精品人人做人人综合试看 | 伊人色综合久久天天小片 | 九一九色国产 | 少妇邻居内射在线 | 99国产精品白浆在线观看免费 | 波多野结衣高清一区二区三区 | 精品无码一区二区三区爱欲 | 999久久久国产精品消防器材 | 久久99国产综合精品 | 亚洲另类伦春色综合小说 | 日韩精品乱码av一区二区 | 少妇无码一区二区二三区 | 国产乱人伦av在线无码 | 精品久久综合1区2区3区激情 | 欧美人与禽zoz0性伦交 | 成人免费视频视频在线观看 免费 | 国产绳艺sm调教室论坛 | 中文字幕无线码免费人妻 | 牲欲强的熟妇农村老妇女视频 | 日本va欧美va欧美va精品 | 久久久亚洲欧洲日产国码αv | 激情综合激情五月俺也去 | 大地资源网第二页免费观看 | 亚洲无人区一区二区三区 | 丁香啪啪综合成人亚洲 | 亚洲欧美精品aaaaaa片 | 好男人www社区 | 强辱丰满人妻hd中文字幕 | 美女黄网站人色视频免费国产 | 日本va欧美va欧美va精品 | 国产亚洲美女精品久久久2020 | 国产特级毛片aaaaaa高潮流水 | 天天拍夜夜添久久精品大 | 日本乱人伦片中文三区 | 亚洲国产成人av在线观看 | 18无码粉嫩小泬无套在线观看 | 亚洲人成网站在线播放942 | 天堂久久天堂av色综合 | 奇米影视7777久久精品人人爽 | 久久天天躁狠狠躁夜夜免费观看 | 国产超级va在线观看视频 | 天天摸天天透天天添 | 久久99精品久久久久婷婷 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 六月丁香婷婷色狠狠久久 | 一本大道久久东京热无码av | 波多野42部无码喷潮在线 | 久久久国产一区二区三区 | 精品久久久无码人妻字幂 | 精品久久久无码中文字幕 | 狂野欧美性猛交免费视频 | 亚洲无人区一区二区三区 | 欧美性色19p | 中文字幕人妻无码一区二区三区 | 综合网日日天干夜夜久久 | 中文字幕人成乱码熟女app | 亚洲色大成网站www | 国内揄拍国内精品人妻 | 久久成人a毛片免费观看网站 | 国语精品一区二区三区 | 国产区女主播在线观看 | 成人免费视频视频在线观看 免费 | 亚洲狠狠婷婷综合久久 | 久久精品视频在线看15 | 国产精品亚洲综合色区韩国 | 国产免费久久久久久无码 | 55夜色66夜色国产精品视频 | 牛和人交xxxx欧美 | 日欧一片内射va在线影院 | 日本欧美一区二区三区乱码 | 狠狠综合久久久久综合网 | 成人三级无码视频在线观看 | 久久亚洲精品中文字幕无男同 | 特大黑人娇小亚洲女 | aa片在线观看视频在线播放 | 中文毛片无遮挡高清免费 | 亚洲 日韩 欧美 成人 在线观看 | 狠狠色欧美亚洲狠狠色www | 日韩视频 中文字幕 视频一区 | 亚洲国产精品久久人人爱 | 内射欧美老妇wbb | 亚洲中文字幕乱码av波多ji | 99er热精品视频 | 久久久久久a亚洲欧洲av冫 | 亚洲一区二区观看播放 | 99er热精品视频 | 国产激情艳情在线看视频 | 日本一区二区三区免费高清 | 精品久久久久久人妻无码中文字幕 | 中文字幕乱码亚洲无线三区 | 色欲综合久久中文字幕网 | 久久亚洲精品中文字幕无男同 | 四虎国产精品一区二区 | 国产97人人超碰caoprom | 国产乱人无码伦av在线a | 欧美成人家庭影院 | 亚洲狠狠婷婷综合久久 | 欧美第一黄网免费网站 | 99久久亚洲精品无码毛片 | 97色伦图片97综合影院 | 性欧美videos高清精品 | 色婷婷欧美在线播放内射 | 九九久久精品国产免费看小说 | 18黄暴禁片在线观看 | 欧美一区二区三区 | 国产成人精品一区二区在线小狼 | 老司机亚洲精品影院 | 久久久精品456亚洲影院 | 国产9 9在线 | 中文 | 少女韩国电视剧在线观看完整 | 老熟妇仑乱视频一区二区 | 两性色午夜视频免费播放 | 精品国产一区二区三区四区 | 天天摸天天碰天天添 | 东京热一精品无码av | 18禁止看的免费污网站 | 精品国产青草久久久久福利 | 亚洲国产精品一区二区美利坚 | 亚洲欧洲无卡二区视頻 | 九九久久精品国产免费看小说 | 无码任你躁久久久久久久 | 日日橹狠狠爱欧美视频 | 国产精品亚洲一区二区三区喷水 | 日韩人妻少妇一区二区三区 | 亚洲の无码国产の无码步美 | 伊人久久大香线蕉亚洲 | 男人的天堂2018无码 | 黑人玩弄人妻中文在线 | 乌克兰少妇性做爰 | 欧洲精品码一区二区三区免费看 | 亚洲日韩一区二区三区 | 狂野欧美激情性xxxx | 无码中文字幕色专区 | 领导边摸边吃奶边做爽在线观看 | 无码人妻精品一区二区三区不卡 | 荫蒂被男人添的好舒服爽免费视频 |