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

帶你吃透幾種大廠分布式ID設計方案

網絡 通信技術 分布式
最近公司在擴招后端高級開發,有幸成為面試官之一,其中問的最多一個問題就是分布式ID的幾種解決方案,不客氣的說前身小公司的開發答得完整的很少。

[[403803]]

本文轉載自微信公眾號「無聊學Java」,作者無聊。轉載本文請聯系無聊學Java公眾號。

前言

最近公司在擴招后端高級開發,有幸成為面試官之一,其中問的最多一個問題就是分布式ID的幾種解決方案,不客氣的說前身小公司的開發答得完整的很少。

于是就抽出了周末的時間整理了幾種主流的分布式ID生成方案,希望能夠幫助到你們。

開篇幾個問題

1. 為什么需要分布式全局唯一ID以及分布式ID的業務需求

在復雜分布式系統中,往往需要對大量的數據和消息進行唯一標識。

  • 如在美團點評的金融、支付、餐飲、酒店等業務場景
  • 貓眼電影等產品的系統中數據日漸增長,對數據分庫分表后需要有一個唯一ID來表示一條數據或者消息。
  • 特別一點的如訂單、騎手、優惠劵也都需要一個唯一ID做為標識。

此時一個能生成唯一ID的系統是非常必要的。

2. ID生成規則部分硬性要求

  • 全局唯一:既然是唯一標識,那么全局唯一是最基本的要求。
  • 趨勢遞增:在MySQL的InnoDB引擎中使用的是聚集索引,由于多數RDBMS使用Btree的數據結構來存儲索引數據,在主鍵的選擇上面我們應該盡量使用有序的主鍵來保證寫入性能。
  • 單調遞增:保證下一個ID一定大于上一個ID,例如事務版本號、IM增量消息、排序等特殊需求。
  • 信息安全:如果ID是連續的,那么惡意用戶的扒取工作就非常容易做了,直接按照順序下載指定URL即可;如果是訂單號那么更加危險,競爭對手可以知道我們一天的單量;所以在一些應用場景下,需要ID無規則不規則,讓競爭對手不好猜。
  • 含時間戳:這樣就能在開發中快速了解這個分布式ID的生成時間。

3. ID生成系統的可用性要求

  • 高可用:發一個獲取分布式ID的請求,服務器就要保證99.999%的情況下給我創建一個唯一分布式ID
  • 低延遲:發一個獲取分布式ID的請求,服務器就要快,極速
  • 高QPS:假如并發一口氣10萬個創建分布式ID請求同時過來,服務器需要頂得住且成功創建10萬個分布式ID

通用的幾種方案

隨著系統架構以及業務的演變,分布式ID生成也是有N中解決方案,以下就簡單的列舉幾種。

1. UUID

這種方案估計大家都了解,最簡單的一種方案。

  1. public static void main(String[] args) { 
  2.     String uuid = UUID.randomUUID().toString(); 
  3.     System.out.println(uuid); 

如果只是考慮唯一性,那么UUID基本可以滿足需求。

缺點

  • 無序:無法預測他的生成順序,不能生成遞增有序的數字
  • 主鍵:ID作為主鍵時在特定的環境下會存在一些問題,比如做DB主鍵的場景下,UUID非常不適用,MySQL官方有明確的建議主鍵要盡量越短越好,36位的UUID不合要求。
  • 索引:會導致B+樹索引的分裂。

2. 數據庫自增主鍵

此種方案有一定的局限性,在高并發集群上此策略不可用。

3. 基于Redis生成全局ID策略

  • 因為Redis是單線程,天生保證原子性,所以可以使用INCR和INCRBY來實現。
  • 集群分布式

在Redis集群下,同樣和MySQL一樣需要設置不同的增長步數,同時key需要設置有效期;可以使用Redis集群來獲取更高的吞吐量;假如一個集群中有五個Redis,那么初始化每臺Redis步長分別是1,2,3,4,5,然后步長都是5。

4. snowflake(雪花算法)

  • 推特的雪花算法生成ID能夠按照時間有序生成。
  • 雪花算法生成ID的結果是一個64bit大小的整數,為一個Long型(轉換為字符串后長度最多19)
  • 分布式系統內不會產生ID碰撞(由datecenter和workerId作區分),并且效率較高。

結構

雪花算法的幾個核心組成部分如下圖:

號段解析

  • 1bit符號位:不用,因為二進制最高位是符號位,1表示負數,0表示正數,生成的id一般都是用正數,所以最高位固定位0
  • 41bit時間戳,用于記錄時間戳,毫秒級
    • 41位可以表示2^41 - 1個數字
    • 如果只用來表示正整數(計算機正數包含0),可以表示的數值范圍是0-2^41 - 1,減一是因為可表示的數值范圍是從0開始算的,而不是1
    • 也就是說41位可以表示2^41 - 1個毫秒的值,轉換為單位年則是69年。
  • 10bit工作進程位,用于記錄工作機器id
    • 可以部署在2^10 = 1024個節點,包括五位datacenterId和五位workerId
    • 五位可以表示的最大整數位2^5 - 1 = 31,即可以使用0,1,2…31這32個數字來表示不同的datacenterId和workerId
  • 12bit序列號,序列號,用來記錄同毫秒內 產生的不同的ID
    • 12bit可以表示的最大正整數位2^12 - 1 = 4095,即可以表示0,1….4094這4095個數字
    • 表示同一機器同一時間戳(毫秒)中產生的4095個ID序號

優點

  • 所有生成的id按時間趨勢遞增
  • 整個分布式內不會產生重復id,因為有datacenterId和workerId來做區分。
  • 毫秒數在高位,自增序列在低位,整個ID都是趨勢遞增的
  • 不依賴數據庫、redis等第三方系統,以服務的方式部署,穩定性更高,生成ID的性能也是非常高的。
  • 可以根據自身業務分配bit位,非常靈活。

缺點

  • 依賴機器時鐘,如果機器時鐘回退,會導致重復ID生成
  • 在單機上是遞增的,但是由于設計到分布式環境,每臺機器上的時鐘不可能完全同步,有時候會出現不是全局遞增的情況。(此缺點可以認為蕪鎖胃,一般分布式ID只要求趨勢遞增,并不會嚴格要求遞增,90%的需求都只需要趨勢遞增)

源碼

  1. /** 
  2.  * twitter的snowflake算法 -- java實現 
  3.  *  
  4.  * @author beyond 
  5.  * @date 2016/11/26 
  6.  */ 
  7. public class SnowFlake { 
  8.  
  9.     /** 
  10.      * 起始的時間戳 
  11.      */ 
  12.     private final static long START_STMP = 1480166465631L; 
  13.  
  14.     /** 
  15.      * 每一部分占用的位數 
  16.      */ 
  17.     private final static long SEQUENCE_BIT = 12; //序列號占用的位數 
  18.     private final static long MACHINE_BIT = 5;   //機器標識占用的位數 
  19.     private final static long DATACENTER_BIT = 5;//數據中心占用的位數 
  20.  
  21.     /** 
  22.      * 每一部分的最大值 
  23.      */ 
  24.     private final static long MAX_DATACENTER_NUM = -1L ^ (-1L << DATACENTER_BIT); 
  25.     private final static long MAX_MACHINE_NUM = -1L ^ (-1L << MACHINE_BIT); 
  26.     private final static long MAX_SEQUENCE = -1L ^ (-1L << SEQUENCE_BIT); 
  27.  
  28.     /** 
  29.      * 每一部分向左的位移 
  30.      */ 
  31.     private final static long MACHINE_LEFT = SEQUENCE_BIT; 
  32.     private final static long DATACENTER_LEFT = SEQUENCE_BIT + MACHINE_BIT; 
  33.     private final static long TIMESTMP_LEFT = DATACENTER_LEFT + DATACENTER_BIT; 
  34.  
  35.     private long datacenterId;  //數據中心 
  36.     private long machineId;     //機器標識 
  37.     private long sequence = 0L; //序列號 
  38.     private long lastStmp = -1L;//上一次時間戳 
  39.  
  40.     public SnowFlake(long datacenterId, long machineId) { 
  41.         if (datacenterId > MAX_DATACENTER_NUM || datacenterId < 0) { 
  42.             throw new IllegalArgumentException("datacenterId can't be greater than MAX_DATACENTER_NUM or less than 0"); 
  43.         } 
  44.         if (machineId > MAX_MACHINE_NUM || machineId < 0) { 
  45.             throw new IllegalArgumentException("machineId can't be greater than MAX_MACHINE_NUM or less than 0"); 
  46.         } 
  47.         this.datacenterId = datacenterId; 
  48.         this.machineId = machineId; 
  49.     } 
  50.  
  51.     /** 
  52.      * 產生下一個ID 
  53.      * 
  54.      * @return 
  55.      */ 
  56.     public synchronized long nextId() { 
  57.         long currStmp = getNewstmp(); 
  58.         if (currStmp < lastStmp) { 
  59.             throw new RuntimeException("Clock moved backwards.  Refusing to generate id"); 
  60.         } 
  61.  
  62.         if (currStmp == lastStmp) { 
  63.             //相同毫秒內,序列號自增 
  64.             sequence = (sequence + 1) & MAX_SEQUENCE; 
  65.             //同一毫秒的序列數已經達到最大 
  66.             if (sequence == 0L) { 
  67.                 currStmp = getNextMill(); 
  68.             } 
  69.         } else { 
  70.             //不同毫秒內,序列號置為0 
  71.             sequence = 0L; 
  72.         } 
  73.  
  74.         lastStmp = currStmp; 
  75.  
  76.         return (currStmp - START_STMP) << TIMESTMP_LEFT //時間戳部分 
  77.                 | datacenterId << DATACENTER_LEFT       //數據中心部分 
  78.                 | machineId << MACHINE_LEFT             //機器標識部分 
  79.                 | sequence;                             //序列號部分 
  80.     } 
  81.  
  82.     private long getNextMill() { 
  83.         long mill = getNewstmp(); 
  84.         while (mill <= lastStmp) { 
  85.             mill = getNewstmp(); 
  86.         } 
  87.         return mill; 
  88.     } 
  89.  
  90.     private long getNewstmp() { 
  91.         return System.currentTimeMillis(); 
  92.     } 
  93.  
  94.     public static void main(String[] args) { 
  95.         SnowFlake snowFlake = new SnowFlake(2, 3); 
  96.  
  97.         for (int i = 0; i < (1 << 12); i++) { 
  98.             System.out.println(snowFlake.nextId()); 
  99.         } 
  100.  
  101.     } 

測試

  1. //測試使用雪花算法生成ID 
  2. //構造函數中傳入datacenterId和workerId 
  3. SnowFlake snowFlake = new SnowFlake(1,1); 
  4. for (int i = 0; i < 10; i++) { 
  5.     long id = snowFlake.nextId(); 
  6.     System.out.println("id:" + id + "\t" + String.valueOf(id).length() + "位"); 
  7.     System.out.println("------------------------------------------"); 

Spring Boot整合雪花算法

引入hutool-all,maven依賴引入如下:

  1. <dependencies> 
  2.     <dependency> 
  3.         <groupId>cn.hutool</groupId> 
  4.         <artifactId>hutool-all</artifactId> 
  5.         <version>5.4.2</version> 
  6.     </dependency> 
  7.     <dependency> 
  8.         <groupId>org.springframework.boot</groupId> 
  9.         <artifactId>spring-boot-starter-web</artifactId> 
  10.         <version>2.2.1.RELEASE</version> 
  11.     </dependency> 
  12.     <dependency> 
  13.         <groupId>org.projectlombok</groupId> 
  14.         <artifactId>lombok</artifactId> 
  15.         <version>1.18.16</version> 
  16.     </dependency> 
  17. </dependencies> 

 

 

創建一個SnowFlake配置類

  1. @Configuration 
  2. public class SnowFlakeConfig { 
  3.     @Value("${application.datacenterId}"
  4.     private Long datacenterId; 
  5.     @Value("${application.workerId}"
  6.     private Long workerId; 
  7.  
  8.     /*** 
  9.      * 注入一個生成雪花ID的對象 
  10.      * @return 
  11.      */ 
  12.     @Bean 
  13.     public Snowflake snowflake() { 
  14.         return new Snowflake(workerId,datacenterId); 
  15.     } 

yml配置文件:

  1. application: 
  2.   datacenterId: 2 
  3.   workerId: 1 
  4. server: 
  5.   port: 7777 

service 層:

  1. @Service 
  2. public class OrderService { 
  3.     @Autowired 
  4.     private Snowflake snowflake; 
  5.  
  6.     public String getIdBySnowFlake() { 
  7.         return String.valueOf(snowflake.nextId()); 
  8.     } 

其他開源的解決方案

很多大廠都對雪花算法做出了改進,開源了一些改進方案,如下:

 

  • 百度開源的分布式唯一ID生成器UidGenerator
  • Leaf–美團點評分布式ID生成系統

 

責任編輯:武曉燕 來源: 無聊學Java
相關推薦

2025-03-28 10:27:29

2022-06-16 07:31:15

MySQL服務器服務

2019-05-13 09:20:02

京東云RedisMongoDB

2024-01-31 22:08:18

分布式重試框架

2023-03-05 18:23:38

分布式ID節點

2023-03-01 08:07:51

2021-07-07 07:14:48

分布式ID分布式系統

2024-11-19 15:55:49

2021-02-02 16:37:25

Redis分布式

2021-06-05 07:33:09

ID分布式架構

2017-07-01 16:02:39

分布式ID生成器

2021-05-08 08:01:05

Session登錄瀏覽器

2022-02-10 08:57:45

分布式線程鎖

2023-01-12 17:46:37

分庫分表id如何生成

2020-06-02 14:45:48

PostgreSQL架構分布式

2021-01-19 05:43:33

分布式2PC3PC

2019-09-05 13:06:08

雪花算法分布式ID

2024-01-10 08:02:03

分布式技術令牌,

2022-08-01 08:01:04

ID發號器系統

2017-06-19 17:55:22

CASID分布式
點贊
收藏

51CTO技術棧公眾號

亚洲国产成人av网| 国产精品一区二区久久精品爱涩| 亚洲女人天堂色在线7777| 日本精品久久久久中文字幕| 97在线观看免费观看高清| 精品影视av免费| 久久久久久尹人网香蕉| jizz欧美性20| 成人国产精品久久| 天天色天天操综合| 亚洲一区二区三区乱码| 亚洲av少妇一区二区在线观看| 亚洲在线观看| 日韩中文字幕网址| 一区二区在线免费观看视频| 欧美二三四区| 亚洲永久免费av| 日韩国产欧美一区| 欧美熟妇交换久久久久久分类 | 日韩视频永久免费观看| 白嫩情侣偷拍呻吟刺激| 国产福利一区二区三区在线播放| 亚洲国产你懂的| 中文网丁香综合网| 免费黄色在线视频网站| 国产成人精品一区二区三区网站观看| 欧洲一区二区视频| 国产一级片久久| 久久一级电影| 国产午夜精品一区二区三区| 800av在线播放| 国产免费区一区二区三视频免费| 在线精品观看国产| 欧美一级视频免费看| 国产成人无吗| 国产精品高潮久久久久无| 国产伦精品一区二区三区视频孕妇 | 国产精品入口尤物| 国产又大又黄又粗| 亚洲福利电影| 欧美极品少妇xxxxⅹ裸体艺术| 欧美一区二区三区公司| 久久黄色片视频| a篇片在线观看网站| 中文子幕无线码一区tr| 欧美一区二区影视| 偷拍自拍在线| 成人动漫一区二区在线| 亚洲综合中文字幕在线观看| 夜夜躁很很躁日日躁麻豆| 久热精品在线| 26uuu另类亚洲欧美日本老年| www.av视频在线观看| 欧美日韩国产欧| 久久99亚洲热视| 午夜免费激情视频| 一区二区三区午夜视频| 精品国产一区av| 在线观看美女av| 亚洲欧美综合久久久| 久久久99免费视频| 东方av正在进入| 艳女tv在线观看国产一区| 久久久国产成人精品| 成人免费视频国产免费观看| 综合亚洲视频| 97精品国产aⅴ7777| 欧美bbbbbbbbbbbb精品| 亚洲免费婷婷| 日本老师69xxx| 五月婷婷激情五月| 日本va欧美va欧美va精品| 国产精品高精视频免费| 亚洲中文字幕在线观看| 韩国成人福利片在线播放| 亚洲字幕在线观看| 欧美一级片免费| 91性感美女视频| 日本欧洲国产一区二区| 尤物视频在线免费观看| 亚洲品质自拍视频| 僵尸世界大战2 在线播放| 忘忧草在线影院两性视频| 色噜噜狠狠色综合欧洲selulu| 在线观看的毛片| 国产精品1区| 亚洲成人黄色在线观看| 全黄一级裸体片| 久久一区二区三区电影| 欧美国产极速在线| 7799精品视频天天看| 老司机精品视频在线| 99久热re在线精品996热视频| 免费的黄色av| 中文乱码免费一区二区| av动漫在线播放| 激情都市亚洲| 日韩午夜中文字幕| 成人精品999| 欧美成人69| 97久久精品人人澡人人爽缅北| 男人的天堂av网站| 国产乱理伦片在线观看夜一区| 不卡一区二区三区四区五区| 九色蝌蚪在线| 亚洲综合色婷婷| 黄色av免费在线播放| 免费一区二区三区在线视频| 亚洲精品第一国产综合精品| 香蕉成人在线视频| 亚洲少妇诱惑| 亚洲wwwav| 精品欧美不卡一区二区在线观看| 亚洲免费观看高清完整版在线| 国产最新免费视频| 欧洲精品99毛片免费高清观看 | 国产精自产拍久久久久久蜜| 丰满熟妇人妻中文字幕| 欧美国产日韩在线观看| 91免费黄视频| 老司机亚洲精品一区二区| 亚洲人成电影网站| 亚洲一区 视频| 精品一区二区国语对白| 日本不卡免费新一二三区| 金瓶狂野欧美性猛交xxxx| 欧美美女bb生活片| 老熟妇一区二区| 国产偷自视频区视频一区二区| 99国产在线| 日本美女在线中文版| 在线精品视频小说1| av网站免费在线播放| 亚洲无线视频| 成人福利视频在线观看| 国产二区在线播放| 色婷婷综合久久久久中文 | 国产精品成人午夜| 国产欧美高清在线| 久久久免费毛片| 精品中文字幕在线2019| 国产精品自偷自拍| 中文字幕在线不卡国产视频| 熟妇人妻无乱码中文字幕真矢织江| 国产精品黄网站| 欧美精品www| 亚洲av无码国产综合专区| 亚洲欧美一区二区三区孕妇| 午夜视频在线网站| 91亚洲成人| 成人高清视频观看www| 日韩三级影院| 欧美精品久久99| 亚洲波多野结衣| 国产一区在线不卡| 黄色一级视频播放| 国产剧情一区二区在线观看| 欧美美女操人视频| 亚洲成人一级片| 亚洲成在线观看| 中国一级特黄录像播放| 国产亚洲激情| 欧美成熟毛茸茸复古| 丝袜诱惑一区二区| 亚洲免费电影在线观看| 国产精品成人久久久| 国产精品久久久久aaaa樱花 | 成人中文字幕电影| 成人黄色大片网站| 天堂综合网久久| 国产成人欧美在线观看| 在线观看国产原创自拍视频| 这里只有精品99re| 久久久久久国产精品免费播放| 成人avav影音| 无码人妻丰满熟妇区五十路百度| 欧美一二区在线观看| 成人羞羞国产免费| 黄色小说在线播放| 亚洲精品在线视频| 中文在线字幕av| 一区二区三区精品久久久| 中国一级特黄录像播放| 男男成人高潮片免费网站| 宅男一区二区三区| 91精品入口| 日韩美女视频在线观看| 麻豆网在线观看| 亚洲成人激情在线| 尤物视频免费观看| 亚洲精品国产品国语在线app| 在线免费看黄色片| 日韩激情中文字幕| 欧美中日韩在线| 欧洲乱码伦视频免费| 97视频热人人精品| 成人福利av| 九九热这里只有精品6| 精品久久久久一区二区三区| 日韩一级黄色大片| 国模叶桐国产精品一区| 日本精品福利视频| 巨人精品**| 国产精品成av人在线视午夜片| 香蕉视频网站在线观看| 欧美精品久久99| 在线观看亚洲欧美| 国产日产欧美一区| 9191在线视频| 美女mm1313爽爽久久久蜜臀| 无码粉嫩虎白一线天在线观看 | 精品网站在线看| 亚洲伊人精品酒店| 日本一欧美一欧美一亚洲视频| 久久久久久久中文| 久久99免费视频| 动漫3d精品一区二区三区 | 精品国产老师黑色丝袜高跟鞋| 男人天堂资源网| 91亚洲精品乱码久久久久久蜜桃| 波多野结衣免费观看| 日韩国产欧美在线视频| 国产免费黄色av| 欧美日韩国产探花| 一区二区在线不卡| 欧美猛男同性videos| 国产高清在线一区二区| 国产中文欧美日韩在线| 国产精品一区二区三| 在线中文字幕播放| 午夜精品久久久久久久99热浪潮| а√中文在线8| 丝袜一区二区三区| 国产区视频在线| 精品网站999www| 黑人精品一区二区| 欧美一区二区美女| 国产精品久久久久久69| 欧美日韩亚洲丝袜制服| 久久久久久久久久成人| 黄色成人在线播放| 日本熟伦人妇xxxx| 亚洲一区在线视频| 玖玖爱免费视频| 亚洲欧美另类小说| chinese全程对白| 中文字幕日韩一区| 911国产在线| 国产精品乱人伦一区二区| 女人十八毛片嫩草av| 国产欧美精品一区二区色综合 | 青草久久视频| 韩国精品一区二区三区六区色诱| 久久婷婷国产| 国产一区精品视频| 好吊妞视频这里有精品| 国产精品自拍首页| 精品亚洲精品| 久久久久久99| 精品在线观看入口| 亚洲国产欧洲综合997久久| 成人激情视频| 中文字幕一区二区三区乱码 | 国产精品宾馆在线精品酒店| 亚洲专区一区| 在线免费视频a| 精品一区在线看| 色哟哟网站在线观看| jvid福利写真一区二区三区| 熟妇高潮精品一区二区三区| 久久久国产一区二区三区四区小说| 精品国产成人亚洲午夜福利| 国产精品久久久久久户外露出| 国产大片免费看| 五月天中文字幕一区二区| 丁香六月婷婷综合| 欧美亚洲一区二区在线| a级片免费观看| 亚洲精品久久久久中文字幕二区| 毛片网站在线观看| 久久精品人人做人人爽| 成人免费高清观看| 国产不卡在线观看| 国产精品一级在线观看| 国产一区二区三区四区hd| 久久99视频| av动漫在线免费观看| 久久免费国产| 女人扒开双腿让男人捅 | 久久精品国产美女| 久久视频在线| 日韩精品xxxx| 久久超碰97中文字幕| 中文成人无字幕乱码精品区| 国产精品久久久久天堂| 国产一级淫片免费| 欧美日韩日日骚| 天天干天天干天天干| 最近2019年中文视频免费在线观看 | 国产无遮挡又黄又爽又色视频| 制服丝袜日韩国产| 韩国三级av在线免费观看| 欧美日本精品在线| 成人午夜sm精品久久久久久久| 成人自拍爱视频| 色135综合网| 青青在线视频观看| 国产激情一区二区三区桃花岛亚洲| 国产精品密蕾丝袜| 亚洲国产成人91porn| 91丨porny丨在线中文| 亚洲久久久久久久久久久| 成人免费视屏| 国产精品久久久久久久久久久久久久 | 丁香花视频在线观看| 国产精品视频免费观看www| 国产无遮挡裸体免费久久| 国产高清精品软男同| 天堂蜜桃一区二区三区| 你懂的在线观看网站| 一区二区三区中文在线观看| 在线观看xxxx| 亚洲色图偷窥自拍| 一个人www视频在线免费观看| av一区二区在线看| 中文字幕一区二区三区久久网站| 天天干天天干天天干天天干天天干| www.亚洲激情.com| 国产亚洲欧美精品久久久www| 欧美丰满高潮xxxx喷水动漫| 成人在线免费视频| 日韩免费精品视频| 欧美中文一区| 福利视频免费在线观看| 国产福利一区二区三区| 日本精品人妻无码77777| 欧美日韩精品二区第二页| 国产在线色视频| 日韩av第一页| 视频一区在线观看| 99热成人精品热久久66| 97aⅴ精品视频一二三区| 国产精品不卡av| 亚洲第一福利网| av影院在线| 国产欧美丝袜| 99精品欧美| 亚洲黄色免费在线观看| 性做久久久久久免费观看欧美| 粉嫩av一区二区夜夜嗨| 欧美激情网友自拍| 国产劲爆久久| 亚洲美免无码中文字幕在线| 99久久99久久精品免费观看| 一区二区三区福利视频| 亚洲美女自拍视频| 亚洲欧美在线成人| 一本一道久久久a久久久精品91| 久久精品久久99精品久久| 一级性生活免费视频| 欧美一级高清大全免费观看| 欧美另类tv| 精品视频在线观看| 日韩电影免费在线| 成人一级黄色大片| 欧美xxxxx牲另类人与| cao在线视频| 欧美精品一区二区三区在线看午夜 | 波多野结衣天堂| 国产精品国产三级国产aⅴ入口 | 黄频视频在线观看| 国产成人亚洲精品狼色在线| 日本网站在线免费观看| 亚洲欧美日韩区| 亚州精品国产| 国产 欧美 日韩 一区| 99久久精品国产一区二区三区 | 欧美伦理一区二区| 青青草国产精品亚洲专区无| 一级片一级片一级片| 亚洲电影免费观看高清完整版在线观看| 乱人伦视频在线| 天天好比中文综合网| 国产另类ts人妖一区二区| 日本在线视频免费观看| 国产一区二区三区丝袜| 亚洲一级大片| 日日摸天天爽天天爽视频| 亚洲天堂精品视频| 日韩一级免费视频| 国产精品极品美女在线观看免费| 亚洲欧美综合久久久| 中文在线永久免费观看| 欧美日韩黄色影视| 国产v日韩v欧美v| 亚洲欧美日韩国产yyy| 99视频有精品| 国产毛片在线视频| 日韩av免费看| 欧美日一区二区在线观看 |