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

MariaDB之Spider存儲引擎實踐詳解

存儲 存儲軟件 MariaDB
本文探討使用MySQL/MariaDB的Spider存儲引擎通過使用單個表鏈接到多臺服務器的實例。Spider是MariaDB提供的一個新存儲引擎,可以讓一個標準配置的MariaDB成為一個分布式數據。

 本文探討使用MySQL/MariaDB的Spider存儲引擎通過使用單個表鏈接到多臺服務器的實例。

Spider是MariaDB提供的一個新存儲引擎,可以讓一個標準配置的MariaDB成為一個分布式數據。

雖然實現起來還是會有點復雜,但技術并不太難。本文就來給各位介紹Spider存儲引擎的工作與技術原理,并會提供一些實用案例。

[[318892]]

MariaDB存儲引擎

存儲引擎是用于管理低級別數據訪問的代碼級別實現,它處理寫入和讀取數據,行鎖定,多版本控制以及事務處理等。

從MySQL版本開始,存儲引擎不斷發展,由表的基礎開始,定義一張表使用指定的存儲引擎(ENGINE Table),創建后數據庫管理系統開始處理,比如表之間的連接,從一張表中選擇數據等。在MySQL和MariaDB中,創建完表后,仍然可以更改表的存儲引擎。

高能Spider

Spider,一款名為蜘蛛的存儲引擎,它提供的是從一臺MariaDB服務器訪問另一臺MariaDB服務器的方法,保存實際表數據的MariaDB服務器可以沒有任何Spider處理代碼,一臺普通的MySQL/MariaDB服務器即可。

可以在一臺MariaDB上配置Spider,通過使用Spider存儲引擎訪問常規的MySQL API通信協議就可以正常訪問另一臺MariaDB上的數據。

 

上圖中,我們看到,Spider僅在引用節點上安裝激活,目標節點并不需要安裝Spider。即創建一個Spider表,這意味著我們定義了一張表,這張表包括目標表中的相同一列或此列的子集以及引用的服務器。

安裝Spider存儲引擎

Spider已經包含在MariaDB服務器中,并提供了一個安裝Spider的腳本,我們使用它來安裝。

如果將MariaDB以RPM方式安裝,Spider將安裝在/usr/share/mysql中,腳本名字是install_spider.sql。我們使用MariaDB的命令行source執行即可:

  1. $ mysql -u root 
  2. Welcome to the MariaDB monitor. Commands end with ; or \g. 
  3. Your MariaDB connection id is 2835 
  4. Server version: 10.4.6-MariaDB-log MariaDB Server 
  5. Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. 
  6. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. 
  7.  
  8. MariaDB> source /usr/share/mysql/install_spider.sql 

腳本運行完成,使用SHOW ENGINES命令來查看所有安裝的存儲引擎:

  1. MariaDB> SHOW ENGINES; 
  2. +--------------------+---------+-------------------------------------------------------------------------------------------------+--------------+------+------------+ 
  3.  
  4. | Engine | Support | Comment | Transactions | XA | Savepoints | 
  5.  
  6. +--------------------+---------+-------------------------------------------------------------------------------------------------+--------------+------+------------+ 
  7.  
  8. | SPIDER | YES | Spider storage engine | YES | YES | NO | 
  9.  
  10. | MRG_MyISAM | YES | Collection of identical MyISAM tables | NO | NO | NO | 
  11.  
  12. | MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO | 
  13.  
  14. | Aria | YES | Crash-safe tables with MyISAM heritage. Used for internal temporary tables and privilege tables | NO | NO | NO | 
  15.  
  16. | MyISAM | YES | Non-transactional engine with good performance and small data footprint | NO | NO | NO | 
  17.  
  18. SEQUENCE | YES | Generated tables filled with sequential values | YES | NO | YES | 
  19.  
  20. | InnoDB | DEFAULT | Supports transactions, row-level locking, foreign keys and encryption for tables | YES | YES | YES | 
  21.  
  22. | PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO | 
  23.  
  24. | CSV | YES | Stores tables as CSV files | NO | NO | NO | 
  25.  
  26. +--------------------+---------+-------------------------------------------------------------------------------------------------+--------------+------+------------+ 
  27.  
  28. rows in set (0.001 sec) 

可以看到Spider引擎已經就緒,已經可以開始使用。

Spider單表連接

來看一個基礎的例子:在目標服務器上創建一張表。再次提示,目標服務器不需要Spider,僅訪問遠端數據的服務器是必需的。現在我們在目標服務器上創建一張新表,不妨稱它為Sever2:

  1. $ mysql -u root -S /tmp/mariadb2.sock -u root 
  2.  
  3. Welcome to the MariaDB monitor. Commands end with ; or \g. 
  4.  
  5. Your MariaDB connection id is 11 
  6.  
  7. Server version: 10.4.8-MariaDB MariaDB Server 
  8.  
  9. Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. 
  10.  
  11.  
  12.  
  13. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. 
  14.  
  15.  
  16.  
  17.  
  18.  
  19. MariaDB [(none)]> CREATE DATABASE spidertest; 
  20.  
  21. Query OK, 1 row affected (0.001 sec) 
  22.  
  23. MariaDB [(none)]> use spidertest; 
  24.  
  25. Database changed 
  26.  
  27. MariaDB [spidertest]> CREATE TABLE customer( 
  28.  
  29. id INT NOT NULL PRIMARY KEY AUTO_INCREMENT, 
  30.  
  31. name VARCHAR(200) NOT NULL
  32.  
  33. address VARCHAR(255) NOT NULL); 
  34.  
  35. Query OK, 0 rows affected (0.539 sec) 

接下來向該表中插入一些測試數據:

  1. MariaDB [spidertest]> INSERT INTO customer VALUES(NULL'John Doe''1 Main Street'); 
  2.  
  3. Query OK, 1 row affected (0.309 sec) 
  4.  
  5. MariaDB [spidertest]> INSERT INTO customer VALUES(NULL'Bob Smith''45 Elm Street'); 
  6.  
  7. Query OK, 1 row affected (0.092 sec) 
  8.  
  9. MariaDB [spidertest]> INSERT INTO customer VALUES(NULL'Jane Jones'
  10.  
  11. '18 Second Street'); 
  12.  
  13. Query OK, 1 row affected (0.094 sec) 

我承認這個不是瑪麗.居里夫人發明鐳一樣的驚喜實驗,但可以看到數據也已經成功插入到剛才的新表中。現在要做的事是從MariaDB服務器的另一個實例來訪問該表。當Spider以普通用戶身份連接到遠程服務器,需要在同一臺MariaDB Server上創建一個用戶帳戶,并為它授予創建數據表的權限。

  1. MariaDB [spidertest]> CREATE USER 'spider'@'192.168.0.11' IDENTIFIED BY 'spider'
  2.  
  3. Query OK, 0 rows affected (0.236 sec) 
  4.  
  5. MariaDB [spidertest]> GRANT ALL ON spidertest.* TO 'spider'@'192.168.0.11'
  6.  
  7. Query OK, 0 rows affected (0.238 sec) 
  8.  
  9.  
  10.  
  11. MariaDB [spidertest]> GRANT ALL ON mysql.* TO 'spider'@'192.168.0.11'
  12.  
  13. Query OK, 0 rows affected (0.238 sec) 

下一步創建一個Server。如果之前你沒有用過Spider,也不會用到這個命令,它是用來連接MariaDB Server實例以及相關參數,該服務器是在MariaDB Server實例上定義的。

下面是訪問我們在上面創建的表(稱為Server1)

  1. $ mysql -u root -S /tmp/mariadb1.sock -u root 
  2.  
  3. Welcome to the MariaDB monitor. Commands end with ; or \g. 
  4.  
  5. Your MariaDB connection id is 12 
  6.  
  7. Server version: 10.4.8-MariaDB MariaDB Server 
  8.  
  9. Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. 
  10.  
  11. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. 
  12.  
  13.  
  14.  
  15. MariaDB [none]> CREATE SERVER Server2 FOREIGN DATA WRAPPER mysql 
  16.  
  17. OPTIONS(HOST '192.168.0.11'DATABASE 'spidertest', PORT 10482, 
  18.  
  19. USER 'spider'PASSWORD 'spider'); 
  20.  
  21. Query OK, 0 rows affected (0.233 sec) 

好的,下面就可以用Spider創建從Server1到Server2的鏈接了(我們也不必使用目標表中的所有字段)。

  1. $ mysql -u root -S /tmp/mariadb1.sock -u root 
  2.  
  3. Welcome to the MariaDB monitor. Commands end with ; or \g. 
  4.  
  5. Your MariaDB connection id is 33 
  6.  
  7. Server version: 10.4.8-MariaDB MariaDB Server 
  8.  
  9. Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. 
  10.  
  11. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. 
  12.  
  13.  
  14.  
  15. MariaDB [(none)]> DROP DATABASE IF EXISTS spidertest; 
  16.  
  17. Query OK, 0 rows affected, 1 warning (0.000 sec) 
  18.  
  19. MariaDB [(none)]> CREATE DATABASE spidertest; 
  20.  
  21. Query OK, 1 row affected (0.001 sec) 
  22.  
  23. MariaDB [(none)]> use spidertest; 
  24.  
  25. Database changed 
  26.  
  27. MariaDB [spidertest]> CREATE TABLE customer( 
  28.  
  29. id INT NOT NULL PRIMARY KEY AUTO_INCREMENT, 
  30.  
  31. name VARCHAR(200) NOT NULL) ENGINE=Spider 
  32.  
  33. COMMENT = 'wrapper "mysql", srv "Server2"'
  34.  
  35. Query OK, 0 rows affected (0.132 sec) 

OK,沒有出現任何錯誤。接著我們來用SELECT獲取數據。

  1. MariaDB [spidertest]> SELECT * FROM customer; 
  2.  
  3. +----+------------+ 
  4.  
  5. | id | name | 
  6.  
  7. +----+------------+ 
  8.  
  9. | 1 | John Doe | 
  10.  
  11. | 2 | Bob Smith | 
  12.  
  13. | 3 | Jane Jones | 
  14.  
  15. +----+------------+ 
  16.  
  17. rows in set (0.006 sec) 

我們看到了,命令運行也已經成功。居里夫人鼓勵我繼續下一步,我們正在一步步接近目標。

用于單表鏈接

即使是單表鏈接,也有不少用途,比如上述表的鏈接。在某些情況下,它只是用來復制單張表,可以用它來替換復制。

比如你有一張表,它在維護著一個數據庫實例,比如客戶數據信息,你希望從另一個MariaDB Server中的應用程序可以引用該庫的CustomerID。

這種配置存在一些缺點。比如,性能是一個大問題,對于使用Spider表的每個語句,都要建立與服務器的連接,本地表與Spider表之間的聯接也可能很慢。總體來說,Spider存儲引擎性能很出色,本身并不瓶頸,還存在很大的調整空間。

第三個選擇是當我們只有一張表時,比如日志表,我并不想與任何其它表混在一起用。那么,Spider表是實現此目標的一種選擇。

使用Spider在多臺服務器上的狀態

比如你運行的MariaDB集群是一個主數據庫和多個輔助數據組成,我們可以將此集群的所有服務器視為一個單元。接著派Spider出場,在當前場景下,有兩個要監視的服務器,一個叫moe,另一個叫homer,moe是主服務器,我們還希望在此中看到兩個服務器的全局狀態。

在homer服務器上,我們基于infomation_schema.GLOBAL STATUS創建一個視圖,添加一個用來保存服務器名字的字段再保存到數據庫中。如下:

  1. CREATE OR REPLACE VIEW global_status_homer 
  2.  
  3. AS SElECT 'homer' host, gs.variable_name, gs.variable_value 
  4.  
  5. FROM information_schema.global_status gs; 

我們在moe服務器上做相同的事情:

  1. CREATE OR REPLACE VIEW global_status_moe 
  2.  
  3. AS SElECT 'moe' host, gs.variable_name, gs.variable_value 
  4.  
  5. FROM information_schema.global_status gs; 

接下來,創建主服務器moe到另一臺服務器homer的鏈接。在moe上我們創建如下命令:

  1. CREATE OR REPLACE SERVER homer FOREIGN DATA WRAPPER mysql 
  2.  
  3. OPTIONS(HOST '192.168.0.11'DATABASE 'mysql', PORT 10482, USER 'spider'
  4.  
  5. PASSWORD 'spider'); 

如此就在moe上創建了一個新視圖,用來查看homer服務器的狀態。

  1. CREATE OR REPLACE TABLE global_status_homer(host varchar(2048), variable_name VARCHAR(64), variable_value VARCHAR(64)) ENGINE=Spider COMMENT='wrapper "mysql", srv "homer"'

在homer服務器上,現有一張表和一張視圖。每臺服務器都有一個視圖,具有相似的架構,它們反映著整個集群的狀態。接下來把兩張表結合成一個視圖。

  1. CREATE OR REPLACE VIEW global_status_all AS 
  2.  
  3. SELECT host, variable_name, variable_value 
  4.  
  5. FROM global_status_homer 
  6.  
  7. UNION 
  8.  
  9. SELECT host, variable_name, variable_value 
  10.  
  11. FROM global_status_moe; 

然后,視圖會顯示整個集群的狀態。

  1. CREATE OR REPLACE VIEW global_status_total AS 
  2.  
  3. SELECT variable_name, SUM(variable_value) sumMAX(variable_value) max
  4.  
  5. MIN(variable_value) min 
  6.  
  7. FROM global_status_all 
  8.  
  9. GROUP BY variable_name; 

來測試下,它能不能正常工作:

  1. MariaDB [mysql]> SELECT * FROM global_status_total WHERE variable_name LIKE 'open%'
  2.  
  3. +--------------------------+------+------+------+ 
  4.  
  5. | variable_name | sum | max | min | 
  6.  
  7. +--------------------------+------+------+------+ 
  8.  
  9. | OPENED_FILES | 629 | 477 | 152 | 
  10.  
  11. | OPENED_PLUGIN_LIBRARIES | 1 | 1 | 0 | 
  12.  
  13. | OPENED_TABLES | 112 | 75 | 37 | 
  14.  
  15. | OPENED_TABLE_DEFINITIONS | 125 | 95 | 30 | 
  16.  
  17. | OPENED_VIEWS | 85 | 43 | 42 | 
  18.  
  19. | OPEN_FILES | 132 | 76 | 56 | 
  20.  
  21. | OPEN_STREAMS | 0 | 0 | 0 | 
  22.  
  23. | OPEN_TABLES | 77 | 46 | 31 | 
  24.  
  25. | OPEN_TABLE_DEFINITIONS | 83 | 49 | 34 | 
  26.  
  27. +--------------------------+------+------+------+ 
  28.  
  29. rows in set (0.029 sec) 

嗯,盡管這是一個簡單實例,但它卻很有用。如果服務器多于兩臺時,它會更有價值。

合并多個服務器表

在上面的例子中,我們研究了如何使用Spider表將具有相似內容和相同結構的表合并到一個視圖中,這在實際場合中有價值的應用,比如有一個多實例的應用程序,如某個由多個部門使用的ERP應用,如果要從報表服務器做跨部門報告,則可以使用此模型訪問該應用程序的全部實例。

Spider的替代解決方案是使用多源復制,但它需要在報表服務器中存儲更多冗余的數據,這便是Spider解決方案的優勢。

Spider分表

分片(也可稱為分表)是Spider最常見的用例了。在前面我將一臺服務器的表映射到另外一臺服務器的表,也可以將Spider用于服務器上的分區表,每個分區都在單獨的服務器上,除此之外在實踐上并沒有什么區別。

盡管Spider可以在分區用例上做更多有趣的事情,對于這些特定用例Spider還有一些性能增強能力。

來舉一個簡單的示例,我們來展示使用兩個分片來設置分區,為了展示其原理,我們將使用customer表。在此實例中總共有三臺服務器,兩臺“數據服務器”,其中包含兩個分片數據和一臺服務器,而“Spider”服務器中沒有任何正在使用表的實際數據,而指向的是駐留在其它兩以服務器上的數據。

 

從最基礎開始,先創建在MariaDB Server2和Server3中使用的表(與Customer表相似,但也不完全相同)。這兩臺服務器均以root用戶身份運行。

  1. CREATE DATABASE IF NOT EXISTS spidertest; 
  2.  
  3. CREATE TABLE spidertest.customer( 
  4.  
  5. id INT NOT NULL PRIMARY KEY
  6.  
  7. name VARCHAR(200) NOT NULL
  8.  
  9. address VARCHAR(255) NOT NULL); 

現在已經創建兩個分表,接著來創建鏈接,從MariaDB Server1來訪問它們,我們在Server1上執行類似于以下SQL語句,里面的端口、主機名以及帳號根據情況可以自己更換。

  1. CREATE OR REPLACE SERVER Server2 FOREIGN DATA WRAPPER mysql 
  2.  
  3. OPTIONS(HOST '192.168.0.11'DATABASE 'spidertest', PORT 10482, 
  4.  
  5. USER 'spider'PASSWORD 'spider'); 
  6.  
  7. CREATE OR REPLACE SERVER Server3 FOREIGN DATA WRAPPER mysql 
  8.  
  9. OPTIONS(HOST '192.168.0.11'DATABASE 'spidertest', PORT 10483, 
  10.  
  11. USER 'spider'PASSWORD 'spider'); 

接下來,我們將它和一個分區表綁定在一起,注意你可以在此使用任何合理的分區方案,我們只是選擇一個簡單的方案來說明這一點。

  1. CREATE TABLE spidertest.customer(id INT NOT NULL PRIMARY KEY
  2.  
  3. name VARCHAR(200) NOT NULL
  4.  
  5. address VARCHAR(255) NOT NULL) ENGINE=Spider 
  6.  
  7. COMMENT 'wrapper "mysql", table "customer"' 
  8.  
  9. PARTITION BY RANGE(id) ( 
  10.  
  11. PARTITION p0 VALUES LESS THAN (1000) COMMENT = 'srv "Server2"'
  12.  
  13. PARTITION p1 VALUES LESS THAN (2000) COMMENT = 'srv "Server3 

現在,我們在Server1上可以插入一些數據,并在Server2和Server3看到它們的顯示。

  1. INSERT INTO customer VALUES(1, 'Larry''Main Street 1'); 
  2.  
  3. INSERT INTO customer VALUES(2, 'Ed''Main Street 1'); 
  4.  
  5. INSERT INTO customer VALUES(3, 'Bob''Main Street 1'); 
  6.  
  7. INSERT INTO customer VALUES(1001, 'Monty''Main Street 1'); 
  8.  
  9. INSERT INTO customer VALUES(1002, 'David''Main Street 1'); 
  10.  
  11. INSERT INTO customer VALUES(1003, 'Allan''Main Street 1'); 

根據分區設置,1-3行將進入Server2,最后3行將進入Server3。我們會在本節完成之前提出來,分區分表是常見的MariaDB實景,沒有Spider存儲引擎,因此可以通過連接到Server2或Server3,逐個分表來訪問。

用于Spider的分片

分片的明顯優勢是在處理大型數據集合時可以有效提高性能。除了以上功能外,Spider存儲引擎還有其它優點,比如每個分片都可以單獨訪問普通的MariaDB Server,即可以按分片查看數據集,而不存在任何瓶頸,亦可以將其視為整體,同時使用Spider。

小結

本文介紹了Spider存儲引擎的一些基本用法,這些用法對開發者都是很有用的,相關文檔還可參考Spider的分片用例文檔:https://mariadb.com/docs/usage/sharding/,你會發現前兩種用法對于一些人會驚訝加啟發。

責任編輯:武曉燕 來源: 21CTO
相關推薦

2018-09-05 13:14:54

MySQLInnoDBMyISAM

2011-05-03 10:09:37

MySQL存儲引擎

2015-07-09 13:47:37

IOSFMDB

2018-06-07 16:33:31

大數據冷熱數據存儲平臺

2020-04-10 12:12:13

InnoDB存儲架構

2023-02-28 11:29:09

存儲函數MySQL

2018-12-19 13:45:56

Hive實踐存儲

2025-02-28 09:20:00

Future開發代碼

2011-04-06 08:54:38

游標腳本性能問題

2012-03-20 11:16:24

MySQLMyISAM

2018-08-31 10:53:25

MySQL存儲引擎

2012-12-24 09:01:41

iOSUnity3D

2018-01-03 11:22:45

2020-01-10 17:43:11

MySQL數據庫文章

2019-06-11 16:11:16

MySQLMyISAMInnoDB

2014-12-17 10:54:14

MongoDB

2021-08-10 14:29:06

MySQL數據庫存儲

2019-01-14 14:25:25

MySQL存儲邏輯架構

2019-06-04 15:27:49

InnoDB存儲引擎

2021-10-07 16:45:44

存儲網絡場景
點贊
收藏

51CTO技術棧公眾號

在线综合亚洲欧美在线视频| 免费人成在线不卡| 亚洲国产精品va| av免费播放网址| 最新国产在线观看| 国产一区二区在线观看免费| 97在线视频一区| 超碰人人人人人人人| 国产视频网站一区二区三区| 欧美日韩精品二区| 中文字幕超清在线免费观看| 天天摸天天碰天天爽天天弄| 久久国产三级精品| 5566日本婷婷色中文字幕97| 国产一区二区精彩视频| 妖精一区二区三区精品视频| 日韩一区二区三区免费看| 日本毛片在线免费观看| 4438x成人网全国最大| 久久九九久久九九| dy888夜精品国产专区| 免费看污视频的网站| 亚洲网址在线| 久久精品视频亚洲| 天天躁日日躁aaaxxⅹ| 国产精品极品国产中出| 91精品国产91热久久久做人人| 欧美性大战久久久久xxx| 中文在线观看免费| 国产精品久久久久久妇女6080| 鲁鲁狠狠狠7777一区二区| 亚洲av永久纯肉无码精品动漫| 日日夜夜免费精品视频| 96精品视频在线| 青青操视频在线播放| 日韩精品影视| 中文日韩在线视频| 成年人免费观看视频网站| а√中文在线天堂精品| 日韩一区二区在线播放| 992tv人人草| 羞羞视频在线观看一区二区| 欧美日韩一区三区| 中文字幕第21页| 国产亚洲一区二区手机在线观看| 欧美日韩国产精品专区| 日本国产在线播放| 国产在线天堂www网在线观看| 一区二区三区毛片| 成年在线观看视频| av在线免费播放| 亚洲欧美日韩久久| 国产91porn| 亚洲电影视频在线| 亚洲一区二区高清| 加勒比成人在线| 91在线超碰| 欧美日韩国产精品一区二区三区四区| 狠狠97人人婷婷五月| 性xxxxfreexxxxx欧美丶| 欧美小视频在线| 欧美激情精品久久久久久小说| 欧美xoxoxo| 色欧美片视频在线观看| 性生交免费视频| 日韩伦理一区二区| 欧美一级专区免费大片| 人妻激情偷乱频一区二区三区| 成人精品毛片| 亚洲欧美制服中文字幕| 一级黄色录像毛片| 亚洲成人精品| 久久久欧美精品| 国产91精品一区| 免费不卡在线观看| 97se亚洲综合| 天堂中文在线视频| 久久理论电影网| 一区二区精品视频| 人人澡人人添人人爽一区二区| 亚洲成a人片在线不卡一二三区 | 国产精品三级在线| 国产精品伊人久久| 99久精品国产| 亚洲福利av在线| 午夜dj在线观看高清视频完整版| 五月婷婷激情综合网| 毛葺葺老太做受视频| 中文成人在线| 日韩成人在线视频| 国产人与禽zoz0性伦| 亚洲性感美女99在线| 国产高清在线不卡| 99热精品在线播放| 久久人人爽人人爽| 国产手机视频在线观看| 色在线视频观看| 91精品国产综合久久小美女| 欧产日产国产精品98| 日本不卡免费一区| 97视频在线观看免费高清完整版在线观看| 亚洲 国产 日韩 欧美| 国产精品18久久久久久久久久久久| 久久久久久久久久码影片| 三区四区在线视频| 黑人欧美xxxx| 9191在线视频| 日韩精品午夜| 日本午夜人人精品| 懂色av成人一区二区三区| 中文字幕高清一区| 国产又黄又大又粗视频| 精品久久亚洲| 中文字幕日韩精品在线| 日韩免费黄色片| 国产在线精品一区二区 | 日韩欧美在线中字| 国产91ⅴ在线精品免费观看| 北条麻妃一二三区| 18欧美乱大交hd1984| 99精品人妻少妇一区二区| 久久九九精品视频| 精品国产美女在线| 欧美成人一区二区视频| 久久综合九色综合97婷婷 | 日韩影院在线观看| 精品日本一区二区三区| missav|免费高清av在线看| 日韩亚洲欧美成人一区| 可以免费看av的网址| 日韩va亚洲va欧美va久久| 久久www免费人成精品| 污视频免费在线观看| 日韩一区二区精品在线观看| 久久精品一区二区三区四区五区| 日韩av成人高清| 日韩精品久久久| 日韩a**中文字幕| 精品爽片免费看久久| 日本熟妇成熟毛茸茸| 成人妖精视频yjsp地址| h无码动漫在线观看| 五月亚洲婷婷| 欧美激情一二三| 亚洲国产精品久久人人爱潘金莲| 亚洲免费观看高清完整版在线观看熊| 91丨九色丨蝌蚪| 先锋资源久久| 91青草视频久久| 影音先锋男人资源在线| 日韩欧美中文字幕制服| 免费看一级一片| 成人av在线播放网址| 我的公把我弄高潮了视频| 麻豆精品av| 国产成人精彩在线视频九色| 风间由美一区| 欧美挠脚心视频网站| 国产suv精品一区二区68| 国产精品一卡二| 久久99久久99精品| 亚州综合一区| 国产精品第三页| 免费在线观看av网站| 欧美一区二区精品在线| 国产一级片免费| 91影院在线观看| 男人插女人下面免费视频| 97视频热人人精品免费| 99一区二区三区| 蜜桃视频m3u8在线观看| 亚洲视频免费一区| 国产精品久久久久久久久久久久久久久久久久 | 麻豆精品国产91久久久久久| 99re99热| 久久99精品国产自在现线| 情事1991在线| 国产一二区在线| 亚洲国产精品人久久电影| 日本中文字幕在线观看视频| 亚洲人成网站在线| 中国一级特黄录像播放| 日韩av午夜在线观看| 嫩草影院中文字幕| 禁果av一区二区三区| 91网站免费看| 精品国产免费人成网站| 久久中文字幕在线| 欧美在线观看在线观看| 91精品国产入口在线| 韩国av中文字幕| 最新热久久免费视频| 久久人妻少妇嫩草av无码专区| 日本伊人午夜精品| 国产精品igao激情视频| 精品不卡一区| 极品尤物一区二区三区| 欧美成人黄色| 欧美在线影院在线视频| 超碰porn在线| 中文字幕久久久av一区| 视频一区二区免费| 日韩一区二区三区视频在线观看 | 天堂av在线电影| 国产一区二区动漫| 污视频在线免费| 91精品国产色综合久久ai换脸| 无码视频在线观看| 香蕉成人伊视频在线观看| 五月天色婷婷丁香| 国产日韩av一区二区| 亚洲啪av永久无码精品放毛片 | 午夜av在线免费观看| 中日韩午夜理伦电影免费| 天堂成人在线| 精品欧美一区二区久久| 国产精品久久久久久久成人午夜| 色哟哟日韩精品| 国产成人亚洲欧洲在线| 亚洲精品少妇30p| 亚洲少妇xxx| 日本一区二区高清| 中文字幕第4页| 99国产精品久| 中文字幕在线视频播放| 风间由美一区二区三区在线观看| 日本中文字幕观看| 蜜臀av性久久久久蜜臀av麻豆| 97国产精东麻豆人妻电影 | 91精品国产色综合久久不卡98口| 成人黄视频在线观看| 日韩中文在线中文网在线观看| 免费在线一级视频| 日韩精品在线观看视频| 亚洲欧美自偷自拍| 日韩电影在线观看中文字幕 | 久久综合电影一区| 免费av网站在线看| 日韩在线视频导航| 在线播放麻豆| 日韩中文字幕亚洲| 日韩大片在线永久免费观看网站| 中文字幕免费精品一区| 91短视频版在线观看www免费| 一本久久综合亚洲鲁鲁| 国产高清在线| 日韩亚洲欧美成人| 黄色免费在线观看| 欧美成人中文字幕在线| 五月婷婷视频在线观看| 久久免费精品视频| 激情国产在线| 国产成人91久久精品| 日韩不卡在线| 国产精品久久国产精品99gif| 69堂精品视频在线播放| 国产精自产拍久久久久久| 日韩成人在线一区| 91九色对白| 玖玖玖免费嫩草在线影院一区| 久久视频在线观看中文字幕| 亚洲精品亚洲人成在线观看| 日韩av不卡在线播放| 99热精品久久| 精品人妻人人做人人爽| 一本久道综合久久精品| 女性隐私黄www网站视频| 蜜桃视频一区二区三区| 午夜免费福利网站| www.欧美日韩| 欧美大波大乳巨大乳| 亚洲欧洲日产国码二区| 久久精品久久国产| 日本精品一区二区三区四区的功能| 中文字幕av久久爽| 日韩欧美成人激情| 久久久久久久久亚洲精品| 日韩中文视频免费在线观看| 国产精品国精产品一二| 国产97免费视| 精品视频一二| 欧美日本韩国国产| 亚洲国产精品91| 男女激情无遮挡| 老司机午夜精品| 黄色av网址在线观看| 国产欧美综合在线观看第十页| 成熟的女同志hd| 欧美性极品xxxx做受| 国产精品区在线观看| 精品视频在线观看日韩| 成人在线观看亚洲| 日韩美女视频免费看| 日韩国产在线不卡视频| 欧美亚洲一级二级| 伊人久久大香线蕉综合四虎小说| 黄色片视频在线免费观看| 国产麻豆视频精品| 亚洲欧洲久久久| 亚洲第一福利一区| 一本色道久久综合熟妇| 日韩激情av在线播放| 97caopron在线视频| 国产成人免费av| 九九热hot精品视频在线播放| 亚洲一区尤物| 久久精品亚洲一区二区| 久久精品aⅴ无码中文字字幕重口| 91免费观看在线| 久久久久久久中文字幕| 欧美久久久一区| 精品久久av| 97视频com| 99re6热只有精品免费观看| 一区二区三区精品国产| 久久亚洲风情| theav精尽人亡av| 亚洲一二三区视频在线观看| 国产孕妇孕交大片孕| 一本色道久久综合亚洲精品小说| а√在线中文在线新版| 北条麻妃高清一区| 综合久久婷婷| 成年人三级黄色片| 国产精品毛片高清在线完整版 | 91精品国产综合久久久久久漫画| 九色在线免费| 欧美一区二区三区图| 久久视频在线观看| 日韩小视频网站| 国产成人av一区二区三区在线| 黄视频网站免费看| 欧美精品99久久久**| 番号在线播放| 国产精品久久久久久久久久免费 | 欧美激情啊啊啊| 久久综合偷偷噜噜噜色| 艳母动漫在线观看| 国产一区二区三区精品欧美日韩一区二区三区 | 国产精品免费视频一区| 超碰在线观看91| 综合激情国产一区| 日本欧美在线| 熟女视频一区二区三区| 精品亚洲免费视频| 性欧美videos| 日韩三级在线观看| 美女91在线| 精品欧美国产| 六月婷婷一区| 欧美熟妇激情一区二区三区| 91久久一区二区| 最新真实国产在线视频| 91欧美视频网站| 亚洲国产激情| 免费毛片视频网站| 欧美日韩精品一区二区三区| 欧美13一16娇小xxxx| 亚洲专区中文字幕| 亚洲久久一区| 免费黄在线观看| 91超碰这里只有精品国产| 日本大片在线播放| 蜜桃成人在线| 麻豆精品在线播放| 欧美性猛交xxxxx少妇| 亚洲第一偷拍网| 天天免费亚洲黑人免费| 制服诱惑一区| 成人网在线免费视频| 国产又大又黄又粗| 尤物九九久久国产精品的特点| 国产999精品在线观看| 大伊香蕉精品视频在线| 久久久国产午夜精品| 一级做a爱片久久毛片| 欧美黑人xxx| 欧美美女在线观看| 欧美一级视频在线| 亚洲国产精品久久久久秋霞影院 | 国产精品伊人久久| 69视频在线免费观看| 成人aaaa| 又黄又爽的网站| 欧美色中文字幕| 爱情岛亚洲播放路线| 亚洲bbw性色大片| 成人午夜激情片| 国产又粗又大又爽视频| 97精品视频在线播放| 色小子综合网| 欧美 日本 国产| 宅男噜噜噜66一区二区66| av高清不卡| 成年在线观看视频| 国产精品久久网站| 三级在线视频| αv一区二区三区| 久久狠狠亚洲综合| 国产超碰人人爽人人做人人爱|