日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

高并发-【抢红包案例】之三:使用乐观锁方式修复红包超发的bug

發(fā)布時(shí)間:2025/3/21 编程问答 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 高并发-【抢红包案例】之三:使用乐观锁方式修复红包超发的bug 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

  • 導(dǎo)讀
  • 樂觀鎖
    • CAS 原理
    • ABA問題
  • 庫表改造
  • 代碼改造
    • RedPacketDao新增接口方法及Mapper映射文件
    • UserRedPacketServic接口及實(shí)現(xiàn)類的改造
    • Controller層新增路由方法
    • View層
    • 初始化數(shù)據(jù),啟動應(yīng)用測試
  • 解決因version導(dǎo)致失敗問題
    • 樂觀鎖重入機(jī)制-按時(shí)間戳重入
    • 樂觀鎖重入機(jī)制-按次數(shù)重入
  • 還能更好?
  • 代碼

導(dǎo)讀

高并發(fā)-【搶紅包案例】之一:SSM環(huán)境搭建及復(fù)現(xiàn)紅包超發(fā)問題

高并發(fā)-【搶紅包案例】之二:使用悲觀鎖方式修復(fù)紅包超發(fā)的bug

接下來我們使用樂觀鎖的方式來修復(fù)紅包超發(fā)的bug


樂觀鎖

樂觀鎖是一種不會阻塞其他線程并發(fā)的機(jī)制,它不會使用數(shù)據(jù)庫的鎖進(jìn)行實(shí)現(xiàn),它的設(shè)計(jì)里面由于不阻塞其他線程,所以并不會引發(fā)線程頻繁掛起和恢復(fù),這樣便能夠提高并發(fā)能力,也稱之為為非阻塞鎖。 樂觀鎖使用的是 CAS原理。


CAS 原理

Redis-11使用 watch 命令監(jiān)控事務(wù) 中也介紹了CAS,這里再重新說下

  • 在 CAS 原理中,對于多個(gè)線程共同的資源,先保存一個(gè)舊(Old Value),比如進(jìn)入線程后,查詢當(dāng)前存量為 100 個(gè)紅包,那么先把舊值保存為 100,然后經(jīng)過一定的邏輯處理。
  • 當(dāng)需要扣減紅包的時(shí)候,先比較數(shù)據(jù)庫當(dāng)前的值和舊值是否一致,如果一致則進(jìn)行扣減紅包的操作,否則就認(rèn)為它已經(jīng)被其他線程修改過了,不再進(jìn)行操作。
  • CAS 原理流程如下:

    CAS 原理并不排斥并發(fā),也不獨(dú)占資源,只是在線程開始階段就讀入線程共享數(shù)據(jù),保存為舊值。當(dāng)處理完邏輯,需要更新數(shù)據(jù)的時(shí)候,會進(jìn)行一次 比較,即比較各個(gè)線程當(dāng)前共享的數(shù)據(jù)是否和舊值保持一致。如果一致,就開始更新數(shù)據(jù);如果不一致,則認(rèn)為該前共享的數(shù)據(jù)是否和舊值保持一致。如果一致,就開始更新數(shù)據(jù);如果不一致,則認(rèn)為該重試,這樣就是一個(gè)可重入鎖,但是 CAS 原理會有一個(gè)問題,那就是 ABA 問題,我們先來看下ABA問題


    ABA問題

    在處理復(fù)雜運(yùn)算的時(shí)候,被線程 2 修改的 X 的值有可能導(dǎo)致線程1的運(yùn)算出錯(cuò),而最后線程 2 將 X 的值修改為原來的舊值 A,那么到了線程 1運(yùn)算結(jié)束的時(shí)間順序 T6,它將j檢測 X 的值是否發(fā)生變化,就會拿舊值 A 和 當(dāng)前的 X 的值 A 比對 , 結(jié)果是一致的, 于是提交事務(wù),然后在復(fù)雜計(jì)算的過程中 X 被線程 2 修改過了,這會導(dǎo)致線程1的運(yùn)算出錯(cuò)。

    在這個(gè)過程中,對于線程 2 而言 , X 的值的變化為 A->B->A,所以 CAS 原理的這個(gè)設(shè)計(jì)缺陷被形象地稱為“ABA 問題”。

    ABA 問題的發(fā)生 , 是因?yàn)闃I(yè)務(wù)邏輯存在回退的可能性 。 如果加入一個(gè)非業(yè)務(wù)邏輯的屬性,比如在一個(gè)數(shù)據(jù)中加入版本號( version ),對于版本號有一個(gè)約定,就是只要修改 X變量的數(shù)據(jù),強(qiáng)制版本號( version )只能遞增,而不會回退,即使是其他業(yè)務(wù)數(shù)據(jù)回退,它也會遞增,那么 ABA 問題就解決了。

    只是這個(gè) version 變量并不存在什么業(yè)務(wù)邏輯,只是為了記錄更新次數(shù),只能遞增,幫助我們克服 ABA 問題罷了 , 有了這些理論 , 我們就可以開始使用樂觀鎖來完成搶紅包業(yè)務(wù)了 。



    庫表改造

    為了順利使用樂觀鎖 , 需要先在紅包表 C T RED PACKET ) 加入一個(gè)新的列版本號(version),這個(gè)字段在建表的時(shí)候已經(jīng)建了 , 只是我們還沒有使用 。 這是第一步


    代碼改造

    既然庫表加上了Version字段,那么應(yīng)用中肯定要用到,自然而言的落到了Dao層上。


    RedPacketDao新增接口方法及Mapper映射文件

    RedPacketDao.java

    /*** @Description: 扣減搶紅包數(shù). 樂觀鎖的實(shí)現(xiàn)方式* * @param id* -- 紅包id* @param version* -- 版本標(biāo)記* * @return: 更新記錄條數(shù)*/public int decreaseRedPacketForVersion(@Param("id") Long id, @Param("version") Integer version);

    RedPacket.xml

    <!-- 通過版本號扣減搶紅包 每更新一次,版本增1, 其次增加對版本號的判斷 --><update id="decreaseRedPacketForVersion">update T_RED_PACKET set stock = stock - 1 ,version = version + 1where id = #{id} and version = #{version}</update>

    在扣減紅包的時(shí)候 , 增加了對版本號的判斷,其次每次扣減都會對版本號加一,這樣保證每次更新在版本號上有記錄 , 從而避免 ABA 問題

    對于查詢也不使用 for update 語句 , 避免鎖的發(fā)生 , 這樣就沒有線程阻塞的問題了。 然后就可 以在類 UserRedPacketServic接口中新增方法 grapRedPacketForVersion,然后在其實(shí)現(xiàn)類中完成對應(yīng)的邏輯即可。


    UserRedPacketServic接口及實(shí)現(xiàn)類的改造

    /*** 保存搶紅包信息. 樂觀鎖的方式* * @param redPacketId* 紅包編號* @param userId* 搶紅包用戶編號* @return 影響記錄數(shù).*/public int grapRedPacketForVersion(Long redPacketId, Long userId);

    實(shí)現(xiàn)類

    /*** 樂觀鎖,無重入* */@Override@Transactional(isolation = Isolation.READ_COMMITTED, propagation = Propagation.REQUIRED)public int grapRedPacketForVersion(Long redPacketId, Long userId) {// 獲取紅包信息RedPacket redPacket = redPacketDao.getRedPacket(redPacketId);// 當(dāng)前小紅包庫存大于0if (redPacket.getStock() > 0) {// 再次傳入線程保存的version舊值給SQL判斷,是否有其他線程修改過數(shù)據(jù)int update = redPacketDao.decreaseRedPacketForVersion(redPacketId, redPacket.getVersion());// 如果沒有數(shù)據(jù)更新,則說明其他線程已經(jīng)修改過數(shù)據(jù),則重新?lián)寠Zif (update == 0) {return FAILED;}// 生成搶紅包信息UserRedPacket userRedPacket = new UserRedPacket();userRedPacket.setRedPacketId(redPacketId);userRedPacket.setUserId(userId);userRedPacket.setAmount(redPacket.getUnitAmount());userRedPacket.setNote("redpacket- " + redPacketId);// 插入搶紅包信息int result = userRedPacketDao.grapRedPacket(userRedPacket);return result;}// 失敗返回return FAILED;}

    version 值一開始就保存到了對象中,當(dāng)扣減的時(shí)候,再次傳遞給 SQL ,讓 SQL 對數(shù)據(jù)庫的 version 和當(dāng)前線程的舊值 version 進(jìn)行比較。如果一致則插入搶紅包的數(shù)據(jù),否則就不進(jìn)行操作。


    Controller層新增路由方法

    為了方便區(qū)分測試,在控制器 UserRedPacketController 內(nèi)新建映射

    @RequestMapping(value = "/grapRedPacketForVersion")@ResponseBodypublic Map<String, Object> grapRedPacketForVersion(Long redPacketId, Long userId) {// 搶紅包int result = userRedPacketService.grapRedPacketForVersion(redPacketId, userId);Map<String, Object> retMap = new HashMap<String, Object>();boolean flag = result > 0;retMap.put("success", flag);retMap.put("message", flag ? "搶紅包成功" : "搶紅包失敗");return retMap;}

    View層

    為了區(qū)分,新建個(gè)jsp吧 , 注意POST 請求地址和紅包id 。
    grapForVersion.jsp

    <%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>參數(shù)</title><!-- 加載Query文件--><script type="text/javascript" src="https://code.jquery.com/jquery-3.2.0.js"></script><script type="text/javascript">$(document).ready(function () {//模擬30000個(gè)異步請求,進(jìn)行并發(fā)var max = 30000;for (var i = 1; i <= max; i++) {//jQuery的post請求,請注意這是異步請求$.post({//請求搶id為1的紅包//根據(jù)自己請求修改對應(yīng)的url和大紅包編號url: "./userRedPacket/grapRedPacketForVersion.do?redPacketId=1&userId=" + i,//成功后的方法success: function (result) {}});}});</script></head><body></body> </html>

    初始化數(shù)據(jù),啟動應(yīng)用測試

    一致性數(shù)據(jù)統(tǒng)計(jì):

    經(jīng)過 3 萬次的搶奪,一共搶到了7521個(gè)紅包,剩余12479個(gè)紅包, 也就是存在大量的因?yàn)榘姹静灰恢碌脑蛟斐蓳尲t包失敗的請求。 這失敗率太高了。。

    有時(shí)候會容忍這個(gè)失敗,這取決于業(yè)務(wù)的需要,因?yàn)樵试S用戶自己再發(fā)起搶奪紅包。


    性能數(shù)據(jù)統(tǒng)計(jì):


    解決因version導(dǎo)致失敗問題

    為提高成功率,可以考慮使用重入機(jī)制 。 也就是一旦因?yàn)榘姹驹驔]有搶到紅包,則重新嘗試搶紅包,但是過多的重入會造成大量的 SQL 執(zhí)行,所以目前流行的重入會加入兩種限制

  • 一種是按時(shí)間戳的重入,也就是在一定時(shí)間戳內(nèi)(比如說 100毫秒),不成功的會循環(huán)到成功為止,直至超過時(shí)間戳,不成功才會退出,返回失敗。
  • 一種是按次數(shù),比如限定 3 次,程序嘗試超過 3 次搶紅包后,就判定請求失效,這樣有助于提高用戶搶紅包的成功率。

  • 樂觀鎖重入機(jī)制-按時(shí)間戳重入

    因?yàn)闃酚^鎖造成大量更新失敗的問題,使用時(shí)間戳執(zhí)行樂觀鎖重入,是一種提高成功率的方法,比如考慮在 100 毫秒內(nèi)允許重入,把 UserRedPacketServicelmpl 中的方法grapRedPacketForVersion 修改下

    /*** * * 樂觀鎖,按時(shí)間戳重入* * @Description: 樂觀鎖,按時(shí)間戳重入* * @param redPacketId* @param userId* @return* * @return: int*/@Override@Transactional(isolation = Isolation.READ_COMMITTED, propagation = Propagation.REQUIRED)public int grapRedPacketForVersion(Long redPacketId, Long userId) {// 記錄開始時(shí)間long start = System.currentTimeMillis();// 無限循環(huán),等待成功或者時(shí)間滿100毫秒退出while (true) {// 獲取循環(huán)當(dāng)前時(shí)間long end = System.currentTimeMillis();// 當(dāng)前時(shí)間已經(jīng)超過100毫秒,返回失敗if (end - start > 100) {return FAILED;}// 獲取紅包信息,注意version值RedPacket redPacket = redPacketDao.getRedPacket(redPacketId);// 當(dāng)前小紅包庫存大于0if (redPacket.getStock() > 0) {// 再次傳入線程保存的version舊值給SQL判斷,是否有其他線程修改過數(shù)據(jù)int update = redPacketDao.decreaseRedPacketForVersion(redPacketId, redPacket.getVersion());// 如果沒有數(shù)據(jù)更新,則說明其他線程已經(jīng)修改過數(shù)據(jù),則重新?lián)寠Zif (update == 0) {continue;}// 生成搶紅包信息UserRedPacket userRedPacket = new UserRedPacket();userRedPacket.setRedPacketId(redPacketId);userRedPacket.setUserId(userId);userRedPacket.setAmount(redPacket.getUnitAmount());userRedPacket.setNote("搶紅包 " + redPacketId);// 插入搶紅包信息int result = userRedPacketDao.grapRedPacket(userRedPacket);return result;} else {// 一旦沒有庫存,則馬上返回return FAILED;}}}

    當(dāng)因?yàn)榘姹咎栐蚋率『?#xff0c;會重新嘗試搶奪紅包,但是會實(shí)現(xiàn)判斷時(shí)間戳,如果時(shí)間戳在 100 毫秒內(nèi),就繼續(xù),否則就不再重新嘗試,而判定失敗,這樣可以避免過多的SQL 執(zhí)行 , 維持系統(tǒng)穩(wěn)定。

    初始化數(shù)據(jù)后,進(jìn)行測試

    從結(jié)果來看,之前大量失敗的場景消失了,也沒有超發(fā)現(xiàn)象 , 3 萬次嘗試搶光了所有的紅包 , 避免了總是失敗的結(jié)果,但是有時(shí)候時(shí)間戳并不是那么穩(wěn)定,也會隨著系統(tǒng)的空閑或者繁忙導(dǎo)致重試次數(shù)不一。有時(shí)候我們也會考慮、限制重試次數(shù),比如 3 次,如下所示


    樂觀鎖重入機(jī)制-按次數(shù)重入

    /*** * * @Title: grapRedPacketForVersion* * @Description: 樂觀鎖,按次數(shù)重入* * @param redPacketId* @param userId* * @return: int*/@Override@Transactional(isolation = Isolation.READ_COMMITTED, propagation = Propagation.REQUIRED)public int grapRedPacketForVersion(Long redPacketId, Long userId) {for (int i = 0; i < 3; i++) {// 獲取紅包信息,注意version值RedPacket redPacket = redPacketDao.getRedPacket(redPacketId);// 當(dāng)前小紅包庫存大于0if (redPacket.getStock() > 0) {// 再次傳入線程保存的version舊值給SQL判斷,是否有其他線程修改過數(shù)據(jù)int update = redPacketDao.decreaseRedPacketForVersion(redPacketId, redPacket.getVersion());// 如果沒有數(shù)據(jù)更新,則說明其他線程已經(jīng)修改過數(shù)據(jù),則重新?lián)寠Zif (update == 0) {continue;}// 生成搶紅包信息UserRedPacket userRedPacket = new UserRedPacket();userRedPacket.setRedPacketId(redPacketId);userRedPacket.setUserId(userId);userRedPacket.setAmount(redPacket.getUnitAmount());userRedPacket.setNote("搶紅包 " + redPacketId);// 插入搶紅包信息int result = userRedPacketDao.grapRedPacket(userRedPacket);return result;} else {// 一旦沒有庫存,則馬上返回return FAILED;}}return FAILED;}

    通過 for 循環(huán)限定重試 3 次, 3 次過后無論成敗都會判定為失敗而退出 , 這樣就能避免過多的重試導(dǎo)致過多 SQL 被執(zhí)行的問題,從而保證數(shù)據(jù)庫的性能.

    同樣的測試步驟,來看下統(tǒng)計(jì)結(jié)果

    3 萬次請求,所有紅包都被搶到了 , 也沒有發(fā)生超發(fā)現(xiàn)象,這樣就可以消除大量的請求失敗,避免非重入的時(shí)候大量請求失敗的場景。


    還能更好?

    現(xiàn)在是使用數(shù)據(jù)庫的情況,有時(shí)候并不想使用數(shù)據(jù)庫作為搶紅包時(shí)刻的數(shù)據(jù)保存載體,而是選擇性能優(yōu)于數(shù)據(jù)庫的 Redis。 之前接觸過了Redis的事務(wù),結(jié)合lua來實(shí)現(xiàn)搶紅包的功能

    Redis-09Redis的基礎(chǔ)事務(wù)

    Redis-10Redis的事務(wù)回滾

    Redis-11使用 watch 命令監(jiān)控事務(wù)

    先看下理論知識,下篇博文一起來探討使用Redis + lua 實(shí)現(xiàn)搶紅包的功能吧。


    代碼

    https://github.com/yangshangwei/ssm_redpacket

    總結(jié)

    以上是生活随笔為你收集整理的高并发-【抢红包案例】之三:使用乐观锁方式修复红包超发的bug的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    国产麻豆精品久久一二三 | 激情五月在线观看 | 三级动图 | 久久精品久久久精品美女 | 国产高清无av久久 | 色综合夜色一区 | 五月激情丁香图片 | 免费男女羞羞的视频网站中文字幕 | 国产高潮久久 | 日韩av中文在线 | 国产色视频一区二区三区qq号 | 国产精品69av | 久草精品视频在线播放 | 精品欧美一区二区在线观看 | 久久五月婷婷丁香 | 色偷偷88888欧美精品久久 | 99精品在线免费视频 | 四虎免费av| 天天鲁一鲁摸一摸爽一爽 | 91mv.cool在线观看 | 国产理论免费 | 精品久久久久久久久久久久久久久久 | 在线中文字幕网站 | 欧美另类69| 国产午夜精品理论片在线 | 国精产品999国精产品视频 | 成人久久亚洲 | 天天操天天操天天操天天操 | 色综合久久88色综合天天6 | 狠狠色丁香久久婷婷综 | 激情av资源 | 国产一区二区久久久 | 中文字幕在线播放一区二区 | 亚洲涩涩色 | 日韩精品视频在线观看网址 | 天天操天天摸天天爽 | 狠狠色丁香婷婷 | 91香蕉嫩草 | 夜夜骑天天操 | 亚洲专区视频在线观看 | 日韩精品免费在线 | 999热视频| www.色婷婷 | 久久国产精品免费 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 成人av电影免费在线观看 | 国产精品欧美在线 | 美女福利视频一区二区 | 在线国产福利 | 黄色在线免费观看网站 | 在线亚洲成人 | 国内精品视频一区二区三区八戒 | 91亚洲精品乱码久久久久久蜜桃 | 免费h漫在线观看 | 日本精品在线 | 亚洲天堂网在线观看视频 | 综合在线色 | 手机看片久久 | 欧美一区二区三区在线视频观看 | 亚洲永久精品国产 | 欧美色伊人 | 精品国产日本 | 色噜噜日韩精品一区二区三区视频 | 国产传媒中文字幕 | 97成人超碰| 日日干天天射 | 国产69精品久久久久久 | av黄在线播放 | 成人在线黄色电影 | 毛片精品免费在线观看 | 丁香婷婷电影 | 在线成人高清电影 | 干av在线| 亚洲国产欧美在线人成大黄瓜 | 欧美精品九九99久久 | 久久国产精品99久久久久 | 天天操网址 | 手机av资源| 日日色综合 | 久草网站在线观看 | 99亚洲国产精品 | 免费视频久久久久久久 | 一级黄色片在线免费观看 | 国产免费亚洲高清 | 西西444www大胆无视频 | 日韩簧片在线观看 | 色香蕉视频 | 国产又粗又长的视频 | 欧美视频日韩视频 | 中文字幕欲求不满 | 国产一区二区在线看 | 99热精品在线 | 99se视频在线观看 | 国产精品久久久久久久毛片 | www九九热 | 麻豆va一区二区三区久久浪 | 91色一区二区三区 | 热久久影视 | 99久久这里只有精品 | 久久高清 | 中文字幕一区二区三区久久蜜桃 | 三上悠亚一区二区在线观看 | 日色在线视频 | 丁香激情视频 | 91九色国产| 欧美精彩视频在线观看 | 九草在线观看 | 久久国产美女视频 | 亚洲国产精品500在线观看 | 区一区二区三在线观看 | 人人澡人人草 | 国产成视频在线观看 | 久草在线电影网 | av免费观看高清 | 成人久久视频 | 日韩av午夜 | 亚洲视频中文 | 97超级碰碰碰视频在线观看 | 99视频在线免费 | 欧美另类v| 欧美日韩中文字幕综合视频 | 国产精品综合久久久久久 | 久久久资源 | 国内精品久久久久久久久久久 | 日本久久久久久久久 | 亚洲精品在线看 | 亚洲精品成人av在线 | 日韩av影片在线观看 | 在线免费观看羞羞视频 | www91在线观看 | 国产成人a亚洲精品v | 色婷丁香 | 久久精品美女视频网站 | 99re视频在线观看 | 17婷婷久久www| 香蕉视频国产在线 | 在线观看亚洲精品 | 中文字幕视频免费观看 | 在线国产欧美 | 午夜精品三区 | 免费黄色网址网站 | 欧美日韩精品综合 | 91理论片午午伦夜理片久久 | 国产亚洲精品女人久久久久久 | 久久理论视频 | 久久久人人人 | 欧美日韩中文字幕视频 | 国产在线观看一 | 日本高清免费中文字幕 | 国产91精品高清一区二区三区 | 久久女教师 | 在线观看你懂的网址 | 欧美激情第一页xxx 午夜性福利 | 亚洲年轻女教师毛茸茸 | 丰满少妇麻豆av | 日本三级吹潮在线 | 五月天国产 | 日韩中文在线观看 | 中文字幕亚洲在线观看 | 97小视频| 免费看v片网站 | 久久se视频 | 青青草国产在线 | 日韩欧美视频免费看 | 97超级碰碰碰碰久久久久 | 天堂v中文 | 在线播放精品一区二区三区 | 免费av在线网站 | 久青草电影| 久久tv视频 | 国产精品久久久久免费观看 | 中文字幕免费高清在线观看 | 日韩在线视频一区 | 色91av| 国产黄色免费看 | 国产一级二级视频 | 三级av网| 五月婷丁香网 | 免费网站看v片在线a | 在线观看久| 欧美视频日韩视频 | 亚州精品在线视频 | 五月婷香蕉久色在线看 | 久久久网页 | 97超碰人人| 91秒拍国产福利一区 | 91亚洲精品国偷拍自产在线观看 | 91在线网站| 1024手机在线看 | 国产 视频 久久 | 国产国语在线 | 国产精品18久久久久久久 | 中文字幕在线观看网址 | av 一区 二区 久久 | 99精品系列 | 国产精品色在线 | 99视频免费观看 | www.狠狠操.com | wwwwwww黄| 国产一区在线精品 | 玖玖玖在线 | 久免费| 国产精品日韩欧美一区二区 | 天天操网站| 久久精品久久久精品美女 | 国产日韩欧美在线观看 | 中文字幕av免费观看 | 精品国产一区二区三区久久久蜜臀 | 娇妻呻吟一区二区三区 | 日韩欧美在线观看一区二区三区 | 久久人人射 | 中文字幕在线影院 | 欧美精品久久天天躁 | 久久综合婷婷综合 | 四虎永久视频 | 97国产精品免费 | 91污视频在线观看 | 91在线中文字幕 | 久草在线久草在线2 | 国产一级精品视频 | 久久天堂精品视频 | 国产精品入口久久 | 99 色| 成人影片在线免费观看 | 成年人免费电影在线观看 | 天天舔天天搞 | 在线观看91网站 | 国产在线日本 | 日韩精品高清视频 | 国产精品久久久久久久久毛片 | 日本三级大片 | 色五月激情五月 | 欧美va天堂va视频va在线 | 在线成人小视频 | 99久久精品国产网站 | 久操中文字幕在线观看 | 99视频在线免费播放 | 日韩久久精品一区二区三区 | 日韩一级电影网站 | 成人午夜黄色影院 | 国产高h视频| 国产夫妻自拍av | 97精品视频在线 | 欧美激情第28页 | 91精品国产91 | 欧美国产日韩激情 | www.天天操.com| 在线一二三四区 | av五月婷婷 | 国产精品久久久久一区二区三区 | 黄色片免费电影 | 久久任你操 | 亚洲综合干| 国产在线观看 | 色多多污污 | 久久久久久久国产精品影院 | 亚洲精品在线一区二区 | 天天射综合网站 | 免费一级片在线 | 中文字幕中文字幕在线中文字幕三区 | 国产精品午夜av | 视频一区在线免费观看 | 在线观看视频你懂得 | 日韩网站免费观看 | 成人午夜剧场在线观看 | 香蕉视频啪啪 | zzijzzij亚洲日本少妇熟睡 | 国产伦理精品一区二区 | 久久国产经典 | 中文在线www | 超碰人人在线观看 | 亚洲视频精品在线 | www.伊人网| 黄色精品一区二区 | 碰超在线| 男女全黄一级一级高潮免费看 | 中文字幕一区二区三区乱码不卡 | 一区免费观看 | 日本女人在线观看 | 黄色成人在线网站 | 免费黄色av.| 久久免费视频网站 | 成人久久综合 | 婷婷丁香在线 | 不卡电影一区二区三区 | 麻豆视频入口 | 激情网婷婷 | 久精品一区| 九九久久精品视频 | 丝袜美腿一区 | 成人av高清在线观看 | 91九色丨porny丨丰满6 | 99国产高清 | 日韩精品电影在线播放 | 亚洲精品tv| 亚洲免费资源 | 中文字幕乱码一区二区 | 97超视频免费观看 | 欧美日韩高清一区二区三区 | 91欧美日韩国产 | 激情五月激情综合网 | 精品人人人人 | 美女中文字幕 | 97在线视频观看 | 99在线精品免费视频九九视 | 日韩二区三区在线 | 中文免费在线观看 | 在线电影 一区 | 亚洲精品影视在线观看 | 国产99re| 91大神精品视频在线观看 | 国产成视频在线观看 | 激情五月伊人 | 久草在线观看视频免费 | 久久久蜜桃 | 激情网色| 中文字幕在线观看免费 | 国产精品亚洲视频 | 在线观看视频三级 | 免费在线成人av | 亚洲精品美女久久17c | 久久精品99视频 | 色妞色视频一区二区三区四区 | 久久视频一区二区 | 黄色aaa级片| 激情影院在线观看 | 视频在线观看国产 | 国产一区二区久久久 | 黄色的片子 | 免费日韩视| 国产精品久久9 | 中文字幕一区二区三区乱码不卡 | av免费观看在线 | 天天操 夜夜操 | 色亚洲激情 | 国产97在线播放 | 丁香婷婷激情国产高清秒播 | 精品久久久久久久久久久久久 | 亚洲精品玖玖玖av在线看 | 91丨九色丨高潮 | 亚洲色影爱久久精品 | 免费看污在线观看 | 久久99久久99免费视频 | www.99在线观看| 欧美精品视 | 最近日本字幕mv免费观看在线 | 国产色 在线 | 天堂av网在线 | 久久久久美女 | 国产婷婷一区二区 | 亚洲伊人网在线观看 | 91av视频免费观看 | 欧美性久久久 | 国产涩涩网站 | 亚洲欧美视频在线 | 激情久久伊人 | 亚洲视频一区二区三区在线观看 | 久久高清片 | 在线a亚洲视频播放在线观看 | 国产精品国产自产拍高清av | 国产一区网址 | 欧美在线观看视频 | 丁香久久婷婷 | 亚洲视频第一页 | 91成年人视频 | 成人在线观看免费视频 | 久久天天躁夜夜躁狠狠85麻豆 | 狠狠色丁香婷婷综合久小说久 | 91女神的呻吟细腰翘臀美女 | 国产美女在线精品免费观看 | 婷婷六月丁香激情 | a成人v| 久久综合五月天 | 天堂在线视频免费观看 | 一级欧美一级日韩 | 欧美中文字幕第一页 | 蜜臀精品久久久久久蜜臀 | 亚洲理论在线 | 一区二区不卡在线观看 | av资源网在线播放 | 国产精品v欧美精品v日韩 | 在线观看中文字幕第一页 | 97日日碰人人模人人澡分享吧 | 中文字幕在线观看免费高清电影 | 五月天国产| www91在线| 成人黄色电影免费观看 | 在线观看一区视频 | 999久久久久 | 久久不射电影院 | 国产精品一区二区无线 | 天天天操操操 | 成人久久视频 | 伊人欧美 | www.玖玖玖 | 在线观看日本高清mv视频 | 中文字幕在线乱 | 午夜婷婷综合 | 久久涩视频 | 黄色免费观看视频 | 亚洲狠狠丁香婷婷综合久久久 | 亚洲一区二区麻豆 | 欧美a级在线免费观看 | 国产高清免费观看 | 99精品色| 91亚洲狠狠婷婷综合久久久 | aav在线| 国产剧情在线一区 | 久久久久久网址 | 国产一级黄色免费看 | 91人人人| 日韩一区精品 | 中文字幕一区二区三区四区视频 | 亚洲精品视频在线观看免费视频 | 天天干天天操天天入 | 揉bbb玩bbb少妇bbb | www.黄色小说.com | 一区二区三区精品在线 | 天天曰天天曰 | 一级一片免费观看 | 国产在线观看免费观看 | 国产精品视频大全 | 久久艹国产视频 | 激情综合婷婷 | 久久久久久久久久伊人 | 91亚洲精品久久久蜜桃 | 亚洲人成人在线 | 中文字幕成人一区 | 激情九九 | 国产精品久久99综合免费观看尤物 | 成年人在线观看免费视频 | 欧美不卡视频在线 | 在线观看视频精品 | 免费又黄又爽 | 亚洲国产欧美一区二区三区丁香婷 | 一本一本久久a久久精品综合妖精 | 日日摸日日碰 | 蜜桃视频在线观看一区 | 久香蕉| 中国老女人日b | 久久免费福利 | 国产精品第一页在线观看 | 天天干天天玩天天操 | 精品国模一区二区 | 久在线观看 | 91在线播放国产 | 国产一级大片在线观看 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 99国产情侣在线播放 | 深夜视频久久 | 国产免费影院 | 成人黄色小说视频 | 欧美一级久久久久 | 国产精品一区在线播放 | 五月婷婷视频 | 久久久久区 | 国产精品美女毛片真酒店 | 成人亚洲精品国产www | 中文字幕精品视频 | 久久99婷婷 | 免费看v片网站 | 韩国av一区二区三区 | 99在线观看视频网站 | 久草视频在线资源站 | 黄色av成人在线 | 国产亚洲精品久久19p | 天天射天天干天天 | 又黄又爽又湿又无遮挡的在线视频 | 少妇性bbb搡bbb爽爽爽欧美 | 免费中文字幕视频 | 99这里都是精品 | 国产经典 欧美精品 | 91福利在线导航 | 日本在线观看一区二区 | 欧美日韩国产一区二区三区在线观看 | 91豆麻精品91久久久久久 | 91 在线视频播放 | 五月花激情 | 欧美一级淫片videoshd | 最近日本mv字幕免费观看 | 91看片在线播放 | 黄色免费在线视频 | 日韩在线观看你懂得 | 成年人在线观看免费视频 | 五月天网站在线 | 色av男人的天堂免费在线 | 久久久久久久久久久网站 | 日韩精品一区在线观看 | 99在线视频播放 | 黄色a在线观看 | 国产三级视频在线 | 91.dizhi永久地址最新 | 最新国产精品拍自在线播放 | 国产一级二级三级在线观看 | 久久久久五月 | 91在线播放视频 | 亚洲欧美视频网站 | 91在线国产观看 | 婷婷久月 | 免费麻豆网站 | 欧美夫妻生活视频 | 最近中文字幕视频完整版 | www国产亚洲精品久久网站 | 欧美日韩成人一区 | 日日夜夜天天射 | 久久免费观看少妇a级毛片 久久久久成人免费 | 日韩高清精品免费观看 | 92国产精品久久久久首页 | 国产精品一区二区美女视频免费看 | 日韩三级免费观看 | 97成人精品视频在线播放 | 国产九九九九九 | 人人看人人 | 99久久www免费 | 精品一区二区久久久久久久网站 | 国产精品免费av | 国产91综合一区在线观看 | 在线香蕉视频 | av在线免费播放 | 人人爽人人乐 | 久久九九免费视频 | 亚洲黄a| 国产在线国偷精品产拍 | 国产丝袜高跟 | 九九热在线播放 | 亚洲精品电影在线 | 日韩成人在线免费观看 | 最新国产精品视频 | 国产一级精品视频 | 亚洲麻豆精品 | 色婷婷综合久久久 | 91九色蝌蚪国产 | 中文字幕在线播放一区二区 | 久久手机免费观看 | 国内视频一区二区 | 免费视频成人 | av免费看av | 中国一级片视频 | 在线视频a | 久久午夜免费视频 | 亚洲欧美日韩精品久久奇米一区 | 亚洲一区二区三区四区精品 | 999日韩 | 九九在线视频免费观看 | 亚洲欧美日韩国产一区二区三区 | 久久综合操 | 久久美女电影 | 最近更新中文字幕 | 国产特黄色片 | 国产视频九色蝌蚪 | 天堂av在线中文在线 | 免费观看一级成人毛片 | av官网在线 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 精品久久久久久久久久久久久 | 久久福利在线 | 日韩av中文在线观看 | 国产国产人免费人成免费视频 | 天天操天天操天天 | 成人99免费视频 | 天天综合视频在线观看 | 精品国产伦一区二区三区 | 亚洲视频h| 97视频在线观看免费 | 日韩av在线小说 | 黄色av网站在线观看免费 | 91在线麻豆 | 日韩二区在线播放 | 国产亚洲成人网 | 欧美韩国日本在线观看 | 永久免费av在线播放 | 国产69精品久久99的直播节目 | 亚洲综合少妇 | 日韩乱码在线 | 91成人在线看 | 亚洲国产操 | 久久精品2| 日韩免费大片 | 综合伊人av | 成人毛片一区 | 久草在线最新免费 | 国产精品国产三级国产不产一地 | 九九热精品视频在线观看 | 亚洲综合激情网 | 国产资源精品在线观看 | 午夜美女网站 | 婷婷伊人综合亚洲综合网 | 国产精品永久在线 | 日日综合网 | 国产精品一区二区在线观看 | 精品一区 精品二区 | 久久99亚洲热视 | 久久久2o19精品 | 九九视频精品免费 | 国产xx视频 | 日夜夜精品视频 | 91视频 - 88av | 婷婷播播网 | 久久久久久久久久久成人 | 成人午夜电影久久影院 | 日韩有码专区 | 激情综合五月天 | 欧美三级在线播放 | 婷婷色综 | 午夜免费视频网站 | 久久久久久久精 | 99视频网站 | 国产精品 日韩精品 | 亚洲乱码久久久 | 在线视频久久 | 西西人体4444www高清视频 | 久久久久久黄色 | 精品综合久久久 | 日韩a在线看 | 视频一区亚洲 | aaa毛片视频 | 亚洲综合爱| avove黑丝| 国产r级在线观看 | 日韩中文字幕视频在线观看 | 日日夜夜中文字幕 | 欧美激情va永久在线播放 | 国产日韩欧美综合在线 | 国产成人精品aaa | 国产精品久久久久久电影 | 日本精品视频免费观看 | 亚洲婷婷在线 | 网站在线观看日韩 | 日日爱av| 91夫妻视频 | 亚洲欧美日韩精品久久奇米一区 | 激情婷婷色 | 激情网色 | 亚洲最大成人网4388xx | 在线 成人 | 91在线免费观看国产 | 中文字幕在线免费播放 | 波多野结衣在线播放视频 | 黄色大片入口 | 一区精品在线 | 香蕉网站在线观看 | 国产精品女同一区二区三区久久夜 | 欧美极品xxxxx| 亚洲激情综合 | 国产99一区视频免费 | 国产精品24小时在线观看 | 久久久久激情视频 | 国产一级片视频 | 亚洲激情精品 | 日本久久免费电影 | 四虎成人精品永久免费av | 国产 日韩 欧美 在线 | 精品久久综合 | 在线性视频日韩欧美 | 天天干天天操av | 久草在线视频资源 | 日本在线观看视频一区 | 日韩中文字幕国产 | 午夜丰满寂寞少妇精品 | 亚洲欧美视频在线 | 91av在线免费观看 | 亚洲成a人片在线观看网站口工 | 最新国产在线 | 中文字幕一区二区三区四区视频 | 超碰免费av | 黄色亚洲 | 美女久久久久久 | 日韩精品一区二区三区在线视频 | 亚洲午夜久久久久久久久久久 | 特级xxxxx欧美 | 激情久久伊人 | 久久国色夜色精品国产 | 黄色网www | 精品久久久久国产免费第一页 | 日韩精品一区二区三区免费观看视频 | 麻豆影视在线播放 | 精品国产乱码久久久久 | 一区在线电影 | 激情久久五月天 | 日韩高清不卡一区二区三区 | 一区二区三区四区五区在线视频 | 国偷自产视频一区二区久 | 国产精品永久在线观看 | 国产精品一区二区久久 | 91精品免费在线观看 | 福利视频导航网址 | 五月天天色 | 色偷偷网站视频 | 国内免费的中文字幕 | 精品久久国产 | 成人精品99 | 日韩一级片网址 | 最近中文字幕免费大全 | 久草在线视频首页 | 久久久免费 | 国产精久久久 | 亚洲一区欧美激情 | 天天翘av| 国产一区黄色 | 日韩高清毛片 | 91精品国产综合久久久久久久 | 婷婷丁香自拍 | av大全在线观看 | 91社区国产高清 | 视频一区二区三区视频 | 97在线看片 | 久久毛片网 | 国产啊v在线观看 | 国产中文字幕一区二区三区 | 亚洲激情六月 | 狠狠色丁香婷婷综合基地 | 青青五月天 | 欧美在线不卡一区 | aaa亚洲精品一二三区 | 一区二区三区国产欧美 | 国产亚洲精品美女 | 国产天天综合 | 亚洲一区二区三区毛片 | 精品不卡av | 中文字幕91视频 | 美女又爽又黄 | 麻豆国产电影 | 精品视频在线播放 | 五月综合在线观看 | 亚洲精品在线一区二区 | 欧美伦理电影一区二区 | 日本在线视频一区二区三区 | 国产精品人人做人人爽人人添 | 97在线视 | 一区三区视频在线观看 | 中文字幕av最新更新 | 日本黄色免费电影网站 | 成人动漫精品一区二区 | 欧美精品999| av在线亚洲天堂 | 深爱激情站 | 亚洲干视频在线观看 | 日韩视频中文 | 最近中文国产在线视频 | 国产在线不卡精品 | 2018好看的中文在线观看 | 国产成人一区在线 | 久久伊人婷婷 | 国产精品麻豆视频 | 日韩精品视频免费在线观看 | 免费看黄电影 | 在线亚洲人成电影网站色www | 日韩a在线播放 | 91av精品| 国产一区欧美一区 | 成人97人人超碰人人99 | 欧美日韩3p| 99婷婷| 精品国产黄色片 | 天天草av | 久99久在线 | 免费h视频 | 久久一区国产 | 24小时日本在线www免费的 | 91人网站 | 国产精品嫩草在线 | 免费中午字幕无吗 | 久久久久久久久久久久电影 | 中文字幕第| 婷婷综合电影 | www.干| 亚洲1区 在线 | 高清不卡毛片 | 亚洲精品久久久久www | 在线黄色观看 | 99久久精品免费一区 | 91女子私密保健养生少妇 | 丁香色综合 | 四虎永久国产精品 | 我要色综合天天 | 中文字幕av全部资源www中文字幕在线观看 | 免费黄色在线 | 男女啪啪网站 | 天天干.com | 国产色在线| 国产一级二级三级视频 | 超碰av在线| 国产精品永久免费 | 中文字幕精品在线 | 91丨九色丨首页 | 91精品一区二区在线观看 | 久久久综合香蕉尹人综合网 | 亚洲人在线视频 | 日韩精品在线视频 | 国产精品久久久久久久久久直播 | 伊人av综合| 国产中文字幕一区二区 | 2019中文 | 91tv国产成人福利 | 六月色丁香 | 91色在线观看视频 | 国产免费久久 | 国产原创av在线 | 91九色综合 | 91大神在线观看视频 | 日本丶国产丶欧美色综合 | 精品伦理一区二区三区 | 国产一级片不卡 | 日本特黄一级片 | 免费在线观看av网址 | 射久久 | 国产福利精品一区二区 | 成人在线一区二区三区 | 久久久免费精品国产一区二区 | 久久在视频 | 天天操夜操视频 | 精品一区二区三区久久久 | 中文字幕在线视频一区二区三区 | 99久久精品国产免费看不卡 | 国产一区成人 | 精品国产一区二区在线 | 精品免费视频123区 午夜久久成人 | 在线电影av | 久久伦理电影网 | 免费在线国产精品 | 最近中文字幕在线 | 亚洲国产精品一区二区久久hs | 日日操天天操夜夜操 | 久久精品视频3 | 人人干人人添 | 久久国产免 | 国产精品系列在线播放 | 成人一区二区三区在线观看 | 欧美一区二区精品在线 | 国产精品一区专区欧美日韩 | av一本久道久久波多野结衣 | 亚洲性视频 | 夜夜操狠狠操 | 成人黄色电影视频 | 欧美一级在线观看视频 | 91热视频| 国产国语在线 | 综合激情av| 一区二区视频在线免费观看 | 国产精品一区一区三区 | 国产精品亚洲片夜色在线 | 精品国产自在精品国产精野外直播 | 中文字幕 影院 | 亚洲理论片在线观看 | 日韩视频www| 亚洲美女视频网 | 国产九九在线 | 特级西西444www大胆高清无视频 | 在线播放视频一区 | 黄色a一级片 | 国产精品久久久久久五月尺 | 毛片精品免费在线观看 | 在线观看免费视频你懂的 | www欧美色| 国产精品在线看 | 精品在线不卡 | 天天操福利视频 | 超碰在线观看99 | 少妇性xxx | 午夜国产在线观看 | 欧美一级在线 | 午夜视频福利 | 一区二区三区四区五区在线 | 狠狠色丁香婷婷综合 | 日韩久久精品 | 国产a网站 | 日韩免费在线视频观看 | 久久精品视频日本 | 一区二区视频电影在线观看 | 99r在线 | 亚洲视频 视频在线 | 国产99在线| 国产xxxx性hd极品 | 一区二区三区免费在线观看 | 国产亚洲人成网站在线观看 | av大片网址 | 中文字幕亚洲在线观看 | 伊人婷婷 | 免费精品在线观看 | 97超级碰碰碰视频在线观看 | 免费在线观看av网址 | 超碰国产97 | 在线视频app| 欧洲色吧| 五月天婷婷在线播放 | 探花在线观看 | 国产精品久久一区二区三区不卡 | 日韩久久精品一区二区三区 | 亚洲资源视频 | 亚洲综合网 | 日本深夜福利视频 | 国产在线看一区 | 中文字幕免费观看视频 | 91麻豆精品国产91久久久久 | 久草| 麻豆精品国产传媒 | 在线观看国产成人av片 | 九九三级毛片 | 在线观av| 久久人人97超碰精品888 | 日本成址在线观看 | 欧美精品第一 | 亚洲欧美乱综合图片区小说区 | 日韩精品视频一二三 | 国产中文a| 黄色网址a| 久久久www成人免费毛片麻豆 | 免费av在线网 | 99中文字幕视频 | 狠狠狠狠狠狠狠狠 | 成人久久久精品国产乱码一区二区 | 国产精品刺激对白麻豆99 | 国产精品99久久久久的智能播放 | 米奇影视7777 | 国产中文字幕在线看 | 国产美女在线免费观看 | 91在线公开视频 | 狠狠色丁香久久婷婷综合_中 | 亚洲欧美日韩一区二区三区在线观看 | 免费日韩一区二区三区 | 色夜视频 | 天天色天天综合 | 一区二区三区视频网站 | 91av在线播放视频 | 亚洲精选国产 | 狠狠色丁香婷婷综合基地 | 欧美日韩国产在线 | 午夜精品中文字幕 | 中文av在线免费观看 | 日本亚洲国产 | 国产一二三在线视频 | 日韩国产精品毛片 | 日韩,精品电影 | 久久高视频 | 国产91在线 | 美洲 | 在线成人短视频 | 777奇米四色 | 免费99精品国产自在在线 | 91成人破解版 | 久久影视一区二区 | 深夜福利视频在线观看 | 激情视频免费在线观看 | 国产99精品在线观看 | 日韩午夜av | 五月天综合婷婷 | 日本精品中文字幕在线观看 | 一区二区三区免费在线 | 欧美精品乱码久久久久久按摩 | 天天天干夜夜夜操 | 久久视频99| 精品一区二区在线播放 | 久草久草在线观看 | 91九色成人蝌蚪首页 | 久久九九影视 | 日日草视频 | 久久久黄色免费网站 | 最近日韩中文字幕中文 | 国产精在线 | 久久看片网站 | 天天爽天天做 | 久草精品视频在线看网站免费 | 亚洲日b视频 | 免费在线一区二区 | 精品在线视频一区二区三区 | 欧美嫩草影院 | 色婷婷一 | 天天操综 | 免费h精品视频在线播放 | 国产精品一区二区三区99 | 久草在线资源观看 | 8x8x在线观看视频 | 黄污污网站| 亚洲成人免费在线 | 亚洲欧洲成人精品av97 | 99精品久久久久久久 | 久久久99精品免费观看乱色 | 亚洲视频456 | 精品亚洲视频在线观看 | a在线免费观看视频 | 日韩极品在线 | 成人黄色电影在线 | www天天操| 国产亚洲免费观看 | 久久九九免费视频 | 99久久久久久久久久 | .国产精品成人自产拍在线观看6 | 国产九九九视频 | 欧美日韩在线免费视频 | 精品国产免费久久 | 精品一区二区久久久久久久网站 | 91成人午夜 | 国产高清黄色 | 久久久午夜剧场 | 成人在线观看免费视频 | 大型av综合网站 | 日韩免费一区二区在线观看 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 91视频下载 |