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

假如讓你來設計數據庫中間件

開發 開發工具
假如讓我來設計數據庫中間件,我覺得數據庫中間層項目背景不再展開,根據前期的調研以及和公司同事的討論,中間層的核心目標主要有兩個。

一、總體目標

數據庫中間層項目背景不再展開,根據前期的調研以及和公司同事的討論,中間層的核心目標主要有兩個:

  • db虛擬化:讓db對業務線透明(本文的db均指mysql),業務線不再需要知道db的真實ip,port,主從關系,讀寫關系,高可用等
  • 分庫的支持:讓db的分庫對業務線透明

二、實現的功能

上述目標相對比較寬泛,具體來說,數據庫中間層需要實現以下功能。

1. 統一接入入口

如果統一接入入口,從今以后,不再有

  1. db1.58.com:3306 
  2. db2.58.com:3306 
  3. im.58.com:3306 
  4. jiaoyou.58.com:3306 

而只有

  1. db.58.com:3306 

所有的業務線,對db的訪問,都只有一個入口,由數據庫中間層來進行權限驗證,由中間件來路由請求,這是一種***的情況。

當然,統一一個總入口目標有點宏大,可以循序漸進,先各業務線統一讀寫訪問入口,故折衷的目標可以是,從今以后,不再有

  1. im.read.db1.58.com:3306 
  2. im.read.db2.58.com:3306 
  3. im.write.db.58.com:3306 

而只有

  1. im.58.com:3306 

im業務對db的訪問,統一到一個入口上來了,由中間層來對請求進行智能路由。

更簡化的,甚至可以初期同一個業務線的db讀寫都不對業務線透明,數據庫中間層只做簡單的請求轉發,先初步的把數據庫訪問入口收攏到數據庫中間層來,為后續的統一,再統一打下基礎。

ROAD-MAP規劃如下:

  • 業務線入口統一(中轉請求)
  • 業務線入口統一(智能路由)
  • 全局入口統一

2.  保持訪問接口

保持訪問接口

原來db的訪問方式主要有以上三種:

  • 手工用mysql客戶端連mysql,直連數據庫執行命令
  • java使用jdbc連接數據庫
  • c/c++使用libmysqlclient.a來對mysql進行訪問

所謂保持訪問接口,是指上游對數據庫的訪問接口完全不用變,中間件服務對上游來說,就是數據庫。

由于SQL協議是非常復雜的,在db的客戶端與服務器插入了一個中間層之后,不一定能對所有的SQL功能都進行支持,支持哪些SQL是需要慎重考慮的。

3.  屏蔽讀寫分離

業務層不需要在關注讀寫分離,由中間件來進行讀寫請求路由。

4.  支持的分庫

58的db的水平擴展,基本是用的分庫的方式(分庫比較好,很容易實現實例的擴容),即:

db.table會水平拆分為:

  1. db1.table 
  2. db2.table 
  3. db3.table 
  4. db4.table 

這樣的話,dao層對于table就只有一個table實例了,比較方便。

支持的分庫

根據前期與各業務線同學的溝通,58在分庫上的業務訪問需求為(這個調研的周期比較長,和很多業務線進行了溝通):

  • patition key普通查詢
  • patition key上的IN查詢
  • 非patition key上的查詢
  • 有限功能的排序+分頁查詢

故對分庫上的分布式SQL功能,數據庫中間層只需要支持上上述四項即可。

5.  高可用性的支持

高可用的支持又分為兩個部分:

***部分,故障自動發現:下游數據庫掛了,能夠自動發現問題,并報警周知相關人員。

第二部分,故障自動轉移:

  • 主庫掛了,能夠自動切換,或者屏蔽寫請求
  • 從庫掛了,能夠自動自動切換讀請求量流量
  • 中間件掛了,自動切換中間件流量,高可用

(6 )可運維性的支持

  • 支持一些統計數據的展現
  • 支持一些管理命令
  • 支持頁面話的運維

however,只要總的框架設計具備可擴展性,這些功能可以循序漸進,逐步添加。

三、設計折衷

1. 協議與整體架構

既然選擇了mysql client server protocol作為業務層與中間層之間的協議,那么中間層必然是作為mysql-server接收上游的請求,作為mysql-client向真正的mysql發送請求的,中間層的整體結構如下:

這樣的話,需要對mysql client server protocol做詳盡的研究,了解:

  • 連接的建立過程
  • 權限認證的過程
  • 壓縮解壓縮的過程
  • 請求響應二進制協議各種細節

協議這一塊的掌握必須詳盡,好在官方文檔相對比較全面:

http://dev.mysql.com/doc/internals/en/client-server-protocol.html

2. 架構細節

總體架構細節圖如上。

(1) 上游

mysql客戶端,java使用jdbc作為上游連接,c/c++使用libmysql.a作為上游連接,使用的是Mysql Client Server協議

DBA也可以向中間件發送一些管理命令,或者查看一些統計信息,使用的是自己定義的內部協議

(2) 下游

處于系統體系結構中的***端,系統中間件的下游就是mysql集群了,中間件與mysql之間使用的也是Mysql Client Server協議。

(3) 中間層-ConfigMgr

中間層配置文件管理組件ConfigMgr是中間層中非常重要的一個部分,請求的轉發,讀寫分離,分庫功能的支持,都需要通過配置來完成。

  1. <mysql> 
  2. <db id=0 logic_db="im"type=1> 
  3.        <item ip="10.58.1.100" port=3306 name="im" /> 
  4. </db> 
  5.   
  6. <db id=1 logic_db="umc"type=2 patition_count=2 key="uid" hash="mod"> 
  7.    <patition id=0> 
  8.        <item ip="10.58.1.100" port=3306 role="w" /> 
  9.        <item ip="10.58.1.101" port=3306 role="r" /> 
  10.        <item ip="10.58.1.102" port=3306 role="r" /> 
  11.    </patition> 
  12.    <patition id=1> 
  13.        <item ip="10.58.1.100" port=3316 role="w" /> 
  14.        <item ip="10.58.1.101" port=3316 role="r" /> 
  15.        <item ip="10.58.1.102" port=3316 role="r" /> 
  16.    </patition> 
  17. </db> 
  18. </mysql> 

 

 

 

 

 

從配置文件可以看出,ConfigMgr需要管理的mysql配置類型有兩種:

a. type=1請求轉發

  1. <db id=0 logic_db="im"type=1> 
  2.        <item ip="10.58.1.100" port=3306 name="im" /> 
  3. </db> 

 

配置的含義是,上游如果訪問邏輯數據庫logic_db=”im”,中間件則將請求轉發到實際的后端數據庫item,item中配置了后端數據庫的ip/port/name。

b. type=2分庫支持

解釋分庫支持的配置之前,先說明一下數據庫的層次結構LOGIC_DB、PARTITION、ITEM。

  • LOGIC_DB:邏輯數據庫,面向上游,例如umc
  • PARTITION:數據庫分區,可以理解為分庫,例如umc0和umc1,這個對上游是透明的
  • ITEM:數據庫項,可以理解為一個分區上的一個讀庫或者寫庫,這個對上游也是透明的

上例中對應的配置文件為:

  1. <db id=1 logic_db="umc"type=2 patition_count=2 key="uid" hash="mod"> 
  2.    <patition id=0> 
  3.        <item ip="10.58.1.100" port=3306 role="w" /> 
  4.        <item ip="10.58.1.101" port=3306 role="r" /> 
  5.        <item ip="10.58.1.102" port=3306 role="r" /> 
  6.    </patition> 
  7.    <patition id=1> 
  8.        <item ip="10.58.1.100" port=3316 role="w" /> 
  9.        <item ip="10.58.1.101" port=3316 role="r" /> 
  10.        <item ip="10.58.1.102" port=3316 role="r" /> 
  11.    </patition> 
  12. </db> 

 

 

 

  • LOGIC_DB:需要關注partition-key-column,也需要關注partition算法,它要實現對PARTITION的請求路由以及結果集的匯總
  • PARTITION:需要關注ITEM的讀寫特性,它要實現對ITEM的讀寫分離
  • ITEM:是最終的數據庫,和它相關的配置是數據庫ip/port/name/wr-type

(4) 中間層-MysqlServerPart

中間層服務端組件MysqlServerPart是中間層中非常重要的一個部分,它負責端口的監聽+請求接收與返回(服務端網絡IO),MysqlProtocol的解析。根據其功能,MysqlServerPart組件又主要分為兩個組件ServerIOMgr組件(服務端IO管理),MysqlProtocolAnalyzer組件(Mysql協議分析)。

這一層次面臨這些細節:

  • server網絡框架的選取:建議使用異步server
  • 并發模型的選取:建議使用IO-thread + multi-work-thread的并發模型
  • 內存管理模型的選取:建議使用內存池
  • 連接上下文管理,最容易想到的上下文,一個數據庫連接是和一個邏輯庫LOGIC_DB綁定的
  • Mysql如何建立數據庫連接:需要考察Mysql協議
  • Mysql協議的細化解析:需要考察Mysql協議

(5) 中間層-MysqlClientPart

中間層客戶端組件MysqlClientPart是中間層中非常重要的一個部分,它負責中間件對mysql的連接池管理,以及返回結果集的解析。根據其功能,MysqlClientPart組件又主要分為兩個組件ClientConnPoolMgr組件(客戶端連接池管理),ResultSetAnalyzer組件(返回結果集分析)。

這一層次面臨這些細節:

  • 數據庫連接池的實現
  • 數據庫連接模型的選型:建議前期使用同步模型
  • 連接上下文管理,最容易想到的上下文,一個數據庫連接是和一個ITEM綁定的
  • Mysql結果集的細化解析:需要考察Mysql協議

(6) 中間層-SqlParser

中間層Sql分析組件SqlParser是中間層中非常重要的一個部分,它負責對sql語句的語法分析與語義分析。

為什么要進行Sql語法語義分析?需要解析出什么東東?

分為兩種情況:

a. type=1請求轉發

對于請求的中轉,上游一個數據庫連接對應一個邏輯庫LOGIC_DB,由ConfigMgr可以知道對應下游一個真實的ITEM(ip/port/db),此時直接轉發請求即可,無需解析Sql語句。

b. type=2分庫支持

對于分庫的支持,解析Sql語句可能需要得到這些問題的答案:Sql是否帶了partition-key-column?partition-key-column的值是多少?

例如一條Sql語句:select * from user where uid=123456;

就必須將“uid”列屬性,以及uid的列屬性值“123456”解析出來,以用作后續請求路由。

注意:更細的情況是,針對每個表,分庫partition-key-column都是不一樣的,上例中還需要將表名user也解析出來。

這一層次面臨這些細節:如何解析Sql語句:可以參考mysql源碼對SQL語句的解析,亦可參照cober對SQL語句的解析方法;

注:由于我們只需要支持多庫,數據庫庫名信息是在“連接”這一層獲取的,又我們支持的分布式Sql的種類有限,故只需解析partition-key-column,offset/limit等少數信息即可。

(7) 中間層-SqlModifier

中間層Sql修改組件SqlModifier是中間層中非常重要的一個部分,它負責對sql語句改寫。

為什么要對Sql語句進行改寫?

type=1的請求轉發,無需修改Sql,但對于type=2的分庫支持,有些Sql語句就必須進行改寫。

例如:

  1. select * from user where uid in(1,2,3,4,5,6); 

假設PARTITION分了0和1奇偶兩個分區,則sql應該分別被改寫為:

  1. select * from user where uid in(2,4,6); => 路由給0庫; 
  2. select * from user where uid in(1,3,5); => 路由給1庫; 

又例如:

  1. select * from user limit 1000,10; 

則sql可能會被改寫為:

select * from user limit 0,1010; => 分別路由到兩個庫,收集完結果集共2020條記錄,再排序取其中1000-1010這10條。

哪些Sql需要改寫,如何改寫?

結合我們需要實現的四類分布式Sql:

  • patition key普通查詢
  • patition key上的IN查詢
  • 非patition key上的查詢
  • 有限功能的排序+分頁查詢

只有(2)和(4)兩項需要改寫,改寫方法上文已述,其中(4)的改寫效率較低,使用起來要謹慎。

(8) 中間層-SqlRouter

中間層Sql路由組件SqlRouter是中間層中非常重要的一個部分,它負責對sql語句進行路由。

哪些Sql需要路由,如何路由?

結合我們需要實現的四類分布式Sql:

  • patition key普通查詢
  • patition key上的IN查詢
  • 非patition key上的查詢
  • 有限功能的排序+分頁查詢

只有(1)和(2)兩項需要路由,(3)和(4)需要將請求分發至所有的PARTITION。

(9) 中間層-ResultSetMerger

中間層結果集合并組件ResultSetMerger是中間層中非常重要的一個部分,它負責對結果集進行合并,篩選。

哪些Sql需要合并結果集,篩選結果集?

結合我們需要實現的四類分布式Sql:

  • patition key普通查詢
  • patition key上的IN查詢
  • 非patition key上的查詢
  • 有限功能的排序+分頁查詢

其中(2)和(3)類查詢需要將結果集進行合并,(4)不但要合并結果集,還需要將結果集在本地進行排序,然后再篩選出真正的結果集。

(10) 其他組件

  • AdminServer:監聽一個新端口,接收數據庫管理員命令的server
  • AdminMgr:實現管理員命令的組件
  • MonitorMgr:實現監控報警的組件
  • StatisticsMgr:實現數據統計功能的組件

上述組件可循序漸進,逐步添加,故一期需要實現的組件及架構圖為:

【本文為51CTO專欄作者“58沈劍”原創稿件,轉載請聯系原作者】

戳這里,看該作者更多好文

責任編輯:趙寧寧 來源: 51CTO專欄
相關推薦

2017-11-30 08:56:14

數據庫中間件架構師

2017-12-01 05:40:56

數據庫中間件join

2022-03-05 18:25:51

SSLTLS協議

2017-12-01 05:04:32

數據庫中間件Atlas

2017-11-27 05:36:16

數據庫中間件TDDL

2017-11-27 05:06:42

數據庫中間件cobar

2018-02-24 19:37:33

Java8數據庫中間件

2011-08-10 13:03:58

CJDBC數據庫集群

2017-05-23 18:55:05

mysql-proxy數據庫架構

2017-07-26 09:41:28

MyCATSQLMongoDB

2017-12-11 13:30:49

Go語言數據庫中間件

2017-07-18 17:35:16

數據庫MyCATPreparedSta

2017-11-03 11:02:08

數據庫中間件

2024-12-06 08:29:29

2023-12-24 22:42:57

數據庫分片中間件

2017-07-18 17:07:40

數據庫 MyCATJoin

2021-09-05 18:25:57

文件系統

2021-07-27 05:49:59

MySQL數據庫中間件

2020-10-15 08:34:32

數據庫中間件漫談

2009-01-20 10:45:55

Oracle數據庫中間件
點贊
收藏

51CTO技術棧公眾號

中文字幕不卡三区视频| 在线中文字幕网站| 加勒比视频一区| 欧美日韩在线视频一区二区| 九九九九精品| 少妇无套内谢久久久久| 欧美午夜一区| 夜夜躁日日躁狠狠久久88av| 亚洲在线观看网站| 综合日韩av| 亚洲女人****多毛耸耸8| 久久国产精品久久精品国产| 在线观看免费黄色小视频| 欧美激情91| 国产亚洲精品久久| 性囗交免费视频观看| 成人交换视频| 黑人精品xxx一区一二区| 99亚洲精品视频| 欧美少妇另类| 国产在线不卡一区| 国产成+人+综合+亚洲欧洲| 校园春色 亚洲| 精品美女视频| 欧美精品一区男女天堂| 鲁一鲁一鲁一鲁一av| 超级白嫩亚洲国产第一| 亚洲欧美日本在线| 亚洲精品人成| 黄色片视频在线观看| 粉嫩av亚洲一区二区图片| 国产免费一区二区三区在线能观看| 五月婷婷激情网| 欧美福利一区| 按摩亚洲人久久| 加勒比一区二区| 国产主播性色av福利精品一区| 在线成人免费视频| 日本人视频jizz页码69| 黑人巨大精品| 欧美日韩色婷婷| 成人免费观看cn| 欧美xxxx免费虐| 亚洲欧美日韩一区| 中文字幕一区二区三区四区五区六区| 国产系列在线观看| 久久久高清一区二区三区| 九9re精品视频在线观看re6| 人妻少妇精品无码专区| 国产精品影音先锋| 91牛牛免费视频| 91成品人影院| 激情综合网激情| 成人激情免费在线| 国产精品久久久久久在线| 美腿丝袜亚洲综合| 国产精品亚洲网站| 中文字幕在线视频第一页| 奇米777欧美一区二区| 国产精品久久久久久久久久小说| 亚洲av无码精品一区二区| 久久精品人人做人人爽电影蜜月| 91精品国产色综合久久不卡98| xxxxxx国产| 中文在线不卡| 国产成人精品av在线| 在线免费一区二区| 麻豆国产一区二区| 成人天堂噜噜噜| 亚洲av综合色区无码一二三区| 国产精品123区| 国产精品v欧美精品∨日韩| 欧美自拍偷拍第一页| 97se亚洲国产综合自在线不卡| 久久影视中文粉嫩av| 国产青青草在线| √…a在线天堂一区| 肉大捧一出免费观看网站在线播放 | 午夜激情综合网| 国产精品欧美激情在线观看| 电影天堂国产精品| 7777精品伊人久久久大香线蕉| 一级黄色片国产| 丁香婷婷成人| 亚洲网在线观看| 麻豆视频在线免费看| 欧美天天视频| 国产99在线|中文| 91免费视频播放| 大美女一区二区三区| 久久亚洲综合网| 一广人看www在线观看免费视频| 亚洲美女免费视频| 国产美女三级视频| 精品国模一区二区三区欧美| 精品一区二区三区四区在线| 日本不卡一区视频| 精品96久久久久久中文字幕无| 日本一区二区在线播放| 国产又粗又猛又爽又黄视频| av不卡在线播放| 影音欧美亚洲| 日韩欧美精品一区二区三区| 欧美男生操女生| 国产真实乱人偷精品| 91日韩在线| 欧美亚洲伦理www| 99热精品在线播放| 久久久精品天堂| 国产精品69久久久| 国语自产精品视频在线看抢先版结局| 精品国产一区二区三区忘忧草| 自拍偷拍亚洲天堂| 国产在线不卡| 成人免费看黄网站| 国产三级电影在线观看| 亚洲成人精品在线观看| 在线免费看污网站| 精品欧美久久| 中文字幕中文字幕一区| 亚洲欧美日韩在线综合 | jizz欧美性11| 校花撩起jk露出白色内裤国产精品 | 久久久久国产免费| 天天操夜夜操国产精品| 国产成人福利网站| 神马午夜一区二区| 亚洲精品中文字幕乱码三区| 男女爽爽爽视频| 欧美黑人巨大videos精品| 欧美成人精品在线视频| 亚洲在线精品视频| 国产日韩欧美精品一区| 99色精品视频| 国产精品极品| 久久久久久久久久久网站| 国产熟女一区二区丰满| 综合自拍亚洲综合图不卡区| 欧美女同在线观看| av亚洲免费| 国产精品爱啪在线线免费观看 | 最近2019年好看中文字幕视频| 亚洲天堂一区在线| 99re成人精品视频| 欧美二区在线视频| 欧美亚洲色图校园春色| 91精品国产91久久久久| 少妇无码一区二区三区| 亚洲成人av福利| 黄色免费看视频| 亚洲作爱视频| 久久精品成人一区二区三区蜜臀 | 精品国产免费久久久久久婷婷| 欧美好骚综合网| 成人免费淫片视频软件| 黄色在线观看网站| 欧美一级爆毛片| 欧美黑人一级片| 丁香激情综合国产| 日韩免费一级视频| 久久av电影| 国产精品欧美亚洲777777| 在线观看a视频| 91精品婷婷国产综合久久性色| 婷婷久久综合网| 粉嫩嫩av羞羞动漫久久久| 精品久久一二三| 国产精品欧美三级在线观看| 国产欧美精品一区二区| jizzjizz亚洲| 亚洲国产精品va在线看黑人动漫| 欧美另类一区二区| 国产欧美日韩激情| 樱花草www在线| 精品福利av| 欧洲一区二区日韩在线视频观看免费| 另类专区亚洲| 久久午夜a级毛片| 后进极品白嫩翘臀在线视频| 日韩欧美在线观看| 久久福利免费视频| 懂色av一区二区三区免费看| 久久久久久久久久久福利| 日本电影一区二区| 99在线观看视频网站| 最新中文字幕在线播放| 久久精品视频中文字幕| 日本人妻丰满熟妇久久久久久| 在线中文字幕一区二区| 麻豆视频在线免费看| 久久久久久亚洲综合| 特级西西444www| 久久国产毛片| 国产又粗又猛又爽又黄的网站| 妖精视频一区二区三区免费观看| 91精品久久久久久久久久入口| 97久久人人超碰caoprom| 一区二区三欧美| 黄色片一区二区三区| 欧美日韩一二区| 国产污视频在线看| 国产精品久久久久久久久免费丝袜 | 中文字幕九色91在线| a在线观看视频| 日本电影亚洲天堂一区| 青青草免费av| 中文字幕精品一区| 日本一区二区在线免费观看| 精品亚洲porn| 日本新janpanese乱熟| 亚洲激情影院| 国产日韩欧美大片| 国产日产精品一区二区三区四区的观看方式 | 久久精品成人动漫| 黄色视屏网站在线免费观看| 欧美va亚洲va在线观看蝴蝶网| 黄色av一区二区| 亚洲成av人**亚洲成av**| 国产一区在线观看免费| 2020日本不卡一区二区视频| 中文字幕永久免费| 精品亚洲porn| 亚洲成人福利在线| 亚洲欧美日本日韩| 成年人看的毛片| 欧美激情视频一区二区三区在线播放| 亚洲 国产 欧美一区| 亚州综合一区| 好吊色欧美一区二区三区| 视频一区视频二区欧美| 成人网在线观看| 日韩精品第二页| 国产精品三级久久久久久电影| 日韩伦理在线一区| 亚州国产精品久久久| 伦理在线一区| 欧美激情亚洲激情| 伊人电影在线观看| 超碰精品一区二区三区乱码| 日本在线观看网站| 亚洲性日韩精品一区二区| 牛牛热在线视频| 亚洲精品少妇网址| 天堂成人在线| 亚洲欧美在线x视频| 色av男人的天堂免费在线| 日韩电影中文字幕在线| 五月婷婷六月色| 精品在线观看国产| 免费福利在线观看| 国产午夜精品视频| 91在线看片| 久久人人爽亚洲精品天堂| 黄色av免费在线| 久国内精品在线| av中文资源在线资源免费观看| 久久免费视频网站| 忘忧草在线日韩www影院| 人人澡人人澡人人看欧美| 男人皇宫亚洲男人2020| 国产成一区二区| 欧美黄色网络| 91日韩在线视频| 91久久精品无嫩草影院| 国产日韩久久| 中文字幕伦av一区二区邻居| 亚洲国产一区在线| 五月天久久网站| 亚洲理论电影在线观看| 国产毛片一区| 亚洲天堂av一区二区| 国产黑丝在线一区二区三区| 国产麻豆剧传媒精品国产av| 久久久夜色精品亚洲| 青青青视频在线免费观看| 亚洲另类色综合网站| 日韩成人免费观看| 91福利区一区二区三区| 国产又大又黑又粗| 亚洲二区在线播放视频| sese一区| 欧美黄色片视频| 精品3atv在线视频| 91久久精品美女高潮| 美腿丝袜亚洲图片| 亚洲欧洲免费无码| 一区二区亚洲| 日本人69视频| 99精品国产91久久久久久| 国产成人精品视频免费| 亚洲大片在线观看| 中文字幕精品一区二区精| 欧美成人三级电影在线| 搞黄视频免费在线观看| 欧美激情中文字幕在线| 制服诱惑亚洲| 成人综合色站| 色欧美自拍视频| 欧美一级免费播放| 久久成人18免费观看| 玖玖爱在线精品视频| 国产精品电影一区二区三区| 日韩少妇高潮抽搐| 欧美一级黄色录像| www.中文字幕久久久| 国外成人在线视频| 国产一区二区三区视频在线| 欧美亚州在线观看| 亚洲视频高清| 中文字幕在线观看日| 久久久亚洲高清| 国产精品第一页在线观看| 欧美精品黑人性xxxx| 国产视频第一页在线观看| 国内久久久精品| 麻豆精品在线| 在线亚洲美日韩| 日韩高清电影一区| 日韩 中文字幕| 亚洲一区在线免费观看| 国产麻豆免费视频| 中文字幕一区二区三区电影| 偷拍精品精品一区二区三区| 九九九九精品九九九九| 精品av久久久久电影| 色哟哟免费视频| 亚洲欧洲一区二区在线播放| 中文字幕 欧美激情| 亚洲午夜av久久乱码| 韩国成人动漫| 欧美亚洲免费高清在线观看| 亚洲少妇自拍| 欧美精品欧美极品欧美激情| 亚洲一区二区视频在线| 国产欧美久久久| 久久精品国产亚洲精品2020| 激情小说亚洲| 亚洲五月六月| 久久精品国产99国产精品| 亚洲精品视频网址| 日本韩国欧美三级| 国产尤物视频在线| 国产成人精彩在线视频九色| 国产成人1区| 欧美精品成人网| 欧美经典一区二区| 91久久久久国产一区二区| 久久九九全国免费精品观看| 999精品嫩草久久久久久99| 韩国黄色一级大片| 国产精品香蕉一区二区三区| 免费在线观看黄色av| 欧美sm极限捆绑bd| av中文字幕在线观看第一页| 精品视频在线观看| 久久xxxx精品视频| 美女av免费看| 91精品国产免费| 日韩123区| 国产综合欧美在线看| 麻豆91精品| 亚洲激情图片网| 欧美成人精品高清在线播放 | 天天影视色香欲综合网老头| 亚洲 国产 欧美 日韩| 国产成人自拍视频在线观看| 四季av一区二区三区免费观看| 国产探花在线观看视频| 午夜影院久久久| 国产三级视频在线| 91久久久久久久久久久| 精品成人一区| 精品成人无码一区二区三区| 在线观看91精品国产麻豆| а√天堂中文在线资源8| 欧美一区二区福利| 久久99精品久久久| 精品一级少妇久久久久久久| 日韩精品在线播放| 日韩三级成人| 男人的天堂狠狠干| 国产精品系列在线| 东京干手机福利视频| 国产成人精品视| 欧美不卡高清| 欧美做受xxxxxⅹ性视频| 日本韩国精品一区二区在线观看| 中文字幕中文字幕在线十八区| 久久大片网站| 国内久久婷婷综合| 亚洲天堂一区在线观看| 久久亚洲精品国产亚洲老地址| 玖玖玖免费嫩草在线影院一区| 在线观看日本一区二区| 亚洲成av人片| 八戒八戒神马在线电影| 你懂的视频在线一区二区| 国产精品一区2区| 中文字幕1区2区3区| 国外色69视频在线观看|