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

基于Zookeeper的分布式鎖

開發 前端 分布式
實現分布式鎖目前有三種流行方案,分別為基于數據庫、Redis、Zookeeper的方案,其中前兩種方案網絡上有很多資料可以參考,本文不做展開。我們來看下使用Zookeeper如何實現分布式鎖。

這篇文章只需要你10分鐘的時間。

實現分布式鎖目前有三種流行方案,分別為基于數據庫、Redis、Zookeeper的方案,其中前兩種方案網絡上有很多資料可以參考,本文不做展開。我們來看下使用Zookeeper如何實現分布式鎖。

什么是Zookeeper?

Zookeeper(業界簡稱zk)是一種提供配置管理、分布式協同以及命名的中心化服務,這些提供的功能都是分布式系統中非常底層且必不可少的基本功能,但是如果自己實現這些功能而且要達到高吞吐、低延遲同時還要保持一致性和可用性,實際上非常困難。因此zookeeper提供了這些功能,開發者在zookeeper之上構建自己的各種分布式系統。

雖然zookeeper的實現比較復雜,但是它提供的模型抽象卻是非常簡單的。Zookeeper提供一個多層級的節點命名空間(節點稱為znode),每個節點都用一個以斜杠(/)分隔的路徑表示,而且每個節點都有父節點(根節點除外),非常類似于文件系統。例如,/foo/doo這個表示一個znode,它的父節點為/foo,父父節點為/,而/為根節點沒有父節點。與文件系統不同的是,這些節點都可以設置關聯的數據,而文件系統中只有文件節點可以存放數據而目錄節點不行。Zookeeper為了保證高吞吐和低延遲,在內存中維護了這個樹狀的目錄結構,這種特性使得Zookeeper不能用于存放大量的數據,每個節點的存放數據上限為1M。

而為了保證高可用,zookeeper需要以集群形態來部署,這樣只要集群中大部分機器是可用的(能夠容忍一定的機器故障),那么zookeeper本身仍然是可用的。客戶端在使用zookeeper時,需要知道集群機器列表,通過與集群中的某一臺機器建立TCP連接來使用服務,客戶端使用這個TCP鏈接來發送請求、獲取結果、獲取監聽事件以及發送心跳包。如果這個連接異常斷開了,客戶端可以連接到另外的機器上。

架構簡圖如下所示:

基于Zookeeper的分布式鎖

客戶端的讀請求可以被集群中的任意一臺機器處理,如果讀請求在節點上注冊了監聽器,這個監聽器也是由所連接的zookeeper機器來處理。對于寫請求,這些請求會同時發給其他zookeeper機器并且達成一致后,請求才會返回成功。因此,隨著zookeeper的集群機器增多,讀請求的吞吐會提高但是寫請求的吞吐會下降。

有序性是zookeeper中非常重要的一個特性,所有的更新都是全局有序的,每個更新都有一個唯一的時間戳,這個時間戳稱為zxid(Zookeeper Transaction Id)。而讀請求只會相對于更新有序,也就是讀請求的返回結果中會帶有這個zookeeper***的zxid。

如何使用zookeeper實現分布式鎖?

在描述算法流程之前,先看下zookeeper中幾個關于節點的有趣的性質:

  • 有序節點:假如當前有一個父節點為/lock,我們可以在這個父節點下面創建子節點;zookeeper提供了一個可選的有序特性,例如我們可以創建子節點“/lock/node-”并且指明有序,那么zookeeper在生成子節點時會根據當前的子節點數量自動添加整數序號,也就是說如果是***個創建的子節點,那么生成的子節點為/lock/node-0000000000,下一個節點則為/lock/node-0000000001,依次類推。
  • 臨時節點:客戶端可以建立一個臨時節點,在會話結束或者會話超時后,zookeeper會自動刪除該節點。
  • 事件監聽:在讀取數據時,我們可以同時對節點設置事件監聽,當節點數據或結構變化時,zookeeper會通知客戶端。當前zookeeper有如下四種事件:1)節點創建;2)節點刪除;3)節點數據修改;4)子節點變更。

下面描述使用zookeeper實現分布式鎖的算法流程,假設鎖空間的根節點為/lock:

  • 客戶端連接zookeeper,并在/lock下創建 臨時的 且 有序的 子節點,***個客戶端對應的子節點為/lock/lock-0000000000,第二個為/lock/lock-0000000001,以此類推。
  • 客戶端獲取/lock下的子節點列表,判斷自己創建的子節點是否為當前子節點列表中 序號最小 的子節點,如果是則認為獲得鎖,否則監聽/lock的子節點變更消息,獲得子節點變更通知后重復此步驟直至獲得鎖;
  • 執行業務代碼;
  • 完成業務流程后,刪除對應的子節點釋放鎖。

步驟1中創建的臨時節點能夠保證在故障的情況下鎖也能被釋放,考慮這么個場景:假如客戶端a當前創建的子節點為序號最小的節點,獲得鎖之后客戶端所在機器宕機了,客戶端沒有主動刪除子節點;如果創建的是***的節點,那么這個鎖永遠不會釋放,導致死鎖;由于創建的是臨時節點,客戶端宕機后,過了一定時間zookeeper沒有收到客戶端的心跳包判斷會話失效,將臨時節點刪除從而釋放鎖。

另外細心的朋友可能會想到,在步驟2中獲取子節點列表與設置監聽這兩步操作的原子性問題,考慮這么個場景:客戶端a對應子節點為/lock/lock-0000000000,客戶端b對應子節點為/lock/lock-0000000001,客戶端b獲取子節點列表時發現自己不是序號最小的,但是在設置監聽器前客戶端a完成業務流程刪除了子節點/lock/lock-0000000000,客戶端b設置的監聽器豈不是丟失了這個事件從而導致永遠等待了?這個問題不存在的。因為zookeeper提供的API中設置監聽器的操作與讀操作是 原子執行 的,也就是說在讀子節點列表時同時設置監聽器,保證不會丟失事件。

***,對于這個算法有個極大的優化點:假如當前有1000個節點在等待鎖,如果獲得鎖的客戶端釋放鎖時,這1000個客戶端都會被喚醒,這種情況稱為“羊群效應”;在這種羊群效應中,zookeeper需要通知1000個客戶端,這會阻塞其他的操作,***的情況應該只喚醒新的最小節點對應的客戶端。應該怎么做呢?在設置事件監聽時,每個客戶端應該對剛好在它之前的子節點設置事件監聽,例如子節點列表為/lock/lock-0000000000、/lock/lock-0000000001、/lock/lock-0000000002,序號為1的客戶端監聽序號為0的子節點刪除消息,序號為2的監聽序號為1的子節點刪除消息。

所以調整后的分布式鎖算法流程如下:

  • 客戶端連接zookeeper,并在/lock下創建 臨時的 且 有序的 子節點,***個客戶端對應的子節點為/lock/lock-0000000000,第二個為/lock/lock-0000000001,以此類推。
  • 客戶端獲取/lock下的子節點列表,判斷自己創建的子節點是否為當前子節點列表中 序號最小 的子節點,如果是則認為獲得鎖,否則 監聽剛好在自己之前一位的子節點刪除消息 ,獲得子節點變更通知后重復此步驟直至獲得鎖;
  • 執行業務代碼;
  • 完成業務流程后,刪除對應的子節點釋放鎖。

Curator的源碼分析

雖然zookeeper原生客戶端暴露的API已經非常簡潔了,但是實現一個分布式鎖還是比較麻煩的…我們可以直接使用 curator 這個開源項目提供的zookeeper分布式鎖實現。

我們只需要引入下面這個包(基于maven):

 

  1. <dependency> 
  2.     <groupId>org.apache.curator</groupId> 
  3.     <artifactId>curator-recipes</artifactId> 
  4.     <version>4.0.0</version> 
  5. </dependency> 

然后就可以用啦!代碼如下:

 

  1. public static void main(String[] args) throws Exception { 
  2.     //創建zookeeper的客戶端 
  3.     RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 3); 
  4.     CuratorFramework client = CuratorFrameworkFactory.newClient("10.21.41.181:2181,10.21.42.47:2181,10.21.49.252:2181", retryPolicy); 
  5.     client.start(); 
  6.  
  7.     //創建分布式鎖, 鎖空間的根節點路徑為/curator/lock 
  8.     InterProcessMutex mutex = new InterProcessMutex(client, "/curator/lock"); 
  9.     mutex.acquire(); 
  10.     //獲得了鎖, 進行業務流程 
  11.     System.out.println("Enter mutex"); 
  12.     //完成業務流程, 釋放鎖 
  13.     mutex.release(); 
  14.      
  15.     //關閉客戶端 
  16.     client.close(); 

可以看到關鍵的核心操作就只有mutex.acquire()和mutex.release(),簡直太方便了!

下面來分析下獲取鎖的源碼實現。acquire的方法如下:

 

  1. /* 
  2.  * 獲取鎖,當鎖被占用時會阻塞等待,這個操作支持同線程的可重入(也就是重復獲取鎖),acquire的次數需要與release的次數相同。 
  3.  * @throws Exception ZK errors, connection interruptions 
  4.  */ 
  5. @Override 
  6. public void acquire() throws Exception 
  7.     if ( !internalLock(-1, null) ) 
  8.     { 
  9.         throw new IOException("Lost connection while trying to acquire lock: " + basePath); 
  10.     } 

這里有個地方需要注意,當與zookeeper通信存在異常時,acquire會直接拋出異常,需要使用者自身做重試策略。代碼中調用了internalLock(-1, null),參數表明在鎖被占用時***阻塞等待。internalLock的代碼如下:

 

  1. private boolean internalLock(long time, TimeUnit unit) throws Exception 
  2.  
  3.     //這里處理同線程的可重入性,如果已經獲得鎖,那么只是在對應的數據結構中增加acquire的次數統計,直接返回成功 
  4.     Thread currentThread = Thread.currentThread(); 
  5.     LockData lockData = threadData.get(currentThread); 
  6.     if ( lockData != null ) 
  7.     { 
  8.         // re-entering 
  9.         lockData.lockCount.incrementAndGet(); 
  10.         return true
  11.     } 
  12.  
  13.     //這里才真正去zookeeper中獲取鎖 
  14.     String lockPath = internals.attemptLock(time, unit, getLockNodeBytes()); 
  15.     if ( lockPath != null ) 
  16.     { 
  17.         //獲得鎖之后,記錄當前的線程獲得鎖的信息,在重入時只需在LockData中增加次數統計即可 
  18.         LockData newLockData = new LockData(currentThread, lockPath); 
  19.         threadData.put(currentThread, newLockData); 
  20.         return true
  21.     } 
  22.  
  23.     //在阻塞返回時仍然獲取不到鎖,這里上下文的處理隱含的意思為zookeeper通信異常 
  24.     return false

代碼中增加了具體注釋,不做展開。看下zookeeper獲取鎖的具體實現:

 

  1. String attemptLock(long time, TimeUnit unit, byte[] lockNodeBytes) throws Exception 
  2.     //參數初始化,此處省略 
  3.     //... 
  4.     
  5.     //自旋獲取鎖 
  6.     while ( !isDone ) 
  7.     { 
  8.         isDone = true
  9.  
  10.         try 
  11.         { 
  12.             //在鎖空間下創建臨時且有序的子節點 
  13.             ourPath = driver.createsTheLock(client, path, localLockNodeBytes); 
  14.             //判斷是否獲得鎖(子節點序號最小),獲得鎖則直接返回,否則阻塞等待前一個子節點刪除通知 
  15.             hasTheLock = internalLockLoop(startMillis, millisToWait, ourPath); 
  16.         } 
  17.         catch ( KeeperException.NoNodeException e ) 
  18.         { 
  19.             //對于NoNodeException,代碼中確保了只有發生session過期才會在這里拋出NoNodeException,因此這里根據重試策略進行重試 
  20.             if ( client.getZookeeperClient().getRetryPolicy().allowRetry(retryCount++, System.currentTimeMillis() - startMillis, RetryLoop.getDefaultRetrySleeper()) ) 
  21.             { 
  22.                 isDone = false
  23.             } 
  24.             else 
  25.             { 
  26.                 throw e; 
  27.             } 
  28.         } 
  29.     } 
  30.  
  31.     //如果獲得鎖則返回該子節點的路徑 
  32.     if ( hasTheLock ) 
  33.     { 
  34.         return ourPath; 
  35.     } 
  36.  
  37.     return null

上面代碼中主要有兩步操作:

  • driver.createsTheLock:創建臨時且有序的子節點,里面實現比較簡單不做展開,主要關注幾種節點的模式:1)PERSISTENT(***);2)PERSISTENT_SEQUENTIAL(***且有序);3)EPHEMERAL(臨時);4)EPHEMERAL_SEQUENTIAL(臨時且有序)。
  • internalLockLoop:阻塞等待直到獲得鎖。

看下internalLockLoop是怎么判斷鎖以及阻塞等待的,這里刪除了一些無關代碼,只保留主流程:

 

  1. //自旋直至獲得鎖 
  2. while ( (client.getState() == CuratorFrameworkState.STARTED) && !haveTheLock ) 
  3.     //獲取所有的子節點列表,并且按序號從小到大排序 
  4.     List<String>        children = getSortedChildren(); 
  5.      
  6.     //根據序號判斷當前子節點是否為最小子節點 
  7.     String              sequenceNodeName = ourPath.substring(basePath.length() + 1); // +1 to include the slash 
  8.     PredicateResults    predicateResults = driver.getsTheLock(client, children, sequenceNodeName, maxLeases); 
  9.     if ( predicateResults.getsTheLock() ) 
  10.     { 
  11.         //如果為最小子節點則認為獲得鎖 
  12.         haveTheLock = true
  13.     } 
  14.     else 
  15.     { 
  16.         //否則獲取前一個子節點 
  17.         String  previousSequencePath = basePath + "/" + predicateResults.getPathToWatch(); 
  18.  
  19.         //這里使用對象監視器做線程同步,當獲取不到鎖時監聽前一個子節點刪除消息并且進行wait(),當前一個子節點刪除(也就是鎖釋放)時,回調會通過notifyAll喚醒此線程,此線程繼續自旋判斷是否獲得鎖 
  20.         synchronized(this) 
  21.         { 
  22.             try  
  23.             { 
  24.                 //這里使用getData()接口而不是checkExists()是因為,如果前一個子節點已經被刪除了那么會拋出異常而且不會設置事件監聽器,而checkExists雖然也可以獲取到節點是否存在的信息但是同時設置了監聽器,這個監聽器其實永遠不會觸發,對于zookeeper來說屬于資源泄露 
  25.                 client.getData().usingWatcher(watcher).forPath(previousSequencePath); 
  26.  
  27.                 //如果設置了阻塞等待的時間 
  28.                 if ( millisToWait != null ) 
  29.                 { 
  30.                     millisToWait -= (System.currentTimeMillis() - startMillis); 
  31.                     startMillis = System.currentTimeMillis(); 
  32.                     if ( millisToWait <= 0 ) 
  33.                     { 
  34.                         doDelete = true;    // 等待時間到達,刪除對應的子節點 
  35.                         break; 
  36.                     } 
  37.                      
  38.                     //等待相應的時間 
  39.                     wait(millisToWait); 
  40.                 } 
  41.                 else 
  42.                 { 
  43.                    //永遠等待 
  44.                     wait(); 
  45.                 } 
  46.             } 
  47.             catch ( KeeperException.NoNodeException e )  
  48.             { 
  49.                 //上面使用getData來設置監聽器時,如果前一個子節點已經被刪除那么會拋出NoNodeException,只需要自旋一次即可,無需額外處理 
  50.             } 
  51.         } 
  52.     } 

具體邏輯見注釋,不再贅述。代碼中設置的事件監聽器,在事件發生回調時只是簡單的notifyAll喚醒當前線程以重新自旋判斷,比較簡單不再展開。

以上。

責任編輯:未麗燕 來源: 深元的博客
相關推薦

2022-10-27 10:44:14

分布式Zookeeper

2021-02-28 07:49:28

Zookeeper分布式

2021-10-25 10:21:59

ZK分布式鎖ZooKeeper

2021-07-16 07:57:34

ZooKeeperCurator源碼

2019-07-16 09:22:10

RedisZookeeper分布式鎖

2020-11-16 12:55:41

Redis分布式鎖Zookeeper

2017-04-13 10:51:09

Consul分布式

2018-01-25 19:01:47

Zookeeper分布式數據

2019-06-19 15:40:06

分布式鎖RedisJava

2022-07-25 06:44:19

ZooKeeper分布式鎖

2021-07-08 09:21:17

ZooKeeper分布式鎖 Curator

2021-06-03 00:02:43

RedisRedlock算法

2021-07-30 00:09:21

Redlock算法Redis

2022-03-08 07:22:48

Redis腳本分布式鎖

2019-10-10 09:16:34

Zookeeper架構分布式

2015-05-18 09:59:48

ZooKeeper分布式計算Hadoop

2022-11-06 19:28:02

分布式鎖etcd云原生

2024-11-28 15:11:28

2019-11-18 14:16:10

ZookeeperRedis大數據

2021-07-10 10:02:30

ZooKeeperCurator并發
點贊
收藏

51CTO技術棧公眾號

久久久噜噜噜久噜久久综合| 欧美精品首页| 精品视频全国免费看| 午夜精品视频在线观看一区二区| 91在线公开视频| 欧美在线亚洲综合一区| 亚洲国产成人av在线| 色婷婷综合久久久久中文字幕| 一级毛片视频在线| 成人黄色av电影| 国产精品日本精品| 国产一级二级三级视频| 国产亚洲一区| 精品毛片乱码1区2区3区| 熟女人妇 成熟妇女系列视频| www视频在线免费观看| 91在线视频播放地址| 成人黄色av免费在线观看| 日韩欧美亚洲国产| 91视频精品| 日韩av在线免播放器| www.欧美激情.com| 性欧美1819sex性高清| 亚洲精品国产精华液| 免费精品视频一区| 成人激情四射网| 美美哒免费高清在线观看视频一区二区| 欧美激情亚洲另类| 欧日韩不卡视频| 日韩成人av在线资源| 日韩午夜av一区| 色综合色综合色综合色综合| 色资源二区在线视频| 亚洲自拍与偷拍| 国产成人精品免费看在线播放| 日本私人网站在线观看| 国产不卡视频一区| 91九色视频在线| 波多野结衣电影在线播放| 亚洲精品影院在线观看| 欧美激情精品久久久久久免费印度| 性欧美一区二区| 西野翔中文久久精品字幕| 精品精品欲导航| 日本亚洲一区二区三区| 成人午夜sm精品久久久久久久| 日韩欧美亚洲一二三区| 国模无码视频一区二区三区| 岛国毛片av在线| 一区二区三区四区不卡在线| 欧美性受xxxx黑人猛交88| 在线观看二区| 亚洲国产精品高清| 色就是色欧美| 国产一区二区影视| 久久久激情视频| 久久人人97超碰人人澡爱香蕉| 日韩永久免费视频| 成人免费看黄yyy456| 国产精品10p综合二区| va婷婷在线免费观看| 国产在线播精品第三| 91精品国产综合久久香蕉最新版 | 美女久久99| 日韩高清免费观看| 播金莲一级淫片aaaaaaa| 亚洲精品亚洲人成在线观看| 亚洲开心激情网| 在线观看福利片| 韩日一区二区三区| 国产午夜精品全部视频在线播放| 97在线观看免费视频| 精品视频免费| 日韩视频免费观看| 私库av在线播放| 国产精品v日韩精品v欧美精品网站 | 99久久99久久精品国产片果冰| xxxxx成人.com| 日本福利片在线观看| 国产一区视频在线观看免费| 26uuu国产精品视频| 在线观看日本网站| 久久成人久久爱| 国产精品三区四区| 四虎精品在线| 国产精品视频在线看| 欧美aaa在线观看| 高清电影在线免费观看| 欧美性猛交xxxx偷拍洗澡| 搡女人真爽免费午夜网站| 中文成人在线| 亚洲精品成人久久久| 欧洲美熟女乱又伦| 欧美1级日本1级| 8x海外华人永久免费日韩内陆视频| 免费看污视频的网站| 国产一区二区三区久久久 | 久操成人av| 日韩在线视频网站| 日本三级中文字幕| 日本中文一区二区三区| www国产亚洲精品| 可以在线观看的av| 一区二区在线观看不卡| 人妻精品无码一区二区三区 | 91国产福利在线| 无套白嫩进入乌克兰美女| 欧美一级全黄| 久久精品国产精品亚洲| 亚洲一区欧美在线| 久久电影网电视剧免费观看| 久久精品99久久| 国产不卡在线| 欧美少妇一区二区| 日韩精品一区二区三区高清免费| 香蕉视频官网在线观看日本一区二区| 91精品国产高清自在线| av小说天堂网| 中文一区一区三区高中清不卡| 国产欧美日韩小视频| 色诱色偷偷久久综合| 国产婷婷色综合av蜜臀av | 欧美另类女人| 国产精品天天狠天天看| 青青视频在线观| 亚洲国产视频在线| 91av视频免费观看| 国产日产精品_国产精品毛片| 欧美黄色片视频| 136福利视频导航| 国产日韩影视精品| 女人扒开屁股爽桶30分钟| 亚洲精品在线a| 日韩中文字幕av| 中文字幕超碰在线| 91在线视频官网| 青青草精品视频在线| 欧美a在线观看| 色噜噜狠狠狠综合曰曰曰| 国产免费a视频| 久久夜色精品国产欧美乱极品| 日本人妻伦在线中文字幕| 99久久这里有精品| 久久精品在线播放| 91亚洲国产成人久久精品麻豆| 国产日产亚洲精品系列| 超碰av在线免费观看| 国产成人精品免费视| 日本精品va在线观看| 丰满大乳国产精品| 亚洲无线码一区二区三区| 日韩成人av影院| 精品二区视频| 精品久久精品久久| 国产h片在线观看| 日韩国产精品一区| 黄色片网站在线免费观看| 91欧美激情一区二区三区成人| heyzo亚洲| 西野翔中文久久精品字幕| 奇门遁甲1982国语版免费观看高清| 三级在线电影| 欧美在线一二三四区| www.涩涩爱| 国产综合色在线视频区| 黄色一级片网址| 99re热精品视频| 国产91精品久| a黄色在线观看| 7878成人国产在线观看| 清纯粉嫩极品夜夜嗨av| 成人午夜又粗又硬又大| 欧美性久久久久| 欧美日韩精品一区二区视频| 国产色视频一区| av免费网站在线| 亚洲的天堂在线中文字幕| 91午夜精品亚洲一区二区三区| 中文欧美字幕免费| 日韩精品xxx| 国产精品美女| 亚洲午夜久久久影院伊人| 日韩精品一级| 4p变态网欧美系列| www.国产精品.com| 日韩精品一区二区三区视频播放 | av观看在线| 日韩成人网免费视频| 伊人久久一区二区| 亚洲一二三专区| 精品无码在线观看| 国产精品一品二品| 国产xxxxx视频| 欧美激情91| 日本一区视频在线| 日韩精品一区二区三区中文字幕| 欧美在线视频一区二区| 国产在线激情视频| 亚洲精品一区二区久| 国产模特av私拍大尺度| 天天射综合影视| 手机在线免费看毛片| 久久午夜免费电影| 国产伦精品一区二区三区88av| 免费精品视频最新在线| 福利视频一区二区三区四区| 欧美在线电影| 精品国产一二| 疯狂欧洲av久久成人av电影| 日本一本a高清免费不卡| 男女视频在线| 精品国内产的精品视频在线观看| 天堂91在线| 日韩欧美电影一区| 国产一区二区在线视频聊天| 色综合久久久久网| 亚洲精品77777| 亚洲人成影院在线观看| 免费看日本黄色片| www国产精品av| 无码人妻一区二区三区免费n鬼沢| 日本最新不卡在线| 免费无码av片在线观看| 亚洲黄色三级| 黄色三级中文字幕| 91精品福利| 亚洲黄色一区二区三区| 中文字幕精品影院| 精品国产一区二区三区麻豆免费观看完整版 | 国产欧美在线播放| 嫩草伊人久久精品少妇av杨幂| 高清在线视频日韩欧美| 秋霞在线视频| 九九热精品视频国产| 黄色成人影院| 日韩在线免费视频| 午夜在线小视频| 一本色道久久88综合亚洲精品ⅰ| 欧美伦理影视网| 亚洲精品网址在线观看| 亚洲av成人无码网天堂 | 日本一本草久在线中文| 亚洲精品成人久久久| 天天操天天爱天天干| 亚洲成人激情图| 色婷婷av一区二区三| 亚洲国产成人久久综合一区| 黄色av小说在线观看| 精品国产91久久久久久久妲己| 亚洲精品字幕在线| 精品福利一区二区三区免费视频| 精品国产亚洲av麻豆| 日韩欧美一二三| 亚洲精品中文字幕成人片| 亚洲成av人乱码色午夜| 熟妇人妻系列aⅴ无码专区友真希| 精品国产一区二区亚洲人成毛片| 成人av无码一区二区三区| 亚洲成人久久久久| 免费在线国产| 国产亚洲精品成人av久久ww| 一区二区高清不卡| 欧美麻豆久久久久久中文| 日本高清成人vr专区| 久久久亚洲欧洲日产国码aⅴ| 99色在线观看| 日韩免费观看av| 国产亚洲精彩久久| 亚洲va男人天堂| 白嫩白嫩国产精品| 久久精精品视频| 色综合久久一区二区三区| 一级全黄肉体裸体全过程| 欧美涩涩网站| 久久精品网站视频| 精品在线观看视频| 中国特级黄色片| 国产网站一区二区三区| 欧美爱爱免费视频| 亚洲h动漫在线| 午夜精品一区二| 在线不卡中文字幕| 人妻与黑人一区二区三区| 亚洲欧美成人网| 黄色片网站在线| 国内精品久久久久久久| 日韩一区二区三区免费视频| 亚洲一区二区三区乱码aⅴ蜜桃女| 加勒比视频一区| 手机看片福利永久国产日韩| 欧美欧美天天天天操| 99色精品视频| 国产高清在线观看免费不卡| 成年人在线观看av| 亚洲丝袜另类动漫二区| 久久国产黄色片| 337p亚洲精品色噜噜噜| 手机亚洲第一页| 免费91在线视频| 视频二区不卡| 国产一区二区精品在线| 婷婷久久一区| 久久精品香蕉视频| 成人一区二区三区视频在线观看| 在线视频第一页| 亚洲成人免费av| 国产精品亚洲lv粉色| 日韩久久精品电影| 综合久久2019| 国产欧美va欧美va香蕉在| 久久中文字幕导航| 老司机午夜网站| 日韩成人午夜电影| 免费观看一级一片| 一区二区免费在线播放| 国产又爽又黄免费软件| 亚洲美女在线观看| 超碰资源在线| 91在线视频免费| 久久福利影院| 哪个网站能看毛片| 99精品欧美一区二区三区小说| 一区二区三区四区五区| 欧美色大人视频| 免费在线观看污视频| 97国产精品人人爽人人做| 不卡一区视频| 亚洲一区三区| 免费欧美日韩国产三级电影| 无码人妻aⅴ一区二区三区| 亚洲不卡av一区二区三区| 国产视频一二三四区| www.久久色.com| 日本h片久久| 日本精品免费| 久久久久99| 日本少妇色视频| 福利视频导航一区| 手机福利在线| 欧美性一区二区三区| 色老板在线视频一区二区| 国产资源在线视频| 99精品1区2区| 91精品国产乱码久久久张津瑜| 精品国产乱码久久久久久蜜臀| 午夜av在线播放| 99国产超薄丝袜足j在线观看| 亚洲精品中文字幕乱码| 久久婷婷中文字幕| 一区二区三区四区不卡在线| www.99视频| 国内外成人免费激情在线视频| 国产精品自在| 自慰无码一区二区三区| 久久这里只有精品首页| 国产日韩久久久| 色妞色视频一区二区三区四区| 人人精品久久| 91精品一区二区三区四区| 国产精品一区二区视频| 玖玖爱免费视频| 亚洲国产精品va在线观看黑人| 成年女人在线看片| 任我爽在线视频精品一| 青草av.久久免费一区| h色网站在线观看| 精品少妇一区二区三区视频免付费| 丰乳肥臀在线| 欧美日韩国产高清视频| 蜜臀av性久久久久蜜臀aⅴ| av最新在线观看| 精品久久人人做人人爱| 中文在线资源| 亚洲精品tv久久久久久久久| 久久av资源站| 国产精品2020| 亚洲天天在线日亚洲洲精| www.久久久久爱免| 日韩欧美国产综合在线| 欧美国产欧美综合| 国产三级在线观看视频| 91国产精品91| 不卡中文一二三区| 99riav国产精品视频| 日韩欧美国产激情| 国产福利在线播放麻豆| 国产在线精品一区| 蜜臀91精品一区二区三区| 欧美人妻精品一区二区免费看| 亚洲精品久久久久国产| 免费成人高清在线视频| 狠狠干 狠狠操| 国产精品理伦片| 免费看日韩av| 国产精品视频区1| 亚洲免费精品| 99热这里只有精品4| 亚洲精品美女在线| 国产精品毛片aⅴ一区二区三区| 欧美在线观看成人|