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

監(jiān)控系統(tǒng)哪家強(qiáng)?EMonitor與CAT大比拼!

安全 數(shù)據(jù)安全 應(yīng)用安全
本文通過對(duì)比分析下兩者所做的事情為契機(jī)討論監(jiān)控系統(tǒng)或許該有的面貌,以及淺談下監(jiān)控系統(tǒng)發(fā)展的各個(gè)階段。

 本文通過對(duì)比分析下兩者所做的事情為契機(jī)討論監(jiān)控系統(tǒng)或許該有的面貌,以及淺談下監(jiān)控系統(tǒng)發(fā)展的各個(gè)階段。

[[283123]]

 

圖片來自 Pexels

餓了么監(jiān)控系統(tǒng) EMonitor :是一款服務(wù)于餓了么所有技術(shù)部門的一站式監(jiān)控系統(tǒng),覆蓋了系統(tǒng)監(jiān)控、容器監(jiān)控、網(wǎng)絡(luò)監(jiān)控、中間件監(jiān)控、業(yè)務(wù)監(jiān)控、接入層監(jiān)控以及前端監(jiān)控的數(shù)據(jù)存儲(chǔ)與查詢。

每日處理總數(shù)據(jù)量近 PB ,每日寫入指標(biāo)數(shù)據(jù)量百 T,每日指標(biāo)查詢量幾千萬,配置圖表個(gè)數(shù)上萬,看板個(gè)數(shù)上千。

CAT:是基于 Java 開發(fā)的實(shí)時(shí)應(yīng)用監(jiān)控平臺(tái),為美團(tuán)點(diǎn)評(píng)提供了全面的實(shí)時(shí)監(jiān)控告警服務(wù)。

CAT 做的事情(開源版)

首先要強(qiáng)調(diào)的是這里我們只能拿到 GitHub 上開源版 CAT 的最新版 3.0.0 ,所以是基于此進(jìn)行對(duì)比。接下來說說 CAT 做了哪些事情?

①抽象出監(jiān)控模型

抽象出 Transaction、Event、Heartbeat、Metric 4 種監(jiān)控模型:

  • Transaction:用來記錄一段代碼的執(zhí)行時(shí)間和次數(shù)。
  • Event:用來記錄一件事發(fā)生的次數(shù)。
  • Heartbeat:表示程序內(nèi)定期產(chǎn)生的統(tǒng)計(jì)信息,如 CPU 利用率。
  • Metric:用于記錄業(yè)務(wù)指標(biāo),可以記錄次數(shù)和總和。

針對(duì) Transaction 和 Event 都固定了兩個(gè)維度, type 和 name ,并且針對(duì) type 和 name 進(jìn)行分鐘級(jí)聚合成報(bào)表并展示曲線。

 

②采樣鏈路

針對(duì)上述 Transaction、Event 的 type 和 name 分別有對(duì)應(yīng)的分鐘級(jí)的采樣鏈路。

 

③自定義的 Metric 打點(diǎn)

目前支持 Counter 和 Timer 類型的打點(diǎn),支持 tag ,單機(jī)內(nèi)單個(gè) Metric 的 tag 組合數(shù)限制 1000 。

并且有簡單的監(jiān)控看板,如下圖所示:

 

④與其他組件集成

比如和 Mybatis 集成,在客戶端開啟相關(guān)的 sql 執(zhí)行統(tǒng)計(jì),并將該統(tǒng)計(jì)劃分到 Transaction 統(tǒng)計(jì)看板中的 type=SQL 的一欄下。

 

⑤告警

可以針對(duì)上述的 Transaction、Event 等做一些簡單的閾值告警。

餓了么 EMonitor 和 CAT 的對(duì)比

餓了么 EMonitor 借鑒了 CAT 的相關(guān)思想,同時(shí)又進(jìn)行了改進(jìn)。

①引入 Transaction、Event 的概念

針對(duì) Transaction 和 Event 都固定了兩個(gè)維度, type 和 name ,不同地方在于聚合用戶發(fā)過來的數(shù)據(jù)。

CAT 的架構(gòu)圖如下所示:

 

CAT 的消費(fèi)機(jī)需要做如下兩件事情:

  • 對(duì) Transaction、Event 等消息模型按照 type 和 name 進(jìn)行當(dāng)前小時(shí)的聚合,歷史小時(shí)的聚合數(shù)據(jù)寫入到 MySQL 中。
  • 將鏈路數(shù)據(jù)寫入到本地文件或者遠(yuǎn)程 HDFS 上。

EMonitor 的架構(gòu)圖如下所示:

EMonitor 分兩路對(duì)數(shù)據(jù)進(jìn)行隔離處理:

 

  • Real-Time Streaming Compute:對(duì)用戶發(fā)過來的鏈路中的 Transaction 、Event 等監(jiān)控模型轉(zhuǎn)變成指標(biāo)數(shù)據(jù)并進(jìn)行 10s 的預(yù)聚合,同時(shí)也對(duì)用戶發(fā)過來的 Metric 數(shù)據(jù)進(jìn)行 10s 預(yù)聚合。

最后將 10s 預(yù)聚合的數(shù)據(jù)寫入到 LinDB 時(shí)序數(shù)據(jù)庫(已開源,有興趣的可以關(guān)注 star 下)中,以及 Kafka 中,讓告警模塊 watchdog 去消費(fèi) Kafka 做實(shí)時(shí)告警。

  • Real-Time Data Writer:對(duì)用戶發(fā)過來的鏈路數(shù)據(jù)構(gòu)建鏈路索引、向 HDFS 和 HBase 寫入索引和鏈路數(shù)據(jù),同時(shí)會(huì)構(gòu)建應(yīng)用之間的依賴關(guān)系,將依賴關(guān)系寫入到 Neo4j 中。

所以 EMonitor 和 CAT 的一個(gè)很大不同點(diǎn)就在于對(duì)指標(biāo)的處理上, EMonitor 交給專業(yè)的時(shí)序數(shù)據(jù)庫來做。

而 CAT 自己做聚合就顯得功能非常受限,如下所示:

  • CAT 只能整小時(shí)的查看 type 和 name 數(shù)據(jù),不能跨小時(shí),即不能查看任意兩個(gè)時(shí)間之間的報(bào)表數(shù)據(jù), EMonitor 沒有此限制。
  • CAT 沒法查看所有 type 匯總后的響應(yīng)時(shí)間和 QPS , EMonitor 可以靈活的自由組合 type 和 name 進(jìn)行聚合。
  • CAT 的 type 和 name 報(bào)表是分鐘級(jí)的, EMonitor 是 10s 級(jí)別的。
  • CAT 的 type 和 name 沒能和歷史報(bào)表曲線直接對(duì)比, EMonitor 可以對(duì)比歷史報(bào)表曲線,更容易發(fā)現(xiàn)問題。
  • CAT 的 type 和 name 列表首頁展示了一堆數(shù)字,無法立即獲取一些直觀信息。
  • 比如給出了響應(yīng)時(shí)間 TP99 100ms 這個(gè)到底是好還是壞, EMonitor 有當(dāng)前曲線和歷史曲線,相對(duì)來說可以直接判斷到底 ok 不 ok。
  • CAT的 TP99、TP999 基于單機(jī)內(nèi)某個(gè)小時(shí)內(nèi)的報(bào)表是準(zhǔn)確的,除此之外多機(jī)或者多個(gè)小時(shí)的聚合 TP99、TP999 是用加權(quán)平均來計(jì)算的,準(zhǔn)確性有待提高。

但是CAT也有自己的優(yōu)勢(shì):

  • CAT 含有 TP999、TP9999 線(但是準(zhǔn)確性還有些問題), EMonitor 只能細(xì)到 TP99 。
  • CAT 的 type 和 name 可以按照機(jī)器維度進(jìn)行過濾, EMonitor 沒有做到這么細(xì)粒度。

②采樣鏈路

目前 CAT 和 EMonitor 都可以通過 type 和 name 來過濾采樣鏈路,不同點(diǎn)在于:

CAT 的采樣鏈路是分鐘級(jí)別的, EMonitor 是 10s 級(jí)別的。

針對(duì)某一個(gè) type 和 name ,CAT 目前無法輕松找想要的鏈路, EMonitor 可以輕松的找到某個(gè)時(shí)刻或者說某段時(shí)間內(nèi)響應(yīng)時(shí)間想要的鏈路(目前已經(jīng)申請(qǐng)專利)。

EMonitor 的鏈路如下所示:

 

  • 上圖是某個(gè)10s 時(shí)刻、某個(gè) type 和 name 過濾條件下的采樣鏈路。
  • 第一行是這 10s 內(nèi)的采樣鏈路,按照響應(yīng)時(shí)間進(jìn)行了排序。
  • 可以隨意點(diǎn)擊某個(gè)響應(yīng)時(shí)間來查看對(duì)應(yīng)的鏈路詳情。

③自定義的 Metric 打點(diǎn)

EMonitor 支持 Counter、Timer、Histogram、Payload、Gauge 等等多種形式的打點(diǎn)方式,并且支持 tag :

  • Counter:計(jì)數(shù)累加類型。
  • Timer:可以記錄一段代碼的耗時(shí),包含執(zhí)行次數(shù)、耗時(shí)最大值、最小值、平均值。
  • Histogram:包含 Timer 的所有東西,同時(shí)支持計(jì)算 TP99 線,以及其他任意 TP 線(從 0 到 100 )。
  • Payload:可以記錄一個(gè)數(shù)據(jù)包的大小,包含數(shù)據(jù)包個(gè)數(shù)、包的最大值、最小值、平均值。
  • Gauge:測(cè)量值,一般用于衡量隊(duì)列大小、連接數(shù)、CPU、內(nèi)存等等。

也就是任意 Metric 打點(diǎn)都可以流經(jīng) EMonitor 進(jìn)行處理了并輸送到 LinDB 時(shí)序數(shù)據(jù)庫中。

至此, EMonitor 就可以將任何監(jiān)控指標(biāo)統(tǒng)一在一起了,比如機(jī)器監(jiān)控都可以通過 EMonitor 來保存了,這為一站式監(jiān)控系統(tǒng)奠定了基礎(chǔ)。

④自定義 Metric 看板

CAT 只有一個(gè)簡易的 Metric 看板。EMonitor 針對(duì) Metric 開發(fā)了一套可以媲美 Grafana 的指標(biāo)看板。

相比 Grafana 的優(yōu)勢(shì):

  • 有一套類似 SQL 的非常簡單的配置指標(biāo)的方式。
  • 跟公司人員組織架構(gòu)集成,更加優(yōu)雅的權(quán)限控制,不同的部門可以建屬于自己的看板。
  • 指標(biāo)和看板的收藏,當(dāng)源指標(biāo)或看板改動(dòng)后,無需收藏人員再改動(dòng)。
  • alpha、beta、prod 不同環(huán)境之間的一鍵同步指標(biāo)和看板,無需配置多次。
  • PC 端和移動(dòng)端的同步查看指標(biāo)和看板。

 

類 SQL 的配置查詢指標(biāo)方式如下所示:

  • 可以配置圖表的展現(xiàn)形式。
  • 可以配置要查詢的字段以及字段之間的加減乘除等豐富的表達(dá)式。
  • 可以配置多個(gè)任意 tag 的過濾條件。
  • 可以配置 group by 以及 order by。

看板整體如下所示:

 

移動(dòng)端顯示如下:

 

⑤與其他組件集成

 

目前 EMonitor 已經(jīng)打通了 IaaS 層、 PaaS 層、應(yīng)用層的所有鏈路和指標(biāo)的監(jiān)控,再也不用在多個(gè)監(jiān)控系統(tǒng)中切換來切換去了。

如下所示:

 

  • IaaS 層物理機(jī)、機(jī)房網(wǎng)絡(luò)交換機(jī)等的監(jiān)控指標(biāo)。
  • PaaS 層中間件服務(wù)端的監(jiān)控指標(biāo)。
  • 應(yīng)用層 SOA、Exception、JVM、MQ 等客戶端的相關(guān)指標(biāo)。
  • 應(yīng)用層自定義的監(jiān)控指標(biāo)。

以打通餓了么分庫分表中間件 DAL 為例:

 

可以根據(jù)機(jī)房、執(zhí)行狀態(tài)、表、操作類型(比如 Insert、Update、Select 等)進(jìn)行過濾查看:

  • 左邊列表給出每條 SQL 的執(zhí)行的平均耗時(shí)。
  • 右邊 2 個(gè)圖表給出該條 SQL 在 DAL 中間件層面、 DB 層面的耗時(shí)以及調(diào)用 QPS。
  • 可以給出該 SQL 打在后端 DAL 中間、 DB 上的分布情況,可以用于排查是否存在一些熱點(diǎn)的情況。
  • 還有一些 SQL 查詢結(jié)果的數(shù)據(jù)包大小的曲線、 SQL 被 DAL 限流的情況等等。
  • 可以查看任何時(shí)間點(diǎn)上該 SQL 的調(diào)用鏈路信息。

 

再以打通餓了么 SOA 服務(wù)為例:

  • 可以根據(jù)機(jī)房和狀態(tài)信息進(jìn)行過濾。
  • 左邊一欄列出該應(yīng)用提供的 SOA 服務(wù)接口,同時(shí)給出平均響應(yīng)時(shí)間以及和昨天的對(duì)比情況。
  • 右邊的兩個(gè)圖表分別給出了對(duì)應(yīng)服務(wù)接口的服務(wù)響應(yīng)時(shí)間和 QPS 以及和昨天的對(duì)比情況,同時(shí)可以切換平均響應(yīng)時(shí)間到 TP99 或者其他 TP 值,同時(shí)配有可以快速對(duì)相關(guān)曲線添加告警的跳轉(zhuǎn)鏈接。
  • 可以切換到單機(jī)維度來查看每臺(tái)機(jī)器該 SOA 接口的響應(yīng)時(shí)間和 QPS ,用來定位某臺(tái)機(jī)器的問題。
  • 可以給出該 SOA 接口調(diào)用在不同集群的分布占比。
  • 可以給出該 SOA 接口的所有調(diào)用方以及他們的 QPS。
  • 可以查看任何時(shí)間點(diǎn)上該 SOA 接口的調(diào)用鏈路信息。

⑥告警

可以針對(duì)所有的監(jiān)控指標(biāo)配置如下告警方式:

  • 閾值:簡單的閾值告警,適用于 CPU 、內(nèi)存等。
  • 同環(huán)比:與過去同期比較的告警。
  • 趨勢(shì):適合于相對(duì)平滑連續(xù)的無需閾值的智能告警。
  • 其他告警形式。

淺談監(jiān)控系統(tǒng)的發(fā)展趨勢(shì)

①日志監(jiān)控階段

本階段實(shí)現(xiàn)方式:程序打日志,使用 ELK 來存儲(chǔ)和查詢程序的運(yùn)行日志,ELK 也能簡單顯示指標(biāo)曲線。

排障過程:一旦有問題,則去 ELK 中搜索可能的異常日志來進(jìn)行分析排障。

②鏈路監(jiān)控階段

上一個(gè)階段存在的問題:ELK 只是基于一行一行日志進(jìn)行聚合或者搜索分析,日志之間沒有上下文關(guān)聯(lián)。很難知道一次請(qǐng)求耗時(shí)較長究竟耗時(shí)在哪個(gè)階段。

本階段實(shí)現(xiàn)方式:CAT 橫空出世,通過建模抽象出 Transaction、Metric 等監(jiān)控模型,將鏈路分析和簡單的報(bào)表帶入了大家的視野。

告警方式:針對(duì)報(bào)表可以進(jìn)行閾值監(jiān)控排障過程:一旦有告警,可以通過點(diǎn)擊報(bào)表來詳細(xì)定位到是哪個(gè) type 或 name 有一定問題,順便找到對(duì)應(yīng)的鏈路,查看詳細(xì)的信息。

③指標(biāo)監(jiān)控階段

上一階段存在的問題:CAT 對(duì)自定義指標(biāo)支持的比較弱,也無法實(shí)現(xiàn)或者展現(xiàn)更加多樣的查詢聚合需求。

本階段的實(shí)現(xiàn)方式:支持豐富的 Metric 指標(biāo),將鏈路上的一些報(bào)表數(shù)據(jù)也可以劃分到指標(biāo)中,交給專業(yè)的時(shí)序數(shù)據(jù)庫來做指標(biāo)的存儲(chǔ)和查詢,對(duì)接或者自研豐富的指標(biāo)看板如 Grafana 。

告警方式:針對(duì)指標(biāo)進(jìn)行更加豐富的告警策略排障過程:一旦有告警,可能需要到各個(gè)系統(tǒng)上查看指標(biāo)看板,粗略定位根因,再結(jié)合鏈路總和分析。

④平臺(tái)打通整合階段

上一階段存在的問題:系統(tǒng)監(jiān)控、中間件和業(yè)務(wù)監(jiān)控、部分業(yè)務(wù)監(jiān)控、鏈路監(jiān)控與指標(biāo)監(jiān)控都各搞一套數(shù)據(jù)收集、預(yù)處理、存儲(chǔ)、查詢、展現(xiàn)、告警流程,各個(gè)系統(tǒng)處理數(shù)據(jù)格式、使用方式不統(tǒng)一。

本階段的實(shí)現(xiàn)方式:打通從系統(tǒng)層面、容器層面、中間件層面、業(yè)務(wù)層面等等的可能的鏈路和指標(biāo)監(jiān)控,統(tǒng)一數(shù)據(jù)的處理流程,同時(shí)整合發(fā)布、變更、告警與監(jiān)控曲線結(jié)合,成為一站式監(jiān)控平臺(tái)。

告警方式:可以統(tǒng)一的針對(duì)各個(gè)層面的監(jiān)控?cái)?shù)據(jù)做統(tǒng)一化的告警排障過程:只需要在一個(gè)監(jiān)控系統(tǒng)中就可以查看到所有的監(jiān)控曲線和鏈路信息。

目前我們 EMonitor 已完成這個(gè)階段,將公司之前存在已久的 3 套獨(dú)立的監(jiān)控系統(tǒng)統(tǒng)一整合成現(xiàn)如今的一套監(jiān)控系統(tǒng)。

⑤深度分析階段

上一階段存在的問題:

  • 用戶雖然可以在一個(gè)系統(tǒng)中看到所有各個(gè)層面的監(jiān)控?cái)?shù)據(jù)了,但是每次排障時(shí)仍然要花很多的時(shí)間去查看各個(gè)層面是否有問題,一旦漏看一項(xiàng)可能就錯(cuò)過了問題所在的根因。
  • 沒有整個(gè)業(yè)務(wù)的全局監(jiān)控視角,都停留在各自應(yīng)用的角度。

總之:之前的階段都是去做一個(gè)監(jiān)控平臺(tái),用戶查詢什么指標(biāo)就展示相應(yīng)的數(shù)據(jù),監(jiān)控平臺(tái)并不去關(guān)心用戶所存儲(chǔ)數(shù)據(jù)的內(nèi)容。

現(xiàn)在呢就需要轉(zhuǎn)變思路,監(jiān)控平臺(tái)需要主動(dòng)去幫用戶分析里面所存儲(chǔ)的數(shù)據(jù)內(nèi)容。

本階段的實(shí)現(xiàn)方式:所要做的就是把幫用戶分析的過程抽象出來,為用戶構(gòu)建應(yīng)用大盤和業(yè)務(wù)大盤,以及為大盤做相關(guān)的根因分析。

應(yīng)用大盤:就是為當(dāng)前應(yīng)用構(gòu)建上下游應(yīng)用依賴的監(jiān)控、當(dāng)前應(yīng)用所關(guān)聯(lián)的機(jī)器監(jiān)控、Redis、MQ、Database 等等監(jiān)控,可以時(shí)刻為應(yīng)用做體檢,來主動(dòng)暴露出問題,而不是等用戶去一個(gè)個(gè)查指標(biāo)而后發(fā)現(xiàn)問題。

業(yè)務(wù)大盤:就是根據(jù)業(yè)務(wù)來梳理或者利用鏈路來自動(dòng)生產(chǎn)大盤,該大盤可以快速告訴用戶是哪些業(yè)務(wù)環(huán)節(jié)出的問題。

根因分析:一個(gè)大盤有很多的環(huán)節(jié),每個(gè)環(huán)節(jié)綁定有很多的指標(biāo),每次某個(gè)告警出來有可能需要詳細(xì)的分析下每個(gè)環(huán)節(jié)的指標(biāo)。

比如消費(fèi) Kafka 的延遲上升,有各種各樣的原因都可能導(dǎo)致,每次告警排查都需要將分析流程再全部人為分析排查下,非常累,所以需要將定位根因的過程通過建模抽象下,來進(jìn)行統(tǒng)一解決。

趨勢(shì)報(bào)表分析:主動(dòng)幫用戶發(fā)現(xiàn)一些逐漸惡化的問題點(diǎn),比如用戶發(fā)布之后,接口耗時(shí)增加,很可能用戶沒有發(fā)現(xiàn),雖然當(dāng)前沒有問題,但是很有可能在明天的高峰期就會(huì)暴露問題,這些都是已經(jīng)實(shí)實(shí)在在發(fā)生的事故。

要想做主動(dòng)分析,還深度依賴指標(biāo)下鉆分析,即某個(gè)指標(biāo)調(diào)用量下降了,能主動(dòng)分析出是哪些 tag 維度組合導(dǎo)致的下降,這是上述很多智能分析的基礎(chǔ),這一塊也不簡單。

告警方式:可以統(tǒng)一的針對(duì)各個(gè)層面的監(jiān)控?cái)?shù)據(jù)做統(tǒng)一化的告警排障過程:NOC 根據(jù)業(yè)務(wù)指標(biāo)或者業(yè)務(wù)大盤快速得知是哪些業(yè)務(wù)或者應(yīng)用先出了問題,應(yīng)用的 owner 通過應(yīng)用大盤的體檢得知相關(guān)的變動(dòng)信息。

比如是 Redis 波動(dòng)、Database 波動(dòng)、上下游應(yīng)用的某個(gè)方法波動(dòng)等等,來達(dá)到快速定位問題目的,或者通過對(duì)大盤執(zhí)行根因分析來定位到根因。

再談 Logging、Tracing、Metrics

三者關(guān)系如下圖所示:

 

三者的確都不可或缺,相輔相成,但是我想說以下幾點(diǎn):

  • 三者在監(jiān)控排障中的所占比例卻大不一樣:Metrics 占據(jù)大頭, Tracing 次之, Logging 最后。
  • Tracing 含有重要的應(yīng)用之間的依賴信息, Metrics 有更多的可深度分析和挖掘的空間,所以未來必然是在 Metrics 上大做文章。

再結(jié)合 Tracing 中的應(yīng)用依賴來做更深度全局分析,即 Metrics 和 Tracing 兩者結(jié)合發(fā)揮出更多的可能性。

參考資料:

  • CAT
  • https://github.com/dianping/cat
  • 深度剖析開源分布式監(jiān)控 CAT

https://tech.meituan.com/2018/11/01/cat-in-depth-java-application-monitoring.html

作者:李剛

簡介:網(wǎng)名乒乓狂魔,餓了么監(jiān)控組研發(fā)專家,餓了么內(nèi)部時(shí)序數(shù)據(jù)庫 LinDB 項(xiàng)目負(fù)責(zé)人,目前致力于監(jiān)控的智能分析領(lǐng)域。

 

責(zé)任編輯:武曉燕 來源: 阿里巴巴中間件
相關(guān)推薦

2020-05-18 11:07:53

監(jiān)控系統(tǒng)架構(gòu)技術(shù)

2016-09-22 15:05:01

BAT開發(fā)座椅

2023-05-26 15:53:48

MidjourneyAI圖像

2010-04-21 12:54:46

Unix內(nèi)核

2019-08-27 09:00:00

敏捷開發(fā)開發(fā)方法項(xiàng)目

2011-01-19 11:10:30

2009-10-13 14:46:00

思科認(rèn)證

2010-03-18 14:54:46

主流無線技術(shù)

2009-07-02 18:50:43

2009-06-01 09:46:57

2010-07-14 13:38:51

Perl開發(fā)工具

2020-08-04 17:06:40

Merging Rebasing Git

2012-02-14 14:06:48

筆記本評(píng)測(cè)

2016-11-02 09:20:01

SparkHadoop MapR大數(shù)據(jù)

2011-08-18 11:08:02

2013-09-25 10:09:54

閃存SSD存儲(chǔ)

2018-11-15 10:23:18

路由器類別作用

2012-09-20 09:32:23

Ubuntu 12.1文件系統(tǒng)Ubuntu

2017-09-10 14:29:03

眼力

2014-01-07 17:08:02

Java開源框架
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

国产网站一区二区| 欧美fxxxxxx另类| 欧美在线视频你懂得| 一区二区三区精品国产| 国产视频在线观看视频| 99国产精品久久久久久久| 一区二区亚洲欧洲国产日韩| 91日韩精品视频| 免费成人在线电影| 国产精品乱人伦| 国产一区二区高清视频| 超碰在线免费97| 黑丝一区二区三区| 在线观看国产精品淫| 911亚洲精选| abab456成人免费网址| 亚洲一区精品在线| 亚洲v欧美v另类v综合v日韩v| 精品国产无码一区二区| 爽好久久久欧美精品| 欧美日韩成人在线播放| 日韩影视一区二区三区| 91精品国产自产在线丝袜啪| 在线视频国产一区| 精品少妇一区二区三区在线| 免费的黄网站在线观看| www精品美女久久久tv| 亚洲一区中文字幕| 亚洲天堂网视频| 免费在线欧美黄色| 性欧美暴力猛交69hd| 成人免费毛片xxx| 日本午夜一区| 亚洲欧美国产精品| 成人区人妻精品一区二| 欧美黄视频在线观看| 欧美亚日韩国产aⅴ精品中极品| 91动漫在线看| 欧美xxxx免费虐| 亚洲精品你懂的| 午夜精品一区二区在线观看的| 亚洲 国产 欧美 日韩| 国产成人精品亚洲日本在线桃色| 国产欧美亚洲精品| 波多野结衣在线观看视频| av成人激情| 97av在线视频| 伊人久久综合视频| 亚洲深夜福利| 欧美亚洲午夜视频在线观看| 日韩成人高清视频| 国产欧美不卡| 欧美中文字幕在线视频| 亚洲欧美综合另类| 久久亚洲视频| 国产精品露脸av在线| 337p粉嫩色噜噜噜大肥臀| 欧美亚洲一区| 国产精品高潮呻吟久久av无限 | 你懂的好爽在线观看| 91色porny在线视频| 欧美一区二区三区在线播放| 国外av在线| 国产精品国产三级国产a| 中文精品视频一区二区在线观看| 国产午夜精品久久久久免费视| 亚洲色图在线看| 国产精品av免费观看| 国产精品—色呦呦| 欧美午夜激情视频| 亚洲激情在线观看视频| 亚洲成人高清| 欧美精品一区二区三区很污很色的| 97精品人人妻人人| 国产欧美日韩精品一区二区免费 | 欧美成人另类视频| 国产精品久久久久久久久久10秀 | 亚洲裸体xxxx| 日本美女bbw| 91综合久久一区二区| 欧美成人免费小视频| 国产香蕉在线视频| 日韩精品久久理论片| 成人国产精品免费视频| 亚洲国产一二三区| 久久久噜噜噜久久人人看| 亚洲国产精品视频一区| 污污网站在线看| 日韩欧美在线第一页| 国产欧美高清在线| 欧美久久亚洲| 亚洲人成电影在线播放| www.xxxx日本| 久久激情婷婷| 亚洲一区二区自拍| 国产三级视频在线| 一区二区三区不卡在线观看| 日韩视频第二页| 亚洲男女网站| 亚洲另类激情图| 欧美日韩精品一区二区三区视频播放 | 欧洲av一区二区| 欧美一二三区在线| x88av在线| 在线看片一区| 成人黄色中文字幕| 蝌蚪视频在线播放| 亚洲国产日韩a在线播放性色| 毛葺葺老太做受视频| 777久久精品| www.欧美精品| 波多野结衣视频网址| 成人黄色a**站在线观看| 亚欧精品在线| 欧美一区 二区 三区| 精品久久人人做人人爽| 51精品免费网站| 免费人成黄页网站在线一区二区| 久久久久久国产精品免费免费| 精品黄色免费中文电影在线播放| 欧美天天综合色影久久精品| 精品国产一二区| 亚洲h色精品| 国产欧美 在线欧美| 青青草免费在线| 亚洲h精品动漫在线观看| 青青草原播放器| 日韩理论在线| 国产精品亚发布| 欧美成人片在线| 欧美日韩在线观看视频| 激情综合激情五月| 欧美日韩一区二区三区四区在线观看 | www.成人在线视频| 亚洲女同精品视频| 九九热精品视频在线| 99精品视频在线观看| 日韩亚洲欧美视频| 91精品尤物| 欧美激情手机在线视频 | 国产喂奶挤奶一区二区三区| 男人操女人免费软件| 欧美sss在线视频| 性色av一区二区三区免费 | 一区二区三区精品99久久 | 日韩免费性生活视频播放| 久久成人小视频| 黄页网站大全一区二区| 在线播放豆国产99亚洲| 国产一区2区在线观看| 久久久极品av| www.国产免费| 亚洲一区二区三区不卡国产欧美| 欧美熟妇另类久久久久久多毛| 欧美一区91| 国产高清自拍一区| av影院在线免费观看| 日韩黄色在线免费观看| 久久久黄色大片| 国产精品天天摸av网| 亚洲精品www.| 欧美日本免费| 精品在线一区| 亚洲成人一区在线观看| 精品国产欧美一区二区三区成人| 91亚洲视频在线观看| 亚洲人成伊人成综合网小说| 亚欧美一区二区三区| 夜间精品视频| 国产乱码精品一区二区三区日韩精品| 成人爽a毛片免费啪啪动漫| 亚洲精品720p| 无码aⅴ精品一区二区三区| 国产精品午夜久久| 熟妇女人妻丰满少妇中文字幕| 极品中文字幕一区| 日本视频一区二区不卡| 成人97精品毛片免费看| 久久久久国产精品www| 欧美人体大胆444www| 欧美日本视频在线| 国产精品不卡av| 日本一区二区综合亚洲| 26uuu国产| 久久久久久久波多野高潮日日| 亚洲区一区二区三区| 亚洲免费一区三区| 国产成人免费91av在线| dy888亚洲精品一区二区三区| 亚洲第一天堂av| 影音先锋国产在线| 亚洲18色成人| 国产精品视频看看| 99国产精品国产精品毛片| 亚洲污视频在线观看| 伊人久久亚洲影院| 亚洲一区二区精品在线| 成人激情自拍| 国产成人黄色av| 丁香花在线影院| www国产精品com| 日本韩国一区| 欧美成人a∨高清免费观看| 国产免费a视频| 午夜精品一区二区三区免费视频 | 色综合888| 日韩一区二区中文字幕| 一级黄色在线视频| 婷婷久久综合九色综合伊人色| 永久av免费网站| 久久精品网站免费观看| 中文字幕天堂av| 国产一区二区三区综合| 国模杨依粉嫩蝴蝶150p| 亚洲国产免费看| 看全色黄大色大片| 色一区二区三区四区| 久久久久久久久久久久久久久久av| 成人污污视频| 成人黄色免费片| 国产成人免费| 国产91久久婷婷一区二区| free性m.freesex欧美| 色狠狠av一区二区三区香蕉蜜桃| 完全免费av在线播放| 日韩中文字幕av在线| 日韩中出av| 国产精品污www一区二区三区| 国产情侣一区在线| 国产在线精品播放| 国产69精品久久久久按摩| 日本久久久久久久久| www视频在线观看| 欧美激情综合色综合啪啪五月| 超碰人人在线| 美女扒开尿口让男人操亚洲视频网站| av资源网站在线观看| 精品亚洲国产视频| 欧美女子与性| 亚洲欧洲黄色网| 国产高清免费在线播放| 亚洲欧洲一区二区三区久久| 天堂在线资源8| 亚洲精品久久久久久久久久久| 好吊色视频一区二区| 精品久久久久久亚洲综合网| 亚洲精品久久久蜜桃动漫| 精品乱人伦一区二区三区| 亚洲第一第二区| 亚洲精品在线观看网站| 色一情一乱一乱一区91av| 亚洲国产精品成人一区二区| 天天操天天射天天| 亚洲欧美激情另类校园| 少妇精品视频一区二区| 亚洲精品影视在线观看| 高清在线观看av| 精品国产欧美成人夜夜嗨| 新版中文在线官网| 欧美精品电影免费在线观看| 草草视频在线| 国产精品99久久久久久人| 视频91a欧美| 99九九电视剧免费观看| 欧美深夜视频| 天堂资源在线亚洲视频| 亚洲无中文字幕| 蜜臀av色欲a片无码精品一区 | 91香蕉视频导航| 久久99精品久久久久| 久久久精品视频国产| av午夜一区麻豆| 国产精品毛片一区二区| 国产精品久99| 久青草免费视频| 日韩欧美中文在线| 一炮成瘾1v1高h| 精品少妇一区二区三区在线播放 | 一卡二卡在线视频| 亚洲成人av在线| 国产区高清在线| 色综合色综合网色综合| 成人福利视频| 91亚洲国产精品| 天堂在线精品| 中文字幕在线观看一区二区三区| 欧美日本一区| 亚洲免费av一区二区三区| 国产成人精品免费一区二区| av网站有哪些| 亚洲丝袜美腿综合| 久久国产黄色片| 91精品国产91久久久久久一区二区 | 国产极品国产极品| 精品福利在线观看| 国产精品久久久久久69| 国产视频丨精品|在线观看| 老司机在线看片网av| 5278欧美一区二区三区| 成人在线啊v| 欧美日韩精品一区| 国内综合精品午夜久久资源| 牛夜精品久久久久久久| 成人福利在线看| 情侣偷拍对白清晰饥渴难耐| 欧美网站在线观看| 亚洲第一天堂网| 久久成人精品视频| 欧美大片1688网站| 蜜桃欧美视频| 亚洲精品美女91| 麻豆精品国产传媒| 国产精品免费av| av黄色在线播放| 亚洲精品av在线播放| 一色桃子av在线| 国产欧美亚洲视频| 日韩av二区| 日本成人中文字幕在线| 91丨porny丨国产入口| 国产精品999久久久| 777亚洲妇女| 天堂а√在线资源在线| 国产国产精品人在线视| 天堂av一区二区三区在线播放| 日本一级黄视频| 国产精品亚洲一区二区三区妖精| 日本免费网站视频| 欧美日韩国产首页| 超碰免费在线观看| 国产精品扒开腿爽爽爽视频| 亚洲电影男人天堂| av黄色在线网站| 99精品视频在线免费观看| 成年免费在线观看| 日韩电影免费在线观看中文字幕| 爱福利在线视频| 国产欧美欧洲| 亚洲免费播放| av鲁丝一区鲁丝二区鲁丝三区| 亚洲在线中文字幕| 囯产精品久久久久久| 久久久久这里只有精品| 国产厕拍一区| 日韩a∨精品日韩在线观看| 成人午夜视频在线观看| 天天操天天射天天爽| 日韩av中文字幕在线播放| av女在线播放| 欧美下载看逼逼| 日本女优在线视频一区二区| 黄色片在线观看免费| 欧美日韩在线播放| 里番在线观看网站| 亚洲最大福利网站| 国产综合自拍| 免费成人深夜夜行p站| 欧美性猛交xxxx乱大交极品| 国产在线91| 成人xvideos免费视频| 欧美激情第8页| 最近中文字幕无免费| 亚洲成人激情综合网| 水莓100国产免费av在线播放| 热久久这里只有精品| 99久久婷婷这里只有精品| 三级网站免费看| 天天色综合成人网| 风间由美一区| 91影院未满十八岁禁止入内| 激情六月综合| 99久久久无码国产精品衣服| 91精品一区二区三区久久久久久| 青草影视电视剧免费播放在线观看| 国产一区二区精品免费| 久久一本综合频道| 国产一二三区精品| 日韩精品视频在线观看网址| 精品176极品一区| 韩日视频在线观看| 国产偷国产偷精品高清尤物| 国产精品自产拍| 91精品国产高清久久久久久91 | 91美女在线观看| 一区二区三区午夜| 午夜精品久久久久久久99热| 欧美午夜精彩| 在线观看亚洲免费视频| 欧洲日韩一区二区三区| 呦呦在线视频| 日韩激情久久| 成人高清av在线| 国产又粗又大又黄| 欧美中在线观看| 一本精品一区二区三区| 国产一区二区三区四区五区六区 | 欧美成熟毛茸茸| 岛国一区二区三区高清视频| 日韩制服丝袜先锋影音| 久久97人妻无码一区二区三区|