成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > 詳細(xì)講解HDFS的高可用機(jī)制

詳細(xì)講解HDFS的高可用機(jī)制

熱門標(biāo)簽:隨州銷售外呼系統(tǒng)平臺 寧夏保險智能外呼系統(tǒng)哪家好 怎么更改地圖標(biāo)注電話 臨滄移動外呼系統(tǒng)哪家有 交行外呼系統(tǒng)有哪些 防城港市ai電銷機(jī)器人 不同的地圖標(biāo)注 溫嶺代理外呼系統(tǒng) 激戰(zhàn)黃昏地圖標(biāo)注說明

在Hadoop2.X之前,Namenode是HDFS集群中可能發(fā)生單點(diǎn)故障的節(jié)點(diǎn),每個HDFS集群只有一個namenode,一旦這個節(jié)點(diǎn)不可用,則整個HDFS集群將處于不可用狀態(tài)。
HDFS高可用(HA)方案就是為了解決上述問題而產(chǎn)生的,在HA HDFS集群中會同時運(yùn)行兩個Namenode,一個作為活動的Namenode(Active),一個作為備份的Namenode(Standby)。備份的Namenode的命名空間與活動的Namenode是實時同步的,所以當(dāng)活動的Namenode發(fā)生故障而停止服務(wù)時,備份Namenode可以立即切換為活動狀態(tài),而不影響HDFS集群服務(wù)。

 

在一個HA集群中,會配置兩個獨(dú)立的Namenode。在任意時刻,只有一個節(jié)點(diǎn)作為活動的節(jié)點(diǎn),另一個節(jié)點(diǎn)則處于備份狀態(tài)?;顒拥腘amenode負(fù)責(zé)執(zhí)行所有修改命名空間以及刪除備份數(shù)據(jù)塊的操作,而備份的Namenode則執(zhí)行同步操作,以保持與活動節(jié)點(diǎn)命名空間的一致性。
為了使備份節(jié)點(diǎn)與活動節(jié)點(diǎn)的狀態(tài)能夠同步一致,兩個節(jié)點(diǎn)都需要同一組獨(dú)立運(yùn)行的節(jié)點(diǎn)(JournalNodes,JNS)通信。當(dāng)Active Namenode執(zhí)行了修改命名空間的操作時,它會定期將執(zhí)行的操作記錄在editlog中,并寫入JNS的多數(shù)節(jié)點(diǎn)中。而Standby Namenode會一直監(jiān)聽JNS上editlog的變化,如果發(fā)現(xiàn)editlog有改動,Standby Namenode就會讀取editlog并與當(dāng)前的命名空間合并。當(dāng)發(fā)生了錯誤切換時,Standby節(jié)點(diǎn)會保證已經(jīng)從JNS上讀取了所有editlog并與命名空間合并,然后才會從Standby狀態(tài)切換為Active狀態(tài)。通過這種機(jī)制,保證了Active Namenode與Standby Namenode之間命名空間狀態(tài)的一致性,也就是第一關(guān)系鏈的一致性。
為了使錯誤切換能夠很快的執(zhí)行完畢,就要保證Standby節(jié)點(diǎn)也保存了實時的數(shù)據(jù)快的存儲信息,也就是第二關(guān)系鏈。這樣發(fā)生錯誤切換時,Standby節(jié)點(diǎn)就不需要等待所有的數(shù)據(jù)節(jié)點(diǎn)進(jìn)行全量數(shù)據(jù)塊匯報,而直接可以切換到Active狀態(tài)。為了實現(xiàn)這個機(jī)制,Datanode會同時向這兩個Namenode發(fā)送心跳以及塊匯報信息。這樣就實現(xiàn)了Active Namenode 和standby Namenode 的元數(shù)據(jù)就完全一致,一旦發(fā)生故障,就可以馬上切換,也就是熱備。
這里需要注意的是 Standby Namenode只會更新數(shù)據(jù)塊的存儲信息,并不會向namenode 發(fā)送復(fù)制或者刪除數(shù)據(jù)塊的指令,這些指令只能由Active namenode發(fā)送。
在HA架構(gòu)中有一個非常重非要的問題,就是需要保證同一時刻只有一個處于Active狀態(tài)的Namenode,否則機(jī)會出現(xiàn)兩個Namenode同時修改命名空間的問,也就是腦裂(Split-brain)。腦裂的HDFS集群很可能造成數(shù)據(jù)塊的丟失,以及向Datanode下發(fā)錯誤的指令等異常情況。為了預(yù)防腦裂的情況,HDFS提供了三個級別的隔離機(jī)制(fencing):

  • 1.共享存儲隔離:同一時間只允許一個Namenode向JournalNodes寫入editlog數(shù)據(jù)。
  • 2.客戶端隔離:同一時間只允許一個Namenode響應(yīng)客戶端的請求。
  • 3.Datanode隔離:同一時間只允許一個Namenode向Datanode下發(fā)名字節(jié)點(diǎn)指令,李如刪除、復(fù)制數(shù)據(jù)塊指令等等。

在HA實現(xiàn)中還有一個非常重要的部分就是Active Namenode和Standby Namenode之間如何共享editlog日志文件。Active Namenode會將日志文件寫到共享存儲上。Standby Namenode會實時的從共享存儲讀取edetlog文件,然后合并到Standby Namenode的命名空間中。這樣一旦Active Namenode發(fā)生錯誤,Standby Namenode可以立即切換到Active狀態(tài)。在Hadoop2.6中,提供了QJM(Quorum Journal Manager)方案來解決HA共享存儲問題。

所有的HA實現(xiàn)方案都依賴于一個保存editlog的共享存儲,這個存儲必須是高可用的,并且能夠被集群中所有的Namenode同時訪問。Quorum Journa是一個基于paxos算法的HA設(shè)計方案。

Quorum Journal方案中有兩個重要的組件。

  • 1.JournalNoe(JN):運(yùn)行在N臺獨(dú)立的物理機(jī)器上,它將editlog文件保存在JournalNode的本地磁盤上,同時JournalNode還對外提供RPC接口QJournalProtocol以執(zhí)行遠(yuǎn)程讀寫editlog文件的功能。
  • 2.QuorumJournalManager(QJM):運(yùn)行在NmaeNode上,(目前HA集群只有兩個Namenode),通過調(diào)用RPC接口QJournalProtocol中的方法向JournalNode發(fā)送寫入、排斥、同步editlog。

Quorum Journal方案依賴于這樣一個概念:HDFS集群中有2N+1個JN存儲editlog文件,這些editlog 文件是保存在JN的本地磁盤上的。每個JN對QJM暴露QJM接口QJournalProtocol,允許Namenode讀寫editlog文件。當(dāng)Namenode向共享存儲寫入editlog文件時,它會通過QJM向集群中所有的JN發(fā)送寫editlog文件請求,當(dāng)有一半以上的JN返回寫操作成功時,即認(rèn)為寫成功。這個原理是基于Paxos算法的。

使用Quorum Journal實現(xiàn)的HA方案有一下優(yōu)點(diǎn):

  • 1.JN進(jìn)程可以運(yùn)行在普通的PC上,而無需配置專業(yè)的共享存儲硬件。
  • 2.不需要單獨(dú)實現(xiàn)fencing機(jī)制,Quorum Journal模式中內(nèi)置了fencing功能。
  • 3. Quorum Journa不存在單點(diǎn)故障,集群中有2N+1個Journal,可以允許有N個Journal Node死亡。
  • 4. JN不會因為其中一個機(jī)器的延遲而影響整體的延遲,而且也不會因為JN數(shù)量的增多而影響性能(因為Namenode向JournalNode發(fā)送日志是并行的)

互斥機(jī)制

當(dāng)HA集群中發(fā)生Namenode異常切換時,需要在共享存儲上fencing上一個活動的節(jié)點(diǎn)以保證該節(jié)點(diǎn)不能再向共享存儲寫入editlog?;赒uorum Journal模式的HA提供了epoch number來解決互斥問題,這個概念可以在分布式文件系統(tǒng)中找到。epoch number具有以下幾個性質(zhì)。
1.當(dāng)一個Namenode變?yōu)榛顒訝顟B(tài)時,會分配給他一個epoch number。
2.每個epoch number都是唯一的,沒有任意兩個Namenode有相同的epoch number。
3.epoch number 定義了Namenode寫editlog文件的順序。對于任意兩個namenode ,擁有更大epoch number的Namenode被認(rèn)為是活動節(jié)點(diǎn)。

當(dāng)一個Namenode切換為活動狀態(tài)時,它的QJM會向所有的JN發(fā)送命令,以獲取該JN的最后一個promise epoch變量值。當(dāng)QJM接受到了集群中多于一半的JN回復(fù)后,它會將所接收到的最大值加一,并保存到myepoch 中,之后QJM會將該值發(fā)送給所有的JN并提出更新請求。每個JN會將該值與自身的epoch值相互比較,如果新的myepoch比較大,則JN更新,并返回更新成功;如果小,則返回更新失敗。如果QJM接收到超過一半的JN返回成功,則設(shè)置它的epoch number為myepoch;,否則它終止嘗試為一個活動的Namenode,并拋出異常。

當(dāng)活動的NameNode成功獲取并更新了epoch number后,調(diào)用任何修改editlog的RPC請求都必須攜帶epoch number。當(dāng)RPC請求到達(dá)JN后,JN會將請求者的epoch與自身保存的epoch相互對比,若請求者的epoch更大,JN就會更新自己的epoch,并執(zhí)行相應(yīng)的操作,如果請求者的epoch小,就會拒絕相應(yīng)的請求。當(dāng)集群中大多數(shù)的JN拒絕了請求時,這次操作就失敗了。
當(dāng)HDFS集群發(fā)生Namenode錯誤切換后,原來的standby Namenode將集群的epoch number加一后更新。這樣原來的Active namenode的epoch number肯定小于這個值,當(dāng)這個節(jié)點(diǎn)執(zhí)行寫editlog操作時,由于JN節(jié)點(diǎn)不接收epoch number小于自身的promise epoch的寫請求,所以這次寫請求會失敗,也就達(dá)到了fencing的目的。

寫流程

  • 1.將editlog輸出流中緩存的數(shù)據(jù)寫入JN,對于集群中的每一個JN都存在一個獨(dú)立的線程調(diào)用RPC 接口中的方法向JN寫入數(shù)據(jù)。
  • 2.當(dāng)JN收到請求之后,JN會執(zhí)行以下操作:

1)驗證epoch number是否正確

2)確認(rèn)寫入數(shù)據(jù)對應(yīng)的txid是否連續(xù)

3)將數(shù)據(jù)持久化到JN的本地磁盤

4)向QJM發(fā)送正確的響應(yīng)

  • 3.QJM等待集群JN的響應(yīng),如果多數(shù)JN返回成功,則寫操作成功;否則寫操作失敗,QJM會拋出異常。

Namenode會調(diào)用FSEditlogLog下面的方法初始化editlog文件的輸出流,然后使用輸出流對象向editlog文件寫入數(shù)據(jù)。
獲取了QuorumOutputStream輸出流對象之后,Namenode會調(diào)用write方法向editlog文件中寫入數(shù)據(jù),QuorumOutputStream的底層也調(diào)用了EditsDoubleBuffer雙緩存區(qū)。數(shù)據(jù)回先寫入其中一個緩沖區(qū)中,然后調(diào)用flush方法時,將緩沖區(qū)中的數(shù)據(jù)發(fā)送給JN。

讀流程

Standby Namenode會從JN讀取editlog,然后與Sdtandby Namenode的命名空間合并,以保持和Active Namenode命名空間的同步。當(dāng)Sdtandby Namenode從JN讀取editlog時,它會首先發(fā)送RPC請求到集群中所有的JN上。JN接收到這個請求后會將JN本地存儲上保存的所有FINALIZED狀態(tài)的editlog段落文件信息返回,之后QJM會為所有JN返回的editlog段落文件構(gòu)造輸入流對象,并將這些輸入流對象合并到一個新的輸入流對象中,這樣Standby namenode就可以從任一個JN讀取每個editlog段落了。如果其中一個JN失敗了輸入流對象會自動切換到另一個保存了該edirlog段落的JN上。

恢復(fù)流程

當(dāng)Namenode發(fā)生主從切換時,原來的Standby namenode會接管共享存儲并執(zhí)行寫editlog的操作。在切換之前,對于共享存儲會執(zhí)行以下操作:
1.fencing原來的Active Namenode。這部分在互斥部分已經(jīng)講述。
2.恢復(fù)正在處理的editlog。由于Namenode發(fā)生了主從切換,集群中JN上正在執(zhí)行寫入操作的editlog數(shù)據(jù)可能不一致。例如,可能出現(xiàn)某些JN上的editlog正在寫入,但是當(dāng)前Active Namenode發(fā)生錯誤,這時該JN上的editlog文件就與已完成寫入的JN不一致。在這種情況下,需要對JN上所有狀態(tài)不一致的editlog文件執(zhí)行恢復(fù)操作,將他們的數(shù)據(jù)同步一致,并且將editlog文件轉(zhuǎn)化為FINALIZED狀態(tài)。
3.當(dāng)不一致的editlog文件完成恢復(fù)之后,這時原來的Standby Namenode就可以切換為Active Namenode并執(zhí)行寫editlog的操作。
4.寫editlog。在前面已經(jīng)介紹了。

日志恢復(fù)操作可以分為以下幾個階段:

1.確定需要執(zhí)行恢復(fù)操作的editlog段落:在執(zhí)行恢復(fù)操作之前,QJM會執(zhí)行newEpoch()調(diào)用以產(chǎn)生新的epoch number,JN接收到這個請求后除了執(zhí)行更新epoch number外,還會將該JN上保存的最新的editlog段落的txid返回。當(dāng)集群中的大多數(shù)JN都發(fā)回了這個響應(yīng)后,QJM就可以確定出集群中最新的一個正在處理editlog段落的txid,然后QJM就會對這個txid對應(yīng)的editlog段落執(zhí)行恢復(fù)操作了。

2.準(zhǔn)備恢復(fù):QJM向集群中的所有JN發(fā)送RPC請求,查詢執(zhí)行恢復(fù)操作的editlog段落文件在所有JN上的狀態(tài),這里的狀態(tài)包括editlog文件是in-propress還是FINALIZED狀態(tài),以及editlog文件的長度。

3.接受恢復(fù):QJM接收到JN發(fā)回的JN發(fā)回的響應(yīng)后,會根據(jù)恢復(fù)算法選擇執(zhí)行恢復(fù)操作的源節(jié)點(diǎn)。然后QJM會發(fā)送RPC請求給每一個JN,這個請求會包含兩部分信息:源editlog段落文件信息,以及供JN下載這個源editlog段落的url。
接收到這個RPC請求之后,JN會執(zhí)行以下操作:

1)同步editlog段落文件,如果JN磁盤上的editlog段落文件與請求中的段落文件狀態(tài)不同,則JN會從當(dāng)前請求中的url上下載段落文件,并替換磁盤上的editlog段落文件。
2)持久化恢復(fù)元數(shù)據(jù),JN會將執(zhí)行恢復(fù)操作的editlog段落文件的狀態(tài)、觸發(fā)恢復(fù)操作的QJM的epoch number等信息(恢復(fù)的元數(shù)據(jù)信息)持久化到磁盤上。
3)當(dāng)這些操作都執(zhí)行成功后,JN會返回成功響應(yīng)給QJM,如果集群中的大多數(shù)JN都返回了成功,則此次恢復(fù)操作執(zhí)行成功。

4.完成editlog段落文件:到這步操作時,QJM 就能確定集群中大多數(shù)的JN保存的editlog文件的狀態(tài)已經(jīng)一致了,并且JN持久化了恢復(fù)信息。QJM就會向JN發(fā)送指令,將這個editlog段落文件的狀態(tài)轉(zhuǎn)化為FINALIZED狀態(tài),,并且JN會刪除持久化的恢復(fù)元數(shù)據(jù),因為磁盤上保存的editlog文件信息已經(jīng)是正確的了,不需要保存恢復(fù)的元數(shù)據(jù)。

到此這篇關(guān)于詳細(xì)講解HDFS的高可用機(jī)制的文章就介紹到這了,更多相關(guān)HDFS的高可用機(jī)制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • HDFS-Hadoop NameNode高可用機(jī)制
  • JAVA讀取HDFS的文件數(shù)據(jù)出現(xiàn)亂碼的解決方案
  • Hadoop 分布式存儲系統(tǒng) HDFS的實例詳解
  • JAVA操作HDFS案例的簡單實現(xiàn)
  • hadoop的hdfs文件操作實現(xiàn)上傳文件到hdfs

標(biāo)簽:青海 無錫 沈陽 忻州 哈密 紅河 阜陽 河源

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳細(xì)講解HDFS的高可用機(jī)制》,本文關(guān)鍵詞  詳細(xì),講解,HDFS,的,高可用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳細(xì)講解HDFS的高可用機(jī)制》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳細(xì)講解HDFS的高可用機(jī)制的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产精品 欧美 日韩| 亚洲精选久久| 高清视频一区二区三区四区| 少妇高潮惨叫久久久久| 麻豆入口视频在线观看| 成人免费视频国产免费麻豆| 欧美高清影院| 妺妺窝人体色www在线观看| 亚洲欧洲无码一区二区三区| 日韩欧美视频| 日韩欧美在线字幕| 亚洲国产免费| 夜夜嗨av一区二区三区网页| 台湾天天综合人成在线| 91片在线免费观看| 国产盗摄xxxx视频xxx69| 手机在线成人av| 国产成人a视频高清在线观看| 成人福利视频导航| 亚洲色欧美另类| 一级做a爰片久久毛片| 日韩av一卡| 国内精品免费一区二区三区| 在线视频日韩精品| 日日噜噜噜夜夜爽爽| 日本国产欧美一区二区三区| 亚洲精品国产第一综合99久久| 97一区二区国产好的精华液| 日韩一级免费片| 我不卡一区二区| 久久露脸国产精品| 十八禁一区二区三区| 中文字幕第一区第二区| 久久久久久免费| 精品日韩视频| 色网在线视频| 91精品国产91久久久久久最新毛片| 久久精品日产第一区二区三区| a在线免费观看| 久久久久久高潮国产精品视| 免费中文字幕在线| 日韩一区精品字幕| 国产精品久久久久久av公交车| 久久99久久99精品免费看小说| 国产又黄又大久久| 在线观看污视频| 天天操夜夜草| aa一级黄色片| 久久香蕉国产线看观看网| 99re66热这里只有精品8| 中文字幕影音在线| 成人在线激情网| 国产按摩一区二区三区| 精品国产精品久久一区免费式| 91亚洲无吗| 中文字幕精品一区二区三区在线| 欧美成人在线网站| 欧美特级一级片| 黄网站在线播放| a视频在线观看| 欧洲亚洲女同hd| 自产国语精品视频| 在线免费观看高清视频色| 国产精品一区av| 欧美日韩激情网| 一区不卡字幕| 五月婷婷激情在线| 欧美va在线| 午夜亚洲福利| 手机在线理论片| 日韩在线观看精品| 亚洲国产激情一区二区三区| 一级一级黄色片| 国产日韩1区| 国产卡二和卡三的视频| 激情五月综合网| 午夜精品久久久久影视| 亚洲精品乱码久久久久久日本蜜臀| 鲁大师成人一区二区三区| 国产精品videosex性欧美| 国产剧情在线观看一区二区| 亚洲欧美视频一区二区三区| 国产亚洲情侣一区二区无| 91久久精品一区| 欧美bbbxxxxx| 免费福利影院| a级黄色一级片| 精品人妻在线播放| 中文字幕免费观看一区| 精品人伦一区二区三电影| 99免费在线视频观看| 97视频在线免费播放| 国产精品午夜久久| 国产精品日日做人人爱| 亚洲欧美国产精品桃花| 国产二区视频在线播放| 国产精品91一区二区| 老司机午夜免费福利视频| 成人黄色在线播放| 日韩精品――色哟哟| 国偷自产av一区二区三区| 成人免费视频视频在线观看免费| 国产激情99| 5566中文字幕一区二区电影| 三级成人黄色影院| 高清国产一区二区三区| 路边理发店露脸熟妇泻火| 欧美日韩精品免费观看视欧美高清免费大片| 国产精品嫩草影院在线看| 神马精品久久| 亚洲国产美国国产综合一区二区| 91xxx视频| 成人短视频在线| 国产网友自拍视频| 欧美色手机在线观看| 亚洲国产一区在线| 亚洲精品国产精品自产a区红杏吧| 国产亚洲网站| 久久久久久久久久影院| 成年丰满熟妇午夜免费视频| 韩日中文字幕| 欧美日韩免费在线观看| 国产精品伦一区二区三区级视频频| 亚洲电影一二三区| 99国产精品久久久久99打野战| 欧美精品xxxxx| 午夜3点看的视频| 人人干在线视频| 国产男女在线观看| 国产精品三级一区二区| 成人av视屏| 中文字幕天堂av| 亚洲一级毛片| 亚洲AV无码国产成人久久| 国产精品77777竹菊影视小说| 视频在线精品一区| 高清视频在线观看三级| 这里只有久久精品| 欧美日本一区二区高清播放视频| 国产精区一区二区| 国产欧美第一页| 在线播放欧美女士性生活| 成年人小视频在线观看| av在线免费在线观看| av中文字幕第一页| 国产在线观看18| 免费网站看黄yyy222| 最新国产精品拍自在线播放| 白丝美女让我捅| 国产日韩一区| 久久中文免费视频| 欧洲女同同性吃奶| 一区二区三区精彩视频| 亚洲国产精品自拍| 日本小视频网站| 国产午夜久久久| 亚洲综合激情另类专区老铁性| 最新97超碰在线| 日韩脚交footjobhdboots| 久久综合亚州| 亚洲影院在线看| 美国一级黄色录像| 午夜精品视频在线观看| 在线午夜影院| 欧美喷水一区二区| 影音先锋中文字幕在线| 福利一区视频在线观看| 激情自拍一区| 久久久久久久久爱| 欧美日韩精品亚洲精品| 日韩丝袜情趣美女图片| 成人全视频在线观看在线播放高清| 人人爽香蕉精品| 国产中文一区二区| 久久av一区二区三区漫画| 精品一级毛片| 日本视频在线观看免费| 亚洲一区二区三区乱码| 在线观看入口黄最新永久免费国产| 91国内在线视频| 欧美日韩美女在线观看| 久久久久毛片| 午夜精品在线观看| 麻豆视频免费在线播放| 欧美日韩亚洲综合在线| 欧美xxxxxbb| 精品香蕉一区二区三区| 亚洲第一男人天堂| 秋霞电影网一区二区| 91精品国产综合久久久久| 九色视频网站| 欧美国产日韩一区二区| 高清av免费一区中文字幕| 久久久久免费观看| 国产精品入口66mio| 午夜在线精品| 精品精品国产高清一毛片一天堂| 蜜桃av免费在线观看| 在线观看国产小视频| 中文字幕亚洲无线码在线一区| 久久免费黄色网址| 永久免费网站视频在线观看| 国产稀缺精品盗摄盗拍| 在线观看成人黄色| 91高清在线| 在线中文字日产幕| 欧美日韩高清在线| 国产精品伦一区| 日韩精品电影一区二区三区| 久久深夜福利| 老熟妇仑乱一区二区av| 无夜福利视频观看| 99精品欧美一区| 亚洲人视频在线| 久热这里只精品99re8久| 456亚洲精品成人影院| 国产成人av毛片| 亚洲春色一区二区三区| 色欧美88888久久久久久影院| 国产中文字幕一区| 亚洲麻豆国产自偷在线| 3p乱日视频| 日韩精品免费一区二区三区竹菊| 欧日韩在线视频| 人妻激情偷乱频一区二区三区| 欧美肥妇毛茸茸| 毛片精品免费在线观看| 亚洲精品1234| 日本精品久久久久| 日韩人妻精品一区二区三区| 欧美三级中文字幕| 日韩黄色影视| 日本高清一二三区| 色偷偷亚洲第一综合| 日本h在线观看| 国产日韩欧美一区二区三区| 精品一区二区三区影院在线午夜| 亚洲国产一成人久久精品| 日韩精品一区二区三区四区视频| 播五月开心婷婷综合| 日韩av中文字幕在线免费观看| 郴州新闻综合频道在线直播| 日韩不卡av| 久久人人爽人人爽爽久久| 精品少妇一区二区三区在线视频| 日韩大片在线观看视频| 91久久夜色精品国产九色| 亚洲精品免费一区二区三区| 国产中文精品久高清在线不| 欧美成免费一区二区视频| 日韩a一区二区| 中日韩视频在线观看| 无码人妻丰满熟妇精品| 98色花堂精品视频在线观看| 国产手机视频一区二区| 蜜桃精品wwwmitaows| 伊人成人在线观看| 成人18精品视频| 日韩mv欧美mv国产网站| 黄色大秀av大片| 亚洲a∨日韩av高清在线观看| 亚洲精品在线网站| 久久精品日韩欧美| 摸bbb搡bbb搡bbbb| 国产一区视频在线看| 91麻豆精品91久久久久久清纯| 亚洲国产中文字幕在线视频综合| 欧美大人香蕉在线| 麻豆专区一区二区三区四区五区| 伦理欧美一区| 亚洲第一综合网| 在线能看的av网站| 国产美女免费网站| 精品人妻在线播放| 国产精品久久久久久亚洲调教| 日本三级中国三级99人妇网站| 欧美成人精品h版在线观看| 欧美精品久久久久久久久久久| 欧美波霸videosex极品| 国产午夜精品一区二区理论影院| 色老头一区二区三区| av官网在线观看| 国产精品av一区二区| 亚洲精品第一| 久久综合中文字幕| 黄色资源网久久资源365| 45www国产精品网站| 国产一卡2卡3卡4卡网站免费| 国产精品免费视频一区二区三区| 国产亚洲激情| 亚洲香蕉成视频在线观看| 亚洲国产日韩在线人成电影| 国产精品夜夜夜爽阿娇| 娇小发育未年成性色xxx8| 亚洲精品美女| 成人激情视频在线观看| 国产91在线视频| 午夜精品www| 亚洲高清免费在线观看| **日韩最新| 国内小视频在线看| 色姑娘综合天天| 人妻av无码专区| 国产亚洲成av人片在线观看桃| 999www成人| 国产精品情趣视频| 国产精品在线| 久久伊人精品| 9999在线精品视频| 日本黄网站色大片免费观看| 日韩欧美中文字幕公布| 一级片视频免费观看| 91国内精品野花午夜精品| 久久人妻无码一区二区| 欧美日韩在线亚洲一区蜜芽| 任我爽在线视频| 国产日韩一级二级三级| 高清性色生活片在线观看| 91精品人妻一区二区三区蜜桃欧美| 亚洲免费国产视频| 91精品视频专区| 日韩欧美在线观看一区二区三区| 成人黄色在线免费| 午夜国产一区二区三区| gogo久久日韩裸体艺术| 日本成人在线免费视频| 国产无遮挡在线观看| 久久久久无码国产精品不卡|