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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

通过FD耗尽实验谈谈使用HttpClient的正确姿势

發布時間:2024/8/23 编程问答 63 豆豆
生活随笔 收集整理的這篇文章主要介紹了 通过FD耗尽实验谈谈使用HttpClient的正确姿势 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一段問題代碼實驗

在進行網絡編程時,正確關閉資源是一件很重要的事。在高并發場景下,未正常關閉的資源數逐漸積累會導致系統資源耗盡,影響系統整體服務能力,但是這件重要的事情往往又容易被忽視。我們進行一個簡單的實驗,使用HttpClient-3.x編寫一個demo請求指定的url,看看如果不正確關閉資源會發生什么事。

public String doGetAsString(String url) {GetMethod getMethod = null;String is = null;InputStreamReader inputStreamReader = null;BufferedReader br = null;try {HttpClient httpclient = new HttpClient();//問題標記①getMethod = new GetMethod(url);httpclient.executeMethod(getMethod);if (HttpStatus.SC_OK == getMethod.getStatusCode()) {......//對返回結果進行消費,代碼省略}return is;} catch (Exception e) {if (getMethod != null) {getMethod.releaseConnection(); //問題標記② } } finally {inputStreamReader.close();br.close();......//關閉流時的異常處理代碼省略}return null;}

這段代碼邏輯很簡單, 先創建一個HttpClient對象,用url構建一個GetMethod對象,然后發起請求。但是用這段代碼并發地以極高的QPS去訪問外部的url,很快就會在日志中看到“打開文件太多,無法打開文件”的錯誤,后續的http請求都會失敗。這時我們用lsof -p ${javapid}命令去查看java進程打開的文件數,發現達到了655350這么多。
分析上面的代碼片段,發現存在以下2個問題:
(1)初始化方式不對。標記①直接使用new HttpClient()的方式來創建HttpClient,沒有顯示指定HttpClient connection manager,則構造函數內部默認會使用SimpleHttpConnectionManager,而SimpleHttpConnectionManager的默認參數中alwaysClose的值為false,意味著即使調用了releaseConnection方法,連接也不會真的關閉。
(2)在未使用連接池復用連接的情況下,代碼沒有正確調用releaseConnection。catch塊中的標記②是唯一調用了releaseConnection方法的代碼,而這段代碼僅在發生異常時才會走到,大部分情況下都走不到這里,所以即使我們前面用正確的方式初始化了HttpClient,由于沒有手動釋放連接,也還是會出現連接堆積的問題。

可能有同學會有以下疑問:
1、明明是發起Http請求,為什么會打開這么多文件呢?為什么是655350這個上限呢?
2、正確的HttpClient使用姿勢是什么樣的呢?
這就涉及到linux系統中fd的概念。

什么是fd

在linux系統中有“一切皆文件”的概念。打開和創建普通文件、Socket(套接字)、Pipeline(管道)等,在linux內核層面都需要新建一個文件描述符來進行狀態跟蹤和使用。我們使用HttpClient發起請求,其底層需要首先通過系統內核創建一個Socket連接,相應地就需要打開一個fd。
為什么我們的應用最多只能創建655350個fd呢?這個值是如何控制的,能否調整呢?事實上,linux系統對打開文件數有多個層面的限制:
1)限制單個Shell進程以及其派生子進程能打開的fd數量。用ulimit命令能查看到這個值。
2)限制每個user能打開的文件總數。具體調整方法是修改/etc/security/limits.conf文件,比如下圖中的紅框部分就是限制了userA用戶只能打開65535個文件,userB用戶只能打開655350個文件。由于我們的應用在服務器上是以userB身份運行的,自然就受到這里的限制,不允許打開多于655350個文件。

# /etc/security/limits.conf # #<domain> <type> <item> <value> userA - nofile 65535 userB - nofile 655350# End of file

3)系統層面允許打開的最大文件數限制,可以通過“cat /proc/sys/fs/file-max”查看。
前文demo代碼中錯誤的HttpClient使用方式導致連接使用完成后沒有成功斷開,連接長時間保持CLOSE_WAIT狀態,則fd需要繼續指向這個套接字信息,無法被回收,進而出現了本文開頭的故障。

再識HttpClient

我們的代碼中錯誤使用common-httpclient-3.x導致后續請求失敗,那這里的common-httpclient-3.x到底是什么東西呢?相信所有接觸過網絡編程的同學對HttpClient都不會陌生,由于java.net中對于http訪問只提供相對比較低級別的封裝,使用起來很不方便,所以HttpClient作為Jakarta Commons的一個子項目出現在公眾面前,為開發者提供了更友好的發起http連接的方式。然而目前進入Jakarta Commons HttpClient官網,會發現頁面最頂部的“End of life”欄目,提示此項目已經停止維護了,它的功能已經被Apache HttpComponents的HttpClient和HttpCore所取代。
同為Apache基金會的項目,Apache HttpComponents提供了更多優秀特性,它總共由3個模塊構成:HttpComponents Core、HttpComponents Client、HttpComponents AsyncClient,分別提供底層核心網絡訪問能力、同步連接接口、異步連接接口。在大多數情況下我們使用的都是HttpComponents Client。為了與舊版的Commons HttpClient做區分,新版的HttpComponents Client版本號從4.x開始命名。

從源碼上來看,Jakarta Commons HttpClient和Apache HttpComponents Client雖然有很多同名類,但是兩者之間沒有任何關系。以最常使用到的HttpClient類為例,在commons-httpclient中它是一個類,可以直接發起請求;而在4.x版的httpClient中,它是一個接口,需要使用它的實現類。

既然3.x與4.x的HttpClient是兩個完全獨立的體系,那么我們就分別討論它們的正確用法。

HttpClient 3.x用法

回顧引發故障的那段代碼,通過直接new HttpClient()的方式創建HttpClient對象,然后發起請求,問題出在了這個構造函數上。由于我們使用的是無參構造函數,查看三方包源碼,會發現內部會通過無參構造函數new一個SimpleHttpConnectionManager,它的成員變量alwaysClose在不特別指定的情況下默認為false。

alwaysClose這個值是如何影響到我們關閉連接的動作呢?繼續跟蹤下去,發現HttpMethodBase(它的多個實現類分別對應HTTP中的幾種方法,我們最常用的是GetMethod和PostMethod)中的releaseConnection()方法首先會嘗試關閉響應輸入流(下圖中的①所指代碼),然后在finally中調用ensureConnectionRelease(),這個方法內部其實是調用了HttpConnection類的releaseConnection()方法,如下圖中的標記③所示,它又會調用到SimpleHttpConnectionManager的releaseConnection(conn)方法,來到了最關鍵的標記④和⑤。

標記④的代碼說明,如果alwaysClose=true,則會調用httpConnection.close()方法,它的內部會把輸入流、輸出流都關閉,然后把socket連接關閉,如標記⑥和⑦所示。

然后,如果標記④處的alwaysClose=false,則會走到⑤的邏輯中,調用finishLastResponse()方法,如標記⑧所示,這段邏輯實際上只是把請求響應的輸入流關閉了而已。我們的問題代碼就是走到了這段邏輯,導致沒能把之前使用過的連接斷開,而后續的請求又沒有復用這個httpClient,每次都是new一個新的,導致大量連接處于CLOSE_WAIT狀態占用系統文件句柄。

通過以上分析,我們知道使用commons-httpclient-3.x之后如果想要正確關閉連接,就需要指定always=true且正確調用method.releaseConnection()方法。

上述提到的幾個類,他們的依賴關系如下圖(紅色箭頭標出的是我們剛才討論到的幾個類):

其中SimpleHttpConnectionManager這個類的成員變量和方法列表如下圖所示:

事實上,通過對commons-httpclient-3.x其他部分源碼的分析,可以得知還有其他方法也可以正確關閉連接。
方法1:先調用method.releaseConnection(),然后獲取到httpClient對象的SimpleHttpConnectionManager成員變量,主動調用它的shutdown()方法即可。對應的三方包源碼如下圖所示,其內部會調用httpConnection.close()方法。

方法2:先調用method.releaseConnection(),然后獲取到httpClient對象的SimpleHttpConnectionManager成員變量,主動調用closeIdleConnections(0)即可,對應的三方包源碼如下。

方法3:由于我們使用的是HTTP/1.1協議,默認會使用長連接,所以會出現上面的連接不釋放的問題。如果客戶端與服務端雙方協商好不使用長連接,不就可以解決問題了嗎。commons-httpclient-3.x也確實提供了這個支持,從下面的注釋也可以看出來。具體這樣操作,我們在創建了method后使用method.setRequestHeader("Connection", "close")設置頭部信息,并在使用完成后調用一次method.releaseConnection()。Http服務端在看到此頭部后會在response的頭部中也帶上“Connection: close”,如此一來httpClient發現返回的頭部有這個信息,則會在處理完響應后自動關閉連接。

HttpClient 4.x用法

既然官方已經不再維護3.x,而是推薦所有使用者都升級到4.x上來,我們就順應時代潮流,重點看看4.x的用法。

(1)簡易用法

最簡單的用法類似于3.x,調用三方包提供的工具類靜態方法創建一個CloseableHttpClient對象,然后發起調用,如下圖。這種方式創建的CloseableHttpClient,默認使用的是PoolingHttpClientConnectionManager來管理連接。由于CloseableHttpClient是線程安全的,因此不需要每次調用時都重新生成一個,可以定義成static字段在多線程間復用。

如上圖,我們在獲取到response對象后,自己決定如何處理返回數據。HttpClient的三方包中已經為我們提供了EntityUtils這個工具類,如果使用這個類的toString()或consume()方法,則上圖finally塊紅框中的respnose.close()就不是必須的了,因為EntityUtils的方法內部會在處理完數據后把底層流關閉。

(2)簡易用法涉及到的核心類詳解

CloseableHttpClient是一個抽象類,我們通過HttpClients.createDefault()創建的實際是它的子類InternalHttpClient。

/*** Internal class.** @since 4.3*/ @Contract(threading = ThreadingBehavior.SAFE_CONDITIONAL) @SuppressWarnings("deprecation") class InternalHttpClient extends CloseableHttpClient implements Configurable {... ... }

繼續跟蹤httpclient.execute()方法,發現其內部會調用CloseableHttpClient.doExecute()方法,實際會調到InternalHttpClient類的doExecute()方法。通過對請求對象(HttpGet、HttpPost等)進行一番包裝后,最后實際由execChain.execute()來真正執行請求,這里的execChain是接口ClientExecChain的一個實例。接口ClientExecChain有多個實現類,由于我們使用HttpClients.createDefault()這個默認方法構造了CloseableHttpClient,沒有指定ClientExecChain接口的具體實現類,所以系統默認會使用RedirectExec這個實現類。

/*** Base implementation of {@link HttpClient} that also implements {@link Closeable}.** @since 4.3*/ @Contract(threading = ThreadingBehavior.SAFE) public abstract class CloseableHttpClient implements HttpClient, Closeable {private final Log log = LogFactory.getLog(getClass());protected abstract CloseableHttpResponse doExecute(HttpHost target, HttpRequest request,HttpContext context) throws IOException, ClientProtocolException;... ... }

RedirectExec類的execute()方法較長,下圖進行了簡化。

可以看到如果遠端返回結果標識需要重定向(響應頭部是301、302、303、307等重定向標識),則HttpClient默認會自動幫我們做重定向,且每次重定向的返回流都會自動關閉。如果中途發生了異常,也會幫我們把流關閉。直到拿到最終真正的業務返回結果后,直接把整個response向外返回,這一步沒有幫我們關閉流。因此,外層的業務代碼在使用完response后,需要自行關閉流。

執行execute()方法后返回的response是一個CloseableHttpResponse實例,它的實現是什么?點開看看,這是一個接口,此接口唯一的實現類是HttpResponseProxy。

/*** Extended version of the {@link HttpResponse} interface that also extends {@link Closeable}.** @since 4.3*/ public interface CloseableHttpResponse extends HttpResponse, Closeable { }

我們前面經常看到的response.close(),實際是調用了HttpResponseProxy的close()方法,其內部邏輯如下:

/*** A proxy class for {@link org.apache.http.HttpResponse} that can be used to release client connection* associated with the original response.** @since 4.3*/class HttpResponseProxy implements CloseableHttpResponse { @Overridepublic void close() throws IOException {if (this.connHolder != null) {this.connHolder.close();}}... ... } /*** Internal connection holder.** @since 4.3*/ @Contract(threading = ThreadingBehavior.SAFE) class ConnectionHolder implements ConnectionReleaseTrigger, Cancellable, Closeable {... ...@Overridepublic void close() throws IOException {releaseConnection(false);}}

可以看到最終會調用到ConnectionHolder類的releaseConnection(reusable)方法,由于ConnectionHolder的close()方法調用releaseConnection()時默認傳入了false,因此會走到else的邏輯中。這段邏輯首先調用managedConn.close()方法,然后調用manager.releaseConnection()方法。

managedConn.close()方法實際是把連接池中已經建立的連接在socket層面斷開連接,斷開之前會把inbuffer清空,并把outbuffer數據全部傳送出去,然后把連接池中的連接記錄也刪除。manager.releaseConnection()對應的代碼是PoolingHttpClientConnectionManager.releaseConnection(),這段代碼代碼本來的作用是把處于open狀態的連接的socket超時時間設置為0,然后把連接從leased集合中刪除,如果連接可復用則把此連接加入到available鏈表的頭部,如果不可復用則直接把連接關閉。由于前面傳入的reusable已經強制為false,因此實際關閉連接的操作已經由managedConn.close()方法做完了,走到PoolingHttpClientConnectionManager.releaseConnection()中真正的工作基本就是清除連接池中的句柄而已。

如果想了解關閉socket的細節,可以通過HttpClientConnection.close()繼續往下跟蹤,最終會看到真正關閉socket的代碼在BHttpConnectionBase中。

/*** This class serves as a base for all {@link HttpConnection} implementations and provides* functionality common to both client and server HTTP connections.** @since 4.0*/ public class BHttpConnectionBase implements HttpConnection, HttpInetConnection {... ...@Overridepublic void close() throws IOException {final Socket socket = this.socketHolder.getAndSet(null);if (socket != null) {try {this.inbuffer.clear();this.outbuffer.flush();try {try {socket.shutdownOutput();} catch (final IOException ignore) {}try {socket.shutdownInput();} catch (final IOException ignore) {}} catch (final UnsupportedOperationException ignore) {// if one isn't supported, the other one isn't either}} finally {socket.close();}}}... ... }

為什么說調用了EntityUtils的部分方法后,就不需要再顯示地關閉流呢?看下它的源碼就明白了。

/*** Static helpers for dealing with {@link HttpEntity}s.** @since 4.0*/ public final class EntityUtils {/*** Ensures that the entity content is fully consumed and the content stream, if exists,* is closed.** @param entity the entity to consume.* @throws IOException if an error occurs reading the input stream** @since 4.1*/public static void consume(final HttpEntity entity) throws IOException {if (entity == null) {return;}if (entity.isStreaming()) {final InputStream instream = entity.getContent();if (instream != null) {instream.close();}}}... ... }

(3)HttpClient進階用法
在高并發場景下,使用連接池有效復用已經建立的連接是非常必要的。如果每次http請求都重新建立連接,那么底層的socket連接每次通過3次握手創建和4次握手斷開連接將是一筆非常大的時間開銷。
要合理使用連接池,首先就要做好PoolingHttpClientConnectionManager的初始化。如下圖,我們設置maxTotal=200且defaultMaxPerRoute=20。maxTotal=200指整個連接池中連接數上限為200個;defaultMaxPerRoute用來指定每個路由的最大并發數,比如我們設置成20,意味著雖然我們整個池子中有200個連接,但是連接到"http://www.taobao.com"時同一時間最多只能使用20個連接,其他的180個就算全閑著也不能給發到"http://www.taobao.com"的請求使用。因此,對于高并發的場景,需要合理分配這2個參數,一方面能夠防止全局連接數過多耗盡系統資源,另一方面通過限制單路由的并發上限能夠避免單一業務故障影響其他業務。

private static volatile CloseableHttpClient instance;static {PoolingHttpClientConnectionManager cm = new PoolingHttpClientConnectionManager();// Increase max total connection to 200cm.setMaxTotal(200);// Increase default max connection per route to 20cm.setDefaultMaxPerRoute(20);RequestConfig requestConfig = RequestConfig.custom().setConnectTimeout(1000).setSocketTimeout(1000).setConnectionRequestTimeout(1000).build();instance = HttpClients.custom().setConnectionManager(cm).setDefaultRequestConfig(requestConfig).build();}

官方同時建議我們在后臺起一個定時清理無效連接的線程,因為某些連接建立后可能由于服務端單方面斷開連接導致一個不可用的連接一直占用著資源,而HttpClient框架又不能百分之百保證檢測到這種異常連接并做清理,因此需要自給自足,按照如下方式寫一個空閑連接清理線程在后臺運行。

public class IdleConnectionMonitorThread extends Thread {private final HttpClientConnectionManager connMgr;private volatile boolean shutdown;Logger logger = LoggerFactory.getLogger(IdleConnectionMonitorThread.class);public IdleConnectionMonitorThread(HttpClientConnectionManager connMgr) {super();this.connMgr = connMgr;}@Overridepublic void run() {try {while (!shutdown) {synchronized (this) {wait(5000);// Close expired connectionsconnMgr.closeExpiredConnections();// Optionally, close connections// that have been idle longer than 30 secconnMgr.closeIdleConnections(30, TimeUnit.SECONDS);} }} catch (InterruptedException ex) {logger.error("unknown exception", ex);// terminate}}public void shutdown() {shutdown = true;synchronized (this) {notifyAll();}} }

我們討論到的幾個核心類的依賴關系如下:

HttpClient作為大家常用的工具,看似簡單,但是其中卻有很多隱藏的細節值得探索。

?


原文鏈接
本文為云棲社區原創內容,未經允許不得轉載。

總結

以上是生活随笔為你收集整理的通过FD耗尽实验谈谈使用HttpClient的正确姿势的全部內容,希望文章能夠幫你解決所遇到的問題。

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

人人干人人模 | 日韩精品一区在线播放 | 在线精品观看国产 | 国产精品美乳一区二区免费 | 久久av中文字幕片 | 国产精品美女www爽爽爽视频 | 97**国产露脸精品国产 | 婷婷视频 | 99久免费精品视频在线观看 | 在线免费精品视频 | 国产一二区在线观看 | 国产性天天综合网 | 欧美日韩视频在线观看免费 | 中文字幕在线观看完整 | 日韩av成人在线观看 | 不卡国产视频 | 国产成人99av超碰超爽 | 伊人伊成久久人综合网小说 | 亚洲精品91天天久久人人 | 日产乱码一二三区别在线 | 成人在线视频观看 | 综合激情 | 国产精品99久久免费黑人 | 国产日产精品一区二区三区四区的观看方式 | 久久久亚洲麻豆日韩精品一区三区 | 伊人五月综合 | 欧美片一区二区三区 | 中文字幕在线观看网 | 日日夜操| 五月婷婷色综合 | 欧美日韩国产亚洲乱码字幕 | 人人射人人插 | 在线免费观看黄色 | 久久久精品小视频 | 久久综合福利 | 国产精品二区在线观看 | 99欧美精品| 日韩电影一区二区三区在线观看 | 中文字幕五区 | 免费情趣视频 | 日本午夜在线亚洲.国产 | 在线国产一区二区 | 久久av免费| 日韩电影在线观看一区二区 | 777xxx欧美| 毛片网站在线看 | 欧美性生活久久 | 精品电影一区二区 | 91av亚洲| 天天插天天狠天天透 | 久久不见久久见免费影院 | 日韩免费视频网站 | 又大又硬又黄又爽视频在线观看 | 天天综合网入口 | 国产99久久久精品 | 免费看搞黄视频网站 | 日韩一区二区免费视频 | av播放在线 | 国产亚洲成av人片在线观看桃 | 欧美精品乱码99久久影院 | 九九热视频在线免费观看 | 久久精品91视频 | 91大片网站 | 日韩专区在线 | 色网免费观看 | 亚洲一区黄色 | 国产精品女同一区二区三区久久夜 | 国产精品一区二区中文字幕 | www激情com| 9幺看片| 亚洲精品视频网站在线观看 | 玖玖999| 免费在线播放av电影 | 久久国产精品一二三区 | 精品国产伦一区二区三区观看体验 | 久久草草影视免费网 | 成年人免费电影在线观看 | 久久精品直播 | 天天人人综合 | 中文字幕在线视频精品 | 国产精品网站 | 91精品免费看| www.久久免费视频 | 免费日韩在线 | 久久精彩免费视频 | 日韩在线视频免费观看 | 国产精品国产三级国产aⅴ9色 | 国产精品 日本 | 精品成人久久 | 丁香六月激情 | 黄色一级大片在线免费看产 | 亚洲成a人片77777潘金莲 | 91视频免费看 | 激情网站五月天 | 天天射天天干天天插 | 精品视频专区 | 亚洲午夜精品在线观看 | 久草免费在线视频观看 | 成片免费观看视频999 | 99re6热在线精品视频 | 少妇精品久久久一区二区免费 | 久久久久久国产一区二区三区 | www.操.com| 亚洲视频中文 | 日韩3区| 日韩成片 | 国产精品成人一区二区三区吃奶 | 国产精品久久影院 | 在线观看免费91 | 亚洲国产69| 四虎成人精品在永久免费 | 欧美一区视频 | 久久久久蜜桃 | 黄色免费观看网址 | 视频一区二区精品 | 一区二区三区日韩精品 | 99在线免费观看视频 | 手机av电影在线观看 | 有没有在线观看av | 中文字幕二区在线观看 | 亚洲精品88欧美一区二区 | 久久与婷婷 | 欧洲一区二区三区精品 | 欧美精品久久久久久久久免 | 超碰电影在线观看 | 91毛片在线 | 69久久夜色精品国产69 | 国产在线视频在线观看 | 精品久久久久久久久久久久久久久久久久 | 玖玖视频在线 | 免费色黄 | 欧美成人精品三级在线观看播放 | av网站在线免费观看 | 日本中文字幕视频 | 国产九九九视频 | 免费色视频网址 | 国产在线视频一区二区三区 | 国产91精品看黄网站在线观看动漫 | 国产精品综合久久久久 | 日韩欧美高清在线观看 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 日韩丝袜在线 | 久草在线在线精品观看 | 国产91精品一区二区麻豆亚洲 | 亚洲国产精品一区二区尤物区 | 992tv又爽又黄的免费视频 | 免费av大片 | 九九视频精品在线 | 国产精品1024 | 亚洲精品激情 | 99精品视频精品精品视频 | 超级碰碰碰碰 | 三三级黄色片之日韩 | 99精品国产一区二区三区不卡 | 欧美a性 | 久久污视频 | 四虎伊人 | 超碰在线日韩 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 欧美中文字幕久久 | www.久久精品视频 | 高清免费在线视频 | 免费av一级电影 | 丁香在线视频 | 亚洲精选在线 | 日韩亚洲精品电影 | 欧美va天堂va视频va在线 | 免费看91的网站 | 啪啪免费视频网站 | 久久久av电影| 91香蕉国产在线观看软件 | 免费看片成人 | 免费不卡中文字幕视频 | 国产一区在线观看免费 | 国产成人精品久久二区二区 | 美女视频是黄的免费观看 | 成人在线观看日韩 | 久久国产精品一区二区三区 | 国产精品久久一区二区无卡 | 日日夜夜网 | 天天干 天天摸 天天操 | 日本一区二区三区免费观看 | 97色狠狠| 国产日韩欧美在线观看 | 免费人成在线观看网站 | 天堂av最新网址 | 亚洲精品久久激情国产片 | 91在线一区 | 久久国产色 | 久久男人中文字幕资源站 | av电影在线免费观看 | 日韩欧美视频在线观看免费 | 亚洲精品午夜aaa久久久 | 狠狠操.com | 97人人模人人爽人人喊中文字 | 天天干天天操av | 成人毛片一区 | 深夜免费福利网站 | 欧美有色| 日本视频不卡 | 欧美精彩视频在线观看 | 五月婷婷中文 | 国产 在线 日韩 | 国产视频69 | 一区二区三区四区五区在线 | 精品国产免费av | 午夜美女网站 | 看污网站 | 亚洲女同videos | 国产1区2区3区在线 亚洲自拍偷拍色图 | 国产又粗又猛又黄视频 | 久久亚洲精品电影 | 免费观看91视频大全 | 99久久日韩精品免费热麻豆美女 | 精品国产欧美一区二区三区不卡 | 国产99久久精品一区二区永久免费 | 在线电影 你懂得 | 久草视频资源 | 免费在线激情电影 | 四虎影视成人 | 国产一二三区在线观看 | 国产成人黄色在线 | 久久精品永久免费 | 91视频专区| 欧美性直播 | 亚洲电影第一页av | 粉嫩av一区二区三区四区 | 九色91在线视频 | 九九久久久 | 精品a在线 | 国产伦精品一区二区三区高清 | 国产成人精品在线播放 | 日韩欧美99 | 成年人在线观看 | 久久天天躁 | 中文字幕免费久久 | 在线亚洲高清视频 | 国产福利小视频在线 | 国产69精品久久app免费版 | 色综合a| 久久99精品久久久久久秒播蜜臀 | 91精品视频免费观看 | 在线免费观看视频一区 | 久久久高清 | 日本久久免费电影 | 久久人人添人人爽添人人88v | 久久婷婷国产色一区二区三区 | 国产999视频 | 中文字幕一区二区在线播放 | 国产又粗又猛又黄又爽的视频 | 色99导航 | 欧美污在线观看 | 在线观看成人国产 | 国产在线观看地址 | 色吊丝在线永久观看最新版本 | 男女全黄一级一级高潮免费看 | 国产精品美女毛片真酒店 | 国产成人精品午夜在线播放 | 色婷婷激情综合 | 日韩 在线观看 | 国产激情小视频在线观看 | 国产精品国产三级国产不产一地 | 国产又粗又猛又黄又爽 | 日韩精品中文字幕一区二区 | 狠狠干干 | 国产区精品在线 | 亚洲精品字幕 | 国产只有精品 | 国产精品麻豆一区二区三区 | 成年人在线观看免费视频 | 国产麻豆精品久久一二三 | 日韩字幕 | 欧美日韩免费观看一区二区三区 | 亚洲午夜精品一区 | 国产 日韩 欧美 中文 在线播放 | 在线观看中文字幕一区 | 九九精品视频在线 | 亚洲一区美女视频在线观看免费 | 欧美一区二区三区激情视频 | www久久99| 亚洲区精品 | 日韩高清在线一区二区三区 | 欧美精品在线观看免费 | 久黄色| 97精品久久人人爽人人爽 | 91精品国产92久久久久 | 久久久久久久久久久网 | 国产精品久久久久久久久久尿 | 99激情网 | 免费在线观看av的网站 | 在线观看91 | 久久日韩精品 | 国产一级高清 | 在线电影av | 国产精品久久久久影院 | 婷婷精品在线视频 | av最新资源| 狠狠地日 | 99精品电影 | 国产精品免费高清 | 91在线播放综合 | 日韩一区二区三免费高清在线观看 | 2000xxx影视 | 在线观看av免费 | 亚洲天天干 | 午夜影院在线观看18 | 超碰资源在线 | 美腿丝袜一区二区三区 | 久久最新网址 | 亚洲国产美女久久久久 | 日本中文字幕高清 | 香蕉久久国产 | 日本韩国欧美在线观看 | 最新成人在线 | 国产女人18毛片水真多18精品 | 免费日韩电影 | 97超碰香蕉 | 99久久精品费精品 | 97成人在线观看视频 | 国产一线二线三线性视频 | 99久久精| 亚洲aⅴ一区二区三区 | 精品久久久久久国产偷窥 | 欧洲亚洲女同hd | 久草免费在线 | 久久这里有 | 伊人国产在线观看 | 午夜三级福利 | 一级理论片在线观看 | 免费日韩一区 | 九九导航 | 成人在线播放网站 | 五月婷av | 视频在线99re | 91成熟丰满女人少妇 | 久草视频在线免费播放 | 不卡视频在线 | 国产精品福利在线播放 | 高清av不卡 | 五月婷婷中文网 | 久久五月婷婷丁香社区 | 中文字幕在线看视频 | 超碰97中文 | 久久免费看毛片 | 精品国产一区二区三区在线 | 91麻豆视频| 久久激情久久 | 久久艹99| 18岁免费看片 | 草免费视频 | 日本高清中文字幕有码在线 | 亚洲精品在线播放视频 | 久草视频首页 | 日韩高清三区 | 99电影| 国产麻豆精品久久 | www视频免费在线观看 | 国产精品18久久久久久久网站 | 中文av影院 | 日韩欧美国产精品 | 韩国av一区二区三区 | 欧美日韩网址 | 欧美一级片 | 久久视频网 | 国产成人av网站 | 亚洲综合最新在线 | 国产精品中文字幕av | 成人免费看电影 | 欧美黄色高清 | 日本中文字幕高清 | 国产韩国日本高清视频 | 91最新在线| 午夜精品福利一区二区 | 天堂成人在线 | 99精品欧美一区二区三区黑人哦 | 日本护士三级少妇三级999 | 麻豆国产精品永久免费视频 | 日韩综合精品 | 久久亚洲人 | 六月丁香社区 | 亚洲激情中文 | 女人久久久久 | 中文在线资源 | 欧美日韩国产在线一区 | 中文字幕三区 | 国产理论影院 | 激情偷乱人伦小说视频在线观看 | 亚州精品在线视频 | 99视频播放 | 日本久久高清视频 | 黄色一级在线免费观看 | 在线观看精品国产 | av天天干| 日韩av在线影视 | 亚洲专区路线二 | 99久久精品免费视频 | 激情欧美国产 | 日韩一区精品 | 欧美一区视频 | 国产精品日韩精品 | 99久久www免费 | 日韩精品久久久 | 91cn国产在线| 日韩成人黄色av | 国产亚洲婷婷免费 | 麻豆传媒视频观看 | 日日碰狠狠添天天爽超碰97久久 | 久久久久一区二区三区四区 | 一二三区高清 | 久久高清片 | 日本中文乱码卡一卡二新区 | 欧洲视频一区 | 91精品国自产拍天天拍 | 麻豆一二三精选视频 | 天天色天天草天天射 | 午夜久久成人 | 免费在线看v | 中文国产字幕在线观看 | 天天干夜夜爱 | 一区二区精品视频 | 久热色超碰 | 日日骑 | 丝袜网站在线观看 | 久碰视频在线观看 | 国产精品美女久久久久久免费 | 亚洲一区二区三区四区在线视频 | 日韩特级片 | 福利av影院 | 国产玖玖精品视频 | 中文字幕在线观看免费高清电影 | 欧美色图视频一区 | 天天色成人 | 狠狠狠狠狠狠狠狠 | 精品国产自 | 亚洲91精品在线观看 | 午夜视频久久久 | 免费久久99精品国产婷婷六月 | 欧美日韩一区久久 | 亚洲精品在线视频观看 | 麻豆免费看片 | 毛片视频电影 | 视频一区二区三区视频 | 日韩在线观看中文 | 人人插人人澡 | 久久久黄色免费网站 | 免费日韩在线 | 亚洲va天堂va欧美ⅴa在线 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 在线观看黄色av | 激情五月五月婷婷 | 成人精品一区二区三区中文字幕 | 精品a级片 | 日韩免费播放 | 国产一区欧美二区 | 狠狠色丁香久久婷婷综合五月 | 又粗又长又大又爽又黄少妇毛片 | 久久免费影院 | 久久99爱视频| 日韩成人高清在线 | 欧美日韩高清国产 | 国产精品免费观看久久 | 天天超碰 | 99久久国产免费看 | 欧美91精品国产自产 | av不卡免费看| 国产亚洲精品日韩在线tv黄 | 天天操天天操天天操天天操天天操天天操 | 久久最新网址 | 国产麻豆电影 | 91精品免费看 | 狠狠色狠狠色 | 一级a性色生活片久久毛片波多野 | 国产剧情在线一区 | 成人午夜电影在线 | 中文不卡视频在线 | 一级精品视频在线观看宜春院 | 狠狠久久伊人 | 亚洲午夜精品一区二区三区电影院 | zzijzzij日本成熟少妇 | 夜夜干夜夜 | 天堂va在线高清一区 | 国产精品自产拍在线观看蜜 | 久久欧美视频 | 在线看av网址 | 99视频国产精品 | 久久人人精 | 久久99深爱久久99精品 | 亚洲欧美怡红院 | 国产精品网红直播 | 免费能看的av | 久久久久久久久综合 | 精品国产视频一区 | 视频 天天草 | 久久久久久久久影视 | 99中文字幕视频 | 91在线视频一区 | 久久久久久久久久久精 | 精品亚洲视频在线观看 | 青青久视频 | 亚洲精品www久久久久久 | 国产精品欧美在线 | 国产一区精品在线观看 | 97在线成人 | 精品美女视频 | 亚洲综合少妇 | 精品91久久久久 | 久久精品视频网址 | 99久国产| 久久综合免费 | 九九久久国产精品 | 精品一区精品二区高清 | 日本久久久影视 | www.久久久| 97精品国自产拍在线观看 | 日韩精品电影在线播放 | 日韩高清观看 | 欧美精品久久久久久久久免 | 日本h视频在线观看 | 97超碰色 | 久色免费视频 | 狠狠综合网 | 国产日韩欧美网站 | 国产又粗又猛又黄又爽视频 | 成人性生交大片免费看中文网站 | 激情丁香5月 | 伊人永久在线 | 国产精品第一视频 | 免费一级特黄毛大片 | av电影在线不卡 | 色视频 在线 | 五月综合色 | 69夜色精品国产69乱 | 天天色 天天 | 免费在线观看一区二区三区 | 美女国内精品自产拍在线播放 | 久久视频在线观看中文字幕 | 亚洲精品99 | 亚洲欧美在线观看视频 | 久久综合狠狠综合久久激情 | 男女免费av | 超碰人人草 | 欧美成人在线网站 | 国产精品黄色 | 国产精品久久精品国产 | 免费中文字幕 | 91在线看视频免费 | 日韩日韩日韩日韩 | 亚洲精品美女久久久久网站 | 国产视频在 | 在线观看成人av | 欧美日韩中文国产 | 中文字幕中文字幕在线中文字幕三区 | 国产精品久久久久久久久蜜臀 | 中文在线免费视频 | 欧美一级免费 | 婷婷六月丁香激情 | 国产精品18久久久久久vr | 国产精品视频资源 | 在线免费中文字幕 | 在线观看不卡视频 | 国产精品久久久久久久久久免费 | 在线观看中文字幕一区二区 | 在线观看欧美成人 | 九九九九九九精品 | 精品视频免费在线 | 国产午夜av | 日韩电影中文字幕在线观看 | 在线国产小视频 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 久久免费视频在线观看6 | 中文字幕精品一区二区精品 | 热久久这里只有精品 | 久久一线 | 亚洲国产中文字幕 | 综合网成人 | 国产专区视频在线观看 | 国产91精品看黄网站在线观看动漫 | 亚洲国产中文字幕在线 | 久久精品免费看 | 精品国产一二区 | 亚洲精品国产精品国 | 亚洲人成在线观看 | 久久一区二区三区日韩 | 五月天天色 | 亚洲成av人影片在线观看 | 国产成人三级三级三级97 | 九九九九热精品免费视频点播观看 | 97福利社| 91亚洲精品久久久蜜桃 | 色一级片| 99精品国产99久久久久久福利 | 欧美日韩一区二区在线 | 国产成人一区二区三区影院在线 | 亚洲在线看 | 国产在线观看91 | 狠狠色综合网站久久久久久久 | 国产精品成人一区 | 久久高清av| 伊甸园av在线| 人人擦 | 国产一级精品在线观看 | 九九热1 | www.天天操.com | 亚洲毛片在线观看. | 色偷偷男人的天堂av | 草久久久 | 国产精品21区 | 色婷婷狠狠18 | 观看免费av | 成人黄色免费在线观看 | adc在线观看 | 久久夜夜夜 | 国产精品高清一区二区三区 | 91传媒在线播放 | 亚洲一区二区精品视频 | 色视频网站在线观看一=区 a视频免费在线观看 | 怡春院av | 国产中文字幕国产 | 国产精品一区二区无线 | 亚洲午夜大片 | 视频成人永久免费视频 | 色综合天天狠狠 | 综合网天天 | 日韩av网页| 五月婷婷视频在线观看 | 日本一区二区高清不卡 | 丁香六月婷婷激情 | 免费a现在观看 | 在线观看免费视频你懂的 | 国产麻豆视频在线观看 | 久久综合毛片 | 国产乱对白刺激视频在线观看女王 | 激情五月婷婷丁香 | 91成人网页版 | 精品国产一区二区三区久久久蜜臀 | 91视频下载| 亚洲精品国产精品国自产观看 | 中日韩欧美精彩视频 | 欧美日一级片 | 国产精品午夜免费福利视频 | 欧美淫aaa免费观看 日韩激情免费视频 | 国内三级在线观看 | 欧美日韩一区二区久久 | 一区二区三区电影在线播 | 91亚洲精品久久久中文字幕 | 国产一级特黄毛片在线毛片 | 制服丝袜在线 | 久草视频在线资源站 | 国产精品高潮在线观看 | 日本韩国精品在线 | 黄网站色 | 免费人做人爱www的视 | 97超碰中文字幕 | 国产精品自在线拍国产 | 久久久久综合网 | 美女免费视频观看网站 | 国产精彩视频一区二区 | 99久久婷婷国产一区二区三区 | 久久国产精彩视频 | 综合精品久久 | 国产一区二区精品在线 | 国产理论免费 | 成人在线免费观看网站 | 欧美激情视频免费看 | 国产视频精品视频 | 色多视频在线观看 | 日韩在线观看视频中文字幕 | 成人黄色小说网 | 视频成人永久免费视频 | 久久久久一区 | 91精品一区二区三区蜜桃 | 激情偷乱人伦小说视频在线观看 | 91超碰在线播放 | 国产成人精品久久亚洲高清不卡 | 2019天天干天天色 | 黄污视频网站大全 | 干av在线| 91麻豆精品久久久久久 | 69av视频在线观看 | 国产永久免费观看 | 亚洲精品动漫久久久久 | 中文字幕888 | 欧美成人xxxxx| www.黄色小说.com | 夜色在线资源 | 久久好看免费视频 | 91豆花在线 | 麻豆视频国产 | 成人蜜桃网 | 91丨九色丨勾搭 | 欧美精品久久久久久久久老牛影院 | 成人久久免费 | av免费看av | 国产中文 | 亚洲精品中文在线资源 | 亚洲欧洲久久久 | 国产最顶级的黄色片在线免费观看 | 国产精品美女久久久久久久久 | 色综合色综合色综合 | 国产免费又粗又猛又爽 | 97色婷婷| 免费黄色在线 | 日韩视频免费播放 | 精品国产日本 | 婷婷视频在线观看 | 色综合小说 | 二区三区精品 | 五月婷婷播播 | 最近中文国产在线视频 | 亚洲免费观看视频 | 午夜久久久久久久久久久 | 最新国产在线视频 | 日韩系列 | 麻豆一区二区三区视频 | 成 人 黄 色 免费播放 | 99久久久久久 | 久久影院一区 | 天天操天天干天天插 | 五月婷在线播放 | 国产精华国产精品 | 亚洲精品午夜一区人人爽 | 九九热精品在线 | 亚洲国产日韩欧美 | 毛片美女网站 | 狠狠干2018| 99电影456麻豆 | 特级毛片爽www免费版 | 国产91在线播放 | 最新日本中文字幕 | a在线v| 国产一区视频在线播放 | 国产国产人免费人成免费视频 | 91黄色在线看 | 国产成人精品综合 | www.香蕉视频在线观看 | 深爱综合网 | 麻豆视频免费网站 | 亚洲欧洲av在线 | 97超级碰碰碰视频在线观看 | 久草精品视频在线播放 | 亚洲黄色三级 | 国产精品观看 | 国内视频在线观看 | 国产精品自产拍 | 成人91在线观看 | 日韩黄色在线观看 | 欧美久久成人 | 欧洲精品码一区二区三区免费看 | 日韩三级精品 | 91久久精品日日躁夜夜躁国产 | 免费人成网 | 九九一级片 | 国产精品美女久久久久久2018 | 久草 | 精品久久一区 | 四虎免费av| 天天综合91 | 久久观看最新视频 | 国产精品久久久久久久久久久不卡 | 99精品视频在线播放免费 | 免费亚洲视频在线观看 | 中文字幕日韩电影 | 一本到在线 | 久久精品美女视频 | 91精品视频免费观看 | 免费下载高清毛片 | 久久综合99| 一区二区三区动漫 | 色橹橹欧美在线观看视频高清 | 中文字幕亚洲欧美日韩2019 | 黄色在线视频网址 | 一区二区三区韩国免费中文网站 | 91精品国产麻豆国产自产影视 | 天天人人 | 亚洲爱av | 九九热在线观看视频 | 麻豆精品视频在线观看免费 | 国产麻豆精品久久 | 国产精品五月天 | 久久99精品久久久久久三级 | 国产亚洲精品久久久久久大师 | 国产视频精选在线 | 五月婷婷激情综合网 | 成人91在线观看 | 亚洲自拍偷拍色图 | 久久美女免费视频 | 国内揄拍国产精品 | 国产在线欧美日韩 | 亚州五月| 国产高清在线精品 | 精品一区二区影视 | 伊人狠狠操 | 欧美天天射 | 成人免费在线观看av | 97伊人网| 亚洲精品视频免费观看 | 99精品福利视频 | 操夜夜操 | 免费三及片 | 国内外成人免费在线视频 | 久久99电影| 黄色免费在线看 | 欧美日韩在线播放 | 婷婷在线综合 | 国产精品美女久久久久久 | 91精品高清| 激情偷乱人伦小说视频在线观看 | 99久久精品免费看国产四区 | 四虎精品成人免费网站 | 欧美 日韩 国产 中文字幕 | 国产精品岛国久久久久久久久红粉 | 成人精品影视 | 西西4444www大胆视频 | 天天插天天爽 | 国产在线永久 | 色伊人网| 91桃色在线观看视频 | 国产伦精品一区二区三区四区视频 | 国产精品久久久久久久久免费看 | 久久人操| 九九99 | 午夜久久久久 | 婷婷伊人综合亚洲综合网 | 天天干夜夜想 | 天天操夜夜叫 | 免费看在线看www777 | 欧美性天天 | 香蕉影视 | 中文字幕一区二区三区四区视频 | 日韩羞羞 | 国产精品久久久久久久久岛 | 在线观看国产永久免费视频 | 欧美精品亚洲精品日韩精品 | 久久久麻豆视频 | 免费看片网站91 | 综合色婷婷 | 96亚洲精品久久 | 久久综合久久综合这里只有精品 | 97免费在线观看视频 | 波多野结衣动态图 | 精品国产乱码久久久久久天美 | 国产资源精品 | 五月婷婷一区 | 欧美 激情在线 | 国产高清无av久久 | 成人黄色在线电影 | 日韩视频中文字幕 | 激情视频免费在线观看 | 中文亚洲欧美日韩 | 免费视频网| 久草在线 | 国产 一区二区三区 在线 | 五月天激情在线 | 99视频这里只有 | 日日爽| www.超碰| 国产色在线,com | 成人在线免费看视频 | 99中文字幕在线观看 | 99热超碰 | 亚洲一区二区天堂 | 欧美日韩亚洲在线观看 | 日韩毛片在线播放 | 欧美一二区视频 | 亚洲高清av | 美女在线国产 | 天天综合网在线 | 国产91精品看黄网站在线观看动漫 | 一区二区三区在线观看免费视频 | 一区二区视频播放 | 黄色毛片大全 | 成人免费观看网站 | 正在播放亚洲精品 | av解说在线 | 久久久久久亚洲精品 | av观看网站 | 国产专区在线播放 | 91精品成人 | 精品国产亚洲在线 | 一本一本久久a久久精品综合妖精 | 国产手机视频在线播放 | 夜夜嗨av色一区二区不卡 | 天天曰天天射 | 亚洲国内精品视频 | 久久久久久欧美二区电影网 | 欧美日韩视频在线 | 97成人精品视频在线播放 | 亚洲高清色综合 | 日韩国产欧美视频 | 91在线播放综合 | 精品a视频| 人人爽人人av | 日韩一区在线免费观看 | 九九在线免费视频 | 最新午夜 | 天天看天天干 | 激情av在线资源 | av观看免费在线 | 精品久久久久久久久久久院品网 | 国产1区在线 | aaa亚洲精品一二三区 | 久久久精品久久日韩一区综合 | 五月婷激情 | 国产精品中文字幕在线播放 | 午夜久久影院 | 香蕉影视| 狠狠干在线播放 | 国产精品中文字幕在线 | 精品视频免费 | 一区二区精品在线 | 操一草| 欧美淫aaa免费观看 日韩激情免费视频 | 国产福利免费在线观看 | 一本一本久久a久久精品综合 | 99在线视频播放 | 美女国产 | 欧美va在线观看 | 久久午夜视频 | 国产视频在线观看一区二区 | 久久综合色8888 | 911国产| 九九免费在线观看 | 国产激情电影综合在线看 | 婷婷婷国产在线视频 | 一本色道久久精品 | 91精品国产91久久久久 | 午夜国产一区二区三区四区 | 国产中文字幕视频在线观看 | 97人人添人澡人人爽超碰动图 | 91精品久久久久久久久 | 色就干| 国产91精品一区二区 | 96av视频| 亚洲国产精品视频 | 久草电影免费在线观看 | 最新av在线播放 | 少妇bbb搡bbbb搡bbbb | 91av99| 国产精品系列在线播放 | av理论电影 | 国产系列在线观看 | 成 人 黄 色 视频 免费观看 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 日韩中字在线 | 日韩欧在线 | 97在线播放视频 | 色永久免费视频 | 成人免费在线观看av | 91亚洲欧美激情 | 伊人天天色 | 国产精品剧情在线亚洲 | 精品不卡视频 | 久久福利精品 | 高清av在线免费观看 | 国产淫片| 狠狠色丁香婷婷综合久小说久 | 丁香花在线视频观看免费 | 天堂av色婷婷一区二区三区 | 久久精品日产第一区二区三区乱码 | 成年人app网址 | 欧美不卡视频在线 | av成人在线观看 | 欧美日韩精品久久久 | 欧美精品亚州精品 | 人人玩人人添人人澡超碰 | 国产手机在线观看 | 在线免费观看欧美日韩 | 欧美日本不卡高清 | 久香蕉 | 中文字幕精品三区 | 91麻豆精品一区二区三区 | 精品久久久久一区二区国产 | 成人 国产 在线 | 国产第一页在线观看 | 国产高清专区 | 伊人网av| 免费看黄色大全 | 99亚洲天堂| 91精品国产91热久久久做人人 | 国内一区二区视频 | 日韩精品视频在线观看网址 | 国产香蕉视频 | 99久久夜色精品国产亚洲 | www.亚洲精品 | 日韩在线观看免费 | 中文字幕 国产专区 | 五月婷婷在线观看视频 | 国产精品入口66mio女同 | 中文字幕色在线视频 | 女人18精品一区二区三区 | 日本系列中文字幕 | 国产特级毛片aaaaaa毛片 | 日韩精品一区在线观看 | 在线观看成人毛片 | 最近高清中文字幕在线国语5 | 久久精品在线 | 国产一区二区三区在线免费观看 | 五月天伊人 |