久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Java使用Sharding-JDBC分庫(kù)分表進(jìn)行操作

瀏覽:3日期:2023-12-04 09:20:41
目錄主從庫(kù)搭建Compose FileMaster 配置Slave 配置主從配置創(chuàng)建分庫(kù)分表Order 1 庫(kù)Order 2 庫(kù)User 庫(kù)Sharding-JDBC 引入Sharding-JDBC 配置可選配置數(shù)據(jù)源配置主從復(fù)制配置數(shù)據(jù)節(jié)點(diǎn)配置Demo 程序

Sharding-JDBC 是無侵入式的 MySQL 分庫(kù)分表操作工具,所有庫(kù)表設(shè)置僅需要在配置文件中配置即可,無須修改任何代碼。本文寫了一個(gè) Demo,使用的是 SpringBoot 框架,通過 Docker 進(jìn)行 MySQL 實(shí)例管理,分庫(kù)分表結(jié)構(gòu)如下圖,同時(shí)所有的庫(kù)都進(jìn)行了主從復(fù)制:

Java使用Sharding-JDBC分庫(kù)分表進(jìn)行操作

主從庫(kù)搭建

Docker 項(xiàng)目結(jié)構(gòu):

docker├── docker-compose.yml├── master│ ├── data│ ├── log│ │ └── error.log│ ├── my.cnf│ └── mysql-files # Win 需要,Linux 不需要├── README.md└── slave ├── data ├── log │ └── error.log ├── my.cnf └── mysql-filesCompose File

version: ’3’networks: sharding-jdbc-demo: driver: bridge ipam: config:- subnet: 172.25.0.0/24services: master: image: mysql container_name: sharding-jdbc-demo-master ports: - '3307:3306' volumes: - './master/data:/var/lib/mysql' - './master/mysql-files:/var/lib/mysql-files' # win 下的 MySQL8 需要,Linux 不需要 - './master/log/error.log:/var/log/mysql/error.log' - './master/my.cnf:/etc/mysql/my.cnf' environment: MYSQL_ROOT_PASSWORD: 123456 entrypoint: bash -c 'chown -R mysql:mysql /var/log/mysql && chmod 644 /etc/mysql/my.cnf && exec /entrypoint.sh mysqld' restart: unless-stopped networks: sharding-jdbc-demo:ipv4_address: 172.25.0.101 slave: image: mysql container_name: sharding-jdbc-demo-slave ports: - '3308:3306' volumes: - './slave/data:/var/lib/mysql' - './slave/mysql-files:/var/lib/mysql-files' - './slave/log/error.log:/var/log/mysql/error.log' - './slave/my.cnf:/etc/mysql/my.cnf' environment: MYSQL_ROOT_PASSWORD: 123456 entrypoint: bash -c 'chown -R mysql:mysql /var/log/mysql && chmod 644 /etc/mysql/my.cnf && exec /entrypoint.sh mysqld' restart: unless-stopped networks: sharding-jdbc-demo:ipv4_address: 172.25.0.102Master 配置

[mysqld]pid-file = /var/run/mysqld/mysqld.pidsocket = /var/run/mysqld/mysqld.sockdatadir = /var/lib/mysqllog-error= /var/log/mysql/error.logbind-address = 0.0.0.0secure-file-priv = NULLmax_connections = 16384character-set-server = utf8mb4collation-server = utf8mb4_general_ciinit_connect =’SET NAMES utf8mb4’skip-name-resolveserver_id = 1log-bin = mysql-binbinlog-do-db = db_order_1 # 復(fù)制 db_order_1binlog-do-db = db_order_2 # 復(fù)制 db_order_2binlog-do-db = db_user # 復(fù)制 db_userlog-slave-updatessync_binlog = 1auto_increment_offset = 1auto_increment_increment = 1expire_logs_days = 7log_bin_trust_function_creators = 1# Custom config should go here!includedir /etc/mysql/conf.d/Slave 配置

[mysqld]pid-file = /var/run/mysqld/mysqld.pidsocket = /var/run/mysqld/mysqld.sockdatadir = /var/lib/mysqllog-error= /var/log/mysql/error.logbind-address = 0.0.0.0secure-file-priv = NULLmax_connections = 16384character-set-server = utf8mb4collation-server = utf8mb4_general_ciinit_connect =’SET NAMES utf8mb4’skip-name-resolveskip-host-cacheserver_id = 2log-bin = mysql-binlog-slave-updatessync_binlog = 0innodb_flush_log_at_trx_commit = 0 # 提交策略replicate-do-db = db_order_1# 復(fù)制 db_order_1replicate-do-db = db_order_2# 復(fù)制 db_order_2replicate-do-db = db_user # 復(fù)制 db_userslave-net-timeout = 60 # 重連時(shí)間log_bin_trust_function_creators = 1# Custom config should go here!includedir /etc/mysql/conf.d/主從配置

啟動(dòng)容器 docker compose up -d;登錄 Master mysql -uroot -h 127.0.0.1 -P 3307 -p ;查看 master 狀態(tài)。

mysql> show master statusG*************************** 1. row ***************************File: mysql-bin.000004 # 記住 Bin log 當(dāng)前文件名稱Position: 156 # 記住 Bin log 當(dāng)前偏移量Binlog_Do_DB: db_order_1,db_order_2,db_user # 確認(rèn)復(fù)制數(shù)據(jù)庫(kù)是否正確Binlog_Ignore_DB:Executed_Gtid_Set:

登錄 Slave mysql -uroot -h 127.0.0.1 -P 3308 -p設(shè)置 Master 連接,注意 host 與 port 是內(nèi)網(wǎng)的地址和端口。

mysql> change master to master_host=’172.25.0.101’, master_user=’root’, master_password=’123456’, master_port=3306, master_log_file=’mysql-bin.000004’, master_log_pos=156;

啟動(dòng)同步

mysql> start slave;

查看 Slave 狀態(tài),若 Slave_IO 與 Slave_SQL 都在運(yùn)行為 YES 即成功。

mysql> show slave statusG*************************** 1. row ***************************Slave_IO_State: Waiting for source to send eventMaster_Host: 172.25.0.101Master_User: rootMaster_Port: 3306Connect_Retry: 60Master_Log_File: mysql-bin.000004Read_Master_Log_Pos: 156Relay_Log_File: d2a706a02933-relay-bin.000002Relay_Log_Pos: 324Relay_Master_Log_File: mysql-bin.000004Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB: db_order_1,db_order_2,db_user創(chuàng)建分庫(kù)分表

登錄 Master,創(chuàng)建數(shù)據(jù)庫(kù):

CREATE DATABASE db_order_1;CREATE DATABASE db_order_2;CREATE DATABASE db_user;

此時(shí)從庫(kù)也會(huì)創(chuàng)建數(shù)據(jù)庫(kù),若沒有,則是主從配置失敗了。此時(shí)已完成垂直分庫(kù)和水平分庫(kù)。接下來創(chuàng)建數(shù)據(jù)表:

Order 1 庫(kù)

先 USE db_order_1;,再分別創(chuàng)建 t_dict 全局表、t_order_1 和 t_order_2 水平分表。

DROP TABLE IF EXISTS `t_dict`;CREATE TABLE `t_dict`( `id` int NOT NULL AUTO_INCREMENT, `type` int NOT NULL, `enum_value` int NOT NULL, `name` varchar(64) COLLATE utf8mb4_general_ci NOT NULL DEFAULT ’’, PRIMARY KEY (`id`)) ENGINE = InnoDB AUTO_INCREMENT = 7 DEFAULT CHARSET = utf8mb4 COLLATE = utf8mb4_general_ci;LOCK TABLES `t_dict` WRITE;INSERT INTO `t_dict` VALUES (1,1,0,’未定義’),(2,1,1,’未付款’),(3,1,2,’已付款’),(4,1,3,’退款中’),(5,1,4,’已退款’),(6,1,5,’已完成’),(7,2,0,’未定義’),(8,2,1,’已創(chuàng)建’),(9,2,2,’已驗(yàn)證’),(10,2,3,’已凍結(jié)’),(11,2,4,’已注銷’),(12,2,5,’已刪除’);UNLOCK TABLES;DROP TABLE IF EXISTS `t_order_1`;CREATE TABLE `t_order_1`( `id` bigint NOT NULL, `user_id` bigint NOT NULL, `price` decimal(10, 2) NOT NULL, `status` int NOT NULL DEFAULT ’1’, PRIMARY KEY (`id`)) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE = utf8mb4_general_ci;DROP TABLE IF EXISTS `t_order_2`;CREATE TABLE `t_order_2`( `id` bigint NOT NULL, `user_id` bigint NOT NULL, `price` decimal(10, 2) NOT NULL, `status` int NOT NULL DEFAULT ’1’, PRIMARY KEY (`id`)) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4 COLLATE = utf8mb4_general_ci;Order 2 庫(kù)

先 USE db_order_2;,再分別創(chuàng)建 t_dict 全局表、t_order_1 和 t_order_2 水平分表。所執(zhí)行 SQL 與 db_order_1 一致。

User 庫(kù)

先 USE db_user;,再分別創(chuàng)建 t_dict 全局表和 t_user 表,此處就不進(jìn)行水平或垂直分表了。垂直分表 sharding-jdbc 不會(huì)去處理,因?yàn)榇怪狈直碇缶褪钱惐懋悩?gòu)了,執(zhí)行 Join 操作就可以了,或者代碼進(jìn)行多次查詢實(shí)現(xiàn)。

DROP TABLE IF EXISTS `t_dict`;CREATE TABLE `t_dict`( `id` int NOT NULL AUTO_INCREMENT, `type` int NOT NULL, `enum_value` int NOT NULL, `name` varchar(64) COLLATE utf8mb4_general_ci NOT NULL DEFAULT ’’, PRIMARY KEY (`id`)) ENGINE = InnoDB AUTO_INCREMENT = 7 DEFAULT CHARSET = utf8mb4 COLLATE = utf8mb4_general_ci;LOCK TABLES `t_dict` WRITE;INSERT INTO `t_dict` VALUES (1,1,0,’未定義’),(2,1,1,’未付款’),(3,1,2,’已付款’),(4,1,3,’退款中’),(5,1,4,’已退款’),(6,1,5,’已完成’),(7,2,0,’未定義’),(8,2,1,’已創(chuàng)建’),(9,2,2,’已驗(yàn)證’),(10,2,3,’已凍結(jié)’),(11,2,4,’已注銷’),(12,2,5,’已刪除’);UNLOCK TABLES;DROP TABLE IF EXISTS `t_user`;CREATE TABLE `t_user`( `id` bigint NOT NULL AUTO_INCREMENT, `name` varchar(128) COLLATE utf8mb4_general_ci NOT NULL DEFAULT ’’, `type` int NOT NULL DEFAULT ’1’, PRIMARY KEY (`id`)) ENGINE = InnoDB AUTO_INCREMENT = 1426999086541635586 DEFAULT CHARSET = utf8mb4 COLLATE = utf8mb4_general_ci;Sharding-JDBC 引入

Sharding-JDBC maven 包:

<!-- Sharding-jdbc --><dependency><groupId>org.apache.shardingsphere</groupId><artifactId>sharding-jdbc-spring-boot-starter</artifactId><version>4.1.1</version></dependency>

本 Demo 其他用到的依賴,分別是 Junit 測(cè)試、Lombok、MyBatis Plus、Druid 連接池、MySQL 驅(qū)動(dòng)、Java Faker 數(shù)據(jù)生成器:

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.13.2</version><scope>test</scope></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><!-- MyBatis Plus --><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.3.1</version></dependency><!-- Druid --><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.2.6</version></dependency><!-- MySQL --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><!-- Sharding-jdbc --><dependency><groupId>org.apache.shardingsphere</groupId><artifactId>sharding-jdbc-spring-boot-starter</artifactId><version>4.1.1</version></dependency><!-- Data Faker --><dependency><groupId>com.github.javafaker</groupId><artifactId>javafaker</artifactId><version>1.0.2</version></dependency></dependencies>Sharding-JDBC 配置可選配置

啟用 SQL 打印:

spring.shardingsphere.props.sql.show = true數(shù)據(jù)源配置

總共有 t_order_1、t_order_2 和 t_user 三個(gè)庫(kù),加上單主單從的復(fù)制,因此有 6 個(gè)數(shù)據(jù)庫(kù),需要配置六個(gè)數(shù)據(jù)源:

# Datasource Definespring.shardingsphere.datasource.names = o1-master,o2-master,o1-slave,o2-slave,u-master,u-slave# datasource o1-masterspring.shardingsphere.datasource.o1-master.type = com.alibaba.druid.pool.DruidDataSourcespring.shardingsphere.datasource.o1-master.driver-class-name = com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.o1-master.url = jdbc:mysql://localhost:3307/db_order_1?useUnicode=truespring.shardingsphere.datasource.o1-master.username = rootspring.shardingsphere.datasource.o1-master.password = 123456# datasource o1-slavespring.shardingsphere.datasource.o1-slave.type = com.alibaba.druid.pool.DruidDataSourcespring.shardingsphere.datasource.o1-slave.driver-class-name = com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.o1-slave.url = jdbc:mysql://localhost:3308/db_order_1?useUnicode=truespring.shardingsphere.datasource.o1-slave.username = rootspring.shardingsphere.datasource.o1-slave.password = 123456# datasource o2-masterspring.shardingsphere.datasource.o2-master.type = com.alibaba.druid.pool.DruidDataSourcespring.shardingsphere.datasource.o2-master.driver-class-name = com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.o2-master.url = jdbc:mysql://localhost:3307/db_order_2?useUnicode=truespring.shardingsphere.datasource.o2-master.username = rootspring.shardingsphere.datasource.o2-master.password = 123456# datasource o2-slavespring.shardingsphere.datasource.o2-slave.type = com.alibaba.druid.pool.DruidDataSourcespring.shardingsphere.datasource.o2-slave.driver-class-name = com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.o2-slave.url = jdbc:mysql://localhost:3308/db_order_2?useUnicode=truespring.shardingsphere.datasource.o2-slave.username = rootspring.shardingsphere.datasource.o2-slave.password = 123456# datasource u-masterspring.shardingsphere.datasource.u-master.type = com.alibaba.druid.pool.DruidDataSourcespring.shardingsphere.datasource.u-master.driver-class-name = com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.u-master.url = jdbc:mysql://localhost:3307/db_user?useUnicode=truespring.shardingsphere.datasource.u-master.username = rootspring.shardingsphere.datasource.u-master.password = 123456# datasource u-slavespring.shardingsphere.datasource.u-slave.type = com.alibaba.druid.pool.DruidDataSourcespring.shardingsphere.datasource.u-slave.driver-class-name = com.mysql.cj.jdbc.Driverspring.shardingsphere.datasource.u-slave.url = jdbc:mysql://localhost:3308/db_user?useUnicode=truespring.shardingsphere.datasource.u-slave.username = rootspring.shardingsphere.datasource.u-slave.password = 123456主從復(fù)制配置

主從配置不需要聲明,在定義時(shí)會(huì)自動(dòng)讀取 key 中的主從配置庫(kù)作為邏輯庫(kù),如下面的 db-order-1。

# Replication Definespring.shardingsphere.sharding.master-slave-rules.db-order-1.master-data-source-name=o1-masterspring.shardingsphere.sharding.master-slave-rules.db-order-1.slave-data-source-names=o1-slavespring.shardingsphere.sharding.master-slave-rules.db-order-2.master-data-source-name=o2-masterspring.shardingsphere.sharding.master-slave-rules.db-order-2.slave-data-source-names=o2-slavespring.shardingsphere.sharding.master-slave-rules.db-user.master-data-source-name=u-masterspring.shardingsphere.sharding.master-slave-rules.db-user.slave-data-source-names=u-slave數(shù)據(jù)節(jié)點(diǎn)配置

數(shù)據(jù)節(jié)點(diǎn),指的是每張數(shù)據(jù)表,由于存在分庫(kù)、分表、全局的不同類型,因此數(shù)據(jù)節(jié)點(diǎn)也有不同類型。注意,由于我們進(jìn)行了主從復(fù)制,因此這里的數(shù)據(jù)庫(kù)不能直接填數(shù)據(jù)源的名稱,應(yīng)該填在主從復(fù)制配置的 Key 中定義的名稱,如 db-user 而不是 u-master 或 u-slave。

全局表:

# BroadCast Tablespring.shardingsphere.sharding.broadcast-tables = t_dict

單庫(kù)單表:key-generator.column 設(shè)置主鍵列。key-generator.type 設(shè)置主鍵生成類型,這里使用雪花算法,其實(shí)沒必要因?yàn)椴皇欠直淼模遣惶钜矔?huì)默認(rèn)使用這個(gè)。

# Data Node t_userspring.shardingsphere.sharding.tables.t_user.actual-data-nodes = db-user.t_userspring.shardingsphere.sharding.tables.t_user.key-generator.column = idspring.shardingsphere.sharding.tables.t_user.key-generator.type = SNOWFLAKE

分庫(kù)分表:在 actual-data-nodes 中使用 groovy 表達(dá)式進(jìn)行設(shè)置。在 database-strategy 中設(shè)置切分方式,具體自查,暫沒時(shí)間寫。

# Data Node t_order, If there is not master-salve-replication, use datasource name like 'o$-master->{1..2}.t_order_$->{1..2}'spring.shardingsphere.sharding.tables.t_order.actual-data-nodes = db-order-$->{1..2}.t_order_$->{1..2}spring.shardingsphere.sharding.tables.t_order.key-generator.column = idspring.shardingsphere.sharding.tables.t_order.key-generator.type = SNOWFLAKE# database sharding strategyspring.shardingsphere.sharding.tables.t_order.database-strategy.inline.sharding-column = user_idspring.shardingsphere.sharding.tables.t_order.database-strategy.inline.algorithm-expression = db-order-$->{user_id % 2 + 1}# table sharding strategyspring.shardingsphere.sharding.tables.t_order.table-strategy.inline.sharding-column = idspring.shardingsphere.sharding.tables.t_order.table-strategy.inline.algorithm-expression = t_order_$->{id % 2 + 1}Demo 程序

參見:zoharyips/sharding-jdbc-demo (github.com)

到此這篇關(guān)于Java使用Sharding-JDBC分庫(kù)分表進(jìn)行操作的文章就介紹到這了,更多相關(guān)Java Sharding-JDBC分庫(kù)分表內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 精品精品 | 影音在线资源 | 91在线精品一区二区三区 | 久久久久久久一区 | 日韩欧美一区二区三区 | 精品久久久久久亚洲综合网站 | 天堂色网 | 国产精品视频久久 | 精品一区二区三区久久久 | 久久久99久久 | 久久亚洲一区 | 99re6在线视频精品免费 | 亚洲人成网站999久久久综合 | 国产精品99久久久久久动医院 | 欧美中文字幕在线 | 91久久精品国产 | 青青草精品 | 亚洲精品国产成人 | 久久99国产精品久久99大师 | www视频在线观看 | 日日摸天天爽天天爽视频 | 在线精品国产 | 精品无人乱码一区二区三区 | 久久99精品久久久久久琪琪 | 日本高清视频在线播放 | 国产成人精品免高潮在线观看 | 欧美自拍视频在线观看 | xvideos视频 | 91久久国产综合久久91精品网站 | 91在线影院| 日韩免费一区二区 | 91国产精品| 国产一区二区欧美 | 欧美精品1 | 成人午夜精品 | 国产激情久久久久久 | 日韩在线一区二区三区 | 一区二区av | 免费在线色 | 国产一区二区自拍视频 | 欧美一区二区三区在线视频 | 色综合中文 | 国产精品视屏 | 青青草久| a一级黄| 久草视 | 成人一级电影在线观看 | 亚洲精品一区二区三区不 | 国产在线精品一区 | 欧美精品网站 | 一级大片一级一大片 | 国产欧美精品区一区二区三区 | 亚洲视频一区 | 欧美精产国品一二三区 | 精品久久久久久久久久久久久久 | 三区在线 | 日韩视频网站在线观看 | 亚洲视频在线播放 | 国产999精品久久久久久 | 超碰美女 | 99re视频| 伊人免费网 | 另类二区 | 日韩欧美h | 国产一级黄色av | 狠狠操精品视频 | 日韩性xxx | 综合一区 | 成人免费福利 | 天天爽夜夜爽夜夜爽精品视频 | 欧美一区二区三区 | 嫩草视频免费在线观看 | 亚洲成人一区 | 亚洲天堂中文字幕 | 中文字幕天天操 | 99re国产| 欧美专区中文字幕 | 视频一区二区三区在线观看 | 91精品一区二区三区久久久久久 | 日本亚洲视频 | 国产精品免费av | 中文字幕在线看第二 | 美女午夜视频 | 国产精品一区二区久久 | 欧美一区二区三区男人的天堂 | 四虎最新网站 | 九九九九九九精品任你躁 | 国产日韩一区二区三区 | 精品国产1区2区3区 在线国产视频 | 久久久国产一区二区 | av观看免费 | 国产艹 | 久久伊人一区二区 | 精品免费视频 | 国产精品久久嫩一区二区 免费 | 欧美精品一区二区三区手机在线 | 国产aaaaav久久久一区二区 | 亚洲va中文字幕 | 久久久久久久99 | 性色av一区二区三区 | 亚洲成人精品在线观看 | 久久久极品 | 国产成人精品免高潮在线观看 | 亚洲福利二区 | 操操日 | 国产精品久久久久久久一区探花 | 日本一区二区不卡 | 日本中文字幕电影 | 奇米二区 | 精品久久久久久久 | 中文字幕日韩欧美 | 亚洲精品一区二区另类图片 | 国产在线观看免费av | 欧美精品一区二区在线观看 | 91看片| 天堂综合网久久 | 成人精品一区二区 | 国产午夜精品一区二区三区 | 久久99国产精品久久99大师 | 亚洲视频 欧美视频 | 国产美女高潮一区二区三区 | 91午夜在线 | av午夜 | 欧美一级精品 | 超碰在线观看97 | 国产在线一区二区 | 久久精品免费观看 | 午夜私人影院在线观看 | 成人精品在线视频 | 日韩一区二区在线观看 | 亚洲免费一区 | 亚洲aⅴ天堂av在线电影软件 | 一区二区久久久 | 国产精品揄拍一区二区久久国内亚洲精 | 久久亚洲一区二区三 | 亚洲国产日韩欧美 | 成人影院一区二区三区 | 久久久国产精品入口麻豆 | 欧美片网站免费 | 91综合网| 精品国产乱码久久久久久1区2区 | 久久久蜜桃| 情侣av | 久久99精品久久久久国产越南 | 精品美女久久久 | 中文字幕一区二区三区乱码在线 | 亚洲精品视频在线播放 | 精品日韩 | 欧美国产视频 | 国产成人精品av | 香蕉久久久久久 | 91偷拍精品一区二区三区 | 日韩在线成人av | 正在播放国产一区 | 毛片真人毛毛片毛片 | 国产一级视频 | 天堂一区二区三区 | 中文字幕视频在线 | 美日韩一区二区三区 | 黄色欧美一级片 | 精品国产精品国产偷麻豆 | 亚洲精品久久久久久下一站 | 成人久久久久久久久 | 99av| 国产艳妇av视国产精选av一区 | 免费观看视频毛片 | 美女黄网 | 黄色毛片一级 | 久久久国产精品入口麻豆 | 91九色网站 | 国产精品二区三区 | 欧美日韩三级在线 | 免费成人在线视频网站 | 91精品亚洲| 中文字幕视频一区 | 日日操操 | 黄的视频网站 | 日本在线免费 | 国产精品高潮呻吟 | 欧美久久免费 | 亚洲一区中文字幕在线观看 | 四虎影院在线免费播放 | 国产精品久久久久久久久久久久 | 黄色国产视频 | 久久久国产精品入口麻豆 | 欧美午夜精品久久久久久人妖 | 欧美性猛交一区二区三区精品 | 欧美成人免费在线视频 | 狠狠久久综合 | 欧美亚洲视频在线观看 | 神马午夜 | 性色视频免费观看 | 久久伊人在 | 久久精品毛片 | 久久久久久亚洲一区二区三区蜜臀 | 午夜黄色影院 | 91原创视频在线观看 | 亚洲a在线播放 | 国产www网站 | 91天堂| 国产精品不卡 | 日韩成人影院在线观看 | 久久精品一级 | 最新超碰 | 91精品国产欧美一区二区 | 亚洲精品久久久久久动漫 | 久久久久久久一区二区 | 一区二区三区国产 | 成人高清视频在线观看 | 视频二区在线观看 | 视频一区在线播放 | 成人综合社区 | 超级乱淫片国语对白免费视频 | 欧美日韩电影一区二区三区 | 最近日韩中文字幕 | 蜜桃av一区二区三区 | 国产在线观看二区 | 成人av综合 | 国产精品久久久久久亚洲调教 | 精品视频久久久 | 91精品国产综合久久久久 | 亚洲精品片 | 性色av一区二区三区 | 美女91| 欧美国产日韩一区二区 | 国产精品视频播放 | 日韩精品 电影一区 亚洲 | 欧美激情精品久久久久久免费 | 国产一区二区三区在线免费观看 | 日本在线视频中文字幕 | www.嫩草 | 国产一级淫片a级aaa | 日本不卡高字幕在线2019 | 国产激情影院 | 福利网站在线观看 | 精品午夜久久 | 精品91| 欧美日韩久久久久 | 久久久久精| 欧美成人a | 视频一区在线播放 | 亚洲二区在线视频 | 国产成人高清视频 | 玖色视频| 成人日韩在线观看 | 在线精品亚洲欧美日韩国产 | 国产精品美女久久久久久免费 | 91亚洲国产 | 日韩在线成人 | 日韩精品av一区二区三区 | 国产男女视频在线观看 | 精品视频一区二区在线观看 | 亚洲国产网站 | 一本一道久久a久久精品逆3p | www久久久久久久 | 午夜国产羞羞视频免费网站 | 日本乱偷中文字幕 | 中文字幕国产视频 | 美女超碰在线 | 91在线入口 | 韩国精品视频在线观看 | 欧美日韩一区二区三区四区 | 精品久久久久久久久久久久 | 国产精品1区2区3区 欧美 中文字幕 | 中文字幕在线视频一区 | 亚洲精品在线免费看 | 一区二区在线免费观看 | 69av在线视频 | 成人在线免费 | 欧美 亚洲 另类 激情 另类 | 亚洲欧美91 | 在线观看国产视频 | 亚洲成人av电影 | 免费一区二区 | 国产精品久久久久久久久免费桃花 | 91精品久久久久久久久久入口 | 欧美亚洲高清 | 成人在线观看av | 国产精品久久久久久久久动漫 | 国产精品九九九 | 久久久一 | 欧美一区二区三区视频 | 亚洲国产伊人 | 在线看av的网址 | 精品亚洲永久免费精品 | 欧美日韩国产一区二区 | 本道综合精品 | 天堂一区二区三区 | 视频一区二区中文字幕 | 亚洲一级黄色 | 2021狠狠干 | 欧美日韩在线观看视频 | 91免费在线 | 一区二区三区视频在线 | 一级黄色av片 | 国产成人精品一区二区三区视频 | 亚洲国产精品自拍 | 超碰一区 | 99影视| 热久久这里只有精品 | 午夜精品久久久久久久久 | 伊人干 | 激情欧美一区二区三区中文字幕 | 香蕉久久网 | 狠狠干av| 欧美色视 | 狠狠躁夜夜躁人人爽视频 | 日韩精品一区二区三区视频播放 | 精品二区| 中文字幕一区二区三区日韩精品 | 综合一区二区三区 | 欧美精品一区二区三区一线天视频 | 99精品国产高清在线观看 | 奇米成人影视 | 17c一起操 | 无毒黄网| 亚洲成人观看 | 国产精品1区2区 | 久久精品无码一区二区三区 | 国产在线精品一区二区三区 | 成人免费视屏 | 精品日韩一区 | 亚洲超碰av | 欧美成人一区二区 | 欧美三级在线视频 | 欧美日韩三区 | 欧美精品在线免费观看 | 蜜臀在线视频 | 国产成人在线免费观看 | 午夜精品久久久久久久久久久久 | 国产精品久久av | 欧美日韩三级 | 亚洲午夜精品片久久www慈禧 | 精品免费国产 | 亚洲精品视 | 久久久久久九九九九九九 | 日韩成人精品视频 | 中文在线一区 | 成人一区二区三区在线观看 | 日日网| 中文av在线免费观看 | 久久99久久久久 | 日韩在线观看高清 | 亚洲一区精品视频 | 精品欧美一区二区精品久久久 | 91免费在线播放 | 天堂综合网久久 | 久久久久久久 | 欧美日韩视频一区二区 | 91网在线播放 | 中文字幕a视频 | 久久久久久久久久久久久九 | 欧美天天| 日韩在线视频免费 | 欧美一级在线观看 | 黄a在线| 久久精品一区二区三区中文字幕 | 亚洲精彩视频 | 精品亚洲一区二区三区 | 婷婷国产成人精品视频 | 亚洲欧美在线观看 | 日韩精品一区在线 | 天天干天天爽 | 日本欧美在线 | 亚洲激情在线 | 亚洲人成人一区二区在线观看 | 黄色大片视频网站 | 成人av免费在线 | 国产精品二区三区 | 天天拍天天操 | 韩国三级中文字幕hd久久精品 | 日韩中文视频 | 国产精品片aa在线观看 | 国产免费天天看高清影视在线 | 亚洲国产二区 | 中文字幕一区在线观看 | 一卡二卡久久 | 欧洲精品一区 | 日日爱视频 | 性一交一乱一透一a级 | 欧洲精品在线观看 | 久久99久久99精品免视看婷婷 | 欧美激情在线播放 | 黄色成人在线观看视频 | 国产日产精品一区二区三区四区 | 在线观看欧美一区二区三区 | 亚洲一二三 | 免费观看成人性生生活片 | 成人在线黄色 | 亚洲午夜视频 | 国产xxx在线观看 | 美女视频黄的免费 | 亚洲一区中文字幕在线观看 | 国产精品成人久久久久 | 国产h在线 | 91久久久精品视频 | 可以在线观看的av网站 | 久草视频免费在线播放 | 99亚洲国产 | 麻豆.蜜桃.91.天美入口 | 天天综合网久久综合网 | 日韩一区二区在线播放 | 日韩理伦片在线观看视频播放 | 久久亚洲一区二区三区四区 | 91电影在线观看 | 中文字幕精品三区 | 久久精彩视频 | 久久综合一区 | 国产精品1区2区 | 一区二区三区国产视频 | 91久久国产| 国产激情视频 | 国产精品久久久久久久美男 | 欧美日韩在线综合 | 99热播在线 | 久久亚洲二区 | 一级毛片免费观看 | 狠狠综合 | 欧美一区二区久久久 | 国产剧情一区二区 | 国产欧美在线视频 | 欧美日韩国产影院 | 一区二区中文字幕在线观看 | 国产成人精品一区二 | 色橹橹欧美在线观看视频高清 | 午夜爽爽影院 | 亚洲www永久成人夜色 | 在线观看精品91福利 | 精品久久久久久久久久久 | www312aⅴ欧美在线看 | 日韩欧美精品在线 | 亚洲永久精品www | 精品国产91亚洲一区二区三区www | 永久av| 国产精品99久久久久久久久久久久 | 国产精品自拍视频网站 | 欧美成人免费视频 | 成人午夜精品久久久久久久蜜臀 | 天天影视综合 | 伊人激情综合 | 午夜成人免费影院 | av大片在线观看 | 激情自拍偷拍 | 亚洲免费网址 | 国产亚洲欧美一区 | 久久精品99| 啪啪毛片 | 黄色片在线免费观看 | 日韩av在线不卡 | 日韩欧美在线视频免费观看 | 激情久久久 | 97综合色 | 久久人| 高清国产午夜精品久久久久久 | 久久久久久亚洲精品 | 欧美乱码久久久久久蜜桃 | 日韩精品视频久久 | 日韩欧美~中文字幕 | 日韩在线观看成人 | 蜜桃精品久久久久久久免费影院 | 国产在线区| 亚洲黄色一区二区三区 | 久久久久久久久免费视频 | 亚洲中字幕女 | 精品伦精品一区二区三区视频 | 欧美亚洲天堂 | 日韩精品视频免费在线观看 | 国产精品www | 国产午夜精品一区二区 | 久久综合一区 | 久久视频免费 | 国产精品久久国产愉拍 | 久久精品亚洲精品国产欧美 | 亚洲久久一区 | 天天拍拍天天干 | 精品久久中文字幕 | 小川阿佐美88av在线播放 | 一区二区三区不卡视频 | 免费成人在线网站 | 精品国产91乱码一区二区三区 | 日韩欧美国产一区二区三区 | 久久a视频 | 337p亚洲欧洲| 亚洲精品久久久久久久久久久久久 | a亚洲精品 | 在线亚洲人成电影网站色www | 男女视频在线观看 | 亚洲aaa| 午夜视频福利在线观看 | 91精品国产乱码久久久久久久久 | 国产99久久精品一区二区永久免费 | 精品电影| 亚洲欧洲在线观看 | 黄色精品 | 欧美视频一区二区 | 精品护士一区二区三区 | 精品亚洲成a人片在线观看 国产高清在线 | 99在线视频精品 | 国产福利在线 | 精品国产乱码久久久久久1区2区 | av影音资源 | 国产精品乱码久久 | 中文天堂av| 黄色免费观看 | 九色在线观看 | 久久小视频 | 欧美精品一区二区三区一线天视频 | 国产精品国产三级国产aⅴ无密码 | 国模一区二区三区 | 色吧av | 国产精品成人网 | 亚洲中国精品精华液 | 精品一区二区三区免费 | 中文字幕精品视频在线观看 | 久久久精彩视频 | 欧美伊人影院 | 午夜免费视频 | 国产精品久久久久久 | 欧美成人一区二区三区 | 国产精品久久九九 | 成人免费视频观看视频 | 精品在线视频观看 | 中文字幕在线精品 | 亚洲精品久久久狠狠狠爱 | av免费网站在线观看 | 国产日韩欧美高清 | 视频一区二区中文字幕 | 亚洲一区二区在线 | 国产一区二区三区四区在线观看 | 中文字幕亚洲欧美日韩在线不卡 | 午夜a级理论片915影院 | 中文字幕av亚洲精品一部二部 | 精品免费视频一区二区 | 成人在线国产 | 国产精品三级久久久久久电影 | 一级在线观看 | 日本久久精品视频 | 日韩在线成人 | 91在线视频免费观看 | 欧美亚洲免费 | 国产小视频在线观看 | 午夜免费剧场 | the蜜臀av入口| 欧洲尺码日本国产精品 | 蜜桃免费视频 | 久草视频在线播放 | 99亚洲精品 | 农村妇女毛片精品久久久 | 国产香蕉视频在线播放 | 国产一区二区三区免费观看 | 日韩欧美在线视频 | 人人干在线视频 | 国产亚洲精品精品国产亚洲综合 | 91看片 | 伊人久久综合 | 中文字幕在线观看2021 | 日韩在线看片 | 欧美激情一区二区 | 欧美精品中文字幕久久二区 | 精品视频免费观看 | 欧美另类专区 | 天天干夜夜爽 | 亚洲免费视频一区 | 一级片在线观看 | 久久久久久久久久一区二区 | 久精品视频 | 日韩精品在线免费观看视频 | 成人影院www在线观看 | 亚洲午夜一区 | 玖玖国产精品视频 | 日韩三区视频 | 国产亲子乱弄免费视频 | 国产精品一区av | 资源av| 日韩91| 日本免费三片免费观看 | 中文字幕在线观看不卡视频 | 亚洲成人一区 | 国产一二区在线 | 一本一道久久久a久久久精品91 | 成人国产精品久久久 | 成人在线免费视频 | 69性欧美高清影院 | 亚洲国产精品99久久久久久久久 | 欧美2区 | 欧美一区二区 | 中文成人无字幕乱码精品 | 日韩欧美国产成人一区二区 | 国产91av视频在线观看 | 日韩国产欧美视频 | 日韩久久久久 | 欧美99| 黄色免费av | 国产精品成人国产乱一区 | 国产欧美久久一区二区三区 | 日韩欧美一区二区三区 | 一区二区精品在线 | 91亚洲精品乱码久久久久久蜜桃 | 欧美日本韩国一区二区 | 一区二区免费播放 | 色狠狠一区 | 国产91久久精品一区二区 | 精品中文字幕一区二区 | 亚洲综合在线一区 | 影音先锋亚洲精品 | 欧美午夜一区二区三区免费大片 | 玖玖精品 | 玖玖玖精品视频 | 一区二区免费在线 | 色免费视频 | 国产亚洲一区二区三区在线观看 | 婷婷五月色综合香五月 | 自拍一区视频 | 99免费视频 | 日韩精品视频免费专区在线播放 |