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

面試官:Redis的事務滿足原子性嗎?

數據庫 其他數據庫 Redis
熟悉redis的同學肯定知道,在redis中也存在事務,那么它的事務也滿足原子性嗎?下面我們就來一探究竟。和數據庫事務類似,redis事務也是用來一次性地執行多條命令。

[[422510]]

談起數據庫的事務來,估計很多同學的第一反應都是ACID,而排在ACID中首位的A原子性,要求一個事務中的所有操作,要么全部完成,要么全部不完成。熟悉redis的同學肯定知道,在redis中也存在事務,那么它的事務也滿足原子性嗎?下面我們就來一探究竟。

什么是Redis事務?

和數據庫事務類似,redis事務也是用來一次性地執行多條命令。使用起來也很簡單,可以用MULTI開啟一個事務,然后將多個命令入隊到事務的隊列中,最后由EXEC命令觸發事務,執行事務中的所有命令。看一個簡單的事務執行例子:

  1. 127.0.0.1:6379> multi 
  2. OK 
  3. 127.0.0.1:6379> set name Hydra 
  4. QUEUED 
  5. 127.0.0.1:6379> set age 18 
  6. QUEUED 
  7. 127.0.0.1:6379> incr age 
  8. QUEUED 
  9. 127.0.0.1:6379> exec 
  10. 1) OK 
  11. 2) OK 
  12. 3) (integer) 19 

可以看到,在指令和操作數的數據類型等都正常的情況下,輸入EXEC后所有命令被執行成功。

Redis事務滿足原子性嗎?

如果要驗證redis事務是否滿足原子性,那么需要在redis事務執行發生異常的情況下進行,下面我們分兩種不同類型的錯誤分別測試。

語法錯誤

首先測試命令中有語法錯誤的情況,這種情況多為命令的參數個數不正確或輸入的命令本身存在錯誤。下面我們在事務中輸入一個存在格式錯誤的命令,開啟事務并依次輸入下面的命令:

  1. 127.0.0.1:6379> multi 
  2. OK 
  3. 127.0.0.1:6379> set name Hydra 
  4. QUEUED 
  5. 127.0.0.1:6379> incr 
  6. (error) ERR wrong number of arguments for 'incr' command 
  7. 127.0.0.1:6379> set age 18 
  8. QUEUED 

輸入的命令incr后面沒有添加參數,屬于命令格式不對的語法錯誤,這時在命令入隊時就會立刻檢測出錯誤并提示error。使用exec執行事務,查看結果輸出:

  1. 127.0.0.1:6379> exec 
  2. (error) EXECABORT Transaction discarded because of previous errors. 

在這種情況下,只要事務中的一條命令有語法錯誤,在執行exec后就會直接返回錯誤,包括語法正確的命令在內的所有命令都不會被執行。對此進行驗證,看一下在事務中其他指令執行情況,查看set命令的執行結果,全部為空,說明指令沒有被執行。

  1. 127.0.0.1:6379> get name 
  2. (nil) 
  3. 127.0.0.1:6379> get age 
  4. (nil) 

此外,如果存在命令本身拼寫錯誤、或輸入了一個不存在的命令等情況,也屬于語法錯誤的情況,執行事務時會直接報錯。

運行錯誤

運行錯誤是指輸入的指令格式正確,但是在命令執行期間出現的錯誤,典型場景是當輸入參數的數據類型不符合命令的參數要求時,就會發生運行錯誤。例如下面的例子中,對一個string類型的值執行列表的操作,報錯如下:

  1. 127.0.0.1:6379> set key1 value1 
  2. OK 
  3. 127.0.0.1:6379> lpush key1 value2 
  4. (error) WRONGTYPE Operation against a key holding the wrong kind of value 

這種錯誤在redis實際執行指令前是無法被發現的,只能當真正執行才能夠被發現,因此這樣的命令是可以被事務隊列接收的,不會和上面的語法錯誤一樣立即報錯。

具體看一下當事務中存在運行錯誤的情況,在下面的事務中,嘗試對string類型數據進行incr自增操作:

  1. 127.0.0.1:6379> multi 
  2. OK 
  3. 127.0.0.1:6379> set name Hydra 
  4. QUEUED 
  5. 127.0.0.1:6379> set age eighteen 
  6. QUEUED 
  7. 127.0.0.1:6379> incr age 
  8. QUEUED 
  9. 127.0.0.1:6379> del name 
  10. QUEUED 

redis一直到這里都沒有提示存在錯誤,執行exec看一下結果輸出:

  1. 127.0.0.1:6379> exec 
  2. 1) OK 
  3. 2) OK 
  4. 3) (error) ERR value is not an integer or out of range 
  5. 4) (integer) 1 

運行結果可以看到,雖然incr age這條命令出現了錯誤,但是它前后的命令都正常執行了,再看一下這些key對應的值,確實證明了其余指令都執行成功:

  1. 127.0.0.1:6379> get name 
  2. (nil) 
  3. 127.0.0.1:6379> get age 
  4. "eighteen" 

階段性結論

對上面的事務的運行結果進行一下分析:

  • 存在語法錯誤的情況下,所有命令都不會執行
  • 存在運行錯誤的情況下,除執行中出現錯誤的命令外,其他命令都能正常執行

通過分析我們知道了redis中的事務是不滿足原子性的,在運行錯誤的情況下,并沒有提供類似數據庫中的回滾功能。那么為什么redis不支持回滾呢,官方文檔給出了說明,大意如下:

  • redis命令失敗只會發生在語法錯誤或數據類型錯誤的情況,這一結果都是由編程過程中的錯誤導致,這種情況應該在開發環境中檢測出來,而不是生產環境
  • 不使用回滾,能使redis內部設計更簡單,速度更快
  • 回滾不能避免編程邏輯中的錯誤,如果想要將一個鍵的值增加2卻只增加了1,這種情況即使提供回滾也無法提供幫助

基于以上原因,redis官方選擇了更簡單、更快的方法,不支持錯誤回滾。這樣的話,如果在我們的業務場景中需要保證原子性,那么就要求了開發者通過其他手段保證命令全部執行成功或失敗,例如在執行命令前進行參數類型的校驗,或在事務執行出現錯誤時及時做事務補償。

提到其他方式,相信很多小伙伴都聽說使用Lua腳本來保證操作的原子性,例如在分布式鎖中通常使用的就是Lua腳本,那么,神奇的Lua腳本真的能保證原子性嗎?

簡單的Lua腳本入門

在驗證lua腳本的原子性之前,我們需要對它做一個簡單的了解。redis從2.6版本開始支持執行lua腳本,它的功能和事務非常類似,一段lua腳本被視作一條命令執行,這樣將多條redis命令寫入lua,即可實現類似事務的執行結果。我們先看一下下面幾個常用的命令。

EVAL 命令

最常用的EVAL用于執行一段腳本,它的命令的格式如下:

  1. EVAL script numkeys key [key ...] arg [arg ...]  

簡單解釋一下其中的參數:

  • script是一段lua腳本程序
  • numkeys指定后續參數有幾個key,如沒有key則為0
  • key [key …]表示腳本中用到的redis中的鍵,在lua腳本中通過KEYS[i]的形式獲取
  • arg [arg …]表示附加參數,在lua腳本中通過ARGV[i]獲取

看一個簡單的例子:

  1. 127.0.0.1:6379> eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 value1 vauel2 
  2. 1) "key1" 
  3. 2) "key2" 
  4. 3) "value1" 
  5. 4) "vauel2" 

在上面的命令中,雙引號中是lua腳本程序,后面的2表示存在兩個key,分別是key1和key2,之后的參數是附加參數value1和value2。

如果想要使用lua腳本執行set命令,可以寫成這樣:

  1. 127.0.0.1:6379> EVAL "redis.call('SET', KEYS[1], ARGV[1]);" 1 name Hydra 
  2. (nil) 

這里使用了redis內置的lua函數redis.call來完成set命令,這里打印的執行結果nil是因為沒有返回值,如果不習慣的話,其實我們可以在腳本中添加return 0;的返回語句。

SCRIPT LOAD 和 EVALSHA命令

這兩個命令放在一起是因為它們一般成對使用。先看SCRIPT LOAD,它用于把腳本加載到緩存中,返回SHA1校驗和,這時候只是緩存了命令,但是命令沒有被馬上執行,看一個例子:

  1. 127.0.0.1:6379> SCRIPT LOAD "return redis.call('GET', KEYS[1]);" 
  2. "228d85f44a89b14a5cdb768a29c4c4d907133f56" 

這里返回了一個SHA1的校驗和,接下來就可以使用EVALSHA來執行腳本了:

  1. 127.0.0.1:6379> EVALSHA "228d85f44a89b14a5cdb768a29c4c4d907133f56" 1 name 
  2. "Hydra" 

這里使用這個SHA1值就相當于導入了上面緩存的命令,在之后再拼接numkeys、key、arg等參數,命令就能夠正常執行了。

其他命令

使用SCRIPT EXISTS命令判斷腳本是否被緩存:

  1. 127.0.0.1:6379> SCRIPT EXISTS 228d85f44a89b14a5cdb768a29c4c4d907133f56 
  2. 1) (integer) 1 

使用SCRIPT FLUSH命令清除redis中的lua腳本緩存:

  1. 127.0.0.1:6379> SCRIPT FLUSH 
  2. OK 
  3. 127.0.0.1:6379> SCRIPT EXISTS 228d85f44a89b14a5cdb768a29c4c4d907133f56 
  4. 1) (integer) 0 

可以看到,執行了SCRIPT FLUSH后,再次通過SHA1值查看腳本時已經不存在。最后,還可以使用SCRIPT KILL命令殺死當前正在運行的 lua 腳本,但是只有當腳本沒有執行寫操作時才會生效。

從這些操作看來,lua腳本具有下面的優點:

  • 多次網絡請求可以在一次請求中完成,減少網絡開銷,減少了網絡延遲
  • 客戶端發送的腳本會存在redis中,其他客戶端可以復用這一腳本,而不需要再重復編碼完成相同的邏輯

Java代碼中使用lua腳本

在Java代碼中可以使用Jedis中封裝好的API來執行lua腳本,下面是一個使用Jedis執行lua腳本的例子:

  1. public static void main(String[] args) { 
  2.     Jedis jedis = new Jedis("127.0.0.1", 6379); 
  3.     String script="redis.call('SET', KEYS[1], ARGV[1]);" 
  4.             +"return redis.call('GET', KEYS[1]);"
  5.     List<String> keys= Arrays.asList("age"); 
  6.     List<String> values= Arrays.asList("eighteen"); 
  7.     Object result = jedis.eval(script, keys, values); 
  8.     System.out.println(result); 

執行上面的代碼,控制臺打印了get命令返回的結果:

  1. eighteen 

簡單的鋪墊完成后,我們來看一下lua腳本究竟能否實現回滾級別的原子性。對上面的代碼進行改造,插入一條運行錯誤的命令:

  1. public static void main(String[] args) { 
  2.     Jedis jedis = new Jedis("127.0.0.1", 6379); 
  3.     String script="redis.call('SET', KEYS[1], ARGV[1]);" 
  4.             +"redis.call('INCR', KEYS[1]);" 
  5.             +"return redis.call('GET', KEYS[1]);"
  6.     List<String> keys= Arrays.asList("age"); 
  7.     List<String> values= Arrays.asList("eighteen"); 
  8.     Object result = jedis.eval(script, keys, values); 
  9.     System.out.println(result); 

查看執行結果:

再到客戶端執行一下get命令:

  1. 127.0.0.1:6379> get age 
  2. "eighteen" 

也就是說,雖然程序拋出了異常,但異常前的命令還是被正常的執行了且沒有被回滾。再試試直接在redis客戶端中運行這條指令:

  1. 127.0.0.1:6379> flushall 
  2. OK 
  3. 127.0.0.1:6379> eval "redis.call('SET', KEYS[1], ARGV[1]);redis.call('INCR', KEYS[1]);return redis.call('GET', KEYS[1])" 1 age eight 
  4. (error) ERR Error running script (call to f_c2ea9d5c8f60735ecbedb47efd42c834554b9b3b): @user_script:1: ERR value is not an integer or out of range 
  5. 127.0.0.1:6379> get age 
  6. "eight" 

同樣,錯誤之前的指令仍然沒有被回滾,那么我們之前經常聽說的Lua腳本保證原子性操作究竟是怎么回事呢?

其實,在redis中是使用的同一個lua解釋器來執行所有命令,也就保證了當一段lua腳本在執行時,不會有其他腳本或redis命令同時執行,保證了操作不會被其他指令插入或打擾,實現的僅僅是這種程度上的原子操作。

但是遺憾的是,如果lua腳本運行時出錯并中途結束,之后的操作不會進行,但是之前已經發生的寫操作不會撤銷,所以即使使用了lua腳本,也不能實現類似數據庫回滾的原子性。

本文基于redis 5.0.3 進行測試

官方文檔相關說明:https://redis.io/topics/transactions

本文轉載自微信公眾號「碼農參上」

【編輯推薦】

 

責任編輯:姜華 來源: 碼農參上
相關推薦

2021-06-07 17:12:22

線程安全Atomic

2023-01-05 12:30:32

Redis

2020-03-06 15:36:01

Redis內存宕機

2021-04-12 21:34:29

Redis故障數據

2025-11-17 01:22:00

2023-09-01 15:27:31

2021-11-02 09:05:25

Redis

2019-02-27 09:28:15

Redis服務器事務

2024-04-03 00:00:00

Redis集群代碼

2024-01-22 10:07:48

Redis持久化功能緩存擊穿

2020-11-06 07:11:40

內存虛擬Redis

2020-07-02 07:52:11

RedisHash映射

2022-07-18 13:59:43

Redis單線程進程

2015-08-13 10:29:12

面試面試官

2021-06-03 14:00:35

PolarDB

2021-06-02 16:30:33

PolarDB原子性數據庫

2022-07-06 13:48:24

RedisSentinel機制

2024-04-09 10:40:04

2024-10-22 16:39:07

2024-02-28 10:14:47

Redis數據硬盤
點贊
收藏

51CTO技術棧公眾號

久久久久网站| 日韩一二三区在线观看| 国产欧美一区二区精品忘忧草 | 欧美mv日韩mv国产| 欧美久久在线观看| 番号集在线观看| 黄页视频在线91| 午夜精品一区二区三区视频免费看| 欧美 日本 国产| 四虎国产精品成人免费影视| 亚洲图片欧美综合| 午夜欧美性电影| 丰满少妇高潮在线观看| 香蕉久久夜色精品| 久久艳片www.17c.com| 好吊色视频一区二区三区| 高清电影一区| 亚洲国产aⅴ成人精品无吗| 日韩精品久久久毛片一区二区| 国产富婆一级全黄大片| 乱人伦精品视频在线观看| 欧美二区在线播放| 激情无码人妻又粗又大| 亚洲春色h网| 日韩欧美不卡在线观看视频| 国产一区二区在线免费播放| 爱啪视频在线观看视频免费| 国产视频视频一区| 国产视频精品网| 国产精品一级视频| 日韩电影免费在线看| 97免费在线视频| 免看一级a毛片一片成人不卡| 成人午夜av| 亚洲欧洲日产国产网站| 国产女主播在线播放| 欧美区一区二区| 欧美精品1区2区3区| 黄色av免费在线播放| 精品捆绑调教一区二区三区| 一区二区三区成人| 中文字幕日韩一区二区三区不卡| 韩国三级在线观看久| 99精品视频一区二区| 国产精品一 二 三| 亚洲国产成人在线观看| 国产麻豆视频精品| 91网站在线免费观看| 伊人免费在线观看| 蜜桃视频在线观看一区| 国产va免费精品高清在线观看| 日本少妇激情舌吻| 国产精品sm| 色综合色综合网色综合| 久草网站在线观看| 欧美在线1区| 欧美精品在线极品| 欧美日韩综合一区二区| 欧美 日韩 国产精品免费观看| www.欧美三级电影.com| 日韩在线观看免| 中文字幕一区二区三区欧美日韩 | 日本在线不卡一区| 国产精品成人一区| 中文字幕乱码人妻无码久久| 日韩精品电影一区亚洲| 国产精品91免费在线| 免费在线观看av的网站| 麻豆一区二区在线| 亚洲xxxx18| 黄色av网站免费在线观看| 成人h版在线观看| 久久av一区二区| 精品乱码一区二区三四区视频 | 欧美三级精品| 欧美女孩性生活视频| 四虎成人在线播放| 91蝌蚪精品视频| 日韩av在线网址| 中文字字幕码一二三区| 日韩国产一区二区| 久久中国妇女中文字幕| 久久久香蕉视频| 亚洲自拍另类| 国产区精品在线观看| 99在线观看免费| 成人免费福利片| 免费观看成人在线| 欧美激情办公室videoshd| 亚洲激情在线激情| 免费在线激情视频| 欧美视频精品| 日韩欧美的一区二区| 中文精品在线观看| 久久久久国产| 5566成人精品视频免费| 中文字幕+乱码+中文乱码www| 久草在线在线精品观看| 国产一区二区三区四区五区在线| 好男人免费精品视频| 亚洲狠狠丁香婷婷综合久久久| 国产午夜福利100集发布| 日本一道高清亚洲日美韩| 6080日韩午夜伦伦午夜伦| 在线视频 日韩| 久久亚洲成人| 欧美一级片一区| 国产精选久久久| 久久色成人在线| 日本福利视频在线观看| 69堂免费精品视频在线播放| 日韩欧美电影在线| 性爱在线免费视频| 国产欧美日韩一区二区三区在线| 成人久久精品视频| 欧美日韩国产综合视频| 一级特黄大欧美久久久| 中文字幕第100页| 群体交乱之放荡娇妻一区二区| 日韩一区二区欧美| 免费黄色小视频在线观看| 懂色av一区二区三区蜜臀| 亚洲精品美女久久7777777| 97人澡人人添人人爽欧美| 欧美狂野另类xxxxoooo| 91精彩刺激对白露脸偷拍| 亚洲午夜在线| 国产日产久久高清欧美一区| 裸体xxxx视频在线| 精品国产31久久久久久| 深夜视频在线观看| 香蕉视频国产精品| 国产欧美日韩视频| 国产三区四区在线观看| 亚洲高清久久久| 四川一级毛毛片| 国产精品久久观看| 国产精品久久久久久影视| 人成在线免费视频| 婷婷丁香久久五月婷婷| 91人妻一区二区| 欧美天天在线| 亚洲影院在线看| 超碰porn在线| 91精品国产麻豆国产自产在线| 国产在视频线精品视频| 免费看日韩精品| 一本色道婷婷久久欧美| 91欧美精品| 中文字幕亚洲图片| 一区二区视频网站| 综合久久一区二区三区| 在线观看中文av| 欧美成人亚洲| a级国产乱理论片在线观看99| 黄av在线播放| 日韩欧美视频在线| 欧美日韩精品在线观看视频 | 亚洲精品福利电影| 精品亚洲一区二区三区四区五区| 亚洲精品77777| 99精品久久久久久| 爱福利视频一区二区| 伊人成综合网伊人222| 国产成人精品av在线| 国产精品影院在线| 337p亚洲精品色噜噜噜| 欧美丰满熟妇bbbbbb| 国产精品99久久久| 欧美乱大交xxxxx潮喷l头像| 西野翔中文久久精品国产| 热re99久久精品国产66热| 国产片在线观看| 777奇米四色成人影色区| 老司机成人免费视频| 国产成人综合网站| 无码精品a∨在线观看中文| 久9久9色综合| 国产在线精品播放| 都市激情久久综合| 亚洲免费伊人电影在线观看av| 久久这里只有精品9| 中文字幕综合网| 成年人小视频在线观看| 美女91精品| 亚洲三区四区| av一级亚洲| 国产成+人+综合+亚洲欧美丁香花| 91在线不卡| 日韩欧美在线影院| 亚洲精品男人的天堂| 国产精品美女久久久久久久久久久| 免费看的av网站| 天堂成人免费av电影一区| 日韩电影天堂视频一区二区| 久久久久久亚洲精品美女| 777777777亚洲妇女| 天堂中文8资源在线8| 精品sm在线观看| 欧美激情一区二区三区免费观看 | 精品一卡二卡三卡| 国产精品久久久久久久久久10秀| 国内一区在线| 成人网av.com/| 欧美一区二区三区精品电影| 黄在线免费看| 亚洲日本aⅴ片在线观看香蕉| 99久久婷婷国产一区二区三区| 高潮白浆女日韩av免费看| 天堂网中文在线观看| 97久久精品人人做人人爽| 涩涩网站在线看| 石原莉奈一区二区三区在线观看| 日韩一二区视频| 欧美日韩有码| 九色视频成人porny| 美女国产精品久久久| 国产精品久久不能| 国产精品一二三产区| 欧美精品一区二区免费| yw193.com尤物在线| 亚洲黄色在线看| 亚洲av无码一区二区三区性色| 欧美在线免费播放| 九九热精品视频在线| 亚洲综合色网站| 欧美性猛交xxxxx少妇| 欧美国产一区二区| 久久精品国产亚洲AV熟女| 成人精品亚洲人成在线| 亚洲一二区在线观看| 蜜桃久久精品一区二区| 可以在线看的黄色网址| 中文一区在线| 我的公把我弄高潮了视频| 自拍偷拍欧美专区| youjizz.com亚洲| 精品国产a一区二区三区v免费| 久久精品国产美女| 精品深夜福利视频| 国产一区精品视频| 精品自拍偷拍| 精品国产乱码久久久久久88av| 99久热这里只有精品视频免费观看| 91色视频在线导航| 国产精品久久久久久久久久久久久久久| 国产精品成久久久久三级 | 亚洲久久一区| 国产伦精品一区二区三区四区视频_| 欧美片第1页综合| av动漫在线免费观看| 好看的av在线不卡观看| 男人添女人下部视频免费| 欧美日本不卡| 黄色一级片在线看| 亚洲欧美日韩视频二区| 哪个网站能看毛片| 日本亚洲最大的色成网站www| 五月婷婷之综合激情| 美腿丝袜一区二区三区| 奇米视频888| 国产精品18久久久久| 欧美久久久久久久久久久| 99re热这里只有精品视频| 欧美老熟妇乱大交xxxxx| 国产欧美精品一区二区三区四区| 国产精品麻豆免费版现看视频| 日韩一区日韩二区| 青娱乐91视频| 精品动漫一区二区| 成年人视频免费| 538在线一区二区精品国产| 国产高清免费观看| 亚洲国产欧美精品| 成全电影播放在线观看国语| 日韩中文字在线| 女囚岛在线观看| 2025国产精品视频| 91在线成人| dy888夜精品国产专区| 日韩超碰人人爽人人做人人添| 日本在线视频一区| 一区二区三区四区电影| 成人一对一视频| 麻豆精品蜜桃视频网站| 亚洲AV成人精品| 久久天天做天天爱综合色| 日韩av毛片在线观看| 亚洲成av人片在www色猫咪| 国产美女www| 精品少妇一区二区三区视频免付费| 五月天激情婷婷| 久久精品国产96久久久香蕉| freexxx性亚洲精品| 国产女人18毛片水18精品| 成人性生交大片免费看中文视频 | 三级电影在线看| 中文字幕一区二区三区不卡在线| 亚洲国产成人精品激情在线| 欧美日韩国产精品成人| 男人的天堂a在线| 日韩在线不卡视频| 人成在线免费网站| 91色p视频在线| 成人动漫免费在线观看| 97在线国产视频| 久久超级碰视频| 国产精品无码久久久久久| 一区二区三区成人在线视频| 又色又爽又黄无遮挡的免费视频| 欧美精品一区二区三区高清aⅴ | 日韩精品123| 精品中文字幕乱| 国产一区影院| 欧美国产一二三区| 激情五月***国产精品| 爱豆国产剧免费观看大全剧苏畅 | 亚洲精品福利在线观看| 国产黄色在线网站| 国产精品久久久久久久电影| 欧美美女在线直播| 人人妻人人澡人人爽欧美一区 | 成人国产精品av| 国产成人手机高清在线观看网站| 91动漫在线看| 国产福利不卡视频| 免费三级在线观看| 精品视频在线免费| 黄色免费在线播放| 欧美在线激情视频| 精品少妇3p| 热99这里只有精品| 成人高清免费观看| 久草资源在线视频| 日韩视频在线观看一区二区| 国产写真视频在线观看| 国产日韩精品入口| 日本久久一二三四| 九热视频在线观看| 国产午夜精品一区二区三区嫩草 | www.com.cn成人| 精品欧美国产| 中文高清一区| 内射中出日韩无国产剧情| 亚洲成人自拍偷拍| 欧美特黄一级视频| 午夜美女久久久久爽久久| av动漫精品一区二区| 青春草国产视频| aaa亚洲精品| 毛片视频网站在线观看| 日韩精品在线免费观看| 在线精品亚洲欧美日韩国产| 看高清中日韩色视频| 久久黄色影院| 国产美女网站视频| 制服丝袜日韩国产| 99热国产在线| 国产一区免费在线观看| 亚洲综合不卡| 亚洲图片第一页| 91.麻豆视频| 大黄网站在线观看| 久久国产手机看片| 日韩有码一区二区三区| 欧美自拍偷拍网| 91精品国产综合久久久蜜臀图片| 伊人在我在线看导航| 精品国产综合| 日韩成人一区二区三区在线观看| 永久av免费网站| 精品日产卡一卡二卡麻豆| 98色花堂精品视频在线观看| 欧美精品一区在线发布| 免费视频一区二区| 欧美日韩精品亚洲精品| 日韩激情第一页| 成人国产精品| 狠狠干视频网站| 91尤物视频在线观看| 性高潮视频在线观看| 久久躁日日躁aaaaxxxx| 日韩成人动漫在线观看| 欧美婷婷精品激情| 一区二区三区在线播| 秋霞av在线| 亚洲综合在线播放| 国产模特精品视频久久久久| 战狼4完整免费观看在线播放版| 日韩精品一区二区三区中文精品| 天堂中文av在线资源库| 中文字幕欧美日韩一区二区| 99久久夜色精品国产网站| 真实的国产乱xxxx在线91| 欧美黑人性生活视频| 精品久久综合| 动漫美女无遮挡免费| 欧美日韩在线免费视频| av剧情在线观看| 在线一区高清|