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

面試不用愁!5分鐘完全掌握Redis

數據庫 其他數據庫 Redis
基于這些基礎的數據結構,redis封裝了自己的對象系統,包含字符串對象string、列表對象list、哈希對象hash、集合對象set、有序集合對象zset,每種對象都用到了至少一種基礎的數據結構。

[[348690]]

Redis基本數據類型

    1.  字符串:redis沒有直接使用C語言傳統的字符串表示,而是自己實現的叫做簡單動態字符串SDS的抽象類型。C語言的字符串不記錄自身的長度信息,而SDS則保存了長度信息,這樣將獲取字符串長度的時間由O(N)降低到了O(1),同時可以避免緩沖區溢出和減少修改字符串長度時所需的內存重分配次數。

    2.  鏈表linkedlist:redis鏈表是一個雙向無環鏈表結構,很多發布訂閱、慢查詢、監視器功能都是使用到了鏈表來實現,每個鏈表的節點由一個listNode結構來表示,每個節點都有指向前置節點和后置節點的指針,同時表頭節點的前置和后置節點都指向NULL。

    3.  字典hashtable:用于保存鍵值對的抽象數據結構。redis使用hash表作為底層實現,每個字典帶有兩個hash表,供平時使用和rehash時使用,hash表使用鏈地址法來解決鍵沖突,被分配到同一個索引位置的多個鍵值對會形成一個單向鏈表,在對hash表進行擴容或者縮容的時候,為了服務的可用性,rehash的過程不是一次性完成的,而是漸進式的。

    4.  跳躍表skiplist:跳躍表是有序集合的底層實現之一,redis中在實現有序集合鍵和集群節點的內部結構中都是用到了跳躍表。redis跳躍表由zskiplist和zskiplistNode組成,zskiplist用于保存跳躍表信息(表頭、表尾節點、長度等),zskiplistNode用于表示表跳躍節點,每個跳躍表的層高都是1-32的隨機數,在同一個跳躍表中,多個節點可以包含相同的分值,但是每個節點的成員對象必須是唯一的,節點按照分值大小排序,如果分值相同,則按照成員對象的大小排序。

    5.  整數集合intset:用于保存整數值的集合抽象數據結構,不會出現重復元素,底層實現為數組。

    6.  壓縮列表ziplist:壓縮列表是為節約內存而開發的順序性數據結構,他可以包含多個節點,每個節點可以保存一個字節數組或者整數值。

基于這些基礎的數據結構,redis封裝了自己的對象系統,包含字符串對象string、列表對象list、哈希對象hash、集合對象set、有序集合對象zset,每種對象都用到了至少一種基礎的數據結構。

redis通過encoding屬性設置對象的編碼形式來提升靈活性和效率,基于不同的場景redis會自動做出優化。不同對象的編碼如下:

  1.  字符串對象string:int整數、embstr編碼的簡單動態字符串、raw簡單動態字符串
  2.  列表對象list:ziplist、linkedlist
  3.  哈希對象hash:ziplist、hashtable
  4.  集合對象set:intset、hashtable
  5.  有序集合對象zset:ziplist、skiplist

Redis為什么快呢?

redis的速度非常的快,單機的redis就可以支撐每秒10幾萬的并發,相對于mysql來說,性能是mysql的幾十倍。速度快的原因主要有幾點:

  1.  完全基于內存操作
  2.  C語言實現,優化過的數據結構,基于幾種基礎的數據結構,redis做了大量的優化,性能極高
  3.  使用單線程,無上下文的切換成本
  4.  基于非阻塞的IO多路復用機制

那為什么Redis6.0之后又改用多線程呢?

redis使用多線程并非是完全摒棄單線程,redis還是使用單線程模型來處理客戶端的請求,只是使用多線程來處理數據的讀寫和協議解析,執行命令還是使用單線程。

這樣做的目的是因為redis的性能瓶頸在于網絡IO而非CPU,使用多線程能提升IO讀寫的效率,從而整體提高redis的性能。

知道什么是熱key嗎?熱key問題怎么解決?

所謂熱key問題就是,突然有幾十萬的請求去訪問redis上的某個特定key,那么這樣會造成流量過于集中,達到物理網卡上限,從而導致這臺redis的服務器宕機引發雪崩。

針對熱key的解決方案:

  1.  提前把熱key打散到不同的服務器,降低壓力
  2.  加入二級緩存,提前加載熱key數據到內存中,如果redis宕機,走內存查詢

什么是緩存擊穿、緩存穿透、緩存雪崩?

緩存擊穿

緩存擊穿的概念就是單個key并發訪問過高,過期時導致所有請求直接打到db上,這個和熱key的問題比較類似,只是說的點在于過期導致請求全部打到DB上而已。

解決方案:

  1.  加鎖更新,比如請求查詢A,發現緩存中沒有,對A這個key加鎖,同時去數據庫查詢數據,寫入緩存,再返回給用戶,這樣后面的請求就可以從緩存中拿到數據了。
  2.  將過期時間組合寫在value中,通過異步的方式不斷的刷新過期時間,防止此類現象。

https://tva

緩存穿透

緩存穿透是指查詢不存在緩存中的數據,每次請求都會打到DB,就像緩存不存在一樣。

針對這個問題,加一層布隆過濾器。布隆過濾器的原理是在你存入數據的時候,會通過散列函數將它映射為一個位數組中的K個點,同時把他們置為1。

這樣當用戶再次來查詢A,而A在布隆過濾器值為0,直接返回,就不會產生擊穿請求打到DB了。

顯然,使用布隆過濾器之后會有一個問題就是誤判,因為它本身是一個數組,可能會有多個值落到同一個位置,那么理論上來說只要我們的數組長度夠長,誤判的概率就會越低,這種問題就根據實際情況來就好了。

緩存雪崩

當某一時刻發生大規模的緩存失效的情況,比如你的緩存服務宕機了,會有大量的請求進來直接打到DB上,這樣可能導致整個系統的崩潰,稱為雪崩。雪崩和擊穿、熱key的問題不太一樣的是,他是指大規模的緩存都過期失效了。

針對雪崩幾個解決方案:

  1.  針對不同key設置不同的過期時間,避免同時過期
  2.  限流,如果redis宕機,可以限流,避免同時刻大量請求打崩DB
  3.  二級緩存,同熱key的方案。

Redis的過期策略有哪些?

redis主要有2種過期刪除策略

惰性刪除

惰性刪除指的是當我們查詢key的時候才對key進行檢測,如果已經達到過期時間,則刪除。顯然,他有一個缺點就是如果這些過期的key沒有被訪問,那么他就一直無法被刪除,而且一直占用內存。

定期刪除

定期刪除指的是redis每隔一段時間對數據庫做一次檢查,刪除里面的過期key。由于不可能對所有key去做輪詢來刪除,所以redis會每次隨機取一些key去做檢查和刪除。

那么定期+惰性都沒有刪除過期的key怎么辦?

假設redis每次定期隨機查詢key的時候沒有刪掉,這些key也沒有做查詢的話,就會導致這些key一直保存在redis里面無法被刪除,這時候就會走到redis的內存淘汰機制。

  1.  volatile-lru:從已設置過期時間的key中,移出最近最少使用的key進行淘汰
  2.  volatile-ttl:從已設置過期時間的key中,移出將要過期的key
  3.  volatile-random:從已設置過期時間的key中隨機選擇key淘汰
  4.  allkeys-lru:從key中選擇最近最少使用的進行淘汰
  5.  allkeys-random:從key中隨機選擇key進行淘汰
  6.  noeviction:當內存達到閾值的時候,新寫入操作報錯

持久化方式有哪些?有什么區別?

redis持久化方案分為RDB和AOF兩種。

RDB

RDB持久化可以手動執行也可以根據配置定期執行,它的作用是將某個時間點上的數據庫狀態保存到RDB文件中,RDB文件是一個壓縮的二進制文件,通過它可以還原某個時刻數據庫的狀態。由于RDB文件是保存在硬盤上的,所以即使redis崩潰或者退出,只要RDB文件存在,就可以用它來恢復還原數據庫的狀態。

可以通過SAVE或者BGSAVE來生成RDB文件。

SAVE命令會阻塞redis進程,直到RDB文件生成完畢,在進程阻塞期間,redis不能處理任何命令請求,這顯然是不合適的。

BGSAVE則是會fork出一個子進程,然后由子進程去負責生成RDB文件,父進程還可以繼續處理命令請求,不會阻塞進程。

AOF

AOF和RDB不同,AOF是通過保存redis服務器所執行的寫命令來記錄數據庫狀態的。

AOF通過追加、寫入、同步三個步驟來實現持久化機制。

  •  當AOF持久化處于激活狀態,服務器執行完寫命令之后,寫命令將會被追加append到aof_buf緩沖區的末尾
  •  在服務器每結束一個事件循環之前,將會調用flushAppendOnlyFile函數決定是否要將aof_buf的內容保存到AOF文件中,可以通過配置appendfsync來決定。 
  1. always ##aof_buf內容寫入并同步到AOF文件  
  2. everysec ##將aof_buf中內容寫入到AOF文件,如果上次同步AOF文件時間距離現在超過1秒,則再次對AOF文件進行同步  
  3. no ##將aof_buf內容寫入AOF文件,但是并不對AOF文件進行同步,同步時間由操作系統決定  

如果不設置,默認選項將會是everysec,因為always來說雖然最安全(只會丟失一次事件循環的寫命令),但是性能較差,而everysec模式只不過會可能丟失1秒鐘的數據,而no模式的效率和everysec相仿,但是會丟失上次同步AOF文件之后的所有寫命令數據。

怎么實現Redis的高可用?

要想實現高可用,一臺機器肯定是不夠的,而redis要保證高可用,有2個可選方案。

主從架構

主從模式是最簡單的實現高可用的方案,核心就是主從同步。主從同步的原理如下:

  1.  slave發送sync命令到master
  2.  master收到sync之后,執行bgsave,生成RDB全量文件
  3.  master把slave的寫命令記錄到緩存
  4.  bgsave執行完畢之后,發送RDB文件到slave,slave執行
  5.  master發送緩存中的寫命令到slave,slave執行

這里我寫的這個命令是sync,但是在redis2.8版本之后已經使用psync來替代sync了,原因是sync命令非常消耗系統資源,而psync的效率更高。

哨兵

基于主從方案的缺點還是很明顯的,假設master宕機,那么就不能寫入數據,那么slave也就失去了作用,整個架構就不可用了,除非你手動切換,主要原因就是因為沒有自動故障轉移機制。而哨兵(sentinel)的功能比單純的主從架構全面的多了,它具備自動故障轉移、集群監控、消息通知等功能。

哨兵可以同時監視多個主從服務器,并且在被監視的master下線時,自動將某個slave提升為master,然后由新的master繼續接收命令。整個過程如下:

  1.  初始化sentinel,將普通的redis代碼替換成sentinel專用代碼
  2.  初始化masters字典和服務器信息,服務器信息主要保存ip:port,并記錄實例的地址和ID
  3.  創建和master的兩個連接,命令連接和訂閱連接,并且訂閱sentinel:hello頻道
  4.  每隔10秒向master發送info命令,獲取master和它下面所有slave的當前信息
  5.  當發現master有新的slave之后,sentinel和新的slave同樣建立兩個連接,同時每個10秒發送info命令,更新master信息
  6.  sentinel每隔1秒向所有服務器發送ping命令,如果某臺服務器在配置的響應時間內連續返回無效回復,將會被標記為下線狀態
  7.  選舉出領頭sentinel,領頭sentinel需要半數以上的sentinel同意
  8.  領頭sentinel從已下線的的master所有slave中挑選一個,將其轉換為master
  9.  讓所有的slave改為從新的master復制數據
  10.  將原來的master設置為新的master的從服務器,當原來master重新回復連接時,就變成了新master的從服務器

sentinel會每隔1秒向所有實例(包括主從服務器和其他sentinel)發送ping命令,并且根據回復判斷是否已經下線,這種方式叫做主觀下線。當判斷為主觀下線時,就會向其他監視的sentinel詢問,如果超過半數的投票認為已經是下線狀態,則會標記為客觀下線狀態,同時觸發故障轉移。

能說說redis集群的原理嗎?

如果說依靠哨兵可以實現redis的高可用,如果還想在支持高并發同時容納海量的數據,那就需要redis集群。redis集群是redis提供的分布式數據存儲方案,集群通過數據分片sharding來進行數據的共享,同時提供復制和故障轉移的功能。

節點

一個redis集群由多個節點node組成,而多個node之間通過cluster meet命令來進行連接,節點的握手過程:

  1.  節點A收到客戶端的cluster meet命令
  2.  A根據收到的IP地址和端口號,向B發送一條meet消息
  3.  節點B收到meet消息返回pong
  4.  A知道B收到了meet消息,返回一條ping消息,握手成功
  5.  最后,節點A將會通過gossip協議把節點B的信息傳播給集群中的其他節點,其他節點也將和B進行握手

槽slot

redis通過集群分片的形式來保存數據,整個集群數據庫被分為16384個slot,集群中的每個節點可以處理0-16384個slot,當數據庫16384個slot都有節點在處理時,集群處于上線狀態,反之只要有一個slot沒有得到處理都會處理下線狀態。通過cluster addslots命令可以將slot指派給對應節點處理。

slot是一個位數組,數組的長度是16384/8=2048,而數組的每一位用1表示被節點處理,0表示不處理,如圖所示的話表示A節點處理0-7的slot。

當客戶端向節點發送命令,如果剛好找到slot屬于當前節點,那么節點就執行命令,反之,則會返回一個MOVED命令到客戶端指引客戶端轉向正確的節點。(MOVED過程是自動的)

如果增加或者移出節點,對于slot的重新分配也是非常方便的,redis提供了工具幫助實現slot的遷移,整個過程是完全在線的,不需要停止服務。

故障轉移

如果節點A向節點B發送ping消息,節點B沒有在規定的時間內響應pong,那么節點A會標記節點B為pfail疑似下線狀態,同時把B的狀態通過消息的形式發送給其他節點,如果超過半數以上的節點都標記B為pfail狀態,B就會被標記為fail下線狀態,此時將會發生故障轉移,優先從復制數據較多的從節點選擇一個成為主節點,并且接管下線節點的slot,整個過程和哨兵非常類似,都是基于Raft協議做選舉。

了解Redis事務機制嗎?

redis通過MULTI、EXEC、WATCH等命令來實現事務機制,事務執行過程將一系列多個命令按照順序一次性執行,并且在執行期間,事務不會被中斷,也不會去執行客戶端的其他請求,直到所有命令執行完畢。事務的執行過程如下:

  1.  服務端收到客戶端請求,事務以MULTI開始
  2.  如果客戶端正處于事務狀態,則會把事務放入隊列同時返回給客戶端QUEUED,反之則直接執行這個命令
  3.  當收到客戶端EXEC命令時,WATCH命令監視整個事務中的key是否有被修改,如果有則返回空回復到客戶端表示失敗,否則redis會遍歷整個事務隊列,執行隊列中保存的所有命令,最后返回結果給客戶端

WATCH的機制本身是一個CAS的機制,被監視的key會被保存到一個鏈表中,如果某個key被修改,那么REDIS_DIRTY_CAS標志將會被打開,這時服務器會拒絕執行事務。 

 

責任編輯:龐桂玉 來源: Python中文社區
相關推薦

2020-12-17 10:00:16

Python協程線程

2020-12-07 11:23:32

Scrapy爬蟲Python

2021-03-23 15:35:36

Adam優化語言

2021-03-12 09:45:00

Python關聯規則算法

2021-01-29 11:25:57

Python爬山算法函數優化

2017-01-10 09:07:53

tcpdumpGET請求

2010-11-03 11:01:05

求職面試

2019-12-26 09:52:33

Redis集群線程

2009-11-17 14:50:50

Oracle調優

2021-06-07 09:51:22

原型模式序列化

2020-11-24 11:50:52

Python文件代碼

2021-04-19 23:29:44

MakefilemacOSLinux

2018-01-30 05:04:06

2020-12-01 12:44:44

PythonHook鉤子函數

2021-06-06 13:08:22

C#特性Attribute

2012-06-28 10:26:51

Silverlight

2025-01-24 08:38:47

2020-09-11 09:35:18

前端JavaScript策略模式

2021-04-27 10:16:51

優化機器學習人工智能

2021-01-11 09:33:37

Maven數目項目
點贊
收藏

51CTO技術棧公眾號

国产98色在线|日韩| 国产精品99久久| 色播五月激情综合网| 日韩理论片在线观看| 亚洲熟女乱色一区二区三区久久久 | 福利微拍一区二区| 亚洲免费精品视频| 精品久久久久中文慕人妻| 亚洲最黄网站| 色av吧综合网| 国产精品久久久久久亚洲av| 91九色综合| 亚洲狠狠爱一区二区三区| 日本不卡一区| 欧美在线精品一区二区三区| 久久aⅴ国产欧美74aaa| 国产69久久精品成人看| www欧美com| 国产一区三区在线播放| 日韩区在线观看| 日韩av播放器| 91超碰国产在线| 国产精品嫩草影院com| 国产在线精品一区二区三区| 91尤物国产福利在线观看| a91a精品视频在线观看| 欧美精品在线免费| 成熟人妻av无码专区| 久久精品凹凸全集| 日韩免费高清av| 爱爱爱爱免费视频| 好久没做在线观看| 一区二区三区在线观看动漫| 欧美亚洲丝袜| 深夜福利在线看| 成人免费视频免费观看| 91国产丝袜在线放| 国产精品一区二区人人爽| 免费成人美女在线观看.| 97在线精品视频| 日本三级免费看| 欧美激情aⅴ一区二区三区| 日韩资源在线观看| 你懂得视频在线观看| 国产99久久久国产精品成人免费| 亚洲的天堂在线中文字幕| 秋霞午夜鲁丝一区二区| 精品91福利视频| 制服丝袜av成人在线看| 波多野结衣国产精品| 欧美亚洲福利| 91精品国产综合久久久蜜臀图片| 91毛片在线观看| 青青久久av北条麻妃海外网| 91午夜视频在线观看| 亚洲免费精品| 欧美自拍视频在线观看| 无码任你躁久久久久久久| 久久久亚洲人| 国产精品久久久久久久久久久久| 艳妇乳肉豪妇荡乳av无码福利 | 日韩av不卡电影| 黄色av网站免费观看| 日韩 欧美一区二区三区| 国产成人精品在线| 一起草av在线| 国产成人午夜精品影院观看视频 | 国产精品久久在线观看| 亚洲一卡二卡在线观看| 国内精品写真在线观看| av蓝导航精品导航| 神马久久久久久久久久| 国产婷婷精品av在线| 亚洲综合网中心| 在线不卡日本v二区707| 精品久久久久久久久久| 波多野结衣天堂| 高清久久一区| 亚洲第一天堂av| 国产av自拍一区| 91成人观看| 97香蕉超级碰碰久久免费的优势| 欧美成人精品网站| 国产成人综合在线观看| 国产精品theporn88| 国模私拍视频在线| 久久久噜噜噜久噜久久综合| 综合国产精品久久久| 二区三区在线观看| 欧美日韩亚洲一区二区| 亚洲欧美自偷自拍另类| 国产精品自在线拍| 伊人伊成久久人综合网站| 91杏吧porn蝌蚪| 久久久久久久久久影视| 欧美午夜在线播放| 亚洲精品99久久久久中文字幕| 蜜桃av乱码一区二区三区| 欧美精品aa| 国产z一区二区三区| 99热这里只有精品1| 91麻豆.com| 中文字幕精品在线播放| 美女福利一区二区| 欧美一区二区三区在线视频| 国产美女精品久久| 午夜久久99| 国产精品久久久久久av| 高h放荡受浪受bl| 国产精品国产三级国产aⅴ原创 | 久久久香蕉视频| 快she精品国产999| 高清视频一区| 日本不卡在线| 日韩欧美在线视频观看| 国产精久久久久| 天天综合网91| 国产精品久久久久av免费| 色一情一乱一乱一区91av| 自拍偷拍国产亚洲| 欧美性猛交xxx乱久交| 大陆精大陆国产国语精品| 日韩在线视频免费观看高清中文| aaaaaa毛片| 北条麻妃国产九九精品视频| 免费在线精品视频| 国产香蕉久久| 国产亚洲xxx| 日本熟女毛茸茸| 99久久婷婷国产精品综合| 日本大胆人体视频| 一级欧美视频| 日韩视频免费看| 亚洲av无码乱码国产精品fc2| 99精品黄色片免费大全| 久久久久99精品成人片| 欧洲大片精品免费永久看nba| 日韩专区在线播放| 中文字幕在线播出| 中文一区一区三区高中清不卡| 久久久免费视频网站| 亲子伦视频一区二区三区| 国内免费精品永久在线视频| 性欧美videos另类hd| 亚洲精品中文字幕在线观看| 在线视频观看91| 99久久精品费精品国产| 国产精品中文在线| 欧美18一19xxx性| 欧美人成免费网站| 日本 欧美 国产| 国产一区二区三区四| 91社在线播放| 视频二区欧美| 韩国v欧美v日本v亚洲| 无码h黄肉3d动漫在线观看| 亚洲一区免费观看| 久久久久久婷婷| 国产精品久久777777毛茸茸 | 天天做天天爱天天综合网| 国产精品美乳在线观看| 欧美69xxx| 精品免费视频一区二区| 自拍偷拍欧美亚洲| 久久免费美女视频| 性欧美videossex精品| 日韩情爱电影在线观看| 91深夜福利视频| heyzo中文字幕在线| 亚洲精品久久久久久久久久久 | bl视频在线免费观看| 日韩风俗一区 二区| www.亚洲激情| 一区二区三区在线不卡| 亚洲色图14p| 日本女人一区二区三区| 日本a级片在线观看| 日韩精品社区| 国产日韩在线看片| 懂色av一区| 国产亚洲一区二区在线| 国产日韩欧美一区二区东京热| 亚洲一区免费在线观看| 日本黄色特级片| 精久久久久久久久久久| 亚洲色成人www永久在线观看| 亚州综合一区| 成人做爽爽免费视频| 啊啊啊久久久| 最近2019中文免费高清视频观看www99 | 亚洲优女在线| 久久精品国产亚洲一区二区| 日韩一区免费视频| 欧美三级韩国三级日本一级| 男女免费视频网站| 国产欧美日产一区| 国产性猛交96| 免费av网站大全久久| 国产日韩欧美精品在线观看| 成人羞羞网站入口免费| 动漫一区二区在线| 国产精品99| 97在线视频免费播放| 精品国产99久久久久久| 日韩精品视频免费| 国产av无码专区亚洲av| 在线视频观看一区| 国产极品在线播放| 一区免费观看视频| 中文字幕国产综合| 成人少妇影院yyyy| 黄色片免费网址| 日本欧洲一区二区| 超碰97人人射妻| 激情综合网址| 亚洲国产一二三精品无码| 日韩精品1区| 欧美一区1区三区3区公司 | 大桥未久一区二区| 少妇精品久久久一区二区三区 | 婷婷激情5月天| 日韩电影在线一区| 日本精品免费在线观看| 亚洲婷婷免费| 樱花www成人免费视频| 国产中文精品久高清在线不| 国产在线精品一区二区三区》| 日韩精品成人在线观看| 91久久久久久久久| 欧美性aaa| 91精品久久久久久久久久久久久久| jizz内谢中国亚洲jizz| 97视频在线观看视频免费视频| 黄色免费在线观看网站| 中文字幕在线看视频国产欧美在线看完整| 水莓100在线视频| 亚洲精品美女久久| 少妇荡乳情欲办公室456视频| 精品蜜桃在线看| 亚洲美女综合网| 精品国产一区二区三区av性色 | 亚洲男人天堂古典| 酒色婷婷桃色成人免费av网| 日韩精品免费看| 免费毛片在线| 亚洲视频精品在线| 国产精品麻豆一区二区三区| 亚洲系列中文字幕| 91这里只有精品| 日韩在线视频一区| 黄色网在线播放| 欧美精品免费在线| 四虎亚洲精品| 午夜免费日韩视频| 老司机深夜福利在线观看| 538国产精品一区二区在线 | 黄色网址免费在线观看| 久久成人亚洲精品| 免费在线播放电影| 久久久视频精品| 中文字幕在线看片| 国产精品99久久久久久人| 草民电影神马电影一区二区| 国产美女久久久| 欧美黄色一级| 激情小说综合区| 国产精品嫩模av在线| 午夜欧美一区二区三区免费观看| 国产精品99视频| 2019日韩中文字幕mv| 久久九九99| 亚洲免费黄色录像| 成人毛片在线观看| 亚洲精品乱码久久久久久久久久久久| 国产精品视频第一区| 久热这里有精品| 欧美日韩国产一区在线| 伊人久久中文字幕| 欧美一级片在线观看| 午夜视频免费在线| 少妇高潮久久久久久潘金莲| 中文字幕中文字幕在线十八区| 91黄色8090| 精品乱码一区二区三区四区| 国产成人精品免费视频大全最热| 网曝91综合精品门事件在线| 亚洲一区免费看| 亚洲精品孕妇| 国内国产精品天干天干| 成人动漫一区二区三区| 先锋影音av在线| 亚洲国产综合在线| 中文在线最新版天堂| 欧美成人猛片aaaaaaa| 六十路在线观看| 九九热视频这里只有精品| 欧美粗大gay| 97免费资源站| 欧美色图一区| 国产原创中文在线观看| 精品一区二区日韩| 久久精品一区二区免费播放| 亚洲精选免费视频| 中文字幕在线播放日韩| 精品偷拍各种wc美女嘘嘘| 最近中文字幕免费mv2018在线| 日本精品在线视频| 6080成人| 一级全黄肉体裸体全过程| 免费视频一区| 99热超碰在线| 亚洲精品ww久久久久久p站 | 精品奇米国产一区二区三区| 成人高清在线| 热久久免费国产视频| www.成人网| 欧美日韩一区二区三区电影| 蜜桃av噜噜一区| 永久免费成人代码| 精品国产31久久久久久| 亚洲av色香蕉一区二区三区| 日韩中文字幕在线看| 视频精品导航| 日本一区二区三区视频免费看| 在线成人欧美| 日本精品一二三| 亚洲靠逼com| 99精品在线看| 久久久精品久久久久| 久久婷婷五月综合色丁香| 日本一区二区三区www| 亚洲一区二区免费看| 午夜福利三级理论电影| 亚洲综合色噜噜狠狠| 国产黄色av片| 欧美日韩999| 欧美三级一区| av影院在线播放| 国产精品亚洲专一区二区三区 | 91久久伊人青青碰碰婷婷| 久久中文字幕二区| 99视频在线视频| 国产欧美精品一区| 免费一级a毛片| 一区二区三区久久精品| 高清av一区| 一区二区免费在线视频| 蓝色福利精品导航| 黄色片网站在线播放| 欧美精品一级二级| 浪潮av一区| 99国产高清| 国内视频精品| 91丨porny丨对白| 欧美日韩国产一区二区| 国产精品免费观看| 国产欧美精品在线| 亚洲精品二区三区| 国产一级二级av| 亚洲高清不卡在线观看| 天堂在线中文资源| 国产99视频在线观看| 日本一二区不卡| 99精品视频国产| 亚洲va欧美va国产va天堂影院| 亚洲三级黄色片| 国产精品久久久久久av福利软件| 91日韩欧美| 无码人妻一区二区三区精品视频| 精品av在线播放| 成年人视频在线看| 91久久久久久久久久久久久| 亚洲高清久久| 变态另类ts人妖一区二区| 欧美日本韩国一区二区三区视频| а√天堂8资源在线官网| 国产一级精品aaaaa看| 日韩精品三区四区| 一区二区视频免费看| 亚洲精品美女在线观看| 91精品国产经典在线观看| 国产黄色激情视频| 99re这里只有精品首页| 国产精品露脸视频| 欧美激情国产精品| 狠狠综合久久av一区二区蜜桃| 亚洲欧美天堂在线| 黑人极品videos精品欧美裸| 日本免费在线视频| 好吊色欧美一区二区三区四区 | 色猫猫国产区一区二在线视频| 欧美日韩视频在线播放| 精品欧美国产一区二区三区不卡| 美国三级日本三级久久99 | 操你啦在线视频| 明星裸体视频一区二区| 国产乱国产乱300精品| 日韩免费av网站| 久久久久久亚洲精品| 91综合在线|