久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > windows >内容正文

windows

大规模分布式跟踪系统的理论

發(fā)布時(shí)間:2024/2/28 windows 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 大规模分布式跟踪系统的理论 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

概述

當(dāng)代的互聯(lián)網(wǎng)的服務(wù),通常都是用復(fù)雜的、大規(guī)模分布式集群來(lái)實(shí)現(xiàn)的?;ヂ?lián)網(wǎng)應(yīng)用構(gòu)建在不同的軟件模塊集上,這些軟件模塊,有可能是由不同的團(tuán)隊(duì)開(kāi)發(fā)、可能使用不同的編程語(yǔ)言來(lái)實(shí)現(xiàn)、有可能布在了幾千臺(tái)服務(wù)器,橫跨多個(gè)不同的數(shù)據(jù)中心。因此,就需要一些可以幫助理解系統(tǒng)行為、用于分析性能問(wèn)題的工具。

Dapper--Google生產(chǎn)環(huán)境下的分布式跟蹤系統(tǒng),應(yīng)運(yùn)而生。那么我們就來(lái)介紹一個(gè)大規(guī)模集群的跟蹤系統(tǒng),它是如何滿足一個(gè)低損耗、應(yīng)用透明的、大范圍部署這三個(gè)需求的。當(dāng)然Dapper設(shè)計(jì)之初,參考了一些其他分布式系統(tǒng)的理念,尤其是Magpie和X-Trace,但是我們之所以能成功應(yīng)用在生產(chǎn)環(huán)境上,還需要一些畫(huà)龍點(diǎn)睛之筆,例如采樣率的使用以及把代碼植入限制在一小部分公共庫(kù)的改造上。

自從Dapper發(fā)展成為一流的監(jiān)控系統(tǒng)之后,給其他應(yīng)用的開(kāi)發(fā)者和運(yùn)維團(tuán)隊(duì)幫了大忙,所以我們今天才發(fā)表這篇論文,來(lái)匯報(bào)一下這兩年來(lái),Dapper是怎么構(gòu)建和部署的。Dapper最初只是作為一個(gè)自給自足的監(jiān)控工具起步的,但最終進(jìn)化成一個(gè)監(jiān)控平臺(tái),這個(gè)監(jiān)控平臺(tái)促生出多種多樣的監(jiān)控工具,有些甚至已經(jīng)不是由Dapper團(tuán)隊(duì)開(kāi)發(fā)的了。下面我們會(huì)介紹一些使用Dapper搭建的分析工具,分享一下這些工具在google內(nèi)部使用的統(tǒng)計(jì)數(shù)據(jù),展現(xiàn)一些使用場(chǎng)景,最后會(huì)討論一下我們迄今為止從Dapper收獲了些什么。

1. 介紹

我們開(kāi)發(fā)Dapper是為了收集更多的復(fù)雜分布式系統(tǒng)的行為信息,然后呈現(xiàn)給Google的開(kāi)發(fā)者們。這樣的分布式系統(tǒng)有一個(gè)特殊的好處,因?yàn)槟切┐笠?guī)模的低端服務(wù)器,作為互聯(lián)網(wǎng)服務(wù)的載體,是一個(gè)特殊的經(jīng)濟(jì)劃算的平臺(tái)。想要在這個(gè)上下文中理解分布式系統(tǒng)的行為,就需要監(jiān)控那些橫跨了不同的應(yīng)用、不同的服務(wù)器之間的關(guān)聯(lián)動(dòng)作。

下面舉一個(gè)跟搜索相關(guān)的例子,這個(gè)例子闡述了Dapper可以應(yīng)對(duì)哪些挑戰(zhàn)。比如一個(gè)前段服務(wù)可能對(duì)上百臺(tái)查詢(xún)服務(wù)器發(fā)起了一個(gè)Web查詢(xún),每一個(gè)查詢(xún)都有自己的Index。這個(gè)查詢(xún)可能會(huì)被發(fā)送到多個(gè)的子系統(tǒng),這些子系統(tǒng)分別用來(lái)處理廣告、進(jìn)行拼寫(xiě)檢查或是查找一些像圖片、視頻或新聞這樣的特殊結(jié)果。根據(jù)每個(gè)子系統(tǒng)的查詢(xún)結(jié)果進(jìn)行篩選,得到最終結(jié)果,最后匯總到頁(yè)面上。我們把這種搜索模型稱(chēng)為“全局搜索”(universal search)。總的來(lái)說(shuō),這一次全局搜索有可能調(diào)用上千臺(tái)服務(wù)器,涉及各種服務(wù)。而且,用戶對(duì)搜索的耗時(shí)是很敏感的,而任何一個(gè)子系統(tǒng)的低效都導(dǎo)致導(dǎo)致最終的搜索耗時(shí)。如果一個(gè)工程師只能知道這個(gè)查詢(xún)耗時(shí)不正常,但是他無(wú)從知曉這個(gè)問(wèn)題到底是由哪個(gè)服務(wù)調(diào)用造成的,或者為什么這個(gè)調(diào)用性能差強(qiáng)人意。首先,這個(gè)工程師可能無(wú)法準(zhǔn)確的定位到這次全局搜索是調(diào)用了哪些服務(wù),因?yàn)樾碌姆?wù)、乃至服務(wù)上的某個(gè)片段,都有可能在任何時(shí)間上過(guò)線或修改過(guò),有可能是面向用戶功能,也有可能是一些例如針對(duì)性能或安全認(rèn)證方面的功能改進(jìn)。其次,你不能苛求這個(gè)工程師對(duì)所有參與這次全局搜索的服務(wù)都了如指掌,每一個(gè)服務(wù)都有可能是由不同的團(tuán)隊(duì)開(kāi)發(fā)或維護(hù)的。再次,這些暴露出來(lái)的服務(wù)或服務(wù)器有可能同時(shí)還被其他客戶端使用著,所以這次全局搜索的性能問(wèn)題甚至有可能是由其他應(yīng)用造成的。舉個(gè)例子,一個(gè)后臺(tái)服務(wù)可能要應(yīng)付各種各樣的請(qǐng)求類(lèi)型,而一個(gè)使用效率很高的存儲(chǔ)系統(tǒng),比如Bigtable,有可能正被反復(fù)讀寫(xiě)著,因?yàn)樯厦媾苤鞣N各樣的應(yīng)用。

上面這個(gè)案例中我們可以看到,對(duì)Dapper我們只有兩點(diǎn)要求:無(wú)所不在的部署,持續(xù)的監(jiān)控。無(wú)所不在的重要性不言而喻,因?yàn)樵谑褂酶櫹到y(tǒng)的進(jìn)行監(jiān)控時(shí),即便只有一小部分沒(méi)被監(jiān)控到,那么人們對(duì)這個(gè)系統(tǒng)是不是值得信任都會(huì)產(chǎn)生巨大的質(zhì)疑。另外,監(jiān)控應(yīng)該是7x24小時(shí)的,畢竟,系統(tǒng)異?;蚴悄切┲匾南到y(tǒng)行為有可能出現(xiàn)過(guò)一次,就很難甚至不太可能重現(xiàn)。那么,根據(jù)這兩個(gè)明確的需求,我們可以直接推出三個(gè)具體的設(shè)計(jì)目標(biāo):

1.低消耗:跟蹤系統(tǒng)對(duì)在線服務(wù)的影響應(yīng)該做到足夠小。在一些高度優(yōu)化過(guò)的服務(wù),即使一點(diǎn)點(diǎn)損耗也會(huì)很容易察覺(jué)到,而且有可能迫使在線服務(wù)的部署團(tuán)隊(duì)不得不將跟蹤系統(tǒng)關(guān)停。

2.應(yīng)用級(jí)的透明:對(duì)于應(yīng)用的程序員來(lái)說(shuō),是不需要知道有跟蹤系統(tǒng)這回事的。如果一個(gè)跟蹤系統(tǒng)想生效,就必須需要依賴(lài)應(yīng)用的開(kāi)發(fā)者主動(dòng)配合,那么這個(gè)跟蹤系統(tǒng)也太脆弱了,往往由于跟蹤系統(tǒng)在應(yīng)用中植入代碼的bug或疏忽導(dǎo)致應(yīng)用出問(wèn)題,這樣才是無(wú)法滿足對(duì)跟蹤系統(tǒng)“無(wú)所不在的部署”這個(gè)需求。面對(duì)當(dāng)下想Google這樣的快節(jié)奏的開(kāi)發(fā)環(huán)境來(lái)說(shuō),尤其重要。

3.延展性:Google至少在未來(lái)幾年的服務(wù)和集群的規(guī)模,監(jiān)控系統(tǒng)都應(yīng)該能完全把控住。

一個(gè)額外的設(shè)計(jì)目標(biāo)是為跟蹤數(shù)據(jù)產(chǎn)生之后,進(jìn)行分析的速度要快,理想情況是數(shù)據(jù)存入跟蹤倉(cāng)庫(kù)后一分鐘內(nèi)就能統(tǒng)計(jì)出來(lái)。盡管跟蹤系統(tǒng)對(duì)一小時(shí)前的舊數(shù)據(jù)進(jìn)行統(tǒng)計(jì)也是相當(dāng)有價(jià)值的,但如果跟蹤系統(tǒng)能提供足夠快的信息反饋,就可以對(duì)生產(chǎn)環(huán)境下的異常狀況做出快速反應(yīng)。

做到真正的應(yīng)用級(jí)別的透明,這應(yīng)該是當(dāng)下面臨的最挑戰(zhàn)性的設(shè)計(jì)目標(biāo),我們把核心跟蹤代碼做的很輕巧,然后把它植入到那些無(wú)所不在的公共組件種,比如線程調(diào)用、控制流以及RPC庫(kù)。使用自適應(yīng)的采樣率可以使跟蹤系統(tǒng)變得可伸縮,并降低性能損耗,這些內(nèi)容將在第4.4節(jié)中提及。結(jié)果展示的相關(guān)系統(tǒng)也需要包含一些用來(lái)收集跟蹤數(shù)據(jù)的代碼,用來(lái)圖形化的工具,以及用來(lái)分析大規(guī)模跟蹤數(shù)據(jù)的庫(kù)和API。雖然單獨(dú)使用Dapper有時(shí)就足夠讓開(kāi)發(fā)人員查明異常的來(lái)源,但是Dapper的初衷不是要取代所有其他監(jiān)控的工具。我們發(fā)現(xiàn),Dapper的數(shù)據(jù)往往側(cè)重性能方面的調(diào)查,所以其他監(jiān)控工具也有他們各自的用處。

1.1 文獻(xiàn)的總結(jié)

分布式系統(tǒng)跟蹤工具的設(shè)計(jì)空間已經(jīng)被一些優(yōu)秀文章探索過(guò)了,其中的Pinpoint[9]、Magpie[3]和X-Trace[12]和Dapper最為相近。這些系統(tǒng)在其發(fā)展過(guò)程的早期傾向于寫(xiě)入研究報(bào)告中,即便他們還沒(méi)來(lái)得及清楚地評(píng)估系統(tǒng)當(dāng)中一些設(shè)計(jì)的重要性。相比之下,由于Dapper已經(jīng)在大規(guī)模生產(chǎn)環(huán)境中摸爬滾打了多年,經(jīng)過(guò)這么多生產(chǎn)環(huán)境的驗(yàn)證之后,我們認(rèn)為這篇論文最適合重點(diǎn)闡述在部署Dapper的過(guò)程中我們有那些收獲,我們的設(shè)計(jì)思想是如何決定的,以及以什么樣的方式實(shí)現(xiàn)它才會(huì)最有用。Dappe作為一個(gè)平臺(tái),承載基于Dapper開(kāi)發(fā)的性能分析工具,以及Dapper自身的監(jiān)測(cè)工具,它的價(jià)值在于我們可以在回顧評(píng)估中找出一些意想不到的結(jié)果。

雖然Dapper在許多高階的設(shè)計(jì)思想上吸取了Pinpoint和Magpie的研究成果,但在分布式跟蹤這個(gè)領(lǐng)域中,Dapper的實(shí)現(xiàn)包含了許多新的貢獻(xiàn)。例如,我們想實(shí)現(xiàn)低損耗的話,特別是在高度優(yōu)化的而且趨于極端延遲敏感的Web服務(wù)中,采樣率是很必要的。或許更令人驚訝的是,我們發(fā)現(xiàn)即便是1/1000的采樣率,對(duì)于跟蹤數(shù)據(jù)的通用使用層面上,也可以提供足夠多的信息。

我們的系統(tǒng)的另一個(gè)重要的特征,就是我們能實(shí)現(xiàn)的應(yīng)用級(jí)的透明。我們的組件對(duì)應(yīng)用的侵入被先限制在足夠低的水平上,即使想Google網(wǎng)頁(yè)搜索這么大規(guī)模的分布式系統(tǒng),也可以直接進(jìn)行跟蹤而無(wú)需加入額外的標(biāo)注(Annotation)。雖然由于我們的部署系統(tǒng)有幸是一定程度的同質(zhì)化的,所以更容易做到對(duì)應(yīng)用層的透明這點(diǎn),但是我們證明了這是實(shí)現(xiàn)這種程度的透明性的充分條件。

2. Dapper的分布式跟蹤

圖1:這個(gè)路徑由用戶的X請(qǐng)求發(fā)起,穿過(guò)一個(gè)簡(jiǎn)單的服務(wù)系統(tǒng)。用字母標(biāo)識(shí)的節(jié)點(diǎn)代表分布式系統(tǒng)中的不同處理過(guò)程。

分布式服務(wù)的跟蹤系統(tǒng)需要記錄在一次特定的請(qǐng)求后系統(tǒng)中完成的所有工作的信息。舉個(gè)例子,圖1展現(xiàn)的是一個(gè)和5臺(tái)服務(wù)器相關(guān)的一個(gè)服務(wù),包括:前端(A),兩個(gè)中間層(B和C),以及兩個(gè)后端(D和E)。當(dāng)一個(gè)用戶(這個(gè)用例的發(fā)起人)發(fā)起一個(gè)請(qǐng)求時(shí),首先到達(dá)前端,然后發(fā)送兩個(gè)RPC到服務(wù)器B和C。B會(huì)馬上做出反應(yīng),但是C需要和后端的D和E交互之后再返還給A,由A來(lái)響應(yīng)最初的請(qǐng)求。對(duì)于這樣一個(gè)請(qǐng)求,簡(jiǎn)單實(shí)用的分布式跟蹤的實(shí)現(xiàn),就是為服務(wù)器上每一次你發(fā)送和接收動(dòng)作來(lái)收集跟蹤標(biāo)識(shí)符(message identifiers)和時(shí)間戳(timestamped events)。

為了將所有記錄條目與一個(gè)給定的發(fā)起者(例如,圖1中的RequestX)關(guān)聯(lián)上并記錄所有信息,現(xiàn)在有兩種解決方案,黑盒(black-box)和基于標(biāo)注(annotation-based)的監(jiān)控方案。黑盒方案[1,15,2]假定需要跟蹤的除了上述信息之外沒(méi)有額外的信息,這樣使用統(tǒng)計(jì)回歸技術(shù)來(lái)推斷兩者之間的關(guān)系?;跇?biāo)注的方案[3,12,9,16]依賴(lài)于應(yīng)用程序或中間件明確地標(biāo)記一個(gè)全局ID,從而連接每一條記錄和發(fā)起者的請(qǐng)求。雖然黑盒方案比標(biāo)注方案更輕便,他們需要更多的數(shù)據(jù),以獲得足夠的精度,因?yàn)樗麄円蕾?lài)于統(tǒng)計(jì)推論?;跇?biāo)注的方案最主要的缺點(diǎn)是,很明顯,需要代碼植入。在我們的生產(chǎn)環(huán)境中,因?yàn)樗械膽?yīng)用程序都使用相同的線程模型,控制流和RPC系統(tǒng),我們發(fā)現(xiàn),可以把代碼植入限制在一個(gè)很小的通用組件庫(kù)中,從而實(shí)現(xiàn)了監(jiān)測(cè)系統(tǒng)的應(yīng)用對(duì)開(kāi)發(fā)人員是有效地透明。

我們傾向于認(rèn)為,Dapper的跟蹤架構(gòu)像是內(nèi)嵌在RPC調(diào)用的樹(shù)形結(jié)構(gòu)。然而,我們的核心數(shù)據(jù)模型不只局限于我們的特定的RPC框架,我們還能跟蹤其他行為,例如Gmail的SMTP會(huì)話,外界的HTTP請(qǐng)求,和外部對(duì)SQL服務(wù)器的查詢(xún)等。從形式上看,我們的Dapper跟蹤模型使用的樹(shù)形結(jié)構(gòu),Span以及Annotation。

2.1 跟蹤樹(shù)和span

在Dapper跟蹤樹(shù)結(jié)構(gòu)中,樹(shù)節(jié)點(diǎn)是整個(gè)架構(gòu)的基本單元,而每一個(gè)節(jié)點(diǎn)又是對(duì)span的引用。節(jié)點(diǎn)之間的連線表示的span和它的父span直接的關(guān)系。雖然span在日志文件中只是簡(jiǎn)單的代表span的開(kāi)始和結(jié)束時(shí)間,他們?cè)谡麄€(gè)樹(shù)形結(jié)構(gòu)中卻是相對(duì)獨(dú)立的,任何RPC相關(guān)的時(shí)間數(shù)據(jù)、零個(gè)或多個(gè)特定應(yīng)用程序的Annotation的相關(guān)內(nèi)容會(huì)在2.3節(jié)中討論。

圖2:5個(gè)span在Dapper跟蹤樹(shù)種短暫的關(guān)聯(lián)關(guān)系

在圖2中說(shuō)明了span在一個(gè)大的跟蹤過(guò)程中是什么樣的。Dapper記錄了span名稱(chēng),以及每個(gè)span的ID和父ID,以重建在一次追蹤過(guò)程中不同span之間的關(guān)系。如果一個(gè)span沒(méi)有父ID被稱(chēng)為root span。所有span都掛在一個(gè)特定的跟蹤上,也共用一個(gè)跟蹤id(在圖中未示出)。所有這些ID用全局唯一的64位整數(shù)標(biāo)示。在一個(gè)典型的Dapper跟蹤中,我們希望為每一個(gè)RPC對(duì)應(yīng)到一個(gè)單一的span上,而且每一個(gè)額外的組件層都對(duì)應(yīng)一個(gè)跟蹤樹(shù)型結(jié)構(gòu)的層級(jí)。

圖3:在圖2中所示的一個(gè)單獨(dú)的span的細(xì)節(jié)圖

圖3給出了一個(gè)更詳細(xì)的典型的Dapper跟蹤span的記錄點(diǎn)的視圖。在圖2中這種某個(gè)span表述了兩個(gè)“Helper.Call”的RPC(分別為server端和client端)。span的開(kāi)始時(shí)間和結(jié)束時(shí)間,以及任何RPC的時(shí)間信息都通過(guò)Dapper在RPC組件庫(kù)的植入記錄下來(lái)。如果應(yīng)用程序開(kāi)發(fā)者選擇在跟蹤中增加他們自己的注釋(如圖中“foo”的注釋)(業(yè)務(wù)數(shù)據(jù)),這些信息也會(huì)和其他span信息一樣記錄下來(lái)。

記住,任何一個(gè)span可以包含來(lái)自不同的主機(jī)信息,這些也要記錄下來(lái)。事實(shí)上,每一個(gè)RPC span可以包含客戶端和服務(wù)器兩個(gè)過(guò)程的注釋,使得鏈接兩個(gè)主機(jī)的span會(huì)成為模型中所說(shuō)的span。由于客戶端和服務(wù)器上的時(shí)間戳來(lái)自不同的主機(jī),我們必須考慮到時(shí)間偏差。在我們的分析工具,我們利用了這個(gè)事實(shí):RPC客戶端發(fā)送一個(gè)請(qǐng)求之后,服務(wù)器端才能接收到,對(duì)于響應(yīng)也是一樣的(服務(wù)器先響應(yīng),然后客戶端才能接收到這個(gè)響應(yīng))。這樣一來(lái),服務(wù)器端的RPC就有一個(gè)時(shí)間戳的一個(gè)上限和下限。

2.2 植入點(diǎn)

Dapper可以以對(duì)應(yīng)用開(kāi)發(fā)者近乎零浸入的成本對(duì)分布式控制路徑進(jìn)行跟蹤,幾乎完全依賴(lài)于基于少量通用組件庫(kù)的改造。如下:

  • 當(dāng)一個(gè)線程在處理跟蹤控制路徑的過(guò)程中,Dapper把這次跟蹤的上下文的在ThreadLocal中進(jìn)行存儲(chǔ)。追蹤上下文是一個(gè)小而且容易復(fù)制的容器,其中承載了Scan的屬性比如跟蹤ID和span ID。
  • 當(dāng)計(jì)算過(guò)程是延遲調(diào)用的或是異步的,大多數(shù)Google開(kāi)發(fā)者通過(guò)線程池或其他執(zhí)行器,使用一個(gè)通用的控制流庫(kù)來(lái)回調(diào)。Dapper確保所有這樣的回調(diào)可以存儲(chǔ)這次跟蹤的上下文,而當(dāng)回調(diào)函數(shù)被觸發(fā)時(shí),這次跟蹤的上下文會(huì)與適當(dāng)?shù)木€程關(guān)聯(lián)上。在這種方式下,Dapper可以使用trace ID和span ID來(lái)輔助構(gòu)建異步調(diào)用的路徑。
  • 幾乎所有的Google的進(jìn)程間通信是建立在一個(gè)用C++和Java開(kāi)發(fā)的RPC框架上。我們把跟蹤植入該框架來(lái)定義RPC中所有的span。span的ID和跟蹤的ID會(huì)從客戶端發(fā)送到服務(wù)端。像那樣的基于RPC的系統(tǒng)被廣泛使用在Google中,這是一個(gè)重要的植入點(diǎn)。當(dāng)那些非RPC通信框架發(fā)展成熟并找到了自己的用戶群之后,我們會(huì)計(jì)劃對(duì)RPC通信框架進(jìn)行植入。

Dapper的跟蹤數(shù)據(jù)是獨(dú)立于語(yǔ)言的,很多在生產(chǎn)環(huán)境中的跟蹤結(jié)合了用C++和Java寫(xiě)的進(jìn)程的數(shù)據(jù)。在3.2節(jié)中,我們討論應(yīng)用程序的透明度時(shí)我們會(huì)把這些理論的是如何實(shí)踐的進(jìn)行討論。

2.3 Annotation

上述植入點(diǎn)足夠推導(dǎo)出復(fù)雜的分布式系統(tǒng)的跟蹤細(xì)節(jié),使得Dapper的核心功能在不改動(dòng)Google應(yīng)用的情況下可用。然而,Dapper還允許應(yīng)用程序開(kāi)發(fā)人員在Dapper跟蹤的過(guò)程中添加額外的信息,以監(jiān)控更高級(jí)別的系統(tǒng)行為,或幫助調(diào)試問(wèn)題。我們?cè)试S用戶通過(guò)一個(gè)簡(jiǎn)單的API定義帶時(shí)間戳的Annotation,核心的示例代碼入圖4所示。這些Annotation可以添加任意內(nèi)容。為了保護(hù)Dapper的用戶意外的過(guò)分熱衷于日志的記錄,每一個(gè)跟蹤span有一個(gè)可配置的總Annotation量的上限。但是,應(yīng)用程序級(jí)的Annotation是不能替代用于表示span結(jié)構(gòu)的信息和記錄著RPC相關(guān)的信息。

除了簡(jiǎn)單的文本Annotation,Dapper也支持的key-value映射的 Annotation,提供給開(kāi)發(fā)人員更強(qiáng)的跟蹤能力,如持續(xù)的計(jì)數(shù)器,二進(jìn)制消息記錄和在一個(gè)進(jìn)程上跑著的任意的用戶數(shù)據(jù)。鍵值對(duì)的Annotation方式用來(lái)在分布式追蹤的上下文中定義某個(gè)特定應(yīng)用程序的相關(guān)類(lèi)型。

2.4 采樣率

低損耗的是Dapper的一個(gè)關(guān)鍵的設(shè)計(jì)目標(biāo),因?yàn)槿绻@個(gè)工具價(jià)值未被證實(shí)但又對(duì)性能有影響的話,你可以理解服務(wù)運(yùn)營(yíng)人員為什么不愿意部署它。況且,我們想讓開(kāi)發(fā)人員使用Annotation的API,而不用擔(dān)心額外的開(kāi)銷(xiāo)。我們還發(fā)現(xiàn),某些類(lèi)型的Web服務(wù)對(duì)植入帶來(lái)的性能損耗確實(shí)非常敏感。因此,除了把Dapper的收集工作對(duì)基本組件的性能損耗限制的盡可能小之外,我們還有進(jìn)一步控制損耗的辦法,那就是遇到大量請(qǐng)求時(shí)只記錄其中的一小部分。我們將在4.4節(jié)中討論跟蹤的采樣率方案的更多細(xì)節(jié)。

圖5:Dapper收集管道的總覽

2.5 跟蹤的收集

Dapper的跟蹤記錄和收集管道的過(guò)程分為三個(gè)階段(參見(jiàn)圖5)。首先,span數(shù)據(jù)寫(xiě)入(1)本地日志文件中。然后Dapper的守護(hù)進(jìn)程和收集組件把這些數(shù)據(jù)從生產(chǎn)環(huán)境的主機(jī)中拉出來(lái)(2),最終寫(xiě)到(3)Dapper的Bigtable倉(cāng)庫(kù)中。一次跟蹤被設(shè)計(jì)成Bigtable中的一行,每一列相當(dāng)于一個(gè)span。Bigtable的支持稀疏表格布局正適合這種情況,因?yàn)槊恳淮胃櫩梢杂腥我舛鄠€(gè)span。跟蹤數(shù)據(jù)收集(即從應(yīng)用中的二進(jìn)制數(shù)據(jù)傳輸?shù)街醒雮}(cāng)庫(kù)所花費(fèi)的時(shí)間)的延遲中位數(shù)少于15秒。第98百分位的延遲(The 98th percentile latency)往往隨著時(shí)間的推移呈現(xiàn)雙峰型;大約75%的時(shí)間,第98百分位的延遲時(shí)間小于2分鐘,但是另外大約25%的時(shí)間,它可以增漲到幾個(gè)小時(shí)。

Dapper還提供了一個(gè)API來(lái)簡(jiǎn)化訪問(wèn)我們倉(cāng)庫(kù)中的跟蹤數(shù)據(jù)。 Google的開(kāi)發(fā)人員用這個(gè)API,以構(gòu)建通用和特定應(yīng)用程序的分析工具。第5.1節(jié)包含更多如何使用它的信息。

2.5.1 帶外數(shù)據(jù)跟蹤收集

tip1:帶外數(shù)據(jù):傳輸層協(xié)議使用帶外數(shù)據(jù)(out-of-band,OOB)來(lái)發(fā)送一些重要的數(shù)據(jù),如果通信一方有重要的數(shù)據(jù)需要通知對(duì)方時(shí),協(xié)議能夠?qū)⑦@些數(shù)據(jù)快速地發(fā)送到對(duì)方。為了發(fā)送這些數(shù)據(jù),協(xié)議一般不使用與普通數(shù)據(jù)相同的通道,而是使用另外的通道。

tip2:這里指的in-band策略是把跟蹤數(shù)據(jù)隨著調(diào)用鏈進(jìn)行傳送,out-of-band是通過(guò)其他的鏈路進(jìn)行跟蹤數(shù)據(jù)的收集,Dapper的寫(xiě)日志然后進(jìn)行日志采集的方式就屬于out-of-band策略

Dapper系統(tǒng)請(qǐng)求樹(shù)樹(shù)自身進(jìn)行跟蹤記錄和收集帶外數(shù)據(jù)。這樣做是為兩個(gè)不相關(guān)的原因。首先,帶內(nèi)收集方案--這里跟蹤數(shù)據(jù)會(huì)以RPC響應(yīng)頭的形式被返回--會(huì)影響應(yīng)用程序網(wǎng)絡(luò)動(dòng)態(tài)。在Google里的許多規(guī)模較大的系統(tǒng)中,一次跟蹤成千上萬(wàn)的span并不少見(jiàn)。然而,RPC回應(yīng)大小--甚至是接近大型分布式的跟蹤的根節(jié)點(diǎn)的這種情況下-- 仍然是比較小的:通常小于10K。在這種情況下,帶內(nèi)Dapper的跟蹤數(shù)據(jù)會(huì)讓?xiě)?yīng)用程序數(shù)據(jù)和傾向于使用后續(xù)分析結(jié)果的數(shù)據(jù)量相形見(jiàn)絀。其次,帶內(nèi)收集方案假定所有的RPC是完美嵌套的。我們發(fā)現(xiàn),在所有的后端的系統(tǒng)返回的最終結(jié)果之前,有許多中間件會(huì)把結(jié)果返回給他們的調(diào)用者。帶內(nèi)收集系統(tǒng)是無(wú)法解釋這種非嵌套的分布式執(zhí)行模式的。

2.6 安全和隱私考慮

記錄一定量的RPC有效負(fù)載信息將豐富Dapper的跟蹤能力,因?yàn)榉治龉ぞ吣軌蛟谟行лd荷數(shù)據(jù)(方法傳遞的參數(shù))中找到相關(guān)的樣例,這些樣例可以解釋被監(jiān)控系統(tǒng)的為何表現(xiàn)異常。然而,有些情況下,有效載荷數(shù)據(jù)可能包含的一些不應(yīng)該透露給未經(jīng)授權(quán)用戶(包括正在debug的工程師)的內(nèi)部信息。

由于安全和隱私問(wèn)題是不可忽略的,dapper中的雖然存儲(chǔ)RPC方法的名稱(chēng),但在這個(gè)時(shí)候不記錄任何有效載荷數(shù)據(jù)。相反,應(yīng)用程序級(jí)別的Annotation提供了一個(gè)方便的可選機(jī)制:應(yīng)用程序開(kāi)發(fā)人員可以在span中選擇關(guān)聯(lián)那些為以后分析提供價(jià)值的數(shù)據(jù)。

Dapper還提供了一些安全上的便利,是它的設(shè)計(jì)者事先沒(méi)有預(yù)料到的。通過(guò)跟蹤公開(kāi)的安全協(xié)議參數(shù),Dapper可以通過(guò)相應(yīng)級(jí)別的認(rèn)證或加密,來(lái)監(jiān)視應(yīng)用程序是否滿足安全策略。例如。Dapper還可以提供信息,以基于策略的的隔離系統(tǒng)按預(yù)期執(zhí)行,例如支撐敏感數(shù)據(jù)的應(yīng)用程序不與未經(jīng)授權(quán)的系統(tǒng)組件進(jìn)行了交互。這樣的測(cè)算提供了比源碼審核更強(qiáng)大的保障。

3. Dapper部署狀況

Dapper作為我們生產(chǎn)環(huán)境下的跟蹤系統(tǒng)已經(jīng)超過(guò)兩年。在本節(jié)中,我們會(huì)匯報(bào)系統(tǒng)狀態(tài),把重點(diǎn)放在Dapper如何滿足了我們的目標(biāo)——無(wú)處不在的部署和應(yīng)用級(jí)的透明。

3.1 Dapper運(yùn)行庫(kù)

也許Dapper代碼中中最關(guān)鍵的部分,就是對(duì)基礎(chǔ)RPC、線程控制和流程控制的組件庫(kù)的植入,其中包括span的創(chuàng)建,采樣率的設(shè)置,以及把日志寫(xiě)入本地磁盤(pán)。除了做到輕量級(jí),植入的代碼更需要穩(wěn)定和健壯,因?yàn)樗c海量的應(yīng)用對(duì)接,維護(hù)和bug修復(fù)變得困難。植入的核心代碼是由未超過(guò)1000行的C++和不超過(guò)800行Java代碼組成。為了支持鍵值對(duì)的Annotation還添加了額外的500行代碼。

3.2 生產(chǎn)環(huán)境下的涵蓋面

Dapper的滲透可以總結(jié)為兩個(gè)方面:一方面是可以創(chuàng)建Dapper跟蹤的過(guò)程(與Dapper植入的組件庫(kù)相關(guān)),和生產(chǎn)環(huán)境下的服務(wù)器上在運(yùn)行Dapper跟蹤收集守護(hù)進(jìn)程。Dapper的守護(hù)進(jìn)程的分布相當(dāng)于我們服務(wù)器的簡(jiǎn)單的拓?fù)鋱D,它存在于Google幾乎所有的服務(wù)器上。這很難確定精確的Dapper-ready進(jìn)程部分,因?yàn)檫^(guò)程即便不產(chǎn)生跟蹤信息Dapper也是無(wú)從知曉的。盡管如此,考慮到無(wú)處不在Dapper組件的植入庫(kù),我們估計(jì)幾乎每一個(gè)Google的生產(chǎn)進(jìn)程都是支持跟蹤的。

在某些情況下Dapper的是不能正確的跟蹤控制路徑的。這些通常源于使用非標(biāo)準(zhǔn)的控制流,或是Dapper的錯(cuò)誤的把路徑關(guān)聯(lián)歸到不相關(guān)的事件上。Dapper提供了一個(gè)簡(jiǎn)單的庫(kù)來(lái)幫助開(kāi)發(fā)者手動(dòng)控制跟蹤傳播作為一種變通方法。目前有40個(gè)C++應(yīng)用程序和33個(gè)Java應(yīng)用程序需要一些手動(dòng)控制的追蹤傳播,不過(guò)這只是上千個(gè)的跟蹤中的一小部分。也有非常小的一部分程序使用的非組件性質(zhì)的通信庫(kù)(比如原生的TCP Socket或SOAP RPC),因此不能直接支持Dapper的跟蹤。但是這些應(yīng)用可以單獨(dú)接入到Dapper中,如果需要的話。

考慮到生產(chǎn)環(huán)境的安全,Dapper的跟蹤也可以關(guān)閉。事實(shí)上,它在部署的早起就是默認(rèn)關(guān)閉的,直到我們對(duì)Dapper的穩(wěn)定性和低損耗有了足夠的信心之后才把它開(kāi)啟。Dapper的團(tuán)隊(duì)偶爾會(huì)執(zhí)行審查尋找跟蹤配置的變化,來(lái)看看那些服務(wù)關(guān)閉了Dapper的跟蹤。但這種情況不多見(jiàn),而且通常是源于對(duì)監(jiān)控對(duì)性能消耗的擔(dān)憂。經(jīng)過(guò)了對(duì)實(shí)際性能消耗的進(jìn)一步調(diào)查和測(cè)量,所有這些關(guān)閉Dapper跟蹤都已經(jīng)恢復(fù)開(kāi)啟了,不過(guò)這些已經(jīng)不重要了。

3.3 跟蹤Annotation的使用

程序員傾向于使用特定應(yīng)用程序的Annotation,無(wú)論是作為一種分布式調(diào)試日志文件,還是通過(guò)一些應(yīng)用程序特定的功能對(duì)跟蹤進(jìn)行分類(lèi)。例如,所有的Bigtable的請(qǐng)求會(huì)把被訪問(wèn)的表名也記錄到Annotation中。目前,70%的Dapper span和90%的所有Dapper跟蹤都至少有一個(gè)特殊應(yīng)用的Annotation。

41個(gè)Java應(yīng)用和68個(gè)C++應(yīng)用中都添加自定義的Annotation為了更好地理解應(yīng)用程序中的span在他們的服務(wù)中的行為。值得注意的是,迄今為止我們的Java開(kāi)發(fā)者比C++開(kāi)發(fā)者更多的在每一個(gè)跟蹤span上采用Annotation的API。這可能是因?yàn)槲覀兊腏ava應(yīng)用的作用域往往是更接近最終用戶(C++偏底層);這些類(lèi)型的應(yīng)用程序經(jīng)常處理更廣泛的請(qǐng)求組合,因此具有比較復(fù)雜的控制路徑。

4. 處理跟蹤損耗

跟蹤系統(tǒng)的成本由兩部分組成:1.正在被監(jiān)控的系統(tǒng)在生成追蹤和收集追蹤數(shù)據(jù)的消耗導(dǎo)致系統(tǒng)性能下降,2。需要使用一部分資源來(lái)存儲(chǔ)和分析跟蹤數(shù)據(jù)。雖然你可以說(shuō)一個(gè)有價(jià)值的組件植入跟蹤帶來(lái)一部分性能損耗是值得的,我們相信如果基本損耗能達(dá)到可以忽略的程度,那么對(duì)跟蹤系統(tǒng)最初的推廣會(huì)有極大的幫助。

在本節(jié)中,我們會(huì)展現(xiàn)一下三個(gè)方面:Dapper組件操作的消耗,跟蹤收集的消耗,以及Dapper對(duì)生產(chǎn)環(huán)境負(fù)載的影響。我們還介紹了Dapper可調(diào)節(jié)的采樣率機(jī)制如何幫我們處理低損耗和跟蹤代表性之間的平衡和取舍。

4.1 生成跟蹤的損耗

生成跟蹤的開(kāi)銷(xiāo)是Dapper性能影響中最關(guān)鍵的部分,因?yàn)槭占头治隹梢愿菀自诰o急情況下被關(guān)閉。Dapper運(yùn)行庫(kù)中最重要的跟蹤生成消耗在于創(chuàng)建和銷(xiāo)毀span和annotation,并記錄到本地磁盤(pán)供后續(xù)的收集。根span的創(chuàng)建和銷(xiāo)毀需要損耗平均204納秒的時(shí)間,而同樣的操作在其他span上需要消耗176納秒。時(shí)間上的差別主要在于需要在跟span上給這次跟蹤分配一個(gè)全局唯一的ID。

如果一個(gè)span沒(méi)有被采樣的話,那么這個(gè)額外的span下創(chuàng)建annotation的成本幾乎可以忽略不計(jì),他由在Dapper運(yùn)行期對(duì)ThreadLocal查找操作構(gòu)成,這平均只消耗9納秒。如果這個(gè)span被計(jì)入采樣的話,會(huì)用一個(gè)用字符串進(jìn)行標(biāo)注--在圖4中有展現(xiàn)--平均需要消耗40納秒。這些數(shù)據(jù)都是在2.2GHz的x86服務(wù)器上采集的。

在Dapper運(yùn)行期寫(xiě)入到本地磁盤(pán)是最昂貴的操作,但是他們的可見(jiàn)損耗大大減少,因?yàn)閷?xiě)入日志文件和操作相對(duì)于被跟蹤的應(yīng)用系統(tǒng)來(lái)說(shuō)都是異步的。不過(guò),日志寫(xiě)入的操作如果在大流量的情況,尤其是每一個(gè)請(qǐng)求都被跟蹤的情況下就會(huì)變得可以察覺(jué)到。我們記錄了在4.3節(jié)展示了一次Web搜索的負(fù)載下的性能消耗。

4.2 跟蹤收集的消耗

讀出跟蹤數(shù)據(jù)也會(huì)對(duì)正在被監(jiān)控的負(fù)載產(chǎn)生干擾。表1展示的是最壞情況下,Dapper收集日志的守護(hù)進(jìn)程在高于實(shí)際情況的負(fù)載基準(zhǔn)下進(jìn)行測(cè)試時(shí)的cpu使用率。在生產(chǎn)環(huán)境下,跟蹤數(shù)據(jù)處理中,這個(gè)守護(hù)進(jìn)程從來(lái)沒(méi)有超過(guò)0.3%的單核cpu使用率,而且只有很少量的內(nèi)存使用(以及堆碎片的噪音)。我們還限制了Dapper守護(hù)進(jìn)程為內(nèi)核scheduler最低的優(yōu)先級(jí),以防在一臺(tái)高負(fù)載的服務(wù)器上發(fā)生cpu競(jìng)爭(zhēng)。

Dapper也是一個(gè)帶寬資源的輕量級(jí)的消費(fèi)者,每一個(gè)span在我們的倉(cāng)庫(kù)中傳輸只占用了平均426的byte。作為網(wǎng)絡(luò)行為中的極小部分,Dapper的數(shù)據(jù)收集在Google的生產(chǎn)環(huán)境中的只占用了0.01%的網(wǎng)絡(luò)資源。

表1:Dapper守護(hù)進(jìn)程在負(fù)載測(cè)試時(shí)的CPU資源使用率

4.3 在生產(chǎn)環(huán)境下對(duì)負(fù)載的影響

每個(gè)請(qǐng)求都會(huì)利用到大量的服務(wù)器的高吞吐量的線上服務(wù),這是對(duì)有效跟蹤最主要的需求之一;這種情況需要生成大量的跟蹤數(shù)據(jù),并且他們對(duì)性能的影響是最敏感的。在表2中我們用集群下的網(wǎng)絡(luò)搜索服務(wù)作為例子,我們通過(guò)調(diào)整采樣率,來(lái)衡量Dapper在延遲和吞吐量方面對(duì)性能的影響。

表2:網(wǎng)絡(luò)搜索集群中,對(duì)不同采樣率對(duì)網(wǎng)絡(luò)延遲和吞吐的影響。延遲和吞吐的實(shí)驗(yàn)誤差分別是2.5%和0.15%。

我們看到,雖然對(duì)吞吐量的影響不是很明顯,但為了避免明顯的延遲,跟蹤的采樣還是必要的。然而,延遲和吞吐量的帶來(lái)的損失在把采樣率調(diào)整到小于1/16之后就全部在實(shí)驗(yàn)誤差范圍內(nèi)。在實(shí)踐中,我們發(fā)現(xiàn)即便采樣率調(diào)整到1/1024仍然是有足夠量的跟蹤數(shù)據(jù)的用來(lái)跟蹤大量的服務(wù)。保持Dapper的性能損耗基線在一個(gè)非常低的水平是很重要的,因?yàn)樗鼮槟切?yīng)用提供了一個(gè)寬松的環(huán)境使用完整的Annotation API而無(wú)懼性能損失。使用較低的采樣率還有額外的好處,可以讓持久化到硬盤(pán)中的跟蹤數(shù)據(jù)在垃圾回收機(jī)制處理之前保留更長(zhǎng)的時(shí)間,這樣為Dapper的收集組件給了更多的靈活性。

4.4 可變采樣

任何給定進(jìn)程的Dapper的消耗和每個(gè)進(jìn)程單位時(shí)間的跟蹤的采樣率成正比。Dapper的第一個(gè)生產(chǎn)版本在Google內(nèi)部的所有進(jìn)程上使用統(tǒng)一的采樣率,為1/1024。這個(gè)簡(jiǎn)單的方案是對(duì)我們的高吞吐量的線上服務(wù)來(lái)說(shuō)是非常有用,因?yàn)槟切└信d趣的事件(在大吞吐量的情況下)仍然很有可能經(jīng)常出現(xiàn),并且通常足以被捕捉到。

然而,在較低的采樣率和較低的傳輸負(fù)載下可能會(huì)導(dǎo)致錯(cuò)過(guò)重要事件,而想用較高的采樣率就需要能接受的性能損耗。對(duì)于這樣的系統(tǒng)的解決方案就是覆蓋默認(rèn)的采樣率,這需要手動(dòng)干預(yù)的,這種情況是我們?cè)噲D避免在dapper中出現(xiàn)的。

我們?cè)诓渴鹂勺儾蓸拥倪^(guò)程中,參數(shù)化配置采樣率時(shí),不是使用一個(gè)統(tǒng)一的采樣方案,而是使用一個(gè)采樣期望率來(lái)標(biāo)識(shí)單位時(shí)間內(nèi)采樣的追蹤。這樣一來(lái),低流量低負(fù)載自動(dòng)提高采樣率,而在高流量高負(fù)載的情況下會(huì)降低采樣率,使損耗一直保持在控制之下。實(shí)際使用的采樣率會(huì)隨著跟蹤本身記錄下來(lái),這有利于從Dapper的跟蹤數(shù)據(jù)中準(zhǔn)確的分析。

4.5 應(yīng)對(duì)積極采樣(Coping with aggressive sampling)

新的Dapper用戶往往覺(jué)得低采樣率--在高吞吐量的服務(wù)下經(jīng)常低至0.01%--將會(huì)不利于他們的分析。我們?cè)贕oogle的經(jīng)驗(yàn)使我們相信,對(duì)于高吞吐量服務(wù),積極采樣(aggressive sampling)并不妨礙最重要的分析。如果一個(gè)顯著的操作在系統(tǒng)中出現(xiàn)一次,他就會(huì)出現(xiàn)上千次。低吞吐量的服務(wù)--也許是每秒請(qǐng)求幾十次,而不是幾十萬(wàn)--可以負(fù)擔(dān)得起跟蹤每一個(gè)請(qǐng)求,這是促使我們下決心使用自適應(yīng)采樣率的原因。

4.6 在收集過(guò)程中額外的采樣

上述采樣機(jī)制被設(shè)計(jì)為盡量減少與Dapper運(yùn)行庫(kù)協(xié)作的應(yīng)用程序中明顯的性能損耗。Dapper的團(tuán)隊(duì)還需要控制寫(xiě)入中央資料庫(kù)的數(shù)據(jù)的總規(guī)模,因此為達(dá)到這個(gè)目的,我們結(jié)合了二級(jí)采樣。

目前我們的生產(chǎn)集群每天產(chǎn)生超過(guò)1TB的采樣跟蹤數(shù)據(jù)。Dapper的用戶希望生產(chǎn)環(huán)境下的進(jìn)程的跟蹤數(shù)據(jù)從被記錄之后能保存至少兩周的時(shí)間。逐漸增長(zhǎng)的追蹤數(shù)據(jù)的密度必須和Dapper中央倉(cāng)庫(kù)所消耗的服務(wù)器及硬盤(pán)存儲(chǔ)進(jìn)行權(quán)衡。對(duì)請(qǐng)求的高采樣率還使得Dapper收集器接近寫(xiě)入吞吐量的上限。

為了維持物質(zhì)資源的需求和漸增的Bigtable的吞吐之間的靈活性,我們?cè)谑占到y(tǒng)自身上增加了額外的采樣率的支持。我們充分利用所有span都來(lái)自一個(gè)特定的跟蹤并分享同一個(gè)跟蹤ID這個(gè)事實(shí),雖然這些span有可能橫跨了數(shù)千個(gè)主機(jī)。對(duì)于在收集系統(tǒng)中的每一個(gè)span,我們用hash算法把跟蹤ID轉(zhuǎn)成一個(gè)標(biāo)量Z,這里0<=Z<=1。如果Z比我們收集系統(tǒng)中的系數(shù)低的話,我們就保留這個(gè)span信息,并寫(xiě)入到Bigtable中。反之,我們就拋棄他。通過(guò)在采樣決策中的跟蹤ID,我們要么保存、要么拋棄整個(gè)跟蹤,而不是單獨(dú)處理跟蹤內(nèi)的span。我們發(fā)現(xiàn),有了這個(gè)額外的配置參數(shù)使管理我們的收集管道變得簡(jiǎn)單多了,因?yàn)槲覀兛梢院苋菀椎卦谂渲梦募姓{(diào)整我們的全局寫(xiě)入率這個(gè)參數(shù)。

如果整個(gè)跟蹤過(guò)程和收集系統(tǒng)只使用一個(gè)采樣率參數(shù)確實(shí)會(huì)簡(jiǎn)單一些,但是這就不能應(yīng)對(duì)快速調(diào)整在所有部署的節(jié)點(diǎn)上的運(yùn)行期采樣率配置的這個(gè)要求。我們選擇了運(yùn)行期采樣率,這樣就可以?xún)?yōu)雅的去掉我們無(wú)法寫(xiě)入到倉(cāng)庫(kù)中的多余數(shù)據(jù),我們還可以通過(guò)調(diào)節(jié)收集系統(tǒng)中的二級(jí)采樣率系數(shù)來(lái)調(diào)整這個(gè)運(yùn)行期采樣率。Dapper的管道維護(hù)變得更容易,因?yàn)槲覀兙涂梢酝ㄟ^(guò)修改我們的二級(jí)采樣率的配置,直接增加或減少我們的全局覆蓋率和寫(xiě)入速度。

5. 通用的Dapper工具

幾年前,當(dāng)Dapper還只是個(gè)原型的時(shí)候,它只能在Dapper開(kāi)發(fā)者耐心的支持下使用。從那時(shí)起,我們逐漸迭代的建立了收集組件,編程接口,和基于Web的交互式用戶界面,幫助Dapper的用戶獨(dú)立解決自己的問(wèn)題。在本節(jié)中,我們會(huì)總結(jié)一下哪些的方法有用,哪些用處不大,我們還提供關(guān)于這些通用的分析工具的基本的使用信息。

5.1 Dapper Depot API

Dapper的“Depot API”或稱(chēng)作DAPI,提供在Dapper的區(qū)域倉(cāng)庫(kù)中對(duì)分布式跟蹤數(shù)據(jù)一個(gè)直接訪問(wèn)。DAPI和Dapper跟蹤倉(cāng)庫(kù)被設(shè)計(jì)成串聯(lián)的,而且DAPI意味著對(duì)Dapper倉(cāng)庫(kù)中的元數(shù)據(jù)暴露一個(gè)干凈和直觀的的接口。我們使用了以下推薦的三種方式去暴露這樣的接口:

  • 通過(guò)跟蹤ID來(lái)訪問(wèn):DAPI可以通過(guò)他的全局唯一的跟蹤ID讀取任何一次跟蹤信息。
  • 批量訪問(wèn):DAPI可以利用的MapReduce提供對(duì)上億條Dapper跟蹤數(shù)據(jù)的并行讀取。用戶重寫(xiě)一個(gè)虛擬函數(shù),它接受一個(gè)Dapper的跟蹤信息作為其唯一的參數(shù),該框架將在用戶指定的時(shí)間窗口中調(diào)用每一次收集到的跟蹤信息。
  • 索引訪問(wèn):Dapper的倉(cāng)庫(kù)支持一個(gè)符合我們通用調(diào)用模板的唯一索引。該索引根據(jù)通用請(qǐng)求跟蹤特性(commonly-requested trace features)進(jìn)行繪制來(lái)識(shí)別Dapper的跟蹤信息。因?yàn)楦橧D是根據(jù)偽隨機(jī)的規(guī)則創(chuàng)建的,這是最好的辦法去訪問(wèn)跟某個(gè)服務(wù)或主機(jī)相關(guān)的跟蹤數(shù)據(jù)。

所有這三種訪問(wèn)模式把用戶指向不同的Dapper跟蹤記錄。正如第2.1節(jié)所述的,Dapper的由span組成的跟蹤數(shù)據(jù)是用樹(shù)形結(jié)構(gòu)建模的,因此,跟蹤數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu),也是一個(gè)簡(jiǎn)單的由span組成遍歷樹(shù)。Span就相當(dāng)于RPC調(diào)用,在這種情況下,RPC的時(shí)間信息是可用的。帶時(shí)間戳的特殊的應(yīng)用標(biāo)注也是可以通過(guò)這個(gè)span結(jié)構(gòu)來(lái)訪問(wèn)的。

選擇一個(gè)合適的自定義索引是DAPI設(shè)計(jì)中最具挑戰(zhàn)性的部分。壓縮存儲(chǔ)要求在跟蹤數(shù)據(jù)種建立一個(gè)索引的情況只比實(shí)際數(shù)據(jù)小26%,所以消耗是巨大的。最初,我們部署了兩個(gè)索引:第一個(gè)是主機(jī)索引,另一個(gè)是服務(wù)名的索引。然而,我們并沒(méi)有找到主機(jī)索引和存儲(chǔ)成本之間的利害關(guān)系。當(dāng)用戶對(duì)每一臺(tái)主機(jī)感興趣的時(shí)候,他們也會(huì)對(duì)特定的服務(wù)感興趣,所以我們最終選擇把兩者相結(jié)合,成為一個(gè)組合索引,它允許以服務(wù)名稱(chēng),主機(jī),和時(shí)間戳的順序進(jìn)行有效的查找。

5.1.1 DAPI在Google內(nèi)部的使用

DAPI在谷歌的使用有三類(lèi):使利用DAPI的持續(xù)的線上Web應(yīng)用,維護(hù)良好的可以在控制臺(tái)上調(diào)用的基于DAPI的工具,可以被寫(xiě)入,運(yùn)行、不過(guò)大部分已經(jīng)被忘記了的一次性分析工具。我們知道的有3個(gè)持久性的基于DAPI的應(yīng)用程序,8個(gè)額外的按需定制的基于DAPI分析工具,以及使用DAPI框架構(gòu)建的約15~20一次性的分析工具。在這之后的工具就這是很難說(shuō)明了,因?yàn)殚_(kāi)發(fā)者可以構(gòu)建、運(yùn)行和丟棄這些項(xiàng)目,而不需要Dapper團(tuán)隊(duì)的技術(shù)支持。

5.2 Dapper的用戶接口

絕大多數(shù)用戶使用發(fā)生在基于web的用戶交互接口。篇幅有限,我們不能列出每一個(gè)特點(diǎn),而只能把典型的用戶工作流在圖6中展示。

圖6

  • 用戶描述的他們關(guān)心的服務(wù)和時(shí)間,和其他任何他們可以用來(lái)區(qū)分跟蹤模板的信息(比如,span的名稱(chēng))。他們還可以指定與他們的搜索最相關(guān)的成本度量(cost metric)(比如,服務(wù)響應(yīng)時(shí)間)。
  • 一個(gè)關(guān)于性能概要的大表格,對(duì)應(yīng)確定的服務(wù)關(guān)聯(lián)的所有分布式處理圖表。用戶可以把這些執(zhí)行圖標(biāo)排序成他們想要的,并選擇一種直方圖去展現(xiàn)出更多的細(xì)節(jié)。
  • 一旦某個(gè)單一的分布式執(zhí)行部分被選中后,用戶能看到關(guān)于執(zhí)行部分的的圖形化描述。被選中的服務(wù)被高亮展示在該圖的中心。
  • 在生成與步驟1中選中的成本度量(cost metric)維度相關(guān)的統(tǒng)計(jì)信息之后,Dapper的用戶界面會(huì)提供了一個(gè)簡(jiǎn)單的直方圖。在這個(gè)例子中,我們可以看到一個(gè)大致的所選中部分的分布式響應(yīng)時(shí)間分布圖。用戶還會(huì)看到一個(gè)關(guān)于具體的跟蹤信息的列表,展現(xiàn)跟蹤信息在直方圖中被劃分為的不同區(qū)域。在這個(gè)例子中,用戶點(diǎn)擊列表種第二個(gè)跟蹤信息實(shí)例時(shí),會(huì)在下方看到這個(gè)跟蹤信息的詳細(xì)視圖(步驟5)。
  • 絕大多數(shù)Dapper的使用者最終的會(huì)檢查某個(gè)跟蹤的情況,希望能收集一些信息去了解系統(tǒng)行為的根源所在。我們沒(méi)有足夠的空間來(lái)做跟蹤視圖的審查,但我們使用由一個(gè)全局時(shí)間軸(在上方可以看到),并能夠展開(kāi)和折疊樹(shù)形結(jié)構(gòu)的交互方式,這也很有特點(diǎn)。分布式跟蹤樹(shù)的連續(xù)層用內(nèi)嵌的不同顏色的矩形表示。每一個(gè)RPC的span被從時(shí)間上分解為一個(gè)服務(wù)器進(jìn)程中的消耗(綠色部分)和在網(wǎng)絡(luò)上的消耗(藍(lán)色部分)。用戶Annotation沒(méi)有顯示在這個(gè)截圖中,但他們可以選擇性的以span的形式包含在全局時(shí)間軸上。
  • 為了讓用戶查詢(xún)實(shí)時(shí)數(shù)據(jù),Dapper的用戶界面能夠直接與Dapper每一臺(tái)生產(chǎn)環(huán)境下的服務(wù)器上的守護(hù)進(jìn)程進(jìn)行交互。在該模式下,不可能指望能看到上面所說(shuō)的系統(tǒng)級(jí)的圖表展示,但仍然可以很容易基于性能和網(wǎng)絡(luò)特性選取一個(gè)特定的跟蹤。在這種模式下,可在幾秒鐘內(nèi)查到實(shí)時(shí)的數(shù)據(jù)。

    根據(jù)我們的記錄,大約有200個(gè)不同的Google工程師在一天內(nèi)使用的Dapper的UI;在一周的過(guò)程中,大約有750-1000不同的用戶。這些用戶數(shù),在新功能的內(nèi)部通告上,是按月連續(xù)的。通常用戶會(huì)發(fā)送特定跟蹤的連接,這將不可避免地在查詢(xún)跟蹤情況時(shí)中產(chǎn)生很多一次性的,持續(xù)時(shí)間較短的交互。

    6. 經(jīng)驗(yàn)

    Dapper在Google被廣泛應(yīng)用,一部分直接通過(guò)Dapper的用戶界面,另一部分間接地通過(guò)對(duì)Dapper API的二次開(kāi)發(fā)或者建立在基于api的應(yīng)用上。在本節(jié)中,我們并不打算羅列出每一種已知的Dapper使用方式,而是試圖覆蓋Dapper使用方式的“基本向量”,并努力來(lái)說(shuō)明什么樣的應(yīng)用是最成功的。

    6.1 在開(kāi)發(fā)中使用Dapper

    Google AdWords系統(tǒng)是圍繞一個(gè)大型的關(guān)鍵詞定位準(zhǔn)則和相關(guān)文字廣告的數(shù)據(jù)庫(kù)搭建的。當(dāng)新的關(guān)鍵字或廣告被插入或修改時(shí),它們必須通過(guò)服務(wù)策略術(shù)語(yǔ)的檢查(如檢查不恰當(dāng)?shù)恼Z(yǔ)言,這個(gè)過(guò)程如果使用自動(dòng)復(fù)查系統(tǒng)來(lái)做的話會(huì)更加有效)。

    當(dāng)輪到從頭重新設(shè)計(jì)一個(gè)廣告審查服務(wù)時(shí),這個(gè)團(tuán)隊(duì)迭代的從第一個(gè)系統(tǒng)原型開(kāi)始使用Dapper,并且,最終用Dapper一直維護(hù)著他們的系統(tǒng)。Dapper幫助他們從以下幾個(gè)方面改進(jìn)了他們的服務(wù):

    • 性能:開(kāi)發(fā)人員針對(duì)請(qǐng)求延遲的目標(biāo)進(jìn)行跟蹤,并對(duì)容易優(yōu)化的地方進(jìn)行定位。Dapper也被用來(lái)確定在關(guān)鍵路徑上不必要的串行請(qǐng)求--通常來(lái)源于不是開(kāi)發(fā)者自己開(kāi)發(fā)的子系統(tǒng)--并促使團(tuán)隊(duì)持續(xù)修復(fù)他們。
    • 正確性:廣告審查服務(wù)圍繞大型數(shù)據(jù)庫(kù)系統(tǒng)搭建。系統(tǒng)同時(shí)具有只讀副本策略(數(shù)據(jù)訪問(wèn)廉價(jià))和讀寫(xiě)的主策略(訪問(wèn)代價(jià)高)。Dapper被用來(lái)在很多種情況中確定,哪些查詢(xún)是無(wú)需通過(guò)主策略訪問(wèn)而可以采用副本策略訪問(wèn)。Dapper現(xiàn)在可以負(fù)責(zé)監(jiān)控哪些主策略被直接訪問(wèn),并對(duì)重要的系統(tǒng)常量進(jìn)行保障。
    • 理解性:廣告審查查詢(xún)跨越了各種類(lèi)型的系統(tǒng),包括BigTable—之前提到的那個(gè)數(shù)據(jù)庫(kù),多維索引服務(wù),以及其他各種C++和Java后端服務(wù)。Dapper的跟蹤用來(lái)評(píng)估總查詢(xún)成本,促進(jìn)重新對(duì)業(yè)務(wù)的設(shè)計(jì),用以在他們的系統(tǒng)依賴(lài)上減少負(fù)載。
    • 測(cè)試:新的代碼版本會(huì)經(jīng)過(guò)一個(gè)使用Dapper進(jìn)行跟蹤的QA過(guò)程,用來(lái)驗(yàn)證正確的系統(tǒng)行為和性能。在跑測(cè)試的過(guò)程中能發(fā)現(xiàn)很多問(wèn)題,這些問(wèn)題來(lái)自廣告審查系統(tǒng)自身的代碼或是他的依賴(lài)包。

    廣告審查團(tuán)隊(duì)廣泛使用了Dapper Annotation API。Guice[13]開(kāi)源的AOP框架用來(lái)在重要的軟件組件上標(biāo)注“@Traced”。這些跟蹤信息可以進(jìn)一步被標(biāo)注,包含:重要子路徑的輸入輸出大小、基礎(chǔ)信息、其他調(diào)試信息,所有這些信息將會(huì)額外發(fā)送到日志文件中。

    同時(shí),我們也發(fā)現(xiàn)了一些廣告審查小組在使用方面的不足。比如:他們想根據(jù)他們所有跟蹤的Annotation信息,在一個(gè)交互時(shí)間段內(nèi)進(jìn)行搜索,然而這就必須跑一個(gè)自定義的MapReduce或進(jìn)行每一個(gè)跟蹤的手動(dòng)檢查。另外,在Google還有一些其他的系統(tǒng)在也從通用調(diào)試日志中收集和集中信息,把那些系統(tǒng)的海量數(shù)據(jù)和Dapper倉(cāng)庫(kù)整合也是有價(jià)值的。

    總的來(lái)說(shuō),即便如此,廣告審查團(tuán)隊(duì)仍然對(duì)Dapper的作用進(jìn)行了以下評(píng)估,通過(guò)使用Dapper的跟蹤平臺(tái)的數(shù)據(jù)分析,他們的服務(wù)延遲性已經(jīng)優(yōu)化了兩個(gè)數(shù)量級(jí)。

    6.1.1 與異常監(jiān)控的集成

    Google維護(hù)了一個(gè)從運(yùn)行進(jìn)程中不斷收集并集中異常信息報(bào)告的服務(wù)。如果這些異常發(fā)生在Dapper跟蹤采樣的上下文中,那么相應(yīng)的跟蹤ID和span的ID也會(huì)作為元數(shù)據(jù)記錄在異常報(bào)告中。異常監(jiān)測(cè)服務(wù)的前端會(huì)提供一個(gè)鏈接,從特定的異常信息的報(bào)告直接導(dǎo)向到他們各自的分布式跟蹤。廣告審查團(tuán)隊(duì)使用這個(gè)功能可以了解bug發(fā)生的更大范圍的上下文。通過(guò)暴露基于簡(jiǎn)單的唯一ID構(gòu)建的接口,Dapper平臺(tái)被集成到其他事件監(jiān)測(cè)系統(tǒng)會(huì)相對(duì)容易。

    6.2 解決延遲的長(zhǎng)尾效應(yīng)

    考慮到移動(dòng)部件的數(shù)量、代碼庫(kù)的規(guī)模、部署的范圍,調(diào)試一個(gè)像全文搜索那樣服務(wù)(第1節(jié)里提到過(guò))是非常具有挑戰(zhàn)性的。在這節(jié),我們描述了我們?cè)跍p輕全文搜索的延遲分布的長(zhǎng)尾效應(yīng)上做的各種努力。Dapper能夠驗(yàn)證端到端的延遲的假設(shè),更具體地說(shuō),Dapper能夠驗(yàn)證對(duì)于搜索請(qǐng)求的關(guān)鍵路徑。當(dāng)一個(gè)系統(tǒng)不僅涉及數(shù)個(gè)子系統(tǒng),而是幾十個(gè)開(kāi)發(fā)團(tuán)隊(duì)的涉及到的系統(tǒng)的情況下,端到端性能較差的根本原因到底在哪,這個(gè)問(wèn)題即使是我們最好的和最有經(jīng)驗(yàn)的工程師也無(wú)法正確回答。在這種情況下,Dapper可以提供急需的數(shù)據(jù),而且可以對(duì)許多重要的性能問(wèn)題得出結(jié)論。

    圖7:全局搜索的跟蹤片段,在不常遇到高網(wǎng)絡(luò)延遲的情況下,在沿著關(guān)鍵路徑的端到端的請(qǐng)求延遲,如圖所示。

    在調(diào)試延遲長(zhǎng)尾效應(yīng)的過(guò)程中,工程師可以建立一個(gè)小型庫(kù),這個(gè)小型庫(kù)可以根據(jù)DAPI跟蹤對(duì)象來(lái)推斷關(guān)鍵路徑的層級(jí)結(jié)構(gòu)。這些關(guān)鍵路徑的結(jié)構(gòu)可以被用來(lái)診斷問(wèn)題,并且為全文搜索提供可優(yōu)先處理的預(yù)期的性能改進(jìn)。Dapper的這項(xiàng)工作導(dǎo)致了下列發(fā)現(xiàn):

    • 在關(guān)鍵路徑上的短暫的網(wǎng)絡(luò)性能退化不影響系統(tǒng)的吞吐量,但它可能會(huì)對(duì)延遲異常值產(chǎn)生極大的影響。在圖7中可以看出,大部分的全局搜索的緩慢的跟蹤都來(lái)源于關(guān)鍵路徑的網(wǎng)絡(luò)性能退化。
    • 許多問(wèn)題和代價(jià)很高的查詢(xún)模式來(lái)源于一些意想不到的服務(wù)之間的交互。一旦發(fā)現(xiàn),往往容易糾正它們,但是Dapper出現(xiàn)之前想找出這些問(wèn)題是相當(dāng)困難的。
    • 通用的查詢(xún)從Dapper之外的安全日志倉(cāng)庫(kù)中收取,并使用Dapper唯一的跟蹤ID,與Dapper的倉(cāng)庫(kù)做關(guān)聯(lián)。然后,該映射用來(lái)建立關(guān)于在全局搜索中的每一個(gè)獨(dú)立子系統(tǒng)都很慢的實(shí)例查詢(xún)的列表。

    6.3 推斷服務(wù)依賴(lài)

    在任何給定的時(shí)間內(nèi),Google內(nèi)部的一個(gè)典型的計(jì)算集群是一個(gè)匯集了成千上萬(wàn)個(gè)邏輯“任務(wù)”的主機(jī),一套的處理器在執(zhí)行一個(gè)通用的方法。Google維護(hù)著許多這樣的集群,當(dāng)然,事實(shí)上,我們發(fā)現(xiàn)在一個(gè)集群上計(jì)算著的這些任務(wù)通常依賴(lài)于其他的集群上的任務(wù)。由于任務(wù)們之間的依賴(lài)是動(dòng)態(tài)改變的,所以不可能僅從配置信息上推斷出所有這些服務(wù)之間的依賴(lài)關(guān)系。不過(guò),除了其他方面的原因之外,在公司內(nèi)部的各個(gè)流程需要準(zhǔn)確的服務(wù)依賴(lài)關(guān)系信息,以確定瓶頸所在,以及計(jì)劃服務(wù)的遷移。Google的可稱(chēng)為“Service Dependencies”的項(xiàng)目是通過(guò)使用跟蹤Annotation和DAPI MapReduce接口來(lái)實(shí)現(xiàn)自動(dòng)化確定服務(wù)依賴(lài)歸屬的。

    Dapper核心組件與Dapper跟蹤Annotation一并使用的情況下,“Service Dependencies”項(xiàng)目能夠推算出任務(wù)各自之間的依賴(lài),以及任務(wù)和其他軟件組件之間的依賴(lài)。比如,所有的BigTable的操作會(huì)加上與受影響的表名稱(chēng)相關(guān)的標(biāo)記。運(yùn)用Dapper的平臺(tái),Service Dependencies團(tuán)隊(duì)就可以自動(dòng)的推算出依賴(lài)于命名的不同資源的服務(wù)粒度。

    6.4 不同服務(wù)的網(wǎng)絡(luò)使用率

    Google投入了大量的人力和物力資源在他的網(wǎng)絡(luò)結(jié)構(gòu)上。從前網(wǎng)絡(luò)管理員可能只關(guān)注獨(dú)立的硬件信息、常用工具及以及搭建出的各種全局網(wǎng)絡(luò)鳥(niǎo)瞰圖的dashboard上的信息。網(wǎng)絡(luò)管理員確實(shí)可以一覽整個(gè)網(wǎng)絡(luò)的健康狀況,但是,當(dāng)遇到問(wèn)題時(shí),他們很少有能夠準(zhǔn)確查找網(wǎng)絡(luò)負(fù)載的工具,用來(lái)定位應(yīng)用程序級(jí)別的罪魁禍?zhǔn)住?/p>

    雖然Dapper不是設(shè)計(jì)用來(lái)做鏈路級(jí)的監(jiān)控的,但是我們發(fā)現(xiàn),它是非常適合去做集群之間網(wǎng)絡(luò)活動(dòng)性的應(yīng)用級(jí)任務(wù)的分析。Google能夠利用Dapper這個(gè)平臺(tái),建立一個(gè)不斷更新的控制臺(tái),來(lái)顯示集群之間最活躍的網(wǎng)絡(luò)流量的應(yīng)用級(jí)的熱點(diǎn)。此外,使用Dapper我們能夠?yàn)榘嘿F的網(wǎng)絡(luò)請(qǐng)求提供指出的構(gòu)成原因的跟蹤,而不是面對(duì)不同服務(wù)器之間的信息孤島而無(wú)所適從。建立一個(gè)基于Dapper API的dashboard總共沒(méi)花超過(guò)2周的時(shí)間。

    6.5 分層和共享存儲(chǔ)系統(tǒng)

    在Google的許多存儲(chǔ)系統(tǒng)是由多重獨(dú)立復(fù)雜層級(jí)的分布式基礎(chǔ)設(shè)備組成的。例如,Google的App Engine[5]就是搭建在一個(gè)可擴(kuò)展的實(shí)體存儲(chǔ)系統(tǒng)上的。該實(shí)體存儲(chǔ)系統(tǒng)在基于BigTable上公開(kāi)某些RDBMS功能。 BigTable的同時(shí)使用Chubby[7](分布式鎖系統(tǒng))及GFS。再者,像BigTable這樣的系統(tǒng)簡(jiǎn)化了部署,并更好的利用了計(jì)算資源。

    在這種分層的系統(tǒng),并不總是很容易確定最終用戶資源的消費(fèi)模式。例如,來(lái)自于一個(gè)給定的BigTable單元格的GFS大信息量主要來(lái)自于一個(gè)用戶或是由多個(gè)用戶產(chǎn)生,但是在GFS層面,這兩種明顯的使用場(chǎng)景是很難界定。而且,如果缺乏一個(gè)像Dapper一樣的工具的情況下,對(duì)共享服務(wù)的競(jìng)爭(zhēng)可能會(huì)同樣難于調(diào)試。

    第5.2節(jié)中所示的Dapper的用戶界面可以聚合那些調(diào)用任意公共服務(wù)的多個(gè)客戶端的跟蹤的性能信息。這就很容易讓提供這些服務(wù)的源從多個(gè)維度給他們的用戶排名。(例如,入站的網(wǎng)絡(luò)負(fù)載,出站的網(wǎng)絡(luò)負(fù)載,或服務(wù)請(qǐng)求的總時(shí)間)

    6.6 Dapper的救火能力(Firefighting)

    對(duì)于一些“救火”任務(wù),Dapper可以處理其中的一部分?!熬然稹比蝿?wù)在這里是指一些有風(fēng)險(xiǎn)很高的在分布式系統(tǒng)上的操作。通常情況下,Dapper用戶當(dāng)正在進(jìn)行“救火”任務(wù)時(shí)需要使用新的數(shù)據(jù),并且沒(méi)有時(shí)間寫(xiě)新的DAPI代碼或等待周期性的報(bào)告運(yùn)行。

    對(duì)于那些高延遲,不,可能更糟糕的那些在正常負(fù)載下都會(huì)響應(yīng)超時(shí)的服務(wù),Dapper用戶界面通常會(huì)把這些延遲瓶頸的位置隔離出來(lái)。通過(guò)與Dapper守護(hù)進(jìn)程的直接通信,那些特定的高延遲的跟蹤數(shù)據(jù)輕易的收集到。當(dāng)出現(xiàn)災(zāi)難性故障時(shí),通常是沒(méi)有必要去看統(tǒng)計(jì)數(shù)據(jù)以確定根本原因,只查看示例跟蹤就足夠了(因?yàn)榍拔奶岬竭^(guò)從Dapper守護(hù)進(jìn)程中幾乎可以立即獲得跟蹤數(shù)據(jù))。

    但是,如在6.5節(jié)中描述的共享的存儲(chǔ)服務(wù),要求當(dāng)用戶活動(dòng)過(guò)程中突然中斷時(shí)能盡可能快的匯總信息。對(duì)于事件發(fā)生之后,共享服務(wù)仍然可以利用匯總的的Dapper數(shù)據(jù),但是,除非收集到的Dapper數(shù)據(jù)的批量分析能在問(wèn)題出現(xiàn)10分鐘之內(nèi)完成,否則Dapper面對(duì)與共享存儲(chǔ)服務(wù)相關(guān)的“救火”任務(wù)就很難按預(yù)想的那般順利完成。

    7. 其他收獲

    雖然迄今為止,我們?cè)贒apper上的經(jīng)驗(yàn)已經(jīng)大致符合我們的預(yù)期,但是也出現(xiàn)了一些積極的方面是我們沒(méi)有充分預(yù)料到的。首先,我們獲得了超出預(yù)期的Dapper使用用例的數(shù)量,對(duì)此我們可謂歡心鼓舞。另外,在除了幾個(gè)的在第6節(jié)使用經(jīng)驗(yàn)中提到過(guò)的一些用例之外,還包括資源核算系統(tǒng),對(duì)指定的通訊模式敏感的服務(wù)的檢查工具,以及一種對(duì)RPC壓縮策略的分析器,等等。我們認(rèn)為這些意想不到的用例一定程度上是由于我們向開(kāi)發(fā)者以一種簡(jiǎn)單的編程接口的方式開(kāi)放了跟蹤數(shù)據(jù)存儲(chǔ)的緣故,這使得我們能夠充分利用這個(gè)大的多的社區(qū)的創(chuàng)造力。除此之外,Dapper對(duì)舊的負(fù)載的支持也比預(yù)期的要簡(jiǎn)單,只需要在程序中引入一個(gè)用新版本的重新編譯過(guò)的公共組件庫(kù)(包含常規(guī)的線程使用,控制流和RPC框架)即可。

    Dapper在Google內(nèi)部的廣泛使用還為我們?cè)贒apper的局限性上提供了寶貴的反饋意見(jiàn)。下面我們將介紹一些我們已知的最重要的Dapper的不足:

    • 合并的影響:我們的模型隱含的前提是不同的子系統(tǒng)在處理的都是來(lái)自同一個(gè)被跟蹤的請(qǐng)求。在某些情況下,緩沖一部分請(qǐng)求,然后一次性操作一個(gè)請(qǐng)求集會(huì)更加有效。(比如,磁盤(pán)上的一次合并寫(xiě)入操作)。在這種情況下,一個(gè)被跟蹤的請(qǐng)求可以看似是一個(gè)大型工作單元。此外,當(dāng)有多個(gè)追蹤請(qǐng)求被收集在一起,他們當(dāng)中只有一個(gè)會(huì)用來(lái)生成那個(gè)唯一的跟蹤ID,用來(lái)給其他span使用,所以就無(wú)法跟蹤下去了。我們正在考慮的解決方案,希望在可以識(shí)別這種情況的前提下,用盡可能少的記錄來(lái)解決這個(gè)問(wèn)題。
    • 跟蹤批處理負(fù)載:Dapper的設(shè)計(jì),主要是針對(duì)在線服務(wù)系統(tǒng),最初的目標(biāo)是了解一個(gè)用戶請(qǐng)求產(chǎn)生的系統(tǒng)行為。然而,離線的密集型負(fù)載,例如符合MapReduce[10]模型的情況,也可以受益于性能挖潛。在這種情況下,我們需要把跟蹤ID與一些其他的有意義的工作單元做關(guān)聯(lián),諸如輸入數(shù)據(jù)中的鍵值(或鍵值的范圍),或是一個(gè)MapReduce shard。
    • 尋找根源:Dapper可以有效地確定系統(tǒng)中的哪一部分致使系統(tǒng)整個(gè)速度變慢,但并不總是能夠找出問(wèn)題的根源。例如,一個(gè)請(qǐng)求很慢有可能不是因?yàn)樗约旱男袨?#xff0c;而是由于隊(duì)列中其他排在它前面的(queued ahead of)請(qǐng)求還沒(méi)處理完。程序可以使用應(yīng)用級(jí)的annotation把隊(duì)列的大小或過(guò)載情況寫(xiě)入跟蹤系統(tǒng)。此外,如果這種情況屢見(jiàn)不鮮,那么在ProfileMe[11]中提到的成對(duì)的采樣技術(shù)可以解決這個(gè)問(wèn)題。它由兩個(gè)時(shí)間重疊的采樣率組成,并觀察它們?cè)谡麄€(gè)系統(tǒng)中的相對(duì)延遲。
    • 記錄內(nèi)核級(jí)的信息:一些內(nèi)核可見(jiàn)的事件的詳細(xì)信息有時(shí)對(duì)確定問(wèn)題根源是很有用的。我們有一些工具,能夠跟蹤或以其他方式描述內(nèi)核的執(zhí)行,但是,想用通用的或是不那么突兀的方式,是很難把這些信息到捆綁到用戶級(jí)別的跟蹤上下文中。我們正在研究一種妥協(xié)的解決方案,我們?cè)谟脩魧用嫔习岩恍﹥?nèi)核級(jí)的活動(dòng)參數(shù)做快照,然后綁定他們到一個(gè)活動(dòng)的span上。

    8. 相關(guān)產(chǎn)品

    在分布式系統(tǒng)跟蹤領(lǐng)域,有一套完整的體系,一部分系統(tǒng)主要關(guān)注定位到故障位置,其他的目標(biāo)是針對(duì)性能進(jìn)行優(yōu)化。 Dapper確實(shí)被用于發(fā)現(xiàn)系統(tǒng)問(wèn)題,但它更通常用于探查性能不足,以及提高全面大規(guī)模的工作負(fù)載下的系統(tǒng)行為的理解。

    與Dapper相關(guān)的黑盒監(jiān)控系統(tǒng),比如Project5[1],WAP5[15]和Sherlock[2],可以說(shuō)不依賴(lài)運(yùn)行庫(kù)的情況下,黑盒監(jiān)控系統(tǒng)能夠?qū)崿F(xiàn)更高的應(yīng)用級(jí)透明。黑盒的缺點(diǎn)是一定程度上不夠精確,并可能在統(tǒng)計(jì)推斷關(guān)鍵路徑時(shí)帶來(lái)更大的系統(tǒng)損耗。

    對(duì)于分布式系統(tǒng)監(jiān)控來(lái)說(shuō),基于Annotation的中間件或應(yīng)用自身是一個(gè)可能是更受歡迎的解決辦法.拿Pip[14]和Webmon[16]系統(tǒng)舉例,他們更依賴(lài)于應(yīng)用級(jí)的Annotation,而X-Trace[12],Pinpoint[9]和Magpie[3]大多集中在對(duì)庫(kù)和中間件的修改。Dapper更接近后者。像Pinpoint,X-Trace,和早期版本的Magpie一樣,Dapper采用了全局標(biāo)識(shí)符把分布式系統(tǒng)中各部分相關(guān)的事件聯(lián)系在一起。和這些系統(tǒng)類(lèi)似,Dapper嘗試避免使用應(yīng)用級(jí)Annotation,而是把的植入隱藏在通用組件模塊內(nèi)。Magpie放棄使用全局ID,仍然試圖正確的完成請(qǐng)求的正確傳播,他通過(guò)采用應(yīng)用系統(tǒng)各自寫(xiě)入的事件策略,最終也能精確描述不同事件之間關(guān)系。但是目前還不清楚Magpie在實(shí)際環(huán)境中實(shí)現(xiàn)透明性這些策略到底多么有效。 X-Trace的核心Annotation比Dapper更有野心一些,因?yàn)閄-Trace系統(tǒng)對(duì)于跟蹤的收集,不僅在跟蹤節(jié)點(diǎn)層面上,而且在節(jié)點(diǎn)內(nèi)部不同的軟件層也會(huì)進(jìn)行跟蹤。而我們對(duì)于組件的低性能損耗的要求迫使我們不能采用X-Trace這樣的模型,而是朝著把一個(gè)請(qǐng)求連接起來(lái)完整跟蹤所能做到的最小代價(jià)而努力。而Dapper的跟蹤仍然可以從可選的應(yīng)用級(jí)Annotation中獲益。

    9. 總結(jié)

    在本文中,我們介紹Dapper這個(gè)Google的生產(chǎn)環(huán)境下的分布式系統(tǒng)跟蹤平臺(tái),并匯報(bào)了我們開(kāi)發(fā)和使用它的相關(guān)經(jīng)驗(yàn)。 Dapper幾乎在部署在所有的Google系統(tǒng)上,并可以在不需要應(yīng)用級(jí)修改的情況下進(jìn)行跟蹤,而且沒(méi)有明顯的性能影響。Dapper對(duì)于開(kāi)發(fā)人員和運(yùn)維團(tuán)隊(duì)帶來(lái)的好處,可以從我們主要的跟蹤用戶界面的廣泛使用上看出來(lái),另外我們還列舉了一些Dapper的使用用例來(lái)說(shuō)明Dapper的作用,這些用例有些甚至都沒(méi)有Dapper開(kāi)發(fā)團(tuán)隊(duì)參與,而是被應(yīng)用的開(kāi)發(fā)者開(kāi)發(fā)出來(lái)的。

    據(jù)我們所知,這是第一篇匯報(bào)生產(chǎn)環(huán)境下分布式系統(tǒng)跟蹤框架的論文。事實(shí)上,我們的主要貢獻(xiàn)源于這個(gè)事實(shí):論文中回顧的這個(gè)系統(tǒng)已經(jīng)運(yùn)行兩年之久。我們發(fā)現(xiàn),結(jié)合對(duì)開(kāi)發(fā)人員提供簡(jiǎn)單API和對(duì)應(yīng)用系統(tǒng)完全透明來(lái)增強(qiáng)跟蹤的這個(gè)決定,是非常值得的。

    我們相信,Dapper比以前的基于Annotation的分布式跟蹤達(dá)到更高的應(yīng)用透明度,這一點(diǎn)已經(jīng)通過(guò)只需要少量人工干預(yù)的工作量得以證明。雖然一定程度上得益于我們的系統(tǒng)的同質(zhì)性,但它本身仍然是一個(gè)重大的挑戰(zhàn)。最重要的是,我們的設(shè)計(jì)提出了一些實(shí)現(xiàn)應(yīng)用級(jí)透明性的充分條件,對(duì)此我們希望能夠?qū)Ωe(cuò)雜環(huán)境下的解決方案的開(kāi)發(fā)有所幫助。

    最后,通過(guò)開(kāi)放Dapper跟蹤倉(cāng)庫(kù)給內(nèi)部開(kāi)發(fā)者,我們促使更多的基于跟蹤倉(cāng)庫(kù)的分析工具的產(chǎn)生,而僅僅由Dapper團(tuán)隊(duì)默默的在信息孤島中埋頭苦干的結(jié)果遠(yuǎn)達(dá)不到現(xiàn)在這么大的規(guī)模,這個(gè)決定促使了設(shè)計(jì)和實(shí)施的展開(kāi)。

    總結(jié)

    以上是生活随笔為你收集整理的大规模分布式跟踪系统的理论的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

    亚洲 a v无 码免 费 成 人 a v | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 综合激情五月综合激情五月激情1 | 在线 国产 欧美 亚洲 天堂 | 国产一区二区三区精品视频 | 国产97色在线 | 免 | 婷婷色婷婷开心五月四房播播 | 国产人妻精品一区二区三区 | 亚洲精品久久久久久久久久久 | 六月丁香婷婷色狠狠久久 | 国产精品沙发午睡系列 | 免费无码肉片在线观看 | 精品国偷自产在线 | 中文字幕人成乱码熟女app | a在线观看免费网站大全 | 欧洲精品码一区二区三区免费看 | 日本免费一区二区三区最新 | 欧美人与禽zoz0性伦交 | 欧美日本精品一区二区三区 | 风流少妇按摩来高潮 | 日欧一片内射va在线影院 | 小泽玛莉亚一区二区视频在线 | 丰满少妇弄高潮了www | 亚洲精品一区二区三区四区五区 | 国产农村妇女高潮大叫 | 色狠狠av一区二区三区 | 亚洲精品国产a久久久久久 | 18无码粉嫩小泬无套在线观看 | 狠狠亚洲超碰狼人久久 | 国产精品对白交换视频 | 狠狠cao日日穞夜夜穞av | ass日本丰满熟妇pics | 国产两女互慰高潮视频在线观看 | 中文字幕人成乱码熟女app | 欧美肥老太牲交大战 | 欧美变态另类xxxx | 亚洲国产一区二区三区在线观看 | 亚洲午夜福利在线观看 | 中文字幕人妻丝袜二区 | 亚洲午夜久久久影院 | 国产精品久久久久7777 | 色欲综合久久中文字幕网 | 无遮挡啪啪摇乳动态图 | 精品乱子伦一区二区三区 | 老熟女重囗味hdxx69 | 中国女人内谢69xxxxxa片 | 国产一区二区三区日韩精品 | 精品国精品国产自在久国产87 | 精品久久久无码中文字幕 | 亚洲熟妇色xxxxx亚洲 | 波多野42部无码喷潮在线 | 97无码免费人妻超级碰碰夜夜 | 强开小婷嫩苞又嫩又紧视频 | 成在人线av无码免观看麻豆 | 欧美xxxx黑人又粗又长 | 日韩亚洲欧美中文高清在线 | 蜜桃视频插满18在线观看 | 蜜桃视频韩日免费播放 | 好爽又高潮了毛片免费下载 | 久久久久se色偷偷亚洲精品av | 国产精品毛多多水多 | 中文字幕人妻无码一区二区三区 | 高潮毛片无遮挡高清免费 | 国产亚洲精品久久久久久久久动漫 | 久久综合九色综合97网 | 日产精品高潮呻吟av久久 | 亚洲成av人片在线观看无码不卡 | 久久亚洲中文字幕精品一区 | 波多野结衣高清一区二区三区 | 亚洲色大成网站www国产 | 人妻与老人中文字幕 | 国产精品资源一区二区 | 狂野欧美性猛交免费视频 | 国产婷婷色一区二区三区在线 | 国产内射爽爽大片视频社区在线 | 国产精品久久久久9999小说 | 国产精品.xx视频.xxtv | 97精品国产97久久久久久免费 | 精品一区二区三区无码免费视频 | 国产精品亚洲专区无码不卡 | 初尝人妻少妇中文字幕 | 亚洲精品国产品国语在线观看 | 十八禁视频网站在线观看 | 亚洲国产精品久久久久久 | 久久亚洲日韩精品一区二区三区 | 亚洲精品国产精品乱码视色 | 美女毛片一区二区三区四区 | 久久午夜夜伦鲁鲁片无码免费 | 2019午夜福利不卡片在线 | 亚洲精品国偷拍自产在线观看蜜桃 | 无码国产激情在线观看 | 日本一卡二卡不卡视频查询 | 亚洲无人区午夜福利码高清完整版 | 激情五月综合色婷婷一区二区 | 色一情一乱一伦一区二区三欧美 | а天堂中文在线官网 | 久久 国产 尿 小便 嘘嘘 | 少妇性荡欲午夜性开放视频剧场 | 久久精品人人做人人综合 | 国语精品一区二区三区 | 麻豆人妻少妇精品无码专区 | 青青青手机频在线观看 | 日本熟妇人妻xxxxx人hd | 亚洲色偷偷偷综合网 | 国产精品欧美成人 | 日本大香伊一区二区三区 | 免费人成网站视频在线观看 | 一本久久a久久精品亚洲 | 最近中文2019字幕第二页 | 日产国产精品亚洲系列 | 免费网站看v片在线18禁无码 | 久久久婷婷五月亚洲97号色 | 亚洲综合在线一区二区三区 | 亚洲精品一区二区三区大桥未久 | 亚洲狠狠婷婷综合久久 | 久久久精品人妻久久影视 | 特黄特色大片免费播放器图片 | 国精品人妻无码一区二区三区蜜柚 | 久久www免费人成人片 | 理论片87福利理论电影 | 亚洲日韩av片在线观看 | 精品水蜜桃久久久久久久 | 国产日产欧产精品精品app | a国产一区二区免费入口 | 欧美日韩久久久精品a片 | 国内丰满熟女出轨videos | 少妇无码av无码专区在线观看 | 精品成人av一区二区三区 | a国产一区二区免费入口 | 亚洲精品国产精品乱码视色 | 爱做久久久久久 | 成人无码精品一区二区三区 | 东京热一精品无码av | 国产乱码精品一品二品 | 无码福利日韩神码福利片 | 日韩欧美成人免费观看 | 色婷婷久久一区二区三区麻豆 | 国产熟妇另类久久久久 | 国产黄在线观看免费观看不卡 | 亚洲精品国偷拍自产在线观看蜜桃 | 曰本女人与公拘交酡免费视频 | 高潮毛片无遮挡高清免费 | 国产精品二区一区二区aⅴ污介绍 | 国内少妇偷人精品视频 | 精品无码一区二区三区的天堂 | 亚洲中文字幕av在天堂 | 国产特级毛片aaaaaaa高清 | 欧洲精品码一区二区三区免费看 | 精品人妻av区 | 色噜噜亚洲男人的天堂 | 精品国产成人一区二区三区 | 久久精品国产精品国产精品污 | 国产精品久久久久7777 | 成人欧美一区二区三区黑人免费 | 日日干夜夜干 | 激情亚洲一区国产精品 | 色情久久久av熟女人妻网站 | 丰满人妻精品国产99aⅴ | 日本高清一区免费中文视频 | 色欲久久久天天天综合网精品 | 亚洲精品中文字幕乱码 | 久久国内精品自在自线 | 精品久久久中文字幕人妻 | а天堂中文在线官网 | 国产激情无码一区二区app | 亚洲大尺度无码无码专区 | 国精品人妻无码一区二区三区蜜柚 | 亚洲国产日韩a在线播放 | 天干天干啦夜天干天2017 | 自拍偷自拍亚洲精品被多人伦好爽 | 无套内谢老熟女 | 激情爆乳一区二区三区 | 精品无码一区二区三区爱欲 | 欧洲vodafone精品性 | 色综合久久久久综合一本到桃花网 | 亚洲成a人片在线观看无码3d | 久精品国产欧美亚洲色aⅴ大片 | 亚洲精品国偷拍自产在线麻豆 | 精品日本一区二区三区在线观看 | 亚洲精品成人福利网站 | 国产精品内射视频免费 | 亚洲大尺度无码无码专区 | 粉嫩少妇内射浓精videos | 久久精品国产一区二区三区 | 国内精品久久毛片一区二区 | 2020久久香蕉国产线看观看 | 亚洲综合无码久久精品综合 | 亚洲狠狠色丁香婷婷综合 | 国内精品一区二区三区不卡 | 日本精品久久久久中文字幕 | 领导边摸边吃奶边做爽在线观看 | 强奷人妻日本中文字幕 | 亚洲国产精品一区二区美利坚 | 黑人大群体交免费视频 | 精品日本一区二区三区在线观看 | 亚洲一区二区三区国产精华液 | 欧美zoozzooz性欧美 | 精品久久久无码人妻字幂 | 色欲综合久久中文字幕网 | 我要看www免费看插插视频 | 好屌草这里只有精品 | 丰满护士巨好爽好大乳 | 欧美freesex黑人又粗又大 | 久久久久久久女国产乱让韩 | 成人精品一区二区三区中文字幕 | 天干天干啦夜天干天2017 | 国产亚洲欧美在线专区 | 永久免费观看美女裸体的网站 | 国产亚洲精品久久久ai换 | 少妇人妻偷人精品无码视频 | 在线观看欧美一区二区三区 | аⅴ资源天堂资源库在线 | 色偷偷人人澡人人爽人人模 | 樱花草在线播放免费中文 | 亚洲第一网站男人都懂 | 精品国产成人一区二区三区 | 中文字幕无码人妻少妇免费 | 国产精品美女久久久网av | 一本久久a久久精品亚洲 | 久久国内精品自在自线 | 国产乡下妇女做爰 | 亚洲娇小与黑人巨大交 | 又大又硬又爽免费视频 | 性欧美牲交xxxxx视频 | 领导边摸边吃奶边做爽在线观看 | 亚洲第一网站男人都懂 | 亚洲成在人网站无码天堂 | 久久久久久国产精品无码下载 | 成人免费无码大片a毛片 | 扒开双腿疯狂进出爽爽爽视频 | 未满小14洗澡无码视频网站 | 中文字幕乱码中文乱码51精品 | 丰满人妻被黑人猛烈进入 | 日韩亚洲欧美精品综合 | 狠狠噜狠狠狠狠丁香五月 | 国产人妻大战黑人第1集 | 亚洲欧美国产精品专区久久 | 亚洲精品综合五月久久小说 | 麻豆md0077饥渴少妇 | 亚洲春色在线视频 | 亚洲精品国偷拍自产在线麻豆 | 日韩av无码中文无码电影 | 国产国产精品人在线视 | 人妻人人添人妻人人爱 | 午夜福利试看120秒体验区 | 1000部夫妻午夜免费 | 国产精品久久久一区二区三区 | 少妇性l交大片 | 骚片av蜜桃精品一区 | 国产真人无遮挡作爱免费视频 | 欧美日本免费一区二区三区 | 熟女体下毛毛黑森林 | 色综合久久久无码网中文 | 国产精华av午夜在线观看 | 一本加勒比波多野结衣 | 亚洲中文字幕va福利 | 亚洲精品无码国产 | 亚洲综合久久一区二区 | 麻豆果冻传媒2021精品传媒一区下载 | 欧美黑人性暴力猛交喷水 | 欧美熟妇另类久久久久久多毛 | 99久久无码一区人妻 | 麻豆成人精品国产免费 | 久久久亚洲欧洲日产国码αv | 西西人体www44rt大胆高清 | 精品亚洲成av人在线观看 | 最近的中文字幕在线看视频 | 中文字幕久久久久人妻 | 亲嘴扒胸摸屁股激烈网站 | 久久综合久久自在自线精品自 | 76少妇精品导航 | 亚洲国产成人av在线观看 | 亚洲国产精品一区二区美利坚 | 99久久精品国产一区二区蜜芽 | 少妇愉情理伦片bd | 国产激情精品一区二区三区 | 性欧美牲交xxxxx视频 | 国产人妖乱国产精品人妖 | 国产女主播喷水视频在线观看 | 亚洲成a人片在线观看日本 | 久久久久99精品成人片 | 久久精品国产一区二区三区肥胖 | 国产成人无码a区在线观看视频app | 久久综合狠狠综合久久综合88 | 日本va欧美va欧美va精品 | 亚洲日韩中文字幕在线播放 | 日本va欧美va欧美va精品 | 国产精品手机免费 | 国产熟妇高潮叫床视频播放 | 成人性做爰aaa片免费看 | 巨爆乳无码视频在线观看 | 99久久久无码国产aaa精品 | 亚洲中文无码av永久不收费 | 久久久久久国产精品无码下载 | 国产精品久久久久久久影院 | 又大又黄又粗又爽的免费视频 | 亚洲国产av精品一区二区蜜芽 | 天干天干啦夜天干天2017 | 精品偷拍一区二区三区在线看 | 久久精品女人天堂av免费观看 | 高中生自慰www网站 | 久久久国产一区二区三区 | 欧美性黑人极品hd | 小泽玛莉亚一区二区视频在线 | 欧美老妇与禽交 | 国产香蕉97碰碰久久人人 | 精品一区二区三区无码免费视频 | 国产美女精品一区二区三区 | 亚洲精品中文字幕乱码 | 精品国产av色一区二区深夜久久 | 男人的天堂av网站 | 欧美人妻一区二区三区 | 亚洲熟妇色xxxxx欧美老妇 | 九月婷婷人人澡人人添人人爽 | 欧美 丝袜 自拍 制服 另类 | 少妇久久久久久人妻无码 | 成 人影片 免费观看 | 国产熟妇另类久久久久 | 大屁股大乳丰满人妻 | 国产激情无码一区二区app | 久久精品人人做人人综合试看 | 国产亲子乱弄免费视频 | 一区二区传媒有限公司 | 国产内射爽爽大片视频社区在线 | 狂野欧美激情性xxxx | 色诱久久久久综合网ywww | 亚洲欧美日韩综合久久久 | 日韩精品无码一区二区中文字幕 | 欧美丰满老熟妇xxxxx性 | 搡女人真爽免费视频大全 | 日韩精品无码一本二本三本色 | 无码一区二区三区在线观看 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 久久精品国产99精品亚洲 | 精品成人av一区二区三区 | 亚洲欧美国产精品专区久久 | 久久精品国产99精品亚洲 | 欧美日韩视频无码一区二区三 | 女人和拘做爰正片视频 | 欧洲极品少妇 | 麻花豆传媒剧国产免费mv在线 | 俺去俺来也www色官网 | 婷婷六月久久综合丁香 | 久久国产自偷自偷免费一区调 | 国产真实夫妇视频 | 午夜肉伦伦影院 | 高清不卡一区二区三区 | 国精品人妻无码一区二区三区蜜柚 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产激情精品一区二区三区 | 黑人巨大精品欧美一区二区 | 人妻无码αv中文字幕久久琪琪布 | 特级做a爰片毛片免费69 | 日韩精品无码一本二本三本色 | 久久久中文久久久无码 | 亚洲精品一区三区三区在线观看 | 欧美日韩久久久精品a片 | 久青草影院在线观看国产 | 狠狠色噜噜狠狠狠7777奇米 | 欧美大屁股xxxxhd黑色 | 欧美精品无码一区二区三区 | 俄罗斯老熟妇色xxxx | 中文字幕中文有码在线 | 欧美日韩精品 | 欧美亚洲日韩国产人成在线播放 | 97久久超碰中文字幕 | 欧美日本精品一区二区三区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲成a人片在线观看日本 | 在线欧美精品一区二区三区 | 久久国产精品_国产精品 | www国产精品内射老师 | 久久伊人色av天堂九九小黄鸭 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 性啪啪chinese东北女人 | 亚洲日本va中文字幕 | 亚洲日韩精品欧美一区二区 | 在线成人www免费观看视频 | 99久久精品午夜一区二区 | 欧美午夜特黄aaaaaa片 | 无码人妻丰满熟妇区五十路百度 | 国产无遮挡又黄又爽免费视频 | 午夜性刺激在线视频免费 | 中文字幕无码视频专区 | 亚洲呦女专区 | 国产色xx群视频射精 | 久久精品女人的天堂av | 男人扒开女人内裤强吻桶进去 | 午夜精品久久久久久久 | 激情五月综合色婷婷一区二区 | 女人和拘做爰正片视频 | 欧美成人高清在线播放 | 青青久在线视频免费观看 | 丰满妇女强制高潮18xxxx | 久久久久亚洲精品男人的天堂 | 窝窝午夜理论片影院 | 国产乱人伦av在线无码 | 亚洲日韩精品欧美一区二区 | 大屁股大乳丰满人妻 | 美女毛片一区二区三区四区 | 暴力强奷在线播放无码 | 18禁止看的免费污网站 | 少妇性l交大片欧洲热妇乱xxx | 夜精品a片一区二区三区无码白浆 | 中文字幕无码热在线视频 | 西西人体www44rt大胆高清 | 午夜精品久久久内射近拍高清 | 国内精品人妻无码久久久影院蜜桃 | 成人性做爰aaa片免费看不忠 | 麻豆国产人妻欲求不满谁演的 | 亚洲娇小与黑人巨大交 | 无套内谢老熟女 | 少妇高潮喷潮久久久影院 | 亚洲一区二区观看播放 | 亚洲成av人片在线观看无码不卡 | 伊人久久大香线蕉午夜 | 亚洲欧美精品aaaaaa片 | 无码人妻久久一区二区三区不卡 | 波多野结衣高清一区二区三区 | 牲欲强的熟妇农村老妇女视频 | 人人妻人人澡人人爽精品欧美 | 久久久久99精品成人片 | 欧美放荡的少妇 | 麻豆成人精品国产免费 | 极品尤物被啪到呻吟喷水 | 六十路熟妇乱子伦 | 麻豆果冻传媒2021精品传媒一区下载 | 无码人妻出轨黑人中文字幕 | 丁香花在线影院观看在线播放 | 久久久久久久久888 | 日韩精品乱码av一区二区 | 精品 日韩 国产 欧美 视频 | 久久午夜夜伦鲁鲁片无码免费 | 久久久久国色av免费观看性色 | 日韩精品无码免费一区二区三区 | 欧美日韩在线亚洲综合国产人 | 国产精品va在线观看无码 | www国产亚洲精品久久久日本 | 亚洲a无码综合a国产av中文 | аⅴ资源天堂资源库在线 | 国产人妻人伦精品1国产丝袜 | 午夜男女很黄的视频 | 精品厕所偷拍各类美女tp嘘嘘 | 无码av岛国片在线播放 | 国产sm调教视频在线观看 | 国产精品怡红院永久免费 | 18无码粉嫩小泬无套在线观看 | 97夜夜澡人人双人人人喊 | 波多野42部无码喷潮在线 | 日韩少妇白浆无码系列 | 麻豆国产97在线 | 欧洲 | 亚洲天堂2017无码中文 | 中文字幕av日韩精品一区二区 | 亚洲va欧美va天堂v国产综合 | 国产性生大片免费观看性 | 亚洲精品国产品国语在线观看 | 国产成人亚洲综合无码 | 久久久久久久久蜜桃 | 国产高潮视频在线观看 | 国产麻豆精品一区二区三区v视界 | 国内精品久久毛片一区二区 | 亚洲国产精品久久久天堂 | www成人国产高清内射 | 精品久久综合1区2区3区激情 | 牲交欧美兽交欧美 | 中文字幕无码av激情不卡 | 四虎永久在线精品免费网址 | 东京热一精品无码av | 国产精品欧美成人 | 久在线观看福利视频 | 日本饥渴人妻欲求不满 | 免费网站看v片在线18禁无码 | 无码午夜成人1000部免费视频 | 久久久久亚洲精品中文字幕 | 成人性做爰aaa片免费看 | 国产无遮挡吃胸膜奶免费看 | 亚洲熟女一区二区三区 | 亚洲日韩av一区二区三区中文 | 亚洲乱亚洲乱妇50p | 狠狠噜狠狠狠狠丁香五月 | 女人被男人爽到呻吟的视频 | 国产在线一区二区三区四区五区 | 波多野42部无码喷潮在线 | 国产电影无码午夜在线播放 | 日本精品人妻无码免费大全 | 久久精品人人做人人综合 | 国产片av国语在线观看 | 久久五月精品中文字幕 | 性欧美牲交xxxxx视频 | 中文字幕无线码免费人妻 | 亚洲日本在线电影 | 欧美一区二区三区 | 精品国产一区av天美传媒 | 国产一区二区三区精品视频 | 一本久道高清无码视频 | 久久久久成人精品免费播放动漫 | 亚洲精品无码国产 | 欧美人妻一区二区三区 | 精品国产乱码久久久久乱码 | 亚洲国产av美女网站 | 国产精品美女久久久 | 欧美精品国产综合久久 | 色欲综合久久中文字幕网 | 天海翼激烈高潮到腰振不止 | 久久久久99精品成人片 | 日本肉体xxxx裸交 | 少妇太爽了在线观看 | 久久久无码中文字幕久... | 日韩av无码中文无码电影 | 久久 国产 尿 小便 嘘嘘 | 亚洲国产欧美日韩精品一区二区三区 | 伊人久久大香线蕉午夜 | 欧美人与物videos另类 | 丰满少妇弄高潮了www | 无码精品国产va在线观看dvd | 国产精品久免费的黄网站 | 成年女人永久免费看片 | 熟妇激情内射com | 动漫av一区二区在线观看 | 国产两女互慰高潮视频在线观看 | 99国产精品白浆在线观看免费 | 国产午夜亚洲精品不卡 | 欧美老人巨大xxxx做受 | 欧美兽交xxxx×视频 | 日韩少妇内射免费播放 | 婷婷五月综合激情中文字幕 | 亚洲日本一区二区三区在线 | 亚洲欧美日韩成人高清在线一区 | 久久午夜夜伦鲁鲁片无码免费 | 国产精品va在线观看无码 | 久久久久久久人妻无码中文字幕爆 | 国产精品国产自线拍免费软件 | 成年美女黄网站色大免费全看 | 精品乱子伦一区二区三区 | 国产精品a成v人在线播放 | 亚洲 高清 成人 动漫 | 少妇高潮喷潮久久久影院 | 久久天天躁狠狠躁夜夜免费观看 | 久久精品国产精品国产精品污 | 免费乱码人妻系列无码专区 | 国产精品亚洲lv粉色 | 精品国产一区二区三区四区在线看 | 国产午夜亚洲精品不卡 | 国产免费久久精品国产传媒 | 亚洲色大成网站www国产 | 国产精品久久久一区二区三区 | 一二三四在线观看免费视频 | 清纯唯美经典一区二区 | 欧美国产日韩亚洲中文 | 国产精品99久久精品爆乳 | 亚洲成a人片在线观看日本 | 国产亚洲美女精品久久久2020 | 超碰97人人射妻 | 无码人妻精品一区二区三区下载 | 无码av免费一区二区三区试看 | 天干天干啦夜天干天2017 | 中文字幕精品av一区二区五区 | 亚洲日本va午夜在线电影 | 精品无码一区二区三区的天堂 | 性生交大片免费看女人按摩摩 | 又大又硬又爽免费视频 | 亚洲中文无码av永久不收费 | 又紧又大又爽精品一区二区 | 欧美精品无码一区二区三区 | 野狼第一精品社区 | 377p欧洲日本亚洲大胆 | 免费无码午夜福利片69 | 日韩精品一区二区av在线 | 少妇被粗大的猛进出69影院 | 国产人妻精品一区二区三区 | 亚洲色欲色欲天天天www | 国产亚洲精品久久久闺蜜 | 亚洲熟女一区二区三区 | 亚洲成a人片在线观看日本 | 欧美精品在线观看 | 人妻尝试又大又粗久久 | 欧美人与牲动交xxxx | 国产无遮挡又黄又爽又色 | 成人女人看片免费视频放人 | 人人妻人人澡人人爽欧美精品 | 粗大的内捧猛烈进出视频 | 亚洲国产精品美女久久久久 | 夜夜高潮次次欢爽av女 | 男女下面进入的视频免费午夜 | 欧美三级a做爰在线观看 | 亚洲成a人片在线观看日本 | 又粗又大又硬毛片免费看 | 窝窝午夜理论片影院 | 欧美日韩综合一区二区三区 | 永久免费观看美女裸体的网站 | 欧美亚洲国产一区二区三区 | 亚洲一区二区三区含羞草 | 无遮挡国产高潮视频免费观看 | 欧美日韩一区二区免费视频 | 老子影院午夜伦不卡 | 大地资源中文第3页 | 亚洲人成网站色7799 | 亚洲男女内射在线播放 | 人妻少妇精品视频专区 | 扒开双腿疯狂进出爽爽爽视频 | 真人与拘做受免费视频 | 久久久久久亚洲精品a片成人 | 国产成人无码av片在线观看不卡 | aⅴ亚洲 日韩 色 图网站 播放 | 欧美日韩在线亚洲综合国产人 | 天天摸天天透天天添 | 中文字幕乱码中文乱码51精品 | 久久国产36精品色熟妇 | 成在人线av无码免费 | 国产精品久久国产三级国 | 日本大香伊一区二区三区 | 帮老师解开蕾丝奶罩吸乳网站 | 美女张开腿让人桶 | 久久精品人人做人人综合 | 天天躁夜夜躁狠狠是什么心态 | 成人性做爰aaa片免费看 | 国产精品对白交换视频 | 成人性做爰aaa片免费看不忠 | 日韩 欧美 动漫 国产 制服 | √8天堂资源地址中文在线 | 欧美激情综合亚洲一二区 | 午夜成人1000部免费视频 | 亚洲精品国产第一综合99久久 | 国产欧美熟妇另类久久久 | 东北女人啪啪对白 | 日本www一道久久久免费榴莲 | 性做久久久久久久久 | 久久国产自偷自偷免费一区调 | 少妇性俱乐部纵欲狂欢电影 | 亚洲日韩av一区二区三区中文 | 欧美刺激性大交 | а√天堂www在线天堂小说 | 欧美丰满少妇xxxx性 | 伊人久久大香线蕉午夜 | 亚洲爆乳精品无码一区二区三区 | 亚洲gv猛男gv无码男同 | 双乳奶水饱满少妇呻吟 | 99久久无码一区人妻 | 国产xxx69麻豆国语对白 | 亚洲日本va午夜在线电影 | 动漫av一区二区在线观看 | 久久久久成人精品免费播放动漫 | 亚洲毛片av日韩av无码 | 免费人成在线视频无码 | 欧美国产亚洲日韩在线二区 | 日本大乳高潮视频在线观看 | 欧美大屁股xxxxhd黑色 | 久久精品女人天堂av免费观看 | 国产无套粉嫩白浆在线 | 欧美人与物videos另类 | 乱码av麻豆丝袜熟女系列 | 中文字幕无码免费久久99 | 天天躁夜夜躁狠狠是什么心态 | 女人和拘做爰正片视频 | 国产成人无码午夜视频在线观看 | 少妇人妻大乳在线视频 | 午夜精品久久久久久久 | 亚洲精品一区三区三区在线观看 | 中文字幕乱妇无码av在线 | 鲁大师影院在线观看 | 天天综合网天天综合色 | 中文字幕无码av波多野吉衣 | 人妻天天爽夜夜爽一区二区 | 日本丰满护士爆乳xxxx | 国产午夜无码精品免费看 | 亚洲一区二区三区在线观看网站 | 国产成人午夜福利在线播放 | 任你躁在线精品免费 | 亚洲日本va午夜在线电影 | 男女作爱免费网站 | 日韩av无码一区二区三区 | 亚洲va中文字幕无码久久不卡 | 亚洲成av人综合在线观看 | 国产性生交xxxxx无码 | 无码人妻丰满熟妇区毛片18 | 国产精品国产三级国产专播 | 国产人妻人伦精品1国产丝袜 | 国产无av码在线观看 | 中文亚洲成a人片在线观看 | 亚洲天堂2017无码中文 | 天天躁夜夜躁狠狠是什么心态 | 亚洲欧洲中文日韩av乱码 | 国产精品99久久精品爆乳 | 国产av一区二区精品久久凹凸 | 中文字幕av无码一区二区三区电影 | 天天av天天av天天透 | 精品无码国产自产拍在线观看蜜 | 激情五月综合色婷婷一区二区 | 亚无码乱人伦一区二区 | 久久国产精品二国产精品 | 波多野结衣aⅴ在线 | 久久婷婷五月综合色国产香蕉 | 亚洲日本一区二区三区在线 | 欧洲欧美人成视频在线 | 日日噜噜噜噜夜夜爽亚洲精品 | 色窝窝无码一区二区三区色欲 | 蜜桃视频插满18在线观看 | 亚洲精品久久久久avwww潮水 | 久久人人爽人人人人片 | 国产成人无码a区在线观看视频app | 亚洲精品一区二区三区婷婷月 | 双乳奶水饱满少妇呻吟 | 午夜精品一区二区三区在线观看 | 综合网日日天干夜夜久久 | 日韩成人一区二区三区在线观看 | 特黄特色大片免费播放器图片 | 丝袜足控一区二区三区 | 欧美xxxx黑人又粗又长 | 精品一区二区不卡无码av | 99久久99久久免费精品蜜桃 | 99riav国产精品视频 | 乱人伦人妻中文字幕无码 | 欧美野外疯狂做受xxxx高潮 | 四虎国产精品一区二区 | 无套内射视频囯产 | 高清无码午夜福利视频 | 永久免费观看美女裸体的网站 | 国产亲子乱弄免费视频 | 国产精品对白交换视频 | 欧美日韩久久久精品a片 | 国产婷婷色一区二区三区在线 | 欧美乱妇无乱码大黄a片 | 久青草影院在线观看国产 | 东京热无码av男人的天堂 | 久久久久se色偷偷亚洲精品av | 日韩人妻系列无码专区 | 亚洲区欧美区综合区自拍区 | 欧美国产日韩久久mv | 正在播放东北夫妻内射 | 国产激情一区二区三区 | 久久国产36精品色熟妇 | 国产一区二区三区影院 | 18禁止看的免费污网站 | 亚洲 日韩 欧美 成人 在线观看 | 午夜无码区在线观看 | 少妇一晚三次一区二区三区 | 国产精品久久国产三级国 | 亚拍精品一区二区三区探花 | 青草青草久热国产精品 | www一区二区www免费 | 四虎国产精品一区二区 | 日韩视频 中文字幕 视频一区 | 欧美兽交xxxx×视频 | 无码福利日韩神码福利片 | 精品国产乱码久久久久乱码 | 午夜福利一区二区三区在线观看 | 成在人线av无码免费 | 久久这里只有精品视频9 | 亚洲精品中文字幕乱码 | 精品国产乱码久久久久乱码 | 日韩少妇白浆无码系列 | 国产精品毛片一区二区 | 精品国产福利一区二区 | 国产电影无码午夜在线播放 | 成人aaa片一区国产精品 | 国产一区二区三区影院 | 国产超碰人人爽人人做人人添 | 久久久婷婷五月亚洲97号色 | 少妇性俱乐部纵欲狂欢电影 | 少妇性l交大片欧洲热妇乱xxx | 老司机亚洲精品影院无码 | 国产成人精品久久亚洲高清不卡 | 青青草原综合久久大伊人精品 | 久久国产精品二国产精品 | 未满小14洗澡无码视频网站 | 久精品国产欧美亚洲色aⅴ大片 | 骚片av蜜桃精品一区 | 天堂亚洲免费视频 | 国产明星裸体无码xxxx视频 | 97夜夜澡人人双人人人喊 | 999久久久国产精品消防器材 | 荫蒂添的好舒服视频囗交 | 精品国产福利一区二区 | 天堂无码人妻精品一区二区三区 | 在线观看免费人成视频 | 国产精品嫩草久久久久 | 国产小呦泬泬99精品 | 亚洲毛片av日韩av无码 | 乱人伦人妻中文字幕无码 | 野外少妇愉情中文字幕 | 久久伊人色av天堂九九小黄鸭 | 精品国产一区二区三区av 性色 | 国产精品嫩草久久久久 | 麻豆国产丝袜白领秘书在线观看 | 日韩 欧美 动漫 国产 制服 | 麻豆国产人妻欲求不满 | 亚洲 高清 成人 动漫 | 中文字幕无码av波多野吉衣 | 四虎4hu永久免费 | 美女毛片一区二区三区四区 | 曰韩少妇内射免费播放 | 伊人久久大香线蕉午夜 | 久久人人97超碰a片精品 | 俺去俺来也www色官网 | 亚洲色无码一区二区三区 | 波多野42部无码喷潮在线 | 天天爽夜夜爽夜夜爽 | 性色av无码免费一区二区三区 | 精品国精品国产自在久国产87 | 亚洲综合另类小说色区 | 性色欲网站人妻丰满中文久久不卡 | 亚洲精品国偷拍自产在线观看蜜桃 | 内射白嫩少妇超碰 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产成人综合在线女婷五月99播放 | 又色又爽又黄的美女裸体网站 | 300部国产真实乱 | 国产精品第一国产精品 | 人妻天天爽夜夜爽一区二区 | 亚无码乱人伦一区二区 | 国产精品美女久久久久av爽李琼 | 无码人妻出轨黑人中文字幕 | 亚洲乱亚洲乱妇50p | 精品成人av一区二区三区 | av无码不卡在线观看免费 | 国产精品免费大片 | www国产亚洲精品久久久日本 | 亚洲一区二区三区四区 | 少妇性l交大片欧洲热妇乱xxx | 伊人久久婷婷五月综合97色 | 国产做国产爱免费视频 | 扒开双腿疯狂进出爽爽爽视频 | 婷婷五月综合激情中文字幕 | 国产激情无码一区二区 | 九九久久精品国产免费看小说 | 欧美性猛交xxxx富婆 | 2019午夜福利不卡片在线 | 免费人成在线视频无码 | 极品尤物被啪到呻吟喷水 | 人妻互换免费中文字幕 | 久久亚洲日韩精品一区二区三区 | 东京无码熟妇人妻av在线网址 | 老太婆性杂交欧美肥老太 | 双乳奶水饱满少妇呻吟 | 性生交片免费无码看人 | 人人妻人人澡人人爽人人精品 | 永久黄网站色视频免费直播 | 国产av一区二区三区最新精品 | 正在播放老肥熟妇露脸 | 内射欧美老妇wbb | 亚洲国产午夜精品理论片 | 窝窝午夜理论片影院 | 日韩无套无码精品 | 国产超级va在线观看视频 | 99在线 | 亚洲 | 狠狠色欧美亚洲狠狠色www | 日本大乳高潮视频在线观看 | 欧美精品无码一区二区三区 | 伊人色综合久久天天小片 | 少妇人妻偷人精品无码视频 | 亚洲精品国产a久久久久久 | 丰满少妇高潮惨叫视频 | 99精品无人区乱码1区2区3区 | 妺妺窝人体色www婷婷 | 国产麻豆精品精东影业av网站 | 午夜精品久久久内射近拍高清 | 亚洲成色www久久网站 | 国产午夜福利亚洲第一 | 美女黄网站人色视频免费国产 | 成人亚洲精品久久久久 | 亚洲人亚洲人成电影网站色 | 亚洲自偷精品视频自拍 | 帮老师解开蕾丝奶罩吸乳网站 | 久久无码中文字幕免费影院蜜桃 | 日日摸天天摸爽爽狠狠97 | 亚洲理论电影在线观看 | 亚洲国产精品无码久久久久高潮 | 精品 日韩 国产 欧美 视频 | 女人被男人爽到呻吟的视频 | 国产舌乚八伦偷品w中 | 久久久中文字幕日本无吗 | 色一情一乱一伦一区二区三欧美 | 在线a亚洲视频播放在线观看 | 无码一区二区三区在线观看 | 久久久www成人免费毛片 | 又湿又紧又大又爽a视频国产 | 亚洲精品一区二区三区四区五区 | 精品欧美一区二区三区久久久 | 久久无码人妻影院 | 一个人看的www免费视频在线观看 | 精品成在人线av无码免费看 | 夜先锋av资源网站 | 国产高清不卡无码视频 | 夜夜影院未满十八勿进 | 国产成人精品三级麻豆 | 午夜熟女插插xx免费视频 | 熟妇人妻激情偷爽文 | 国内综合精品午夜久久资源 | 福利一区二区三区视频在线观看 | 思思久久99热只有频精品66 | 给我免费的视频在线观看 | 亚洲日韩中文字幕在线播放 | 久久伊人色av天堂九九小黄鸭 | 99久久精品国产一区二区蜜芽 | 亚洲日本va午夜在线电影 | 色欲久久久天天天综合网精品 | ass日本丰满熟妇pics | 麻豆蜜桃av蜜臀av色欲av | 亚洲精品一区三区三区在线观看 | 窝窝午夜理论片影院 | 老熟女乱子伦 | 又湿又紧又大又爽a视频国产 | 男女下面进入的视频免费午夜 | 老子影院午夜精品无码 | 丰满少妇女裸体bbw | 老司机亚洲精品影院 | 亚洲无人区一区二区三区 | 任你躁国产自任一区二区三区 | 精品亚洲韩国一区二区三区 | 成人试看120秒体验区 | 人妻互换免费中文字幕 | 乱码av麻豆丝袜熟女系列 | 国产成人无码专区 | 精品久久久久久人妻无码中文字幕 | 无码人妻精品一区二区三区不卡 | 强奷人妻日本中文字幕 | 四十如虎的丰满熟妇啪啪 | 午夜肉伦伦影院 | 国产亚洲精品久久久ai换 | 免费人成在线观看网站 | 国产精品爱久久久久久久 | 给我免费的视频在线观看 | 伊人色综合久久天天小片 | 日本一卡2卡3卡四卡精品网站 | av无码久久久久不卡免费网站 | 97久久超碰中文字幕 | 午夜丰满少妇性开放视频 | 黑森林福利视频导航 | 亚洲人交乣女bbw | 亚洲精品美女久久久久久久 | 亚洲国产成人av在线观看 | 男人的天堂2018无码 | 强奷人妻日本中文字幕 | 午夜男女很黄的视频 | 国产亚洲精品久久久久久久 | 乱码av麻豆丝袜熟女系列 | 久久天天躁夜夜躁狠狠 | 夜夜夜高潮夜夜爽夜夜爰爰 | 乱人伦人妻中文字幕无码久久网 | 日本精品少妇一区二区三区 | 大乳丰满人妻中文字幕日本 | 亚洲国产精品成人久久蜜臀 | 蜜桃视频韩日免费播放 | 精品无人区无码乱码毛片国产 | 国产美女精品一区二区三区 | 九九热爱视频精品 | 欧美人与善在线com | 色综合久久久无码中文字幕 | 欧美性生交活xxxxxdddd | 亚洲日韩一区二区 | 精品国产精品久久一区免费式 | 精品国产一区av天美传媒 | 宝宝好涨水快流出来免费视频 | 亚洲七七久久桃花影院 | 麻豆果冻传媒2021精品传媒一区下载 | 无码一区二区三区在线观看 | 亚洲熟妇自偷自拍另类 | 九月婷婷人人澡人人添人人爽 | 精品欧洲av无码一区二区三区 | 少妇性俱乐部纵欲狂欢电影 | 欧美午夜特黄aaaaaa片 | 日韩亚洲欧美中文高清在线 | 亚洲男人av天堂午夜在 | 精品一区二区三区波多野结衣 | 在线播放无码字幕亚洲 | 国产在线无码精品电影网 | 日本高清一区免费中文视频 | 少妇性俱乐部纵欲狂欢电影 | 久久久久久久久蜜桃 | 亚洲精品一区二区三区在线观看 | 色五月五月丁香亚洲综合网 | 成人试看120秒体验区 | 特级做a爰片毛片免费69 | 国产精品多人p群无码 | 沈阳熟女露脸对白视频 | 国产色xx群视频射精 | 国产精品亚洲а∨无码播放麻豆 | 无码av中文字幕免费放 | 欧美熟妇另类久久久久久多毛 | 国语精品一区二区三区 | 又大又紧又粉嫩18p少妇 | 成人av无码一区二区三区 | 国内揄拍国内精品少妇国语 | 亚洲人成网站在线播放942 | 51国偷自产一区二区三区 | 综合网日日天干夜夜久久 | 正在播放东北夫妻内射 | 国产亚洲精品久久久ai换 | 国产免费久久久久久无码 | 亚洲人成无码网www | 国产猛烈高潮尖叫视频免费 | 精品一区二区三区无码免费视频 | 激情国产av做激情国产爱 | 久久zyz资源站无码中文动漫 | 国产精品久久久久无码av色戒 | 亚洲日韩一区二区三区 | 久精品国产欧美亚洲色aⅴ大片 | 日韩人妻少妇一区二区三区 | 十八禁视频网站在线观看 | 国产精品二区一区二区aⅴ污介绍 | 在线亚洲高清揄拍自拍一品区 | 亚洲精品成a人在线观看 | 国产精品久久久久久亚洲影视内衣 | 国产麻豆精品精东影业av网站 | 老太婆性杂交欧美肥老太 | 色一情一乱一伦一视频免费看 | 久久精品国产精品国产精品污 | 欧美激情综合亚洲一二区 | 在线天堂新版最新版在线8 | 国产亚洲精品久久久闺蜜 | 欧美日韩久久久精品a片 | 在线看片无码永久免费视频 | 日韩精品成人一区二区三区 | 在线天堂新版最新版在线8 | 风流少妇按摩来高潮 | 少妇太爽了在线观看 | 日本一卡2卡3卡四卡精品网站 | 国产偷国产偷精品高清尤物 | 俺去俺来也在线www色官网 | 清纯唯美经典一区二区 | 亚洲精品一区二区三区大桥未久 | 高清国产亚洲精品自在久久 | 国产亚洲人成a在线v网站 | 曰本女人与公拘交酡免费视频 | 国产精品成人av在线观看 | 中文字幕无码av激情不卡 | 日韩精品无码免费一区二区三区 | 欧美老妇与禽交 | 露脸叫床粗话东北少妇 | 久久综合九色综合欧美狠狠 | 亚洲成熟女人毛毛耸耸多 | 日日摸夜夜摸狠狠摸婷婷 | 国产精品igao视频网 | 亚洲精品国产a久久久久久 | 男人和女人高潮免费网站 | 日本一区二区三区免费播放 | 久久久久国色av免费观看性色 | 国内精品九九久久久精品 | 日本丰满护士爆乳xxxx | 亚洲大尺度无码无码专区 | 精品无码一区二区三区爱欲 | 少妇被黑人到高潮喷出白浆 | 性啪啪chinese东北女人 | 无码毛片视频一区二区本码 | 中文字幕+乱码+中文字幕一区 | 国产sm调教视频在线观看 | 国产精品办公室沙发 | 欧美精品国产综合久久 | 在线亚洲高清揄拍自拍一品区 | 色婷婷av一区二区三区之红樱桃 | 精品一区二区三区波多野结衣 | 天海翼激烈高潮到腰振不止 | 国精产品一品二品国精品69xx | 日日橹狠狠爱欧美视频 | 亚洲无人区午夜福利码高清完整版 | 理论片87福利理论电影 | 性色欲网站人妻丰满中文久久不卡 | 大胆欧美熟妇xx | 中文字幕乱码中文乱码51精品 | 麻豆av传媒蜜桃天美传媒 | 亚洲熟妇自偷自拍另类 | 亚洲精品中文字幕乱码 | 久久国产精品_国产精品 | 国产真实乱对白精彩久久 | 久久综合久久自在自线精品自 | 色老头在线一区二区三区 | 日本丰满护士爆乳xxxx | 国产av一区二区精品久久凹凸 | 97人妻精品一区二区三区 | 西西人体www44rt大胆高清 | 日韩精品无码免费一区二区三区 | 亚洲国产精华液网站w | 嫩b人妻精品一区二区三区 | 国产卡一卡二卡三 | 久久久久亚洲精品中文字幕 | 午夜成人1000部免费视频 | 成在人线av无码免观看麻豆 | 国产精品香蕉在线观看 | 日本乱偷人妻中文字幕 | 精品一区二区三区无码免费视频 | 偷窥日本少妇撒尿chinese | 国产亚洲精品久久久久久久 | 在线观看国产一区二区三区 | 亚洲国产一区二区三区在线观看 | 亚洲男女内射在线播放 | 久9re热视频这里只有精品 | 久久精品中文字幕大胸 | 熟妇人妻无乱码中文字幕 | 国内丰满熟女出轨videos | 国产精品国产三级国产专播 | 午夜精品一区二区三区的区别 | 日韩欧美中文字幕公布 | 无码精品国产va在线观看dvd | 麻豆蜜桃av蜜臀av色欲av | 在线观看欧美一区二区三区 | 日韩成人一区二区三区在线观看 | 天海翼激烈高潮到腰振不止 | 国内老熟妇对白xxxxhd | 强奷人妻日本中文字幕 | 久久综合给久久狠狠97色 | 欧美老妇交乱视频在线观看 | 黑人玩弄人妻中文在线 | 亚洲国产高清在线观看视频 | 日日噜噜噜噜夜夜爽亚洲精品 | 日本熟妇人妻xxxxx人hd | √天堂资源地址中文在线 | 永久免费观看美女裸体的网站 | 波多野结衣乳巨码无在线观看 | 99久久精品午夜一区二区 | 久久无码中文字幕免费影院蜜桃 | 国产精品无套呻吟在线 | 人人澡人人透人人爽 | 久久aⅴ免费观看 | 日本一卡二卡不卡视频查询 | 狠狠cao日日穞夜夜穞av | 午夜肉伦伦影院 | 亚洲精品无码人妻无码 | 亚洲精品一区二区三区四区五区 | 国产精品美女久久久网av | 欧美三级不卡在线观看 | 中国女人内谢69xxxx | 学生妹亚洲一区二区 | 亚洲色成人中文字幕网站 | 中文字幕无码日韩欧毛 | 在线精品国产一区二区三区 | 久久久精品国产sm最大网站 | 亚洲欧美精品aaaaaa片 | 特级做a爰片毛片免费69 | 国产免费观看黄av片 | 免费看少妇作爱视频 | 国产成人精品久久亚洲高清不卡 | 国产免费久久精品国产传媒 | 亚洲精品中文字幕 | 国产美女极度色诱视频www | 国产人妻精品一区二区三区 | 在线精品亚洲一区二区 | 国产性生大片免费观看性 | 久久成人a毛片免费观看网站 | 无码av中文字幕免费放 | 国产办公室秘书无码精品99 | 夜夜躁日日躁狠狠久久av | 色欲综合久久中文字幕网 | 中文字幕 人妻熟女 | 国产亚洲人成a在线v网站 | 亚洲成a人片在线观看日本 | 免费视频欧美无人区码 | 少妇人妻偷人精品无码视频 | 久久精品人人做人人综合 | 澳门永久av免费网站 | 最新国产麻豆aⅴ精品无码 | 久久国产精品二国产精品 | 欧美熟妇另类久久久久久多毛 | 国产精品久久久av久久久 | av小次郎收藏 | 亚洲中文字幕无码中文字在线 | 久久精品一区二区三区四区 | 中文字幕无码av激情不卡 | 欧美日韩一区二区三区自拍 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲中文字幕乱码av波多ji | 一本无码人妻在中文字幕免费 | 六十路熟妇乱子伦 | 2020最新国产自产精品 | 少妇久久久久久人妻无码 | 欧美熟妇另类久久久久久多毛 | a国产一区二区免费入口 | 精品国产精品久久一区免费式 | 亚洲精品成人福利网站 | 99久久人妻精品免费二区 | 亚洲s色大片在线观看 | 国产精品18久久久久久麻辣 | 水蜜桃色314在线观看 | 午夜嘿嘿嘿影院 | 无码精品人妻一区二区三区av | 四虎国产精品一区二区 | 精品成在人线av无码免费看 | 成人片黄网站色大片免费观看 | www一区二区www免费 | 玩弄中年熟妇正在播放 | 国产人妖乱国产精品人妖 | 国产人成高清在线视频99最全资源 | 色妞www精品免费视频 | 大屁股大乳丰满人妻 | 99精品视频在线观看免费 | 欧美人与禽猛交狂配 | 国产成人无码a区在线观看视频app | 亚洲天堂2017无码中文 | 国产麻豆精品一区二区三区v视界 | 十八禁视频网站在线观看 | 性欧美videos高清精品 | 国产av无码专区亚洲awww | 一本久久a久久精品亚洲 | 成人无码精品一区二区三区 | 无码帝国www无码专区色综合 | 美女扒开屁股让男人桶 | 国产在线aaa片一区二区99 | 成人一区二区免费视频 | а√天堂www在线天堂小说 | 国产成人无码专区 | 领导边摸边吃奶边做爽在线观看 | 国产精品人妻一区二区三区四 | 国产热a欧美热a在线视频 | 亚洲s色大片在线观看 | 国产特级毛片aaaaaaa高清 | 国产精品亚洲一区二区三区喷水 | 99re在线播放 | 国产精品igao视频网 | 午夜精品一区二区三区在线观看 | 中文毛片无遮挡高清免费 | 亚洲七七久久桃花影院 | 中文字幕乱码亚洲无线三区 | 在线精品国产一区二区三区 | 日本又色又爽又黄的a片18禁 | 黑人巨大精品欧美一区二区 | 亚洲性无码av中文字幕 | 亚洲欧美精品伊人久久 | 国产无遮挡又黄又爽又色 | 撕开奶罩揉吮奶头视频 | 亚洲综合另类小说色区 | 国产亚洲精品精品国产亚洲综合 | 国产极品美女高潮无套在线观看 | 国产成人无码a区在线观看视频app | 桃花色综合影院 | 免费视频欧美无人区码 | 成人av无码一区二区三区 | 97人妻精品一区二区三区 | 狠狠综合久久久久综合网 | 一本久道久久综合狠狠爱 | 国产在线aaa片一区二区99 | 成人无码视频免费播放 | 免费观看激色视频网站 | 国产精品第一区揄拍无码 | 天堂在线观看www | 午夜精品久久久内射近拍高清 | 97夜夜澡人人双人人人喊 | 成人免费视频在线观看 | 久久99精品久久久久久动态图 | 亚洲欧美色中文字幕在线 | 麻豆国产人妻欲求不满 | 国产肉丝袜在线观看 | 精品久久久中文字幕人妻 | www国产亚洲精品久久久日本 | 精品国产成人一区二区三区 | 色一情一乱一伦一区二区三欧美 | 在线看片无码永久免费视频 | 久久精品中文闷骚内射 | 久久97精品久久久久久久不卡 | 欧美三级a做爰在线观看 | 中国大陆精品视频xxxx | 久久国产精品二国产精品 | 天堂亚洲2017在线观看 | 亚洲热妇无码av在线播放 | 国产凸凹视频一区二区 | 18禁黄网站男男禁片免费观看 | 精品欧美一区二区三区久久久 | 午夜时刻免费入口 | 无码国内精品人妻少妇 | 国产口爆吞精在线视频 | 国产尤物精品视频 | 亚洲精品国产第一综合99久久 | 少妇性俱乐部纵欲狂欢电影 | 麻豆国产丝袜白领秘书在线观看 | 久久综合香蕉国产蜜臀av | 久久精品中文字幕大胸 | 国产亚洲精品久久久闺蜜 | 亚洲一区二区三区在线观看网站 | 久久国产精品偷任你爽任你 | 男女下面进入的视频免费午夜 | 免费乱码人妻系列无码专区 | 欧美激情一区二区三区成人 | 日韩亚洲欧美精品综合 | 亚洲国产精品美女久久久久 | 日本一区二区三区免费高清 | 青青青爽视频在线观看 | 一本大道伊人av久久综合 | 国产精品内射视频免费 | 日韩成人一区二区三区在线观看 | 无码精品人妻一区二区三区av | 亚洲熟悉妇女xxx妇女av | 久久久久se色偷偷亚洲精品av | 无码精品国产va在线观看dvd | 久久视频在线观看精品 | 精品偷拍一区二区三区在线看 | 欧美国产亚洲日韩在线二区 | 伊人色综合久久天天小片 | 高清无码午夜福利视频 | 国产电影无码午夜在线播放 | 亚洲男女内射在线播放 | 中文字幕色婷婷在线视频 | 久久久久久国产精品无码下载 | 亚洲日韩一区二区三区 | 性欧美牲交xxxxx视频 | 久久综合给久久狠狠97色 | 成人试看120秒体验区 | 天堂无码人妻精品一区二区三区 | 国产小呦泬泬99精品 | 精品无人国产偷自产在线 | 少妇久久久久久人妻无码 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲精品中文字幕 | 国产无遮挡又黄又爽又色 | 久久久国产精品无码免费专区 | 天天躁夜夜躁狠狠是什么心态 | 久在线观看福利视频 | 国产欧美精品一区二区三区 | 亚洲日韩av一区二区三区四区 | 国产超碰人人爽人人做人人添 | 18黄暴禁片在线观看 | 亚洲无人区午夜福利码高清完整版 | 97无码免费人妻超级碰碰夜夜 | 日韩精品无码免费一区二区三区 | 亚洲国产成人av在线观看 | 国产无遮挡又黄又爽又色 | 婷婷综合久久中文字幕蜜桃三电影 | 又湿又紧又大又爽a视频国产 | 国产av一区二区三区最新精品 | 97无码免费人妻超级碰碰夜夜 | 国内综合精品午夜久久资源 | 99久久亚洲精品无码毛片 | 大乳丰满人妻中文字幕日本 | 免费无码一区二区三区蜜桃大 | 全黄性性激高免费视频 | 午夜熟女插插xx免费视频 | 特大黑人娇小亚洲女 | 精品一区二区三区无码免费视频 | 风流少妇按摩来高潮 | 全球成人中文在线 | 天堂一区人妻无码 | 国产在线一区二区三区四区五区 | 久久午夜无码鲁丝片秋霞 | 亚洲精品www久久久 | 俺去俺来也在线www色官网 | 中文毛片无遮挡高清免费 | 2019午夜福利不卡片在线 | 亚洲日韩中文字幕在线播放 | 4hu四虎永久在线观看 | 99精品国产综合久久久久五月天 | 国产精品人人爽人人做我的可爱 | 国内丰满熟女出轨videos | 久久久久国色av免费观看性色 | 精品无码一区二区三区爱欲 | 福利一区二区三区视频在线观看 | 天海翼激烈高潮到腰振不止 | 亚洲综合久久一区二区 | 免费看少妇作爱视频 | 国产舌乚八伦偷品w中 | 日日麻批免费40分钟无码 | 人人妻人人澡人人爽欧美精品 | 性生交大片免费看l | 国产精品爱久久久久久久 | 亚洲国产精品无码一区二区三区 | 中文亚洲成a人片在线观看 | 无码成人精品区在线观看 | 欧美国产亚洲日韩在线二区 | 亚洲中文字幕无码中文字在线 | 久久视频在线观看精品 | 欧美日韩久久久精品a片 | 亚洲高清偷拍一区二区三区 | 欧美国产日韩久久mv | 黑人粗大猛烈进出高潮视频 | 国产免费观看黄av片 | 成人aaa片一区国产精品 | 中文字幕av伊人av无码av | 内射爽无广熟女亚洲 | 国产日产欧产精品精品app | 狠狠色丁香久久婷婷综合五月 | 国产精品人人妻人人爽 | 男人扒开女人内裤强吻桶进去 | 欧美性色19p | 久久国产精品精品国产色婷婷 | 婷婷丁香六月激情综合啪 | 特大黑人娇小亚洲女 | 成人影院yy111111在线观看 | 国产9 9在线 | 中文 | 玩弄人妻少妇500系列视频 | 欧美怡红院免费全部视频 | 国产 浪潮av性色四虎 | 国产无遮挡又黄又爽又色 | 欧美性猛交xxxx富婆 | 国产精品资源一区二区 | 国产女主播喷水视频在线观看 | 中文字幕人妻无码一夲道 | 亚洲爆乳大丰满无码专区 | 999久久久国产精品消防器材 | 双乳奶水饱满少妇呻吟 | 亚洲狠狠婷婷综合久久 | 亚洲精品国产品国语在线观看 | 奇米影视7777久久精品人人爽 | 99久久久无码国产aaa精品 | 性生交大片免费看l | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 午夜性刺激在线视频免费 | 中文字幕精品av一区二区五区 | 国产精品国产自线拍免费软件 | 亚洲欧美国产精品久久 | 欧美人妻一区二区三区 | 国产精品va在线播放 | 亚洲国产欧美国产综合一区 | 中文字幕精品av一区二区五区 | 色欲av亚洲一区无码少妇 | ass日本丰满熟妇pics | 2019nv天堂香蕉在线观看 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲国产日韩a在线播放 | 国产在线精品一区二区三区直播 | 天堂一区人妻无码 | 天堂无码人妻精品一区二区三区 | 大胆欧美熟妇xx | 欧美精品无码一区二区三区 | 日韩亚洲欧美中文高清在线 | 特黄特色大片免费播放器图片 | 国产电影无码午夜在线播放 | 欧美变态另类xxxx | 成 人 网 站国产免费观看 | 少妇性荡欲午夜性开放视频剧场 | 欧美老人巨大xxxx做受 | 国产成人综合色在线观看网站 | 伊人久久大香线焦av综合影院 | 久久人人爽人人爽人人片av高清 | 高潮毛片无遮挡高清免费 | 国产特级毛片aaaaaa高潮流水 | 欧美黑人巨大xxxxx | 午夜性刺激在线视频免费 | 性欧美牲交xxxxx视频 | 天天爽夜夜爽夜夜爽 | 性欧美videos高清精品 | 亚洲成色www久久网站 | 亚洲の无码国产の无码步美 | 98国产精品综合一区二区三区 | 小sao货水好多真紧h无码视频 | 久久精品人妻少妇一区二区三区 | 99国产欧美久久久精品 | 中文字幕av无码一区二区三区电影 | 精品国产国产综合精品 | 国产精品成人av在线观看 | 在线成人www免费观看视频 | 婷婷综合久久中文字幕蜜桃三电影 | 最新国产麻豆aⅴ精品无码 | 亚洲a无码综合a国产av中文 | 精品人妻av区 | 国产情侣作爱视频免费观看 | 中国女人内谢69xxxx | 在线成人www免费观看视频 | 高清不卡一区二区三区 | a在线观看免费网站大全 | 内射爽无广熟女亚洲 | 亚洲大尺度无码无码专区 | 呦交小u女精品视频 | 久久久精品国产sm最大网站 | 牛和人交xxxx欧美 | 99久久久无码国产aaa精品 | 99久久无码一区人妻 | 99久久精品日本一区二区免费 | 日韩av激情在线观看 | 东京无码熟妇人妻av在线网址 | 国产va免费精品观看 | 欧美性生交xxxxx久久久 | 亚洲精品鲁一鲁一区二区三区 | 女人被爽到呻吟gif动态图视看 | 亚洲精品国产精品乱码视色 | 亚洲精品一区二区三区在线 | 国产精品亚洲lv粉色 | 亚洲の无码国产の无码步美 | 亚洲日韩一区二区三区 | 欧美日韩色另类综合 | 我要看www免费看插插视频 | 99久久精品午夜一区二区 | 久久精品99久久香蕉国产色戒 | 国内精品久久久久久中文字幕 | 国产猛烈高潮尖叫视频免费 | 亚洲日本一区二区三区在线 | 成人无码影片精品久久久 | 香蕉久久久久久av成人 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲 a v无 码免 费 成 人 a v | 亚洲乱码中文字幕在线 | 亚洲精品久久久久中文第一幕 | 狠狠综合久久久久综合网 | 日韩av无码一区二区三区 | 激情亚洲一区国产精品 | 国产精品亚洲а∨无码播放麻豆 | 精品欧美一区二区三区久久久 | 国产亚洲美女精品久久久2020 | 初尝人妻少妇中文字幕 | 强辱丰满人妻hd中文字幕 | 亚洲色偷偷男人的天堂 | 一本无码人妻在中文字幕免费 | www国产亚洲精品久久久日本 | 久久久婷婷五月亚洲97号色 | 亚洲国产成人av在线观看 | 午夜熟女插插xx免费视频 | 国产亚洲精品久久久ai换 | 精品久久8x国产免费观看 | 婷婷综合久久中文字幕蜜桃三电影 | 男女爱爱好爽视频免费看 | 日韩精品久久久肉伦网站 | 曰韩无码二三区中文字幕 | 国产内射爽爽大片视频社区在线 | 欧美成人高清在线播放 | www成人国产高清内射 | 精品无码国产一区二区三区av | 国产香蕉97碰碰久久人人 | 激情爆乳一区二区三区 | 国产av一区二区精品久久凹凸 | 欧美野外疯狂做受xxxx高潮 | 在线视频网站www色 | 国产9 9在线 | 中文 | 精品成人av一区二区三区 | 奇米影视7777久久精品人人爽 | 欧美国产日产一区二区 | 精品国产av色一区二区深夜久久 | 特级做a爰片毛片免费69 | 99久久精品国产一区二区蜜芽 | 精品久久综合1区2区3区激情 | 国精产品一区二区三区 | 国产乡下妇女做爰 | 成在人线av无码免观看麻豆 | 国产成人精品视频ⅴa片软件竹菊 | 中文字幕人妻丝袜二区 | 装睡被陌生人摸出水好爽 | 亚洲の无码国产の无码影院 | 77777熟女视频在线观看 а天堂中文在线官网 | 精品国产一区二区三区四区 | 亚洲精品一区二区三区婷婷月 | 蜜臀aⅴ国产精品久久久国产老师 | 偷窥村妇洗澡毛毛多 | 在线a亚洲视频播放在线观看 | 精品国产aⅴ无码一区二区 | 国产成人精品无码播放 | 任你躁国产自任一区二区三区 | 国产情侣作爱视频免费观看 | 亚洲国产成人av在线观看 | 少妇人妻偷人精品无码视频 | 无码一区二区三区在线 | 欧美日韩色另类综合 | 久久成人a毛片免费观看网站 | 欧美国产日产一区二区 | 中文字幕中文有码在线 | 国产无套粉嫩白浆在线 | 久在线观看福利视频 | 久久国产精品_国产精品 | 人妻插b视频一区二区三区 | 无码国产色欲xxxxx视频 | 国产精品无码一区二区桃花视频 | 国产一区二区三区日韩精品 | 婷婷色婷婷开心五月四房播播 | 国产成人无码区免费内射一片色欲 | 亚洲精品一区二区三区四区五区 | 成人亚洲精品久久久久软件 | 人人妻人人藻人人爽欧美一区 | 国产69精品久久久久app下载 | 亚洲综合伊人久久大杳蕉 | 精品国产一区av天美传媒 | 欧美日韩一区二区三区自拍 | 人妻天天爽夜夜爽一区二区 | 中文字幕色婷婷在线视频 | 无遮挡国产高潮视频免费观看 | 国产卡一卡二卡三 | 亚洲色偷偷男人的天堂 | 精品无码一区二区三区爱欲 | 国产在线一区二区三区四区五区 | 国产人成高清在线视频99最全资源 | 老头边吃奶边弄进去呻吟 | 激情人妻另类人妻伦 | 精品aⅴ一区二区三区 | 一本大道久久东京热无码av | 久激情内射婷内射蜜桃人妖 | v一区无码内射国产 | 成人无码精品一区二区三区 | 欧洲vodafone精品性 | 日韩精品无码一本二本三本色 | 亚洲日韩中文字幕在线播放 | 性开放的女人aaa片 | 乱人伦人妻中文字幕无码 | 少妇邻居内射在线 | 亚洲狠狠婷婷综合久久 | 无码人妻av免费一区二区三区 | 欧美老妇交乱视频在线观看 | 色综合久久久久综合一本到桃花网 | 熟妇人妻无乱码中文字幕 | 国产97色在线 | 免 | 免费乱码人妻系列无码专区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲aⅴ无码成人网站国产app | 女人高潮内射99精品 | 97色伦图片97综合影院 | 精品国产青草久久久久福利 | 亚洲熟悉妇女xxx妇女av | 亚洲乱亚洲乱妇50p | 亚洲精品国偷拍自产在线观看蜜桃 | 撕开奶罩揉吮奶头视频 | 亚洲综合无码一区二区三区 | 日日麻批免费40分钟无码 | 欧美日韩视频无码一区二区三 | 九九热爱视频精品 | 久久久久99精品成人片 | 久久久久人妻一区精品色欧美 | 亚洲一区二区观看播放 | √天堂中文官网8在线 | 国产精华av午夜在线观看 | 亚洲人成网站在线播放942 | 精品人妻人人做人人爽夜夜爽 | 强伦人妻一区二区三区视频18 | 日本熟妇乱子伦xxxx | 中文字幕人妻无码一区二区三区 | 成人欧美一区二区三区黑人免费 | 国产真实乱对白精彩久久 | 国产一区二区三区影院 | 国产超碰人人爽人人做人人添 | 成人精品天堂一区二区三区 | 97久久国产亚洲精品超碰热 | 伦伦影院午夜理论片 | 性做久久久久久久久 | 久久99精品久久久久久动态图 | 国产成人无码av在线影院 | 亚洲精品一区二区三区四区五区 | 极品嫩模高潮叫床 | 国产办公室秘书无码精品99 | 国产激情无码一区二区 | 国产精品久免费的黄网站 | 99久久久无码国产aaa精品 | 7777奇米四色成人眼影 | 夜夜影院未满十八勿进 | 久久99精品国产麻豆蜜芽 | 在线天堂新版最新版在线8 | 综合人妻久久一区二区精品 | 久久亚洲a片com人成 | 无码福利日韩神码福利片 | 18无码粉嫩小泬无套在线观看 | 亚洲gv猛男gv无码男同 | 日韩欧美成人免费观看 | 国产绳艺sm调教室论坛 | 久久视频在线观看精品 | 亚洲 另类 在线 欧美 制服 | 精品久久久无码中文字幕 | 大肉大捧一进一出好爽视频 | 欧美 日韩 人妻 高清 中文 | 少妇性l交大片欧洲热妇乱xxx | 日韩无码专区 | 婷婷综合久久中文字幕蜜桃三电影 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 天堂久久天堂av色综合 | 好爽又高潮了毛片免费下载 | 人妻与老人中文字幕 | 狠狠色丁香久久婷婷综合五月 | 国产成人无码区免费内射一片色欲 | 久久久久久久人妻无码中文字幕爆 | 高清不卡一区二区三区 | 无码毛片视频一区二区本码 | 丰满岳乱妇在线观看中字无码 | 午夜福利不卡在线视频 | 88国产精品欧美一区二区三区 | 日本www一道久久久免费榴莲 | 无码国内精品人妻少妇 | 无码午夜成人1000部免费视频 | yw尤物av无码国产在线观看 | 色老头在线一区二区三区 | 综合网日日天干夜夜久久 | 奇米影视888欧美在线观看 | 亚洲欧美精品aaaaaa片 | 熟女少妇在线视频播放 | 久久久精品456亚洲影院 | 欧美国产日韩久久mv | 久久精品女人天堂av免费观看 | 亚洲人成网站色7799 | 国内精品久久久久久中文字幕 | 欧美性生交xxxxx久久久 | 福利一区二区三区视频在线观看 | 少妇性俱乐部纵欲狂欢电影 | 精品人妻中文字幕有码在线 | 欧美熟妇另类久久久久久多毛 | 大乳丰满人妻中文字幕日本 | 日日天干夜夜狠狠爱 | 久久久久亚洲精品中文字幕 | 嫩b人妻精品一区二区三区 | 精品无码一区二区三区爱欲 |