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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

高并发之API接口,分布式,防刷限流,如何做?

發布時間:2024/4/11 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 高并发之API接口,分布式,防刷限流,如何做? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

點擊上方“朱小廝的博客”,選擇“設為星標”

后臺回復”加群“加入公眾號專屬技術群

在開發分布式高并發系統時有三把利器用來保護系統:緩存、降級、限流

緩存

緩存的目的是提升系統訪問速度和增大系統處理容量

降級

降級是當服務出現問題或者影響到核心流程時,需要暫時屏蔽掉,待高峰或者問題解決后再打開

限流

限流的目的是通過對并發訪問/請求進行限速,或者對一個時間窗口內的請求進行限速來保護系統,一旦達到限制速率則可以拒絕服務、排隊或等待、降級等處理

問題描述

1、某天A君突然發現自己的接口請求量突然漲到之前的10倍,沒多久該接口幾乎不可使用,并引發連鎖反應導致整個系統崩潰。如何應對這種情況呢?生活給了我們答案:比如老式電閘都安裝了保險絲,一旦有人使用超大功率的設備,保險絲就會燒斷以保護各個電器不被強電流給燒壞。同理我們的接口也需要安裝上“保險絲”,以防止非預期的請求對系統壓力過大而引起的系統癱瘓,當流量過大時,可以采取拒絕或者引流等機制。整編:微信公眾號,搜云庫技術團隊,ID:souyunku

2、緩存的目的是提升系統訪問速度和增大系統能處理的容量,可謂是抗高并發流量的銀彈;而降級是當服務出問題或者影響到核心流程的性能則需要暫時屏蔽掉,待高峰或者問題解決后再打開;而有些場景并不能用緩存和降級來解決,比如稀缺資源(秒殺、搶購)、寫服務(如評論、下單)、頻繁的復雜查詢(評論的最后幾頁),因此需有一種手段來限制這些場景的并發/請求量,即限流。

3、系統在設計之初就會有一個預估容量,長時間超過系統能承受的TPS/QPS閾值,系統可能會被壓垮,最終導致整個服務不夠用。為了避免這種情況,我們就需要對接口請求進行限流。

4、限流的目的是通過對并發訪問請求進行限速或者一個時間窗口內的的請求數量進行限速來保護系統,一旦達到限制速率則可以拒絕服務、排隊或等待。

5、一般開發高并發系統常見的限流模式有控制并發和控制速率,一個是限制并發的總數量(比如數據庫連接池、線程池),一個是限制并發訪問的速率(如nginx的limitconn模塊,用來限制瞬時并發連接數),另外還可以限制單位時間窗口內的請求數量(如Guava的RateLimiter、nginx的limitreq模塊,限制每秒的平均速率)。其他還有如限制遠程接口調用速率、限制MQ的消費速率。另外還可以根據網絡連接數、網絡流量、CPU或內存負載等來限流。

相關概念:

PV:

page view 頁面總訪問量,每刷新一次記錄一次。

UV:

unique view 客戶端主機訪問,指一天內相同IP的訪問記為1次。

QPS:

query per second,即每秒訪問量。qps很大程度上代表了系統的繁忙度,沒次請求可能存在多次的磁盤io,網絡請求,多個cpu時間片,一旦qps超過了預先設置的閥值,可以考量擴容增加服務器,避免訪問量過大導致的宕機。整編:微信公眾號,搜云庫技術團隊,ID:souyunku

RT:

response time,每次請求的響應時間,直接決定用戶體驗性。

本文主要介紹應用級限流方法,分布式限流、流量入口限流(接入層如NGINX limitconn和limitreq 模塊)。

應用級限流

一、控制并發數量

屬于一種較常見的限流手段,在實際應用中可以通過信號量機制(如Java中的Semaphore)來實現。操作系統的信號量是個很重要的概念,Java 并發庫 的Semaphore 可以很輕松完成信號量控制,Semaphore可以控制某個資源可被同時訪問的個數,通過 acquire() 獲取一個許可,如果沒有就等待,而 release() 釋放一個許可。

舉個例子,我們對外提供一個服務接口,允許最大并發數為10,代碼實現如下:

public class DubboService {private final Semaphore permit = new Semaphore(10, true);public void process(){try{permit.acquire();//業務邏輯處理} catch (InterruptedException e) {e.printStackTrace();} finally {permit.release();}} }

在以上代碼中,雖然有30個線程在執行,但是只允許10個并發的執行。Semaphore的構造方法Semaphore(int permits) 接受一個整型的數字,表示可用的許可證數量。Semaphore(10)表示允許10個線程獲取許可證,也就是最大并發數是10。Semaphore的用法也很簡單,首先線程使用Semaphore的acquire()獲取一個許可證,使用完之后調用release()歸還許可證,還可以用tryAcquire()方法嘗試獲取許可證,信號量的本質是控制某個資源可被同時訪問的個數,在一定程度上可以控制某資源的訪問頻率,但不能精確控制,控制訪問頻率的模式見下文描述。

二、控制訪問速率

在工程實踐中,常見的是使用令牌桶算法來實現這種模式,常用的限流算法有兩種:漏桶算法和令牌桶算法。

漏桶算法

漏桶算法思路很簡單,水(請求)先進入到漏桶里,漏桶以一定的速度出水,當水流入速度過大會直接溢出,可以看出漏桶算法能強行限制數據的傳輸速率。

對于很多應用場景來說,除了要求能夠限制數據的平均傳輸速率外,還要求允許某種程度的突發傳輸。這時候漏桶算法可能就不合適了,令牌桶算法更為適合。

令牌桶算法

如圖所示,令牌桶算法的原理是系統會以一個恒定的速度往桶里放入令牌,而如果請求需要被處理,則需要先從桶里獲取一個令牌,當桶里沒有令牌可取時,則拒絕服務,令牌桶算法通過發放令牌,根據令牌的rate頻率做請求頻率限制,容量限制等。整編:微信公眾號,搜云庫技術團隊,ID:souyunku

在Wikipedia上,令牌桶算法是這么描述的:

1、每過1/r秒桶中增加一個令牌。

2、桶中最多存放b個令牌,如果桶滿了,新放入的令牌會被丟棄。

3、當一個n字節的數據包到達時,消耗n個令牌,然后發送該數據包。

4、如果桶中可用令牌小于n,則該數據包將被緩存或丟棄。

令牌桶控制的是一個時間窗口內通過的數據量,在API層面我們常說的QPS、TPS,正好是一個時間窗口內的請求量或者事務量,只不過時間窗口限定在1s罷了。以一個恒定的速度往桶里放入令牌,而如果請求需要被處理,則需要先從桶里獲取一個令牌,當桶里沒有令牌可取時,則拒絕服務。令牌桶的另外一個好處是可以方便的改變速度,一旦需要提高速率,則按需提高放入桶中的令牌的速率。

在我們的工程實踐中,通常使用Google開源工具包Guava提供的限流工具類RateLimiter來實現控制速率,該類基于令牌桶算法來完成限流,非常易于使用,而且非常高效。如我們不希望每秒的任務提交超過1個

public static void main(String[] args) {String start = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());RateLimiter limiter = RateLimiter.create(1.0); // 這里的1表示每秒允許處理的量為1個for (int i = 1; i <= 10; i++) {double waitTime = limiter.acquire(i); // 請求RateLimiter, 超過permits會被阻塞System.out.println("cutTime=" + System.currentTimeMillis() + " call execute:" + i + " waitTime:" + waitTime);}String end = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());System.out.println("start time:" + start);System.out.println("end time:" + end); }

首先通過RateLimiter.create(1.0);創建一個限流器,參數代表每秒生成的令牌數,通過limiter.acquire(i);來以阻塞的方式獲取令牌,令牌桶算法允許一定程度的突發(允許消費未來的令牌),所以可以一次性消費i個令牌;當然也可以通過tryAcquire(int permits, long timeout, TimeUnit unit)來設置等待超時時間的方式獲取令牌,如果超timeout為0,則代表非阻塞,獲取不到立即返回,支持阻塞或可超時的令牌消費。

從輸出來看,RateLimiter支持預消費,比如在acquire(5)時,等待時間是4秒,是上一個獲取令牌時預消費了3個兩排,固需要等待3*1秒,然后又預消費了5個令牌,以此類推。

RateLimiter通過限制后面請求的等待時間,來支持一定程度的突發請求(預消費),在使用過程中需要注意這一點,Guava有兩種限流模式,一種為穩定模式(SmoothBursty:令牌生成速度恒定,平滑突發限流),一種為漸進模式(SmoothWarmingUp:令牌生成速度緩慢提升直到維持在一個穩定值,平滑預熱限流) 兩種模式實現思路類似,主要區別在等待時間的計算上。

SmoothBursty 模式:

RateLimiter limiter = RateLimiter.create(5); RateLimiter.create(5)表示桶容量為5且每秒新增5個令牌,即每隔200毫秒新增一個令牌;limiter.acquire()表示消費一個令牌,如果當前桶中有足夠令牌則成功(返回值為0),如果桶中沒有令牌則暫停一段時間,比如發令牌間隔是200毫秒,則等待200毫秒后再去消費令牌,這種實現將突發請求速率平均為了固定請求速率。

SmoothWarmingUp模式:

RateLimiter limiter = RateLimiter.create(5,1000, TimeUnit.MILLISECONDS);

創建方式:

RateLimiter.create(doublepermitsPerSecond, long warmupPeriod, TimeUnit unit),permitsPerSecond表示每秒新增的令牌數,warmupPeriod表示在從冷啟動速率過渡到平均速率的時間間隔。速率是梯形上升速率的,也就是說冷啟動時會以一個比較大的速率慢慢到平均速率;然后趨于平均速率(梯形下降到平均速率)。可以通過調節warmupPeriod參數實現一開始就是平滑固定速率。整編:微信公眾號,搜云庫技術團隊,ID:souyunku

放在Controller中用Jemter壓測

注:RateLimiter控制的是速率,Samephore控制的是并發量。RateLimiter的原理就是令牌桶,它主要由許可發出的速率來定義,如果沒有額外的配置,許可證將按每秒許可證規定的固定速度分配,許可將被平滑地分發,若請求超過permitsPerSecond則RateLimiter按照每秒 1/permitsPerSecond 的速率釋放許可。注意:RateLimiter適用于單體應用,且RateLimiter不保證公平性訪問。

使用上述方式使用RateLimiter的方式不夠優雅,自定義注解+AOP的方式實現(適用于單體應用),詳細見下面代碼:

自定義注解:

import java.lang.annotation.*; /*** 自定義注解可以不包含屬性,成為一個標識注解*/ @Inherited @Documented @Target({ElementType.METHOD, ElementType.FIELD, ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) public @interface RateLimitAspect { }

自定義切面類

import com.google.common.util.concurrent.RateLimiter; import com.test.cn.springbootdemo.util.ResultUtil; import net.sf.json.JSONObject; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Pointcut; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Scope; import org.springframework.stereotype.Component; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletResponse; import java.io.IOException; @Component @Scope @Aspect public class RateLimitAop {@Autowiredprivate HttpServletResponse response;private RateLimiter rateLimiter = RateLimiter.create(5.0); //比如說,我這里設置"并發數"為5@Pointcut("@annotation(com.test.cn.springbootdemo.aspect.RateLimitAspect)")public void serviceLimit() {}@Around("serviceLimit()")public Object around(ProceedingJoinPoint joinPoint) {Boolean flag = rateLimiter.tryAcquire();Object obj = null;try {if (flag) {obj = joinPoint.proceed();}else{String result = JSONObject.fromObject(ResultUtil.success1(100, "failure")).toString();output(response, result);}} catch (Throwable e) {e.printStackTrace();}System.out.println("flag=" + flag + ",obj=" + obj);return obj;}public void output(HttpServletResponse response, String msg) throws IOException {response.setContentType("application/json;charset=UTF-8");ServletOutputStream outputStream = null;try {outputStream = response.getOutputStream();outputStream.write(msg.getBytes("UTF-8"));} catch (IOException e) {e.printStackTrace();} finally {outputStream.flush();outputStream.close();}} }

測試controller

import com.test.cn.springbootdemo.aspect.RateLimitAspect; import com.test.cn.springbootdemo.util.ResultUtil; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; @Controller public class TestController {@ResponseBody@RateLimitAspect@RequestMapping("/test")public String test(){return ResultUtil.success1(1001, "success").toString();}

壓測結果:

三、控制單位時間窗口內請求數

某些場景下,我們想限制某個接口或服務 每秒/每分鐘/每天 的請求次數或調用次數。例如限制服務每秒的調用次數為50,實現如下:

private LoadingCache < Long, AtomicLong > counter = CacheBuilder.newBuilder().expireAfterWrite(2, TimeUnit.SECONDS).build(new CacheLoader < Long, AtomicLong > () {@Overridepublic AtomicLong load(Long seconds) throws Exception {return new AtomicLong(0);} }); public static long permit = 50; public ResponseEntity getData() throws ExecutionException {//得到當前秒long currentSeconds = System.currentTimeMillis() / 1000;if (counter.get(currentSeconds).incrementAndGet() > permit) {return ResponseEntity.builder().code(404).msg("訪問速率過快").build();}//業務處理 }

到此應用級限流的一些方法就介紹完了。假設將應用部署到多臺機器,應用級限流方式只是單應用內的請求限流,不能進行全局限流。因此我們需要分布式限流和接入層限流來解決這個問題。

分布式限流

自定義注解+攔截器+Redis實現限流 (單體和分布式均適用,全局限流)

自定義注解:

@Inherited @Documented @Target({ElementType.FIELD,ElementType.TYPE,ElementType.METHOD}) @Retention(RetentionPolicy.RUNTIME) public @interface AccessLimit {int limit() default 5; int sec() default 5; }

攔截器:

public class AccessLimitInterceptor implements HandlerInterceptor {@Autowiredprivate RedisTemplate<String, Integer> redisTemplate; //使用RedisTemplate操作redis@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {if (handler instanceof HandlerMethod) {HandlerMethod handlerMethod = (HandlerMethod) handler;Method method = handlerMethod.getMethod();if (!method.isAnnotationPresent(AccessLimit.class)) {return true;}AccessLimit accessLimit = method.getAnnotation(AccessLimit.class);if (accessLimit == null) {return true;}int limit = accessLimit.limit();int sec = accessLimit.sec();String key = IPUtil.getIpAddr(request) + request.getRequestURI();Integer maxLimit = redisTemplate.opsForValue().get(key);if (maxLimit == null) {redisTemplate.opsForValue().set(key, 1, sec, TimeUnit.SECONDS); //set時一定要加過期時間} else if (maxLimit < limit) {redisTemplate.opsForValue().set(key, maxLimit + 1, sec, TimeUnit.SECONDS);} else {output(response, "請求太頻繁!");return false;}}return true;}public void output(HttpServletResponse response, String msg) throws IOException {response.setContentType("application/json;charset=UTF-8");ServletOutputStream outputStream = null;try {outputStream = response.getOutputStream();outputStream.write(msg.getBytes("UTF-8"));} catch (IOException e) {e.printStackTrace();} finally {outputStream.flush();outputStream.close();}}@Overridepublic void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {}@Overridepublic void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {} }

controller:

@Controller @RequestMapping("/activity") public class AopController {@ResponseBody@RequestMapping("/seckill")@AccessLimit(limit = 4,sec = 10) //加上自定義注解即可public String test (HttpServletRequest request,@RequestParam(value = "username",required = false) String userName){//TODO somethings……return "hello world !";} }

配置文件:

/*springmvc的配置文件中加入自定義攔截器*/ <mvc:interceptors><mvc:interceptor><mvc:mapping path="/**"/><bean class="com.pptv.activityapi.controller.pointsmall.AccessLimitInterceptor"/></mvc:interceptor> </mvc:interceptors>

訪問效果如下,10s內訪問接口超過4次以上就過濾請求,原理和計數器算法類似:

接入層限流

主要介紹nginx 限流,采用漏桶算法。

限制原理:可一句話概括為:“根據客戶端特征,限制其訪問頻率”,客戶端特征主要指IP、UserAgent等。使用IP比UserAgent更可靠,因為IP無法造假,UserAgent可隨意偽造。整編:微信公眾號,搜云庫技術團隊,ID:souyunku

用limit_req模塊來限制基于IP請求的訪問頻率:

http://nginx.org/en/docs/http/ngxhttplimitreqmodule.html

也可以用tengine中的增強版:

http://tengine.taobao.org/documentcn/httplimitreqcn.html

1、并發數和連接數控制的配置:

nginx http配置:#請求數量控制,每秒20個limit_req_zone $binary_remote_addr zone=one:10m rate=20r/s;#并發限制30個limit_conn_zone $binary_remote_addr zone=addr:10m;server塊配置limit_req zone=one burst=5;limit_conn addr 30;

2、ngxhttplimitconnmodule 可以用來限制單個IP的連接數:

ngxhttplimitconnmodule模塊可以按照定義的鍵限定每個鍵值的連接數。可以設定單一 IP 來源的連接數。

并不是所有的連接都會被模塊計數;只有那些正在被處理的請求(這些請求的頭信息已被完全讀入)所在的連接才會被計數。

http {limit_conn_zone $binary_remote_addr zone=addr:10m;...server {...location /download/ {limit_conn addr 1;}

以上文章部分出自網絡,參考鏈接如下:

https://blog.csdn.net/fanrenxiang/article/details/80683378

https://blog.csdn.net/top_code/article/details/53242262

https://blog.csdn.net/u010889390/article/details/82151903

想知道更多?描下面的二維碼關注我

【精彩推薦】

  • 入侵你Linux服務器的一萬種玩法...

  • 一個字符串到底能有多少個字符?看完我卻不會了

  • 數據庫分庫分表解決方案匯總!

  • redis面試連環問,快看看你能走到哪一步

朕已閱?

總結

以上是生活随笔為你收集整理的高并发之API接口,分布式,防刷限流,如何做?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

日韩视频免费 | 亚洲精品欧美精品 | 天天天干天天天操 | 久草久草久草久草 | www.精选视频.com | 精品国产理论片 | 国产高清在线观看 | 国产美女在线观看 | 国产精品久久久久久久久久久不卡 | 日韩视频在线不卡 | 国产精品美女久久久久久2018 | 九九九九精品九九九九 | 日韩精品一区二区三区免费观看 | 久久婷婷一区二区三区 | 久久在线免费观看 | 91一区一区三区 | 日韩超碰在线 | 成人小视频在线播放 | 精品国产综合区久久久久久 | 欧美亚洲专区 | 99草在线视频 | 一区免费观看 | 特黄色大片 | 91最新中文字幕 | 成年人免费在线观看网站 | 免费精品国产va自在自线 | 91污污| 中文字幕在线观看91 | 在线播放国产一区二区三区 | 91人人干 | 国产视频精品免费 | 天堂成人在线 | 亚洲国产精品成人女人久久 | av电影不卡在线 | 国产永久网站 | 成人全视频免费观看在线看 | 一区二区视频网站 | 亚色视频在线观看 | 粉嫩av一区二区三区四区在线观看 | 四虎永久免费在线观看 | 日韩精品欧美专区 | 99久久婷婷国产综合精品 | 丁香六月av | 中文字幕 国产专区 | av电影免费在线播放 | 91麻豆精品国产91久久久久久久久 | 久久国精品 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 久久久久亚洲国产精品 | 激情久久一区二区三区 | 四虎在线免费观看 | 人成在线免费视频 | 日韩精品一区二区免费视频 | 亚洲午夜电影网 | 日本久久中文 | 蜜桃视频成人在线观看 | 日免费视频 | 97精品国产97久久久久久 | 午夜av在线播放 | 天天伊人网 | 国产中文字幕在线视频 | 欧美男同视频网站 | 久久99亚洲精品久久久久 | 91精品国产高清自在线观看 | 狠狠地操 | 成人午夜电影久久影院 | 免费成人结看片 | 亚洲视频 一区 | 日本久久久久久 | 99精品在线观看 | avove黑丝 | 日韩a在线播放 | 五月婷婷一区二区三区 | 国产精品毛片久久久久久久久久99999999 | 亚洲精品乱码久久久久久蜜桃欧美 | 六月丁香在线视频 | 91亚洲精品乱码久久久久久蜜桃 | 久久久久久福利 | 911国产在线观看 | 最近中文字幕视频网 | 中文超碰字幕 | 国产精品成人免费 | 欧美日韩高清一区二区 | 中文区中文字幕免费看 | 日韩在线观看 | 日日操夜夜操狠狠操 | 久久久久久免费网 | 久久成人一区 | 欧美精品中文字幕亚洲专区 | 国产一区视频在线 | 久久1区 | 免费在线激情电影 | 国产美女免费观看 | 99精品视频一区二区 | 国产99精品 | 美女网站黄在线观看 | 亚洲一级二级三级 | 日日夜夜免费精品视频 | 亚洲欧美日韩不卡 | 国产第一页福利影院 | 99精品一区| 五月婷婷,六月丁香 | 久久蜜臀av | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 青青草国产成人99久久 | 97精品国自产拍在线观看 | a在线一区 | 久久精品婷婷 | 色中文字幕在线观看 | 日韩乱色精品一区二区 | www亚洲精品| 国产免费a | 婷婷久久五月天 | 国产精品女同一区二区三区久久夜 | 日韩电影在线观看一区二区三区 | 国产裸体永久免费视频网站 | 91精品国产福利在线观看 | 成人午夜黄色 | 91麻豆操 | 亚洲人在线视频 | 国产精品一区二区 91 | 在线观看视频你懂得 | 久久精品亚洲一区二区三区观看模式 | 99久久99久久 | 99久热在线精品视频成人一区 | av动态图片 | 久久呀 | 久久久久久久久久久福利 | 91麻豆文化传媒在线观看 | 午夜丁香视频在线观看 | 夜添久久精品亚洲国产精品 | 国产欧美日韩一区 | 最新动作电影 | 97超碰在线人人 | 超碰99在线 | 久久免费a | 久久在现| 国产精品96久久久久久吹潮 | 欧美日韩精品综合 | 蜜臀91丨九色丨蝌蚪老版 | 亚洲国产精品日韩 | 99久久99热这里只有精品 | www国产一区 | 久久一区二区三区国产精品 | 免费看三片 | 日本精品视频一区二区 | 九九热免费精品视频 | 亚洲第一香蕉视频 | 午夜影视一区 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 香蕉影院在线 | 中中文字幕av在线 | 国产亚洲免费的视频看 | 成人一级影视 | 黄色不卡av| 91av99| 天天干天天拍天天操 | av一本久道久久波多野结衣 | 黄色的网站免费看 | 中文字幕av在线免费 | 午夜影院三级 | 麻豆一区在线观看 | 日日躁你夜夜躁你av蜜 | 在线观看色视频 | 久热电影| 一区二区三区四区在线 | 四虎成人精品 | 国产精品一区二区av日韩在线 | 美女国产精品 | 久久久久久久网站 | 久久深夜福利免费观看 | 国产视频精品免费 | 国产中文字幕一区 | 成人免费观看视频网站 | 久久精品久久精品久久 | 亚洲国产成人久久 | 久久99精品国产99久久6尤 | 久久久精选 | 国产精品一区免费看8c0m | 91免费看黄 | 日韩久久精品一区二区 | 国产成人精品免费在线观看 | 亚洲男人天堂a | 日韩av网站在线播放 | 伊人天天综合 | 91网页版在线观看 | 免费黄色网址网站 | 国产日产高清dvd碟片 | 久热精品国产 | 又黄又刺激视频 | 久久99久久99精品免观看粉嫩 | 69国产在线观看 | 欧美激情综合五月 | 日韩一区二区三区在线看 | 国产精品第十页 | 91影视成人 | 国产精品久久久久婷婷 | 成人羞羞免费 | 久久久久亚洲精品国产 | 免费一级日韩欧美性大片 | 观看免费av| 9999精品免费视频 | 精品国产123 | 黄色免费网 | 国产精选在线 | 激情久久久久 | 国产区av在线 | 成人一区电影 | 激情综合网五月激情 | 久久久久国产精品午夜一区 | 成人网在线免费视频 | 国产黄在线看 | 少妇自拍av | 国产一级片毛片 | 国产专区视频 | 免费看久久久 | 在线免费黄色毛片 | 亚洲一区免费在线 | 91手机电影 | av在线中文 | 中文av在线免费观看 | 免费久久久久久久 | 成年人视频免费在线播放 | 亚洲黄色一级电影 | 国内精品久久久久久久影视麻豆 | 伊人伊成久久人综合网站 | 国产福利一区二区在线 | 一区二区三区四区五区在线视频 | 国产午夜三级一二三区 | 国产美女搞久久 | 欧美性生活免费 | 91精品国自产拍天天拍 | 亚洲成人精品av | 天天色.com | 西西www4444大胆视频 | 狠狠色狠狠色 | 久久免费成人精品视频 | 99精品欧美一区二区三区 | 999久久国精品免费观看网站 | 欧美色图p| 青草视频在线 | 日韩av在线高清 | 亚洲狠狠丁香婷婷综合久久久 | 成x99人av在线www| 91一区啪爱嗯打偷拍欧美 | 91影视成人 | 日韩av电影免费观看 | 国产精品18久久久久白浆 | 五月婷婷综合激情网 | 免费在线色视频 | 国产精品久久久久aaaa九色 | 久久91网| 国产高清不卡一区二区三区 | 天天操天天干天天爱 | 亚洲视频久久 | 中文在线a∨在线 | 久久论理| 中文字幕美女免费在线 | 黄色a级片在线观看 | 国产成人a亚洲精品 | 婷婷国产视频 | 免费视频色| 在线免费试看 | 国产 一区二区三区 在线 | 五月天电影免费在线观看一区 | 国产精品美女久久久久久久 | 国产色网站 | 天天插日日射 | 欧美大香线蕉线伊人久久 | 亚洲精品成人免费 | 久久精品久久国产 | 久久久久久久影视 | 天天操操操操操 | 久久精品久久久久电影 | 亚洲日韩精品欧美一区二区 | 中文字幕资源站 | 九九热免费视频在线观看 | 免费a v网站 | 欧洲高潮三级做爰 | 黄色亚洲 | 国产成人精品一区二区三区福利 | 久久精品99国产精品日本 | 日韩系列| 免费在线观看成年人视频 | 天天操天天干天天操天天干 | 黄色毛片网站在线观看 | 国产欧美最新羞羞视频在线观看 | 欧美日韩国产页 | 干干夜夜 | 国产免费亚洲高清 | 黄色日视频 | 国产精品视频大全 | 亚洲成人午夜av | 国产无遮挡又黄又爽在线观看 | 国产一区欧美日韩 | 国产中年夫妇高潮精品视频 | 六月色| 99re视频在线观看 | 亚洲精品影视 | 人人爽人人香蕉 | 免费黄色av. | 午夜免费福利片 | 夜添久久精品亚洲国产精品 | 91成人精品在线 | 在线电影日韩 | 天天草视频| 色网站在线观看 | 欧美热久久| 91av亚洲| 狠狠干婷婷 | 超碰人人在线 | 久久超碰99 | 日韩电影精品 | 最新日韩视频在线观看 | 去干成人网 | 91精品久久久久久久久 | 欧美污污网站 | 日韩精品一区二区不卡 | 国产在线播放观看 | 99久热在线精品视频成人一区 | 国精产品999国精产品岳 | 黄色一区二区在线观看 | 一区二区三区 中文字幕 | 日本久久片 | av中文字幕在线播放 | 亚洲资源 | 成人午夜剧场在线观看 | 很黄很黄的网站免费的 | 黄色国产高清 | 五月天开心 | 亚洲理论电影 | 香蕉在线视频观看 | 婷婷香蕉 | 亚洲美女视频在线观看 | 91精品91| 国产成人61精品免费看片 | 日本激情视频中文字幕 | 国产在线精品播放 | 五月天天在线 | 91桃色在线免费观看 | 日韩在线视频免费观看 | 日韩高清av在线 | 91在线一区二区 | 亚洲欧美日韩不卡 | 97av影院 | 精品欧美一区二区精品久久 | 免费黄a大片 | 欧美地下肉体性派对 | 99精品视频在线看 | 天天干天天拍 | 97在线精品国自产拍中文 | 天天射日 | 热久久免费视频 | 精品国产不卡 | 超碰97.com| 日韩三级视频在线看 | 免费看搞黄视频网站 | 91久久精品一区二区三区 | 久久久久久高潮国产精品视 | 麻豆国产精品视频 | 天天摸夜夜操 | 日韩精品视频免费看 | 九九久久在线看 | 一区二区精品 | 香蕉视频啪啪 | av手机在线播放 | 99热最新在线 | 国产视频一二区 | 国产精品亚洲视频 | 午夜精品一区二区三区在线视频 | 最近日韩中文字幕中文 | 亚洲精品国产第一综合99久久 | 久久久久亚洲精品男人的天堂 | 国产亚洲欧美精品久久久久久 | 婷婷99| 国产精品一区二区在线看 | 91色蜜桃 | 美女久久99 | 成人一区二区三区中文字幕 | 免费看国产a | a v在线观看 | 一区在线电影 | 在线亚洲播放 | 久久精品电影 | 国产a免费 | 成人一级免费电影 | 久久人人爽人人爽人人 | 97超碰人人澡人人爱学生 | 免费亚洲一区二区 | 在线观看香蕉视频 | 精品国产三级 | 黄污网 | 97在线精品国自产拍中文 | 久久久精品久久日韩一区综合 | 国产午夜精品一区二区三区 | 国内精品久久久久久中文字幕 | 国产视频一区二区在线观看 | 国产小视频在线免费观看 | 97超碰在线人人 | 国产精品久久久久久一二三四五 | 欧美日韩一区二区在线观看 | 一区二区精品在线视频 | 亚洲国产精品成人av | 国产精品对白一区二区三区 | 狠狠狠色丁香婷婷综合久久五月 | 91麻豆精品国产91久久久无需广告 | 十八岁以下禁止观看的1000个网站 | 中文字幕第一页在线视频 | 一区二区三区在线免费观看视频 | 日韩理论片 | 亚洲精品视频在线观看免费 | 一区二区三区免费在线观看视频 | 国产精品去看片 | 五月婷婷视频在线 | 国产在线中文字幕 | 日韩精品视频一二三 | 一区二区三区在线免费观看 | 四虎在线观看精品视频 | 91麻豆福利 | 黄色在线网站噜噜噜 | 人人狠狠综合久久亚洲 | 中文视频在线看 | 日韩精品首页 | 在线不卡a | 久久久久久久久久久免费av | 有没有在线观看av | 五月综合激情婷婷 | 开心激情网五月天 | av丝袜美腿| 国产精品嫩草影院99网站 | 中文字幕高清有码 | 欧美孕妇视频 | 国产精品久久久区三区天天噜 | 91 在线视频 | 亚洲成熟女人毛片在线 | 黄色成人免费电影 | 91人人在线 | 久久婷婷色综合 | 欧美国产高清 | 中文字幕乱视频 | 久久天天躁夜夜躁狠狠85麻豆 | 99热精品在线观看 | 黄在线免费看 | 成人在线黄色电影 | 成年人在线观看免费视频 | av亚洲产国偷v产偷v自拍小说 | 欧美人人| 99精品一区二区三区 | 在线免费观看国产 | 综合色在线观看 | 在线观看国产中文字幕 | 国产一区网址 | 一区 二区电影免费在线观看 | 99精品色| 日本不卡一区二区三区在线观看 | 国产一区私人高清影院 | 国产日韩精品一区二区 | 欧美一级大片在线观看 | 探花视频在线观看免费 | 亚洲综合在 | 亚洲综合婷婷 | 国产综合香蕉五月婷在线 | 九九欧美 | 在线观看中文字幕dvd播放 | 最近免费中文字幕大全高清10 | 久久久久久久久久影院 | 国产精品99久久久久人中文网介绍 | 国产韩国精品一区二区三区 | 人人藻人人澡人人爽 | 欧美激情在线看 | 青青久草在线视频 | 日韩色区| 九九久久影院 | 亚洲激情在线 | 久久久久激情视频 | 黄色免费电影网站 | 国产精品美女视频网站 | 美女黄网久久 | 97人人人人 | 黄色片视频免费 | 久久精品com | 免费进去里的视频 | 成人小电影在线看 | 奇米先锋| 日韩色综合 | 久亚洲 | www.久久色| 免费在线观看黄色网 | 麻豆系列在线观看 | 玖玖玖在线观看 | 97久久久免费福利网址 | 久久国产精品免费观看 | 亚洲精品自在在线观看 | 久久久久久综合网天天 | 国产乱对白刺激视频不卡 | 在线观看 国产 | av一二三区 | 色综合久久久久久中文网 | 国产视频精选 | a色视频| 久久撸在线视频 | 丝袜网站在线观看 | 亚洲综合色激情五月 | 91看片一区二区三区 | 久久视频国产 | 美女黄频 | 97超碰人人模人人人爽人人爱 | 99精品在线观看视频 | 亚洲日韩中文字幕在线播放 | 成人观看视频 | 欧美日韩一区二区免费在线观看 | 亚洲乱码精品久久久久 | 久久久精品一区二区三区 | 国产精品刺激对白麻豆99 | 中文字幕专区高清在线观看 | 天天操天天爱天天干 | 国产精品va在线观看入 | 国产精品99蜜臀久久不卡二区 | 日本中文字幕一二区观 | 免费a v网站 | 久久天天躁狠狠躁夜夜不卡公司 | 操操操人人 | 中文字幕网址 | 91成人精品 | 日韩一区二区三区免费电影 | 天天综合天天综合 | 999在线观看视频 | 免费涩涩网站 | www亚洲精品 | 亚洲国内在线 | 国产97av | 亚洲精品在线观看中文字幕 | 精品一区电影 | 国产无遮挡又黄又爽在线观看 | 午夜婷婷综合 | 日韩av电影免费在线观看 | 91资源在线免费观看 | 在线观看午夜 | 欧美一级特黄aaaaaa大片在线观看 | 四虎最新域名 | 亚洲欧美国产视频 | 久草在线资源观看 | 国产精品99页 | 国产精品永久在线观看 | 国产无遮挡又黄又爽在线观看 | 国产精品午夜在线观看 | 97超碰人人澡人人 | 91视频 - 114av | 久久狠狠婷婷 | 亚洲成人国产 | 久久成人毛片 | 激情五月播播久久久精品 | 久久久久久久久久福利 | 99视频精品全部免费 在线 | 日本中文字幕电影在线免费观看 | 中文字幕在线人 | 中文字幕免费播放 | 亚洲午夜精品久久久久久久久久久久 | 国产中文在线字幕 | 欧美色道 | 日韩精品一区二区三区中文字幕 | h动漫中文字幕 | 色综合人人 | 嫩草av影院| 91成熟丰满女人少妇 | 日韩中文在线字幕 | 日韩黄色大片在线观看 | av在线播放国产 | 亚洲精品成人av在线 | 色欧美综合 | 狠狠色丁香久久婷婷综合丁香 | 免费高清看电视网站 | 久久久久久久国产精品影院 | 在线免费观看黄色 | 国内精品久久久 | 成人午夜剧场在线观看 | www.大网伊人 | 成人午夜电影网 | 91精品久久久久久久久久入口 | 亚洲五月六月 | av一区二区在线观看中文字幕 | 丰满少妇在线观看网站 | 91在线小视频 | 精品一区欧美 | 亚洲精品久久久久中文字幕二区 | 欧美日韩一区二区视频在线观看 | 国产经典av | 国产精品成人一区二区 | 99久久国产免费,99久久国产免费大片 | 国产视频在线观看一区二区 | 一二三区视频在线 | 草久在线观看 | 黄色免费视频在线观看 | 最新中文字幕在线资源 | 麻豆视传媒官网免费观看 | 欧美精品久久久久久久久老牛影院 | ww亚洲ww亚在线观看 | 午夜视频免费在线观看 | 成年人免费在线 | 国产一区二区三区高清播放 | 在线v | 日本久久免费视频 | 日韩免费看的电影 | 久久久国产在线视频 | 成人精品一区二区三区电影免费 | 粉嫩一二三区 | 日韩精品一区二区免费视频 | 97视频免费在线观看 | 色欧美视频 | www.久久婷婷 | 天堂在线一区 | av看片在线 | 欧美日韩高清一区二区 | 久久永久免费 | 日韩综合在线观看 | 亚洲国产成人在线 | 热热热热热色 | 一区二区精品在线视频 | 一区二区三区在线视频观看58 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 99久久综合国产精品二区 | 天天操狠狠操夜夜操 | 日本久久综合网 | 久久99国产精品二区护士 | 丁香资源影视免费观看 | 国产精品久久久久久久婷婷 | 国产一级二级三级在线观看 | 天堂视频一区 | 亚洲污视频 | 免费观看黄色12片一级视频 | 黄污网 | 亚洲一区美女视频在线观看免费 | 日韩在线无| 又黄又爽又色无遮挡免费 | 欧美在线1区 | 波多野结衣一区三区 | 黄色片免费在线 | 狠狠躁夜夜a产精品视频 | 久草视频在线免费看 | 丁香六月在线观看 | 九九九在线观看视频 | 999久久精品 | 久久免费公开视频 | 九九热精品视频在线播放 | 久久久受www免费人成 | 国产成人久久77777精品 | 九九热精品视频在线播放 | 国产999精品 | 色婷婷午夜 | 视频99爱 | 欧美一区在线观看视频 | 午夜性福利| 激情综合网五月激情 | 手机在线小视频 | 超碰伊人网 | 黄色的视频网站 | av日韩精品 | 人人爽人人看 | 免费看的视频 | 国产在线播放不卡 | 在线亚洲欧美日韩 | 丁香花在线观看免费完整版视频 | 婷婷精品进入 | 亚洲欧美综合精品久久成人 | 999电影免费在线观看 | 在线导航福利 | 中文字幕在线影视资源 | 免费视频一区 | 在线观看免费av网站 | 99色在线观看视频 | 香蕉久久久久久久 | 免费观看成人av | 国产第一福利网 | 人人精久 | 在线电影 你懂得 | 在线免费观看视频a | 9色在线视频 | 9草在线 | 中文字幕久久亚洲 | 手机在线中文字幕 | 91在线中文 | 色中文字幕在线观看 | ,久久福利影视 | 在线免费黄色av | 国内精品久久久久久久97牛牛 | 国产成人精品综合 | 免费看片色| 精品国产一二区 | 啪啪免费试看 | 国产区免费在线 | 国产成人精品亚洲日本在线观看 | 日韩在线观看 | 500部大龄熟乱视频使用方法 | av大全在线 | 国产精品免费在线播放 | 色综合久久久久综合体桃花网 | 美女福利视频 | 日韩精品视频一二三 | 亚洲精品久久久久中文字幕m男 | 国产一区高清在线观看 | 久久天天躁 | 在线观看黄色小视频 | 在线观看岛国 | 久久免费视频观看 | 国产成人精品久 | 国产一区免费在线 | 国产一级一片免费播放放 | 亚洲黄色一级大片 | 色婷婷激情网 | 五月激情六月丁香 | 久久99国产精品自在自在app | 在线色网站| 欧美一区二区三区四区夜夜大片 | a√资源在线| 亚洲 欧洲av | 久久婷婷一区 | 在线免费av网站 | 色综合天天 | 亚洲天天摸日日摸天天欢 | 中文国产在线观看 | 亚洲精品播放 | 欧日韩在线视频 | 国产精品中文久久久久久久 | 玖玖综合网 | 国产原创av片 | 久久国内精品视频 | 久久99精品国产99久久6尤 | 国产精品美女久久久久久网站 | 成人av免费在线 | 激情久久综合 | 国产精品久久久久永久免费观看 | 激情五月婷婷综合 | 中文字幕av电影下载 | 97人人网 | 日韩高清久久 | 精品在线99 | 久久午夜电影院 | 91亚州 | 国产美女在线免费观看 | 美女精品国产 | 国产精品一区电影 | 999男人的天堂 | 成人综合免费 | 人人模人人爽 | 色综合亚洲精品激情狠狠 | 国产一级在线播放 | 在线亚洲日本 | 国产特级毛片aaaaaa | 91精品国产福利在线观看 | 亚洲午夜精品一区二区三区电影院 | av线上免费观看 | 久久国内精品99久久6app | 成人av一级片 | 探花视频免费观看 | 亚洲另类视频在线观看 | 亚洲涩涩色 | 中文字幕资源网在线观看 | av高清一区 | aaawww| 久久三级毛片 | 色婷婷国产精品一区在线观看 | 中文字幕一区在线 | 91麻豆福利| 日日夜夜精品视频天天综合网 | 久久天天躁狠狠躁夜夜不卡公司 | 夜夜爽夜夜操 | 人人网av| www.狠狠操.com | 最近中文字幕完整高清 | 国产精品9区| 成人av影院在线观看 | 国产精品网红直播 | 天天狠狠干 | 国产精品久久精品 | 看黄色91 | 午夜成人影视 | 日韩精品免费在线播放 | 五月婷婷操 | 中文字幕在线高清 | 久草在线资源网 | 91av99| 99中文字幕在线观看 | 日韩系列在线 | 日韩在线观看高清 | 国产精品mm | www·22com天天操 | 久久久精品小视频 | 国产成人精品亚洲精品 | 1000部18岁以下禁看视频 | 亚洲,国产成人av | 日韩av高清在线观看 | 久av在线| 99一级片| 久久在线免费 | 久久无码精品一区二区三区 | 国产精品二区三区 | 五月激情久久 | 成全在线视频免费观看 | 久久国语 | va视频在线| 久久躁日日躁aaaaxxxx | 99精品视频在线播放免费 | 日韩精品久久久久 | 天天爱天天操天天射 | av在线一级| 久久永久视频 | 精品久久免费看 | 久久国产热 | 国产成人61精品免费看片 | 国产高清不卡一区二区三区 | 91精品国产福利在线观看 | 日韩中字在线观看 | 久草视频首页 | 欧美精品久久久久性色 | 人人草在线视频 | 91精品啪在线观看国产线免费 | 日韩综合视频在线观看 | av最新资源 | 亚洲网久久 | 色综合久久88色综合天天6 | 手机看片| 夜夜骑日日 | 日本激情动作片免费看 | 国产午夜不卡 | 激情五月激情综合网 | 日韩在线观看高清 | 中文成人字幕 | 久草精品视频在线看网站免费 | 超级碰碰碰碰 | 国产免费高清视频 | 五月婷婷av在线 | 在线观看久久久久久 | 国产91精品高清一区二区三区 | 久久免费激情视频 | 在线精品视频免费观看 | 欧美精品在线视频 | 五月婷婷色丁香 | 久草免费在线观看视频 | 久久久午夜精品福利内容 | av手机版 | 欧美日韩网站 | 久久夜靖品 | 99久高清在线观看视频99精品热在线观看视频 | 成人av在线网址 | 超碰在线94 | 99视频精品 | 亚洲一区视频免费观看 | 在线精品视频免费播放 | 久久久久免费 | av黄色国产 | 亚洲电影院 | 国产字幕在线看 | 中文字幕日韩电影 | 99视频精品免费视频 | 国产黄色视 | 精品国产伦一区二区三区免费 | 亚洲精品中文字幕在线 | 99久久日韩精品视频免费在线观看 | 深爱激情五月婷婷 | 国产97在线观看 | 欧美精品一区二区三区四区在线 | 91大片成人网| 天天操狠狠操夜夜操 | 中文字幕在线观看av | 国产黄免费看 | 狠狠五月婷婷 | 国产毛片久久 | 国产精品高潮呻吟久久av无 | 九九亚洲视频 | 亚洲精品在线视频播放 | 国产黄大片 | 天天爱av导航 | 欧美作爱视频 | 国产在线成人 | 成人av网址大全 | 欧美日韩视频一区二区三区 | 国产黄在线播放 | 久久精品一二三区白丝高潮 | 亚洲少妇xxxx | 99国产成+人+综合+亚洲 欧美 | 天堂视频中文在线 | 日韩美精品视频 | 丁香九月婷婷综合 | 手机在线看永久av片免费 | 日韩在线高清 | 国产精品久久亚洲 | 久久99热精品这里久久精品 | 97品白浆高清久久久久久 | av观看久久久 | 一区二区欧美在线观看 | 久草在线91 | 天天摸天天干天天操天天射 | 国产一二三四在线观看视频 | 人人干人人超 | 久久精品理论 | av在线免费不卡 | 日日草视频 | 九九热精品视频在线观看 | 国产在线精品播放 | 97韩国电影 | 日韩一区正在播放 | a在线观看免费视频 | 国产亚洲视频在线 | 黄色一级免费网站 | 在线观看av大片 | av爱干| 在线a人v观看视频 | 91av视屏 | 国产香蕉av | 久久99精品久久久久久久久久久久 | 视频国产精品 | 国产在线视频一区 | 国内精品一区二区 | 亚洲天堂社区 | 亚洲一级二级三级 | 亚洲精品国 | 国产精品久久久久aaaa | 精品视频在线观看 | 精品国产伦一区二区三区 | 亚洲精品mv在线观看 | 一级片色播影院 | 免费看黄色小说的网站 | 成年人在线观看视频免费 | 7799av| 国内小视频 | 中文在线免费观看 | 国内精品久久久 | 成人91在线 | 最近能播放的中文字幕 | 一级黄色av | 国产一级做a | 日本护士撒尿xxxx18 | 日韩在线视频一区 | 亚洲免费精彩视频 | 久久免费视频播放 | 狠狠干.com| 韩国在线视频一区 | 亚州精品国产 | 亚洲一区欧美激情 | 成人在线观看资源 | 一区二区三区动漫 | 免费裸体视频网 | 日日爱av | 综合av在线 | 久艹在线免费观看 | 欧美a级免费视频 | 成人免费在线视频观看 | 国产在线播放一区 | 中文字幕韩在线第一页 | 国产电影一区二区三区四区 | 色婷婷电影 | 免费在线观看av网站 | 手机在线欧美 | www.五月天婷婷.com | 69久久夜色精品国产69 | 国产在线播放一区二区 | 成人手机在线视频 | 国产精品成人自产拍在线观看 | 久久免费黄色大片 | 日韩欧美在线综合网 | 五月天婷婷在线视频 | 日韩中文字幕视频在线观看 | 成人一区二区三区中文字幕 | 亚洲视频在线播放 | 日韩中文在线字幕 | 狠狠狠狠干| 日韩精品无码一区二区三区 | 精品一二三四视频 | 午夜成人免费电影 | 精品一区二区三区香蕉蜜桃 | 综合亚洲视频 | 国产福利在线免费观看 | 国产精品一区二区久久精品爱涩 | 精品在线视频观看 | 久久久久久不卡 | 91综合久久一区二区 | 国产女人40精品一区毛片视频 | 精品国产一区二区三区噜噜噜 | 综合色影院 | 精品在线观看一区二区 | 91在线网址 | a在线视频v视频 | 国产精品久久久久av免费 | 国产一区二区三精品久久久无广告 | 人人干天天射 | 玖玖爱免费视频 | 亚洲精品网站在线 | 福利av在线| 五月婷婷综合久久 | 国产精品一码二码三码在线 | av免费观看高清 | 国产精品视频线看 | 国产精品一区久久久久 | 欧美成人日韩 | 国产成人久久精品亚洲 | 久久国产欧美日韩 | 欧美9999| 久久久亚洲精华液 |