国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

springboot整合shardingjdbc實現(xiàn)分庫分表最簡單demo

 更新時間:2021年06月07日 14:13:11   作者:易佰菜鳥  
我們知道分庫分表是針對某些數(shù)據(jù)量持續(xù)大幅增長的表,比如用戶表、訂單表等,而不是一刀切將全部表都做分片,這篇文章主要介紹了springboot整合shardingjdbc實現(xiàn)分庫分表最簡單demo,需要的朋友可以參考下

一、概覽

1.1 簡介

ShardingSphere-JDBC定位為輕量級 Java 框架,在 Java 的 JDBC 層提供的額外服務。 它使用客戶端直連數(shù)據(jù)庫,以 jar 包形式提供服務,無需額外部署和依賴,可理解為增強版的 JDBC 驅(qū)動,完全兼容 JDBC 和各種 ORM 框架。

  1. 適用于任何基于 JDBC 的 ORM 框架,如:JPA, Hibernate, Mybatis, Spring JDBC Template 或直接使用 JDBC。
  2. 支持任何第三方的數(shù)據(jù)庫連接池,如:DBCP, C3P0, BoneCP, Druid, HikariCP 等。
  3. 支持任意實現(xiàn) JDBC 規(guī)范的數(shù)據(jù)庫,目前支持 MySQL,Oracle,SQLServer,PostgreSQL 以及任何遵循 SQL92 標準的數(shù)據(jù)庫。

在這里插入圖片描述

1.2 對比

在這里插入圖片描述

名稱 ShardingSphere-JDBC ShardingSphere-Proxy ShardingSphere-Sidecar
數(shù)據(jù)庫 任意 MySQL/PostgreSQL MySQL/PostgreSQL
連接消耗數(shù)
異構(gòu)語言 僅 Java 任意 任意
性能 損耗低 損耗略高 損耗低
無中心化
靜態(tài)入口

1.3 分庫分表場景

隨著時間和業(yè)務的發(fā)展,造成表里面的數(shù)據(jù)越來越多,如果再去對數(shù)據(jù)庫表curd操作,很容易造成性能問題。為了解決由于數(shù)據(jù)量過大而造成數(shù)據(jù)庫性能降低的問題,常見的解決方案如下:

  • 從硬件上增加數(shù)據(jù)庫服務器的存儲,
  • 分庫分表處理

分庫分表又可以分為水平分表、水平分庫、垂直分表、垂直分庫

在這里插入圖片描述

水平分表

特點:
每個表的結(jié)構(gòu)都一樣;
每個表的數(shù)據(jù)都不一樣,沒有交集;
所有表的并集是該表的全量數(shù)據(jù);場景:單表的數(shù)據(jù)量過大或增長速度很快,已經(jīng)影響或即將會影響SQL查詢效率,加重了CPU負擔,提前到達瓶頸。

水平分庫

特點:
每個庫的結(jié)構(gòu)都一樣;
每個庫的數(shù)據(jù)都不一樣,沒有交集;
所有庫的并集是全量數(shù)據(jù);場景:系統(tǒng)絕對并發(fā)量上來了,CPU內(nèi)存壓力大。分表難以根本上解決量的問題,并且還沒有明顯的業(yè)務歸屬來垂直分庫,主庫磁盤接近飽和。

垂直分表

特點:
每個表的結(jié)構(gòu)都不一樣;
每個表的數(shù)據(jù)也不一樣,
有一個關(guān)聯(lián)字段,一般是主鍵或外鍵,用于關(guān)聯(lián)兄弟表數(shù)據(jù);
所有兄弟表的并集是該表的全量數(shù)據(jù);場景:
有幾個字段屬于熱點字段,更新頻率很高,要把這些字段單獨切到一張表里,不然innodb行鎖很惡心的
有大字段,如text,存儲壓力很大,畢竟innodb數(shù)據(jù)和索引是同一個文件;同時,我又喜歡用SELECT *,你懂得,這磁盤IO消耗的,跟玩兒似的,誰都扛不住的。

垂直分庫
縱向切庫基于表進行切分,類似多數(shù)據(jù)源,通常是把新的業(yè)務模塊或集成公共模塊拆分出去,比如我們最熟悉的單點登錄、鑒權(quán)模塊。

1.4 非分片表處理方法

我們知道分庫分表是針對某些數(shù)據(jù)量持續(xù)大幅增長的表,比如用戶表、訂單表等,而不是一刀切將全部表都做分片。那么不分片的表和分片的表如何劃分,一般有兩種解決方案。

  • 嚴格劃分功能庫,分片的庫與不分片的庫剝離開,業(yè)務代碼中按需切換數(shù)據(jù)源訪問
  • 默認數(shù)據(jù)源,以 Sharding-JDBC 為例,不給未分片表設置分片規(guī)則,它們就不會執(zhí)行,因為找不到路由規(guī)則,如果我們設置一個默認數(shù)據(jù)源,在找不到規(guī)則時一律訪問默認庫。
# 配置數(shù)據(jù)源 m1
spring.shardingsphere.datasource.name=m1
spring.shardingsphere.datasource.m1.type=com.alibaba.druid.pool.DruidDataSource
spring.shardingsphere.datasource.m1.driverClassName=com.mysql.jdbc.Driver
spring.shardingsphere.datasource.m1.url=jdbc:mysql://xxxx:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&tinyInt1isBit=false&useSSL=false&serverTimezone=GMT
spring.shardingsphere.datasource.m1.username=root
spring.shardingsphere.datasource.m1.password=xxxx
# 默認數(shù)據(jù)源,未分片的表默認執(zhí)行庫
spring.shardingsphere.sharding.default-data-source-name=m1

1.5 技術(shù)棧

  • SpringBoot2.3.8.RELEASE
  • MyBatis-Plus3.4.0
  • Sharding-JDBC
  • Druid連接池

二、 項目整合

2.1 pom.xml

<!-- shardingjdbc依賴包 -->
		<dependency>
            <groupId>org.apache.shardingsphere</groupId>
            <artifactId>sharding-jdbc-spring-boot-starter</artifactId>
            <version>4.1.1</version>
        </dependency>
       	<!-- 連接池 -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.2.5</version>
        </dependency>

        <!-- 分布式事務所需包 -->
        <!-- 使用 XA 事務時,需要引入此模塊 -->
        <dependency>
            <groupId>org.apache.shardingsphere</groupId>
            <artifactId>sharding-transaction-xa-core</artifactId>
            <version>4.1.1</version>
        </dependency>

<!--        &lt;!&ndash; 使用 BASE 事務時,需要引入此模塊 &ndash;&gt;-->
<!--        <dependency>-->
<!--            <groupId>org.apache.shardingsphere</groupId>-->
<!--            <artifactId>sharding-transaction-base-seata-at</artifactId>-->
<!--            <version>4.1.1</version>-->
<!--        </dependency>-->
<!--        &lt;!&ndash; https://mvnrepository.com/artifact/io.seata/seata-core &ndash;&gt;-->
<!--        <dependency>-->
<!--            <groupId>io.seata</groupId>-->
<!--            <artifactId>seata-core</artifactId>-->
<!--            <version>1.4.2</version>-->
<!--        </dependency>-->

注意:如果原有項目引入了 druid包 以及多數(shù)據(jù)源包dynamic-datasource-spring-boot-starter,需要注釋掉相關(guān)引用

  <!-- https://mvnrepository.com/artifact/com.baomidou/dynamic-datasource-spring-boot-starter -->
<!--        <dependency>-->
<!--            <groupId>com.baomidou</groupId>-->
<!--            <artifactId>dynamic-datasource-spring-boot-starter</artifactId>-->
<!--            <version>3.1.0</version>-->
<!--        </dependency>-->
<!--        <dependency>-->
<!--            <groupId>com.alibaba</groupId>-->
<!--            <artifactId>druid-spring-boot-starter</artifactId>-->
<!--        </dependency>-->

2.2 jpa/mybatis項目其他調(diào)整 springboot啟動類增加如下配置

@SpringBootApplication(exclude = {DruidDataSourceAutoConfigure.class})

分片表ORM映射實體類注釋表名映射

在這里插入圖片描述

數(shù)據(jù)庫鏈接賬號賦予分布式事務XA權(quán)限

GRANT XA_RECOVER_ADMIN ON *.* TO root@'%'

配置springboot數(shù)據(jù)源健康檢查sql(可選)

package com.yss.datamiddle.config;

import org.springframework.beans.factory.ObjectProvider;
import org.springframework.boot.actuate.autoconfigure.jdbc.DataSourceHealthContributorAutoConfiguration;
import org.springframework.boot.actuate.health.AbstractHealthIndicator;
import org.springframework.boot.actuate.jdbc.DataSourceHealthIndicator;
import org.springframework.boot.jdbc.metadata.DataSourcePoolMetadataProvider;
import org.springframework.context.annotation.Configuration;
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
import org.springframework.util.StringUtils;

import javax.sql.DataSource;
import java.util.Map;

/**
 * @description: 重寫健康檢查sql,解決項目啟動健康檢查異常
 * @author: Han LiDong
 * @create: 2021/5/28 14:40
 * @update: 2021/5/28 14:40
 */
@Configuration
public class DataSourceHealthConfig extends DataSourceHealthContributorAutoConfiguration {

    private static final String defaultQuery = "select 1";

    public DataSourceHealthConfig(Map<String, DataSource> dataSources, ObjectProvider<DataSourcePoolMetadataProvider> metadataProviders) {
        super(dataSources, metadataProviders);
    }

    @Override
    protected AbstractHealthIndicator createIndicator(DataSource source) {
        DataSourceHealthIndicator indicator = (DataSourceHealthIndicator) super.createIndicator(source);
        if (!StringUtils.hasText(indicator.getQuery())) {
            indicator.setQuery(defaultQuery);
        }
        return indicator;
    }
}

三、分庫分表實現(xiàn)

3.1 水平分表-單分片鍵(標準分片算法、自定義分布式主鍵生成算法)

創(chuàng)建表單course_1,course_2
約定規(guī)則:如果添加的主鍵ID是偶數(shù)把數(shù)據(jù)添加進course_1表,如果是奇數(shù)添加進course_2表

-- ----------------------------
-- Table structure for course_1
-- ----------------------------
DROP TABLE IF EXISTS `course_1`;
CREATE TABLE `course_1`  (
  `id` bigint(20) NOT NULL,
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '課程名稱',
  `status` int(255) DEFAULT NULL COMMENT '狀態(tài)',
  `create_time` date DEFAULT NULL COMMENT '創(chuàng)建日期',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Table structure for course_2
-- ----------------------------
DROP TABLE IF EXISTS `course_2`;
CREATE TABLE `course_2`  (
  `id` bigint(20) NOT NULL,
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '課程名稱',
  `status` int(255) DEFAULT NULL COMMENT '狀態(tài)',
  `create_time` date DEFAULT NULL COMMENT '創(chuàng)建日期',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

application-table-horizontal.yml配置分表規(guī)則

#水平分表配置
spring:
  main:
    #允許名稱相同的bean的覆蓋(一個實體類對應多張表)
    allow-bean-definition-overriding: true
  shardingsphere:
    props:
      sql:
        show: true
    datasource:
      # 數(shù)據(jù)源名稱,多數(shù)據(jù)源以逗號分隔(m1,m2)
      names: m1
      #names定義的數(shù)據(jù)源名稱作為key(key不能包含下劃線,否則無法識別配置)
      m1:
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        password: xxxx
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
#    rules:
    sharding:
      tables:
        course:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            # 也可以自定義(實現(xiàn)ShardingKeyGenerator,并配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator) SIMPLE
            type: SNOWFLAKE
          # 由數(shù)據(jù)源名 + 表名組成,以小數(shù)點分隔。多個表以逗號分隔,支持inline表達式。缺省表示使用已知數(shù)據(jù)源與邏輯表名稱生成數(shù)據(jù)節(jié)點,用于廣播表(即每個庫中都需要一個同樣的表用于關(guān)聯(lián)查詢,多為字典表)或只分庫不分表且所有庫的表結(jié)構(gòu)完全一致的情況
          actual-data-nodes: m1.course_$->{1..2}
          #分庫策略:單分片鍵
          table-strategy:
            inline:
      		  #分片鍵
              sharding-column: id
              #數(shù)據(jù)分片規(guī)則(ID是偶數(shù)把數(shù)據(jù)添加入course_1,奇數(shù)入course_2)
              algorithm-expression: course_$->{id % 2 + 1}

測試-分表-新增

 /**
     * 測試分表-新增
     */
    @Test
    public void addCourse() {
        for (int i = 0; i < 10; i++) {
            Course course = new Course();
            course.setName("java" + i);
            course.setStatus(1);
            course.setCreateTime(new Date());
            courseMapper.insert(course);
        }
    }

在這里插入圖片描述

測試-分表-查詢

/**
     * 查詢分表數(shù)據(jù)
     */
    @Test
    public void findCourse() {
		//分區(qū)字段查詢數(shù)據(jù):精準匹配分片表,不會去別的表中掃描數(shù)據(jù)
       Course course = courseMapper.selectById(Long.valueOf("607168187053637632"));
        log.info(course.toString());

      //非分區(qū)字段查詢:全表匹配,匯總結(jié)果
        QueryWrapper<Course> queryWrapper2 = new QueryWrapper<Course>();
        queryWrapper2.between("create_time",
                DateUtil.stringToDate("2021-01-26 11:39:05"),
                DateUtil.stringToDate("2021-07-26 11:39:05"));
        List<Course> list2 = courseMapper.selectList(queryWrapper2);
        log.info("數(shù)據(jù)量{}",list2.size());

    }

在這里插入圖片描述

由上可以看出分片字段作為查詢條件時,請準定位分片數(shù)據(jù)所在分片表。非分片字段查詢時,全表匹配,匯總結(jié)果

自定義分布式主鍵生成算法
實現(xiàn)ShardingKeyGenerator接口,自定義分布式主鍵生成算法

import lombok.Data;
import lombok.Getter;
import lombok.Setter;
import org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator;
import org.springframework.stereotype.Component;

import java.util.Properties;
import java.util.concurrent.atomic.AtomicLong;

/**
 * @description: 自定義sharding-jdbc主鍵生成算法
 * @author: Han LiDong
 * @create: 2021/5/25 09:36
 * @update: 2021/5/25 09:36
 */
@Component
public class SimpleShardingKeyGenerator implements ShardingKeyGenerator {

    private AtomicLong atomic = new AtomicLong(0);

    @Getter
    @Setter
    private Properties properties = new Properties();

	/**
	 * 分布式主鍵實現(xiàn)算法。	
	 */
    @Override
    public Comparable<?> generateKey() {
        return atomic.incrementAndGet();
    }

    @Override
    public String getType() {
        //聲明類型,需要在配置文件中配置此key
        return "SIMPLE";
    }
}

resources下配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator

在這里插入圖片描述

配置主鍵生成策略為自定義key

在這里插入圖片描述

3.2 水平分表-單分片鍵-按照月份分表(標準分片算法)

創(chuàng)建course_202101到course_202108表單
約定規(guī)則:按照創(chuàng)建時間對應的yyyyMM將數(shù)據(jù)分片到不同的表中

-- ----------------------------
-- 表名自己調(diào)整,創(chuàng)建202101-202112的表單
-- ----------------------------
DROP TABLE IF EXISTS `course_202101`;
CREATE TABLE `course_202101`  (
  `id` bigint(20) NOT NULL,
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '課程名稱',
  `status` int(255) DEFAULT NULL COMMENT '狀態(tài)',
  `create_time` datetime(0) DEFAULT NULL COMMENT '創(chuàng)建日期',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

application-table-time-horizontal.yml配置月份分表規(guī)則

#按照月份自定義水平分表策略配置
spring:
  main:
    allow-bean-definition-overriding: true
  shardingsphere:
    props:
      sql:
        show: true
    datasource:
      # 數(shù)據(jù)源名稱,多數(shù)據(jù)源以逗號分隔
      names: m1
      m1:
        password: xxxx
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
#    rules:
    sharding:
      tables:
        course:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            type: SNOWFLAKE
          ##配置 t_order 表規(guī)則  ->{a..b}  a必須存在,否則分布式主鍵無法獲取
          actual-data-nodes: m1.course_$->{2021..2200}0$->{1..9},m1.course_$->{2021..2200}$->{10..12}
          table-strategy:
            standard:
              #精確分片算法類名稱,用于 = 和 IN。該類需實現(xiàn)PreciseShardingAlgorithm 接口并提供無參數(shù)的構(gòu)造器
              precise-algorithm-class-name: com.xlhj.sharding.config.CoursePreciseShardingAlgorithm
              # 范圍分片算法類名稱,用于 BETWEEN,可選。該類需實現(xiàn)RangeShardingAlgorithm 接口并提供無參數(shù)的構(gòu)造器
              range-algorithm-class-name: com.xlhj.sharding.config.TableRangeShardAlgorithm
              # 分片字段
              sharding-column: create_time

精準分片算法實現(xiàn)

package com.xlhj.sharding.config;

import com.xlhj.sharding.util.DateUtil;
import org.apache.shardingsphere.api.sharding.standard.PreciseShardingAlgorithm;
import org.apache.shardingsphere.api.sharding.standard.PreciseShardingValue;
import org.springframework.stereotype.Component;

import java.util.Collection;
import java.util.Date;

/**
 * @description: 精準分片算法類
 * @author: Han LiDong
 * @create: 2021/5/25 10:32
 * @update: 2021/5/25 10:32
 */
@Component
public class CoursePreciseShardingAlgorithm implements PreciseShardingAlgorithm<Date> {

    /**
     * 按照 tablename_yyyyMM進行分表 用于 = in等
     * @param collection
     * @param preciseShardingValue
     * @return
     */
    @Override
    public String doSharding(Collection<String> collection, PreciseShardingValue<Date> preciseShardingValue) {
        StringBuffer tableName = new StringBuffer();
        tableName.append(preciseShardingValue.getLogicTableName())
                .append("_").append(DateUtil.dateToString(preciseShardingValue.getValue(),"yyyyMM");
        return tableName.toString();
    }
}

范圍分片算法實現(xiàn)

package com.xlhj.sharding.config;

import com.google.common.collect.Range;
import com.xlhj.sharding.util.DateUtil;
import org.apache.shardingsphere.api.sharding.standard.RangeShardingAlgorithm;
import org.apache.shardingsphere.api.sharding.standard.RangeShardingValue;
import org.springframework.stereotype.Component;

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
import java.util.stream.Collectors;

/**
 * @description: 范圍分片算法類 用于 BETWEEN等
 * @author: Han LiDong
 * @create: 2021/5/25 10:32
 * @update: 2021/5/25 10:32
 */
@Component
public class TableRangeShardAlgorithm implements RangeShardingAlgorithm<Date> {


    private static SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");

    /**
     * 分片鍵日期范圍包含分片表名稱集合
     * @param availableTargetNames
     * @param rangeShardingValue
     * @return
     */
    public Collection<String> doSharding(Collection<String> availableTargetNames, RangeShardingValue<Date> rangeShardingValue) {
        System.out.println("范圍-*-*-*-*-*-*-*-*-*-*-*---------------" + availableTargetNames);
        System.out.println("范圍-*-*-*-*-*-*-*-*-*-*-*---------------" + rangeShardingValue);
        //物理表名集合
        //Collection<String> tables = new LinkedHashSet<>();
        //邏輯表名
        String logicTableName = rangeShardingValue.getLogicTableName();
        //分片鍵的值
        Range<Date> valueRange = rangeShardingValue.getValueRange();
        Date lowerEndpoint = valueRange.lowerEndpoint();

        Date upperEndpoint = valueRange.upperEndpoint();
        List<String> YMList = DateUtil.getYMBetweenDate(lowerEndpoint,upperEndpoint);
        List<String> tables = YMList.stream().map( ym ->{
            return logicTableName + "_" + ym;
        }).collect(Collectors.toList());
        return tables;
    }

}

測試-日期分表-新增

/**
     * 測試分表
     */
    @Test
    public void addCourse() {
        for (int i = 0; i < 10; i++) {
            Course course = new Course();
            course.setName("java" + i);
            course.setStatus(1);
            course.setCreateTime(new Date());
            courseMapper.insert(course);
        }
    }

在這里插入圖片描述

3.3 水平分表-多分片鍵(復合分片算法)

繼續(xù)使用course_1、course_2表單
約定規(guī)則:如果添加的主鍵ID是偶數(shù)把數(shù)據(jù)添加進course_1表,如果是奇數(shù)添加進course_2表

application-table-horizontal-columns.yml配置多分片鍵分表規(guī)則

#水平分表配置
spring:
  main:
    #允許名稱相同的bean的覆蓋(一個實體類對應多張表)
    allow-bean-definition-overriding: true
  shardingsphere:
    props:
      sql:
        show: true
    datasource:
      # 數(shù)據(jù)源名稱,多數(shù)據(jù)源以逗號分隔
      names: m1
      # names定義的數(shù)據(jù)源名稱作為key(key不能包含下劃線,否則無法識別配置)
      m1:
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        password: xxxx
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
    sharding:
      tables:
        # 表名
        course:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            # 也可以自定義(實現(xiàn)ShardingKeyGenerator,并配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator) SIMPLE
            type: SIMPLE
          #由數(shù)據(jù)源名 + 表名組成,以小數(shù)點分隔。多個表以逗號分隔,支持inline表達式。
          #缺省表示使用已知數(shù)據(jù)源與邏輯表名稱生成數(shù)據(jù)節(jié)點,用于廣播表(即每個庫中都需要一個同樣的表用于關(guān)聯(lián)查詢,多為字典表)或只分庫不分表且所有庫的表結(jié)構(gòu)完全一致的情況
          actual-data-nodes: m1.course_$->{1..2}
          #分片策略:多分片鍵
          table-strategy:
            complex:
              # 分片鍵
              sharding-columns: id,status
              # 自定義分片算法
              algorithm-class-name: com.xlhj.sharding.config.CourseShardingAlgorithmColumns

自定義分片算法實現(xiàn)

package com.xlhj.sharding.config;

import org.apache.shardingsphere.api.sharding.complex.ComplexKeysShardingAlgorithm;
import org.apache.shardingsphere.api.sharding.complex.ComplexKeysShardingValue;
import org.springframework.stereotype.Component;

import java.util.*;

/**
 * @description: 分表算法類-多分片鍵
 * @author: Han LiDong
 * @create: 2021/5/25 10:32
 * @update: 2021/5/25 10:32
 */
@Component
public class CourseShardingAlgorithmColumns implements ComplexKeysShardingAlgorithm  {


    /**
     *
     * @param collection        分片表名
     * @param shardingValues    分片字段值
     * @return
     */
    @Override
    public Collection<String> doSharding(Collection collection, ComplexKeysShardingValue shardingValues) {
        System.out.println("collection:" + collection + ",shardingValues:" + shardingValues);
        Map<String, Collection> map = shardingValues.getColumnNameAndShardingValuesMap();
        Collection<Long> idValues = map.get("id");
        Collection<Integer> statusValues = map.get("status");
        List<String> shardingSuffix = new ArrayList<>();
        //邏輯還是按照 id%2 + 1進行數(shù)據(jù)分片
        for (Long id : idValues) {
            Long suf = id % 2 + 1;
            for (Object s : collection) {
                String tableName = (String) s;
                // 分片表名后綴匹配
                if (tableName.endsWith(String.valueOf(suf))) {
                    shardingSuffix.add(tableName);
                }
            }
        }
        return shardingSuffix;
    }
}

測試-多分片鍵-新增

/**
     * 測試分表-新增
     */
    @Test
    public void addCourse() {
        for (int i = 0; i < 10; i++) {
            Course course = new Course();
            course.setName("java" + i);
            course.setStatus(1);
            course.setCreateTime(new Date());
            courseMapper.insert(course);
        }
    }

在這里插入圖片描述

3.4 水平分庫+分表-單分片鍵

另找一個數(shù)據(jù)庫創(chuàng)建表單course_1,course_2
約定規(guī)則:根據(jù)status=0數(shù)據(jù)到庫1,status=1數(shù)據(jù)到庫2. id為奇數(shù)到course_2表,偶數(shù)到course_1表

-- ----------------------------
--  在庫2中創(chuàng)建如下表單
-- ----------------------------
DROP TABLE IF EXISTS `course_1`;
CREATE TABLE `course_1`  (
  `id` bigint(20) NOT NULL,
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '課程名稱',
  `status` int(255) DEFAULT NULL COMMENT '狀態(tài) 0:失效  1:有效',
  `create_time` date DEFAULT NULL COMMENT '創(chuàng)建日期',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;


DROP TABLE IF EXISTS `course_2`;
CREATE TABLE `course_2`  (
  `id` bigint(20) NOT NULL,
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '課程名稱',
  `status` int(255) DEFAULT NULL COMMENT '狀態(tài)',
  `create_time` date DEFAULT NULL COMMENT '創(chuàng)建日期',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

application-database-horizontal.yml配置分庫分表規(guī)則

#水平分庫、分表配置
spring:
  main:
    #允許名稱相同的bean的覆蓋
    allow-bean-definition-overriding: true
  shardingsphere:
    props:
      sql:
        show: true
    datasource:
      # 數(shù)據(jù)源名稱,多數(shù)據(jù)源以逗號分隔
      names: m1,m2
      m1:
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        password: xxxx
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
      m2:
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-2?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        password: xxxx
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
#    rules:
    sharding:
      tables:
        # 表名
        course:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            # 也可以自定義(實現(xiàn)ShardingKeyGenerator,并配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator) SIMPLE
            type: SNOWFLAKE
          #配置 course 表規(guī)則groovy語法  $->{a..b}
          actual-data-nodes: m$->{1..2}.course_$->{1..2}
          #分庫規(guī)則
          database-strategy:
            inline:
              #分庫字段
              sharding-column: status
              #數(shù)據(jù)分庫規(guī)則
              algorithm-expression: m$->{status + 1}
          #分表規(guī)則
          table-strategy:
            inline:
              #分表字段
              sharding-column: id
              #數(shù)據(jù)分表規(guī)則
              algorithm-expression: course_$->{id % 2 + 1}

測試-分庫分表-新增

 /**
     * 測試水平分庫+分表
     */
    @Test
    public void addCourseDB() {
        for (int i = 0; i < 10; i++) {
            Course course = new Course();
            course.setName("java");
            int rand = (int)(Math.random() * 10);
            course.setStatus(rand % 2);
            course.setCreateTime(new Date());
            courseMapper.insert(course);
        }
    }

在這里插入圖片描述

3.5 水平分庫+分表-Hint分片(強制分片路由)

庫2 創(chuàng)建course_yyyyMM相關(guān)表單
約定規(guī)則:查詢/新增數(shù)據(jù)的時候指定分片路由,強制路由到某張表

-- ----------------------------
-- 庫2創(chuàng)建表單,表名自己調(diào)整,創(chuàng)建202101-202112的表單
-- ----------------------------
DROP TABLE IF EXISTS `course_202101`;
CREATE TABLE `course_202101`  (
  `id` bigint(20) NOT NULL,
  `name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '課程名稱',
  `status` int(255) DEFAULT NULL COMMENT '狀態(tài)',
  `create_time` datetime(0) DEFAULT NULL COMMENT '創(chuàng)建日期',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

application-table-hint-horizontal.yml配置強制路由規(guī)則

#強制分片路由hint配置
spring:
  main:
    allow-bean-definition-overriding: true
  shardingsphere:
    props:
      sql:
        show: true
    datasource:
      # 數(shù)據(jù)源名稱,多數(shù)據(jù)源以逗號分隔
      names: m1,m2
      m1:
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        password: xxxx
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
      m2:
        password: xxxx
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-2?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
#    rules:
    sharding:
      tables:
        course:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            # 也可以自定義(實現(xiàn)ShardingKeyGenerator,并配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator) SIMPLE
            type: SNOWFLAKE
          #配置 t_order 表規(guī)則  ->{a..b}  a必須存在,否則分布式主鍵無法獲取
          actual-data-nodes: m1.course_$->{2021..2200}0$->{1..9},m1.course_$->{2021..2200}$->{10..12}
          database-strategy:
            hint:
              # 自定義分庫hit分片算法
              algorithm-class-name: com.xlhj.sharding.config.DatabaseHintShardingKeyAlgorithm
          table-strategy:
            hint:
              # 自定義分表hit分片算法
              algorithm-class-name: com.xlhj.sharding.config.TableHintShardingKeyAlgorithm

自定義強制分庫路由算法實現(xiàn)

package com.xlhj.sharding.config;

import com.alibaba.druid.util.StringUtils;
import org.apache.shardingsphere.api.sharding.ShardingValue;
import org.apache.shardingsphere.api.sharding.hint.HintShardingAlgorithm;
import org.apache.shardingsphere.api.sharding.hint.HintShardingValue;
import org.springframework.stereotype.Component;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;

/**
 * @description:
 * @author: Han LiDong
 * @create: 2021/5/27 09:53
 * @update: 2021/5/27 09:53
 */
@Component
public class DatabaseHintShardingKeyAlgorithm implements HintShardingAlgorithm {

    /**
     * 自定義Hint 實現(xiàn)算法
     * 能夠保證繞過Sharding-JDBC SQL解析過程
     * @param availableTargetNames
     * @param hintShardingValue 不再從SQL 解析中獲取值,而是直接通過hintManager.addTableShardingValue("t_order", 1)參數(shù)指定
     * @return
     */
    @Override
    public Collection<String> doSharding(Collection availableTargetNames, HintShardingValue hintShardingValue) {
        System.out.println("shardingValue=" + hintShardingValue);
        System.out.println("availableTargetNames=" + availableTargetNames);

        List<String> shardingResult = new ArrayList<>();

        Iterator i = availableTargetNames.iterator();
        while (i.hasNext()){
            String targetName = (String) i.next();
            String suffix = targetName.substring(targetName.length() - 1);
            if (StringUtils.isNumber(suffix)) {
                // hint分片算法的ShardingValue有兩種具體類型:
                // ListShardingValue和RangeShardingValue
                // 使用哪種取決于HintManager.addDatabaseShardingValue(String, String, ShardingOperator,...),ShardingOperator的類型
                Iterator j = hintShardingValue.getValues().iterator();
                while (j.hasNext()){
                    Integer value = (Integer) j.next();
                    if (value % 2 + 1 == Integer.parseInt(suffix)) {
                        shardingResult.add(targetName);
                    }
                }
            }
        }
        return shardingResult;
    }

}

自定義強制分表路由算法實現(xiàn)

package com.xlhj.sharding.config;

import com.alibaba.druid.util.StringUtils;
import org.apache.shardingsphere.api.sharding.hint.HintShardingAlgorithm;
import org.apache.shardingsphere.api.sharding.hint.HintShardingValue;
import org.springframework.stereotype.Component;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;

/**
 * @description:
 * @author: Han LiDong
 * @create: 2021/5/27 09:53
 * @update: 2021/5/27 09:53
 */
@Component
public class TableHintShardingKeyAlgorithm implements HintShardingAlgorithm {

    /**
     * 自定義Hint 實現(xiàn)算法
     * 能夠保證繞過Sharding-JDBC SQL解析過程
     * @param availableTargetNames
     * @param hintShardingValue 不再從SQL 解析中獲取值,而是直接通過hintManager.addTableShardingValue("t_order", 1)參數(shù)指定
     * @return
     */
    @Override
    public Collection<String> doSharding(Collection availableTargetNames, HintShardingValue hintShardingValue) {
        System.out.println("shardingValue=" + hintShardingValue);
        System.out.println("availableTargetNames=" + availableTargetNames);

        List<String> shardingResult = new ArrayList<>();

        Iterator i = availableTargetNames.iterator();
        while (i.hasNext()){
            String targetName = (String) i.next();
            String suffix = targetName.substring(targetName.length() - 1);
            if (StringUtils.isNumber(suffix)) {
                // hint分片算法的ShardingValue有兩種具體類型:
                // ListShardingValue和RangeShardingValue
                // 使用哪種取決于HintManager.addDatabaseShardingValue(String, String, ShardingOperator,...),ShardingOperator的類型
                Iterator j = hintShardingValue.getValues().iterator();
                while (j.hasNext()){
                    Integer value = (Integer) j.next();
                    // 匹配月份
                    Integer month = value % 12 == 0 ? 12 : value;
                    if (month == Integer.parseInt(suffix)) {
                        shardingResult.add(targetName);
                    }
                }
            }
        }

        return shardingResult;
    }

}

測試-強制路由

 /**
     * hint分片算法測試
     * @throws Exception
     */
    @Test
    public void shardingHintDB() throws Exception {
        HintManager.clear();
        HintManager hintManager = HintManager.getInstance();
        // 方式1:
        // 下面2句話的意思時: 向3號庫中的1號 course 表執(zhí)行sql
        // 選擇具體的數(shù)據(jù)庫, 3 可以簡單理解為: 3號庫,如果只有2個庫, 那么可以根據(jù)2取模+1,落到 2號庫上面
        hintManager.addDatabaseShardingValue("course", 3);
        // 同理:一個數(shù)據(jù)庫中可以有多張courser表, 2 可以理解為: 2月份相關(guān)表.
        hintManager.addTableShardingValue("course", 2);
        // 方式2
        // 直接指定對應具體的數(shù)據(jù)庫,會想此庫里所有分片表添加數(shù)據(jù)
        //hintManager.setDatabaseShardingValue(0);
        Course course = new Course();
        course.setName("java");
        int rand = (int)(Math.random() * 10);
        course.setStatus(rand % 2);
        course.setCreateTime(new Date());
        courseMapper.insert(course);
        HintManager.clear();
    }

在這里插入圖片描述

3.6 垂直分表

單庫垂直分表相當于 同一個庫的多張表單 通過外鍵關(guān)聯(lián)。
分庫垂直分表相當于多數(shù)據(jù)源。

這幾介紹下單庫垂直分表配置:
主要規(guī)則:

#垂直分庫需要直接指定到庫和表
spring.shardingsphere.sharding.tables.sys_user.actual-data-nodes: m2.sys_user

詳細配置:

#垂直分表策略配置
spring:
  main:
    allow-bean-definition-overriding: true
  shardingsphere:
    props:
      sql:
        show: true
    datasource:
      # 數(shù)據(jù)源名稱,多數(shù)據(jù)源以逗號分隔
      names: m1,m2
      m1:
        password: xxxx
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
      m2:
        password: xxxx
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-2?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
    sharding:
      tables:
        sys_user:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            # 也可以自定義(實現(xiàn)ShardingKeyGenerator,并配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator) SIMPLE
            type: SNOWFLAKE
          #垂直分庫 做到專庫專表  指定到具體庫.具體表
          actual-data-nodes: m2.sys_user

3.7 廣播表

指所有的分片數(shù)據(jù)源中都存在的表,表結(jié)構(gòu)和表中的數(shù)據(jù)在每個數(shù)據(jù)庫中均完全一致。適用于數(shù)據(jù)量不大且需要與海量數(shù)據(jù)的表進行關(guān)聯(lián)查詢的場景,例如:字典表。

庫1和庫2創(chuàng)建字典表t_dict

-- ----------------------------
-- Table structure for t_dict
-- ----------------------------
DROP TABLE IF EXISTS `t_dict`;
CREATE TABLE `t_dict`  (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `dic_code` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '編碼',
  `dic_name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '字典名',
  `dic_value` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '字典值',
  `pcode` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '父編碼',
  `status` varchar(1) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '0:失效 1:生效',
  `dic_sort` varchar(10) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '排序',
  `remarks` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '備注',
  `create_time` datetime(0) DEFAULT NULL COMMENT '創(chuàng)建時間',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 604343147190812673 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

配置廣播表規(guī)則
主要規(guī)則:

# 配置廣播表表名
spring.shardingsphere.sharding.broadcast-tables: t_dict

詳細配置:

#廣播表配置
spring:
  main:
    allow-bean-definition-overriding: true
  shardingsphere:
    props:
      sql:
        show: true
    datasource:
      # 數(shù)據(jù)源名稱,多數(shù)據(jù)源以逗號分隔
      names: m1,m2
      m1:
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        password: xxxx
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
      m2:
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-2?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        driver-class-name: com.mysql.cj.jdbc.Driver
        password: xxxx
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
    sharding:
      tables:
        t_dict:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            # 也可以自定義(實現(xiàn)ShardingKeyGenerator,并配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator) SIMPLE
            type: SNOWFLAKE
      # 配置廣播表
      broadcast-tables: t_dict

測試-廣播表

 /**
     * 測試公共表
     */
    @Test
    public void addDict() {
        TDict dict = new TDict();
        dict.setCreateTime(new Date());
        dict.setDicCode("test");
        dict.setDicName("test");
        dict.setDicSort("1");
        dict.setDicValue("test");
        dict.setPcode("0");
        dict.setStatus("1");
        dictMapper.insert(dict);
    }

在這里插入圖片描述

3.8 綁定表

概念:指分片規(guī)則一致的主表和子表。例如:course表和 course_detail表,均按照 course_id分片,則此兩張表互為綁定表關(guān)系。綁定表之間的多表關(guān)聯(lián)查詢不會出現(xiàn)笛卡爾積關(guān)聯(lián),關(guān)聯(lián)查詢效率將大大提升。

舉例說明,如果 SQL 為:

 select * from course c left join course_detail cd on c.id = cd.course_id where c.id in (10, 11);

在不配置綁定表關(guān)系時,假設分片鍵 course_id將數(shù)值 10 路由至第 0 片,將數(shù)值 11 路由至第 1 片,那么路由后的 SQL 應該為 4 條,它們呈現(xiàn)為笛卡爾積:

 select * from course_1 c left join course_detail_1 cd on c.id = cd.course_id where c.id in (10, 11);
 
 select * from course_1 c left join course_detail_2 cd on c.id = cd.course_id where c.id in (10, 11);

 select * from course_2 c left join course_detail_1 cd on c.id = cd.course_id where c.id in (10, 11);

 select * from course_2 c left join course_detail_2 cd on c.id = cd.course_id where c.id in (10, 11);

在配置綁定表關(guān)系后,路由的 SQL 應該為 2 條:

 select * from course_1 c left join course_detail_1 cd on c.id = cd.course_id where c.id in (10, 11);

 select * from course_2 c left join course_detail_2 cd on c.id = cd.course_id where c.id in (10, 11);

其中 course 在 FROM 的最左側(cè),ShardingSphere 將會以它作為整個綁定表的主表。 所有路由計算將會只使用主表的策略,那么 course_detail表的分片計算將會使用 course 的條件。故綁定表之間的分區(qū)鍵要完全相同。

庫1創(chuàng)建course_detail_1、course_detail_2表單

-- ----------------------------
-- Table structure for course_detail_1
-- ----------------------------
DROP TABLE IF EXISTS `course_detail_1`;
CREATE TABLE `course_detail_1`  (
  `id` bigint(20) NOT NULL,
  `course_id` bigint(20) DEFAULT NULL COMMENT '課程id',
  `remark` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '備注',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Table structure for course_detail_2
-- ----------------------------
DROP TABLE IF EXISTS `course_detail_2`;
CREATE TABLE `course_detail_2`  (
  `id` bigint(20) NOT NULL,
  `course_id` bigint(20) DEFAULT NULL COMMENT '課程id',
  `remark` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '備注',
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

配置廣播表規(guī)則

#水平分表配置
spring:
  main:
    #允許名稱相同的bean的覆蓋(一個實體類對應多張表)
    allow-bean-definition-overriding: true
  shardingsphere:
    props:
      sql:
        show: true
    datasource:
      # 數(shù)據(jù)源名稱,多數(shù)據(jù)源以逗號分隔
      names: m1
      # names定義的數(shù)據(jù)源名稱作為key(key不能包含下劃線,否則無法識別配置)
      m1:
        url: jdbc:mysql://182.92.219.202:3306/sharding_db-1?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
        username: root
        password: xxxx
        driver-class-name: com.mysql.cj.jdbc.Driver
        # 數(shù)據(jù)庫連接池類名稱  com.alibaba.druid.pool.DruidDataSource  com.zaxxer.hikari.HikariDataSource
        type: com.alibaba.druid.pool.DruidDataSource
    sharding:
      tables:
        # 表名
        course:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            # 也可以自定義(實現(xiàn)ShardingKeyGenerator,并配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator) SIMPLE
            type: SNOWFLAKE
          #由數(shù)據(jù)源名 + 表名組成,以小數(shù)點分隔。多個表以逗號分隔,支持inline表達式。
          #缺省表示使用已知數(shù)據(jù)源與邏輯表名稱生成數(shù)據(jù)節(jié)點,用于廣播表(即每個庫中都需要一個同樣的表用于關(guān)聯(lián)查詢,多為字典表)或只分庫不分表且所有庫的表結(jié)構(gòu)完全一致的情況
          actual-data-nodes: m1.course_$->{1..2}
          #分片策略:單分片鍵
          table-strategy:
            inline:
              #分片鍵
              sharding-column: id
              #數(shù)據(jù)分片規(guī)則
              algorithm-expression: course_$->{id % 2 + 1}
        course_detail:
          key-generator:
            column: id
            #主鍵生成策略 可選內(nèi)置的 SNOWFLAKE(雪花算法)/UUID
            # 也可以自定義(實現(xiàn)ShardingKeyGenerator,并配置META-INF/services/org.apache.shardingsphere.spi.keygen.ShardingKeyGenerator) SIMPLE
            type: SNOWFLAKE
          #配置 t_order 表規(guī)則  ->{a..b}  a必須存在,否則分布式主鍵無法獲取
          actual-data-nodes: m1.course_detail_$->{1..2}
          table-strategy:
            inline:
              # 綁定表分片字段要一致(外鍵字段)
              sharding-column: course_id
              algorithm-expression: course_detail_$->{course_id % 2 + 1}
      # 綁定表規(guī)則列表(避免查詢笛卡爾積),多套規(guī)則使用binding-tables[0],binding-tables[1]...
      binding-tables: course_detail,course

注意:綁定表的分區(qū)鍵要一致

測試-綁定表查詢(笛卡爾積)

	/**
     * 綁定表測試(查詢笛卡爾積)
     */
    @Test
    public void bindingTest(){
        List<Long> ids = new ArrayList<>();
        for (int i = 0; i < 4; i++) {
            Course course = new Course();
            course.setName("java" + i);
            course.setStatus(1);
            course.setCreateTime(new Date());
            courseMapper.insert(course);
            CourseDetail courseDetail = new CourseDetail();
            courseDetail.setCourseId(course.getId());
            courseDetail.setRemark("備注" + i);
            courseDetailMapper.insert(courseDetail);
            ids.add(course.getId());
        }
        List<Course> res = courseMapper.binding(ids);
        log.info("查詢結(jié)果:{}",res.size());
    }

首先注釋掉綁定表配置,查看關(guān)聯(lián)查詢笛卡爾積

 # 綁定表規(guī)則列表(避免查詢笛卡爾積),多套規(guī)則使用binding-tables[0],binding-tables[1]...
      #binding-tables: course_detail,course

在這里插入圖片描述
在這里插入圖片描述

然后打開綁定表配置,查看關(guān)聯(lián)查詢是否還有笛卡爾積

# 綁定表規(guī)則列表(避免查詢笛卡爾積),多套規(guī)則使用binding-tables[0],binding-tables[1]...
      binding-tables: course_detail,course

在這里插入圖片描述

3.9 分布式事務XA

默認的 XA 事務管理器為 Atomikos
BASE事務管理器為Seata

配置事務管理器

package com.yss.datamiddle.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;

import javax.sql.DataSource;

/**
 * @description:
 * @author: Han LiDong
 * @create: 2021/5/27 11:16
 * @update: 2021/5/27 11:16
 */
@Configuration
@EnableTransactionManagement
public class TransactionConfiguration {

    @Bean
    public PlatformTransactionManager txManager(final DataSource dataSource) {
        return new DataSourceTransactionManager(dataSource);
    }

    @Bean
    public JdbcTemplate jdbcTemplate(final DataSource dataSource) {
        return new JdbcTemplate(dataSource);
    }
}

使用分布式事務

   @Test
//    @Rollback(value = false)
    @Transactional
    @ShardingTransactionType(TransactionType.XA)  // 支持TransactionType.LOCAL, TransactionType.XA, TransactionType.BASE
    public void transactionTest() {
        Course course = new Course();
        course.setName("java");
        int rand = (int)(Math.random() * 10);
        course.setStatus(rand % 2);
        course.setCreateTime(new Date());
        courseMapper.insert(course);
        Course course1 = new Course();
        course1.setName("java");
        int rand1 = (int)(Math.random() * 10);
        course1.setStatus(rand1 % 2 + 1);
        course1.setCreateTime(new Date());
        courseMapper.insert(course1);
        int a = 1/0;
    }

四、踩坑指南

4.1 項目引入shardingjdbc相關(guān)包,啟動項目報錯required a bean named ‘entityManagerFactory' that could not be found

在這里插入圖片描述

解決方案:
注釋pom中durid、dynamic-datasource-spring-boot-starter引用

<!-- https://mvnrepository.com/artifact/com.baomidou/dynamic-datasource-spring-boot-starter -->
<!--        <dependency>-->
<!--            <groupId>com.baomidou</groupId>-->
<!--            <artifactId>dynamic-datasource-spring-boot-starter</artifactId>-->
<!--            <version>3.1.0</version>-->
<!--        </dependency>-->
<!--        <dependency>-->
<!--            <groupId>com.alibaba</groupId>-->
<!--            <artifactId>druid-spring-boot-starter</artifactId>-->
<!--        </dependency>-->

4.2 項目啟動報錯

Failed to configure a DataSource: ‘url' attribute is not specified and no embedded datasource could be configured.

問題描述:項目引入shardingjdbc包、配置好分片規(guī)則之后啟動項目報錯找不到數(shù)據(jù)庫配置,但是配置文件中明明按照sharding數(shù)據(jù)源配置規(guī)則配置了數(shù)據(jù)庫鏈接信息。

問題原因:DruidDataSourceAutoConfigure在DynamciDataSourceAutoConfiguration之前,其會注入一個DataSourceWrapper,會在原生的spring.datasource下找url,username,password等。而我們動態(tài)數(shù)據(jù)源的配置路徑是變化的。

解決方案二選一

springboot啟動類增加如下配置
@SpringBootApplication(exclude = {DruidDataSourceAutoConfigure.class})項目配置文件新增:

# 使用多數(shù)據(jù)源時要有這個配置,要不然會啟動失敗。單數(shù)據(jù)源的時候不要加這個配置。
 spring.autoconfigure.exclude = com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure

4.3 項目啟動報錯

org.springframework.dao.InvalidDataAccessApiUsageException: ConnectionCallback; isValid; nested exception is java.sql.SQLFeatureNotSupportedException: isValid

在這里插入圖片描述

解決方案:
此問題是Spring Boot 2.3.8數(shù)據(jù)源健康檢查sql為null引起。
解決辦法是繼承 DataSourceHealthContributorAutoConfiguration 重寫 createIndicator 方法

package com.yss.datamiddle.config;

import org.springframework.beans.factory.ObjectProvider;
import org.springframework.boot.actuate.autoconfigure.jdbc.DataSourceHealthContributorAutoConfiguration;
import org.springframework.boot.actuate.health.AbstractHealthIndicator;
import org.springframework.boot.actuate.jdbc.DataSourceHealthIndicator;
import org.springframework.boot.jdbc.metadata.DataSourcePoolMetadataProvider;
import org.springframework.context.annotation.Configuration;
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
import org.springframework.util.StringUtils;

import javax.sql.DataSource;
import java.util.Map;

/**
 * @description: 重寫健康檢查sql,解決項目啟動健康檢查異常
 * @author: Han LiDong
 * @create: 2021/5/28 14:40
 * @update: 2021/5/28 14:40
 */
@Configuration
public class DataSourceHealthConfig extends DataSourceHealthContributorAutoConfiguration {

    private static final String defaultQuery = "select 1";

    public DataSourceHealthConfig(Map<String, DataSource> dataSources, ObjectProvider<DataSourcePoolMetadataProvider> metadataProviders) {
        super(dataSources, metadataProviders);
    }

    @Override
    protected AbstractHealthIndicator createIndicator(DataSource source) {
        DataSourceHealthIndicator indicator = (DataSourceHealthIndicator) super.createIndicator(source);
        if (!StringUtils.hasText(indicator.getQuery())) {
            indicator.setQuery(defaultQuery);
        }
        return indicator;
    }
}

4.4 分片表新增數(shù)據(jù),但是分片鍵未賦值導致全表入庫數(shù)據(jù)。

解決方法:分片鍵必須為非空,否則會全表新增數(shù)據(jù)。

4.5 項目啟動報錯

Caused by: org.hibernate.AnnotationException: No identifier specified for entity: com.yss.datamiddle.po.PrometheusAlertRecordSummaryPo

解決方法:ORM實體類必須有主鍵注解 @Id

4.6 Table ‘xxx_sequences' doesn't exist

在這里插入圖片描述

解決方案:分表字段主鍵生成策略改為:

  @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    private Long id;

4.7 Table ‘tablename' doesn't exist

分片表對應ORM映射實體類 去掉表名映射:@TableName(“source”)
在這里插入圖片描述

4.8 org.springframework.boot.context.properties.source.InvalidConfigurationPropertyNameException: Configuration property name ‘spring.shardingsphere.datasource.monitor_1' is not valid

解決方案:yml配置key不能包含下劃線,調(diào)整monitor_1為monitor-1

4.9 報錯:

Caused by: java.lang.NullPointerException: please config application id within seata.conf file.

原因:使用XA分布式事務,但同時又引入了Base事務相關(guān)包
解決方案:注釋掉Base事務包

<!-- 使用 BASE 事務時,需要引入此模塊 -->
<!--        <dependency>-->
<!--            <groupId>org.apache.shardingsphere</groupId>-->
<!--            <artifactId>sharding-transaction-base-seata-at</artifactId>-->
<!--            <version>4.1.1</version>-->
<!--        </dependency>-->
<!--        &lt;!&ndash; https://mvnrepository.com/artifact/io.seata/seata-core &ndash;&gt;-->
<!--        <dependency>-->
<!--            <groupId>io.seata</groupId>-->
<!--            <artifactId>seata-core</artifactId>-->
<!--            <version>1.4.2</version>-->
<!--        </dependency>-->

以上就是springboot整合shardingjdbc實現(xiàn)分庫分表最簡單demo的詳細內(nèi)容,更多關(guān)于springboot整合shardingjdbc分庫分表的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 帶你快速搞定java多線程(5)

    帶你快速搞定java多線程(5)

    這篇文章主要介紹了java多線程編程實例,分享了幾則多線程的實例代碼,具有一定參考價值,加深多線程編程的理解還是很有幫助的,需要的朋友可以參考下
    2021-07-07
  • SpringMVC多個文件上傳及上傳后立即顯示圖片功能

    SpringMVC多個文件上傳及上傳后立即顯示圖片功能

    這篇文章主要介紹了SpringMVC多個文件上傳及上傳后立即顯示圖片功能,非常不錯,具有參考借鑒價值功能,需要的朋友可以參考下
    2017-10-10
  • MAVEN3.9.x中301問題及解決方法

    MAVEN3.9.x中301問題及解決方法

    本文主要介紹了使用MAVEN3.9.x中301問題及解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2025-01-01
  • Java中的關(guān)鍵字之final詳解

    Java中的關(guān)鍵字之final詳解

    這篇文章主要介紹了Java中的關(guān)鍵字之final詳解,final關(guān)鍵字算是個高頻的java基礎問題了,面試官可能會問說說final,final修飾的抽象類能夠被繼承嗎等等,下面匯總關(guān)于final關(guān)鍵字的知識點,需要的朋友可以參考下
    2024-01-01
  • feign name指定服務調(diào)用無效問題及解決

    feign name指定服務調(diào)用無效問題及解決

    文章主要介紹了FeignClient注解的常用屬性,并通過一個具體的例子說明了為什么某個Feign調(diào)用需要使用url指定路徑才能訪問,最后,文章給出了解決辦法,即使用path屬性指定前綴
    2024-11-11
  • apache commons工具集代碼詳解

    apache commons工具集代碼詳解

    這篇文章主要介紹了apache commons工具集代碼詳解,具有一定借鑒價值,需要的朋友可以參考下
    2017-12-12
  • Java中notify()和notifyAll()的使用區(qū)別

    Java中notify()和notifyAll()的使用區(qū)別

    本文主要介紹了Java中notify()和notifyAll()的使用區(qū)別,文中通過示例代碼介紹的非常詳細,感興趣的小伙伴們可以參考一下
    2021-06-06
  • Java中基于Shiro,JWT實現(xiàn)微信小程序登錄完整例子及實現(xiàn)過程

    Java中基于Shiro,JWT實現(xiàn)微信小程序登錄完整例子及實現(xiàn)過程

    這篇文章主要介紹了Java中基于Shiro,JWT實現(xiàn)微信小程序登錄完整例子 ,實現(xiàn)了小程序的自定義登陸,將自定義登陸態(tài)token返回給小程序作為登陸憑證。需要的朋友可以參考下
    2018-11-11
  • Java如何使用ReentrantLock實現(xiàn)長輪詢

    Java如何使用ReentrantLock實現(xiàn)長輪詢

    這篇文章主要介紹了如何使用ReentrantLock實現(xiàn)長輪詢,對ReentrantLock感興趣的同學,可以參考下
    2021-04-04
  • java 中 zookeeper簡單使用

    java 中 zookeeper簡單使用

    ZooKeeper是一個分布式的,開放源碼的分布式應用程序協(xié)調(diào)服務,是Google的Chubby一個開源的實現(xiàn),是Hadoop和Hbase的重要組件。下面通過本文給大家分享java 中 zookeeper簡單使用,需要的朋友參考下吧
    2017-09-09

最新評論

日本一二三中文字幕| 无码国产精品一区二区高潮久久4| 国产精品人妻66p| av手机在线观播放网站| 国产chinesehd精品麻豆| 国产亚洲天堂天天一区| 国产乱子伦一二三区| 国产老熟女伦老熟妇ⅹ| 亚洲最大免费在线观看| 中文字幕在线视频一区二区三区 | 中文字幕日韩精品就在这里| 91极品新人『兔兔』精品新作| 人人人妻人人澡人人| 一区二区三区久久中文字幕| 亚洲av成人网在线观看| 又粗又硬又猛又爽又黄的| 国产使劲操在线播放| 中文字幕高清资源站| 91精品一区二区三区站长推荐| 欧美黑人性猛交xxxxⅹooo| 亚洲av日韩精品久久久久久hd| 啪啪啪啪啪啪啪啪啪啪黄色| 岛国黄色大片在线观看| 黄色片年轻人在线观看| 天天操,天天干,天天射| 午夜频道成人在线91| 亚洲国产第一页在线观看| 国产精品黄页网站视频| 一区二区三区蜜臀在线| 黄色在线观看免费观看在线| 日本五十路熟新垣里子| 大香蕉日本伊人中文在线| 日韩精品一区二区三区在线播放| 最新国产亚洲精品中文在线| 在线观看黄色成年人网站| 开心 色 六月 婷婷| 女警官打开双腿沦为性奴| 超级福利视频在线观看| 大屁股肉感人妻中文字幕在线| 在线观看欧美黄片一区二区三区| 日韩成人性色生活片| 亚洲一区久久免费视频| 伊人开心婷婷国产av| 天天摸天天日天天操| 亚洲 自拍 色综合图| 护士小嫩嫩又紧又爽20p| 丝袜美腿视频诱惑亚洲无| 动漫黑丝美女的鸡巴| 亚洲高清免费在线观看视频| 亚洲成人线上免费视频观看| 亚洲 国产 成人 在线| 亚洲成人激情视频免费观看了| 早川濑里奈av黑人番号| 色哟哟在线网站入口| 男人操女人逼逼视频网站| 69精品视频一区二区在线观看| 午夜在线观看岛国av,com| 天天操天天爽天天干| 伊人成人在线综合网| 亚洲区欧美区另类最新章节| 中文字幕人妻一区二区视频| 人妻久久久精品69系列| 人妻最新视频在线免费观看| 国内精品在线播放第一页| 国产欧美日韩第三页| 国产剧情演绎系列丝袜高跟| 国产精品欧美日韩区二区| 青娱乐蜜桃臀av色| 大陆精品一区二区三区久久| 和邻居少妇愉情中文字幕| 黑人变态深video特大巨大| 久久精品国产999| 亚洲欧美成人综合视频| 欧美成人一二三在线网| 国产精品人妻66p| 亚洲成人午夜电影在线观看| 日本免费一级黄色录像| 少妇人妻久久久久视频黄片| 成人色综合中文字幕| 国内精品在线播放第一页| 国产露脸对白在线观看| 国产精品探花熟女在线观看| 人妻3p真实偷拍一二区| 天堂va蜜桃一区入口| 在线观看视频 你懂的| 手机看片福利盒子日韩在线播放| 中文字幕在线乱码一区二区| 欧美一区二区三区在线资源| 欧美综合婷婷欧美综合| 色狠狠av线不卡香蕉一区二区 | 99精品免费观看视频| 狠狠躁狠狠爱网站视频| 最新日韩av传媒在线| 婷婷午夜国产精品久久久| 天天日天天干天天插舔舔| 亚洲图片欧美校园春色| 91天堂精品一区二区| 国产久久久精品毛片| 精品少妇一二三视频在线| 中文字幕人妻av在线观看| 日日日日日日日日夜夜夜夜夜夜| 男人操女人逼逼视频网站| 精品成人午夜免费看| 99国内精品永久免费视频| 57pao国产一区二区| 涩涩的视频在线观看视频| 搡老熟女一区二区在线观看| 绝顶痉挛大潮喷高潮无码| nagger可以指黑人吗| 午夜91一区二区三区| 99精品国产自在现线观看| 中文亚洲欧美日韩无线码| 亚洲国产欧美一区二区三区…| 日本乱人一区二区三区| 男人的天堂av日韩亚洲| 国产精彩对白一区二区三区| 亚洲免费va在线播放| 天天射夜夜操狠狠干| 自拍偷拍 国产资源| 粉嫩小穴流水视频在线观看| 9l人妻人人爽人人爽| 99国内小视频在现欢看| 国产老熟女伦老熟妇ⅹ| 亚洲av第国产精品| 2022国产精品视频| 日本女大学生的黄色小视频| 亚洲精品亚洲人成在线导航| 亚洲第一伊人天堂网| 粉嫩小穴流水视频在线观看| 久久www免费人成一看片| 少妇深喉口爆吞精韩国| 成人资源在线观看免费官网| av大全在线播放免费| 91九色国产porny蝌蚪| 精品视频国产在线观看| 夜色撩人久久7777| 人妻熟女中文字幕aⅴ在线| 成人24小时免费视频| 91九色porny国产蝌蚪视频| 欧美激情电影免费在线| 伊人日日日草夜夜草| aiss午夜免费视频| 九一传媒制片厂视频在线免费观看| 97年大学生大白天操逼| 天天插天天色天天日| 亚洲成人免费看电影| 人妻无码中文字幕专区| 中文亚洲欧美日韩无线码| 亚洲免费福利一区二区三区| 国产高潮无码喷水AV片在线观看| 国产精品中文av在线播放| 亚洲欧美日韩视频免费观看| 青青青青青青青青青国产精品视频 | 老司机午夜精品视频资源| 又粗又长 明星操逼小视频| 伊人情人综合成人久久网小说| 成人av免费不卡在线观看| 亚洲精品午夜久久久久| 欧美成人综合色在线噜噜| 成年人该看的视频黄免费| 五十路丰满人妻熟妇| 中文字幕在线视频一区二区三区| 传媒在线播放国产精品一区| 国产精品自拍视频大全| 啪啪啪啪啪啪啪啪av| 欧美伊人久久大香线蕉综合| 国产欧美精品免费观看视频| 国产亚洲国产av网站在线| 国产一区二区三免费视频| 2025年人妻中文字幕乱码在线| 亚洲一级av大片免费观看| 激情图片日韩欧美人妻| 大香蕉伊人中文字幕| 国产超码片内射在线| av破解版在线观看| 一区二区三区蜜臀在线| 人妻素人精油按摩中出| 高清成人av一区三区| 青青青青操在线观看免费| 色吉吉影音天天干天天操| 亚洲久久午夜av一区二区| 日本后入视频在线观看| asmr福利视频在线观看| 欧美视频一区免费在线| 中文字幕乱码人妻电影| 国产一区二区神马久久| av视屏免费在线播放| 国产成人自拍视频在线免费观看| 亚洲成a人片777777| 欧美交性又色又爽又黄麻豆| 啊慢点鸡巴太大了啊舒服视频| 日韩美女精品视频在线观看网站| 久草视频在线免播放| 青青青爽视频在线播放| 天天日天天爽天天干| 视频一区二区综合精品| 一区二区三区蜜臀在线| 天天日天天干天天舔天天射| 老司机免费福利视频网| 午夜的视频在线观看| 在线新三级黄伊人网| 日韩亚洲高清在线观看| 日韩激情文学在线视频| 亚洲日本一区二区久久久精品| 成人av在线资源网站| 97国产在线av精品| 91片黄在线观看喷潮| 蜜桃视频入口久久久| 日本男女操逼视频免费看| 国产精品久久久久久久久福交| 可以免费看的www视频你懂的| 视频 一区二区在线观看| 自拍偷拍日韩欧美亚洲| 清纯美女在线观看国产| 日韩写真福利视频在线观看| 狠狠操操操操操操操操操| 青青青青青操视频在线观看| 免费福利av在线一区二区三区| 日本精品一区二区三区在线视频。| 93人妻人人揉人人澡人人| 欧美天堂av无线av欧美| 揄拍成人国产精品免费看视频| 青青青青在线视频免费观看| 中文字幕第三十八页久久| 一区二区三区精品日本| 在线观看的a站 最新| 成人福利视频免费在线| 2020国产在线不卡视频| 亚洲欧美清纯唯美另类| 淫秽激情视频免费观看| 第一福利视频在线观看| 五月色婷婷综合开心网4438| 免费观看理论片完整版| 一区二区三区 自拍偷拍| 亚洲精品一线二线在线观看| 93精品视频在线观看| 操人妻嗷嗷叫视频一区二区| 青青操免费日综合视频观看| 国产成人精品午夜福利训2021| www骚国产精品视频| 视频一区二区在线免费播放| 欧美香蕉人妻精品一区二区| 欧美偷拍亚洲一区二区| 色婷婷六月亚洲综合香蕉| 特黄老太婆aa毛毛片| 日韩av有码中文字幕| 中文字幕—97超碰网| 国产一级麻豆精品免费| 热99re69精品8在线播放| 真实国产乱子伦一区二区| 最新中文字幕乱码在线| 一区二区三区 自拍偷拍| 99精品视频之69精品视频| 日本午夜久久女同精女女| 国产九色91在线观看精品| 人妻无码色噜噜狠狠狠狠色| av网址在线播放大全| 青青青aaaa免费| 一个人免费在线观看ww视频| 亚洲综合图片20p| 日韩av熟妇在线观看| 欧美亚洲中文字幕一区二区三区| 日本熟妇一区二区x x| 99热这里只有精品中文| 婷婷久久久久深爱网| 午夜91一区二区三区| 精品久久久久久久久久久a√国产| 亚洲在线免费h观看网站| 国产一区成人在线观看视频| 后入美女人妻高清在线| 欧美美女人体视频一区| 午夜dv内射一区区| 国产实拍勾搭女技师av在线| 国产清纯美女al在线| 天天操天天干天天日狠狠插 | 岛国毛片视频免费在线观看| 香蕉片在线观看av| 3337p日本欧洲大胆色噜噜| 中文字幕一区二区三区人妻大片| 亚洲男人在线天堂网| aⅴ五十路av熟女中出| 后入美女人妻高清在线| 国产精品久久久黄网站| 漂亮 人妻被中出中文| 天堂中文字幕翔田av| 免费黄色成人午夜在线网站| 亚洲欧美综合另类13p| 国产久久久精品毛片| 中文字幕日韩精品就在这里| 不戴胸罩引我诱的隔壁的人妻| 欧亚乱色一区二区三区| 久久久久国产成人精品亚洲午夜| 亚洲欧美激情国产综合久久久| 国产成人自拍视频播放| 国产+亚洲+欧美+另类| 制丝袜业一区二区三区| 黄网十四区丁香社区激情五月天| 亚洲高清视频在线不卡| 99国内精品永久免费视频| 女生自摸在线观看一区二区三区| 水蜜桃国产一区二区三区| 五月天久久激情视频| 欧美视频不卡一区四区| 亚洲成av人无码不卡影片一| 绝顶痉挛大潮喷高潮无码| 国产精品大陆在线2019不卡| 日韩精品一区二区三区在线播放| 五十路av熟女松本翔子| 午夜在线观看岛国av,com| 可以在线观看的av中文字幕| av中文字幕网址在线| 一区二区三区精品日本| 99精品国自产在线人| 精品高跟鞋丝袜一区二区| 久久艹在线观看视频| 狠狠躁夜夜躁人人爽天天久天啪| 扒开腿挺进肉嫩小18禁视频| asmr福利视频在线观看| 新97超碰在线观看| 中文字幕av一区在线观看| 97青青青手机在线视频| 日本熟女50视频免费| 免费无毒热热热热热热久| 伊人综合aⅴ在线网| 9l人妻人人爽人人爽| 天天日天天透天天操| sw137 中文字幕 在线| 日本在线不卡免费视频| 老司机在线精品福利视频| 动漫精品视频在线观看| 97成人免费在线观看网站| 青青青aaaa免费| 久久久久国产成人精品亚洲午夜| 自拍偷拍一区二区三区图片| 亚洲精品乱码久久久本| 欧美日韩不卡一区不区二区| 天堂女人av一区二区| 成人亚洲精品国产精品| 免费啪啪啪在线观看视频| 人妻自拍视频中国大陆| 国产综合视频在线看片| 日本熟女50视频免费| 毛片av在线免费看| 美女av色播在线播放| 黑人解禁人妻叶爱071| 2021久久免费视频| 果冻传媒av一区二区三区| 大香蕉伊人中文字幕| 春色激情网欧美成人| 91高清成人在线视频| 97瑟瑟超碰在线香蕉| 成人av亚洲一区二区| 密臀av一区在线观看| av森泽佳奈在线观看| 动色av一区二区三区| 国产高清在线观看1区2区| av视屏免费在线播放| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 亚洲 中文 自拍 另类 欧美| 亚洲天堂有码中文字幕视频| 爆乳骚货内射骚货内射在线| 激情色图一区二区三区| av一本二本在线观看| 五十路丰满人妻熟妇| 天天摸天天亲天天舔天天操天天爽| 91chinese在线视频| 久久美欧人妻少妇一区二区三区| eeuss鲁片一区二区三区| 日本少妇人妻xxxxx18| gay gay男男瑟瑟在线网站| 扒开腿挺进肉嫩小18禁视频| 熟女视频一区,二区,三区| 色av色婷婷人妻久久久精品高清| 日本啪啪啪啪啪啪啪| 99精品免费观看视频| 狠狠嗨日韩综合久久| 插逼视频双插洞国产操逼插洞| 青青操免费日综合视频观看| 亚洲国产成人无码麻豆艾秋| 自拍偷拍日韩欧美一区二区| eeuss鲁片一区二区三区| 在线不卡成人黄色精品| 中文字幕在线观看国产片| 三级av中文字幕在线观看| 成人av免费不卡在线观看| 91国语爽死我了不卡| 超pen在线观看视频公开97| 日本韩国免费一区二区三区视频| 亚洲成人国产综合一区| 大香蕉福利在线观看| 97人妻色免费视频| 抽查舔水白紧大视频| 中文字幕av一区在线观看| 欧美性受xx黑人性猛交| 社区自拍揄拍尻屁你懂的| 亚洲免费va在线播放| 欧美香蕉人妻精品一区二区| av天堂资源最新版在线看| 成人午夜电影在线观看 久久| 国产亚洲成人免费在线观看| 天天插天天色天天日| 青青青激情在线观看视频| 一区二区三区毛片国产一区| 99久久99一区二区三区| 高清成人av一区三区| 在线观看视频网站麻豆| 98视频精品在线观看| 国产精品久久久黄网站| 韩国女主播精品视频网站| 午夜毛片不卡在线看| 99热色原网这里只有精品| 欧美国品一二三产区区别| 精品久久久久久久久久中文蒉| 欧美在线精品一区二区三区视频| 91 亚洲视频在线观看| 国产欧美精品一区二区高清| 国产精品3p和黑人大战| 91色九色porny| 国产av国片精品一区二区| 国产成人无码精品久久久电影| 国产精品自偷自拍啪啪啪| 午夜免费体验区在线观看| 国产无遮挡裸体免费直播视频| 中文字幕在线观看国产片| 97超碰人人搞人人| 97超碰免费在线视频| 黄色片一级美女黄色片| 日韩av有码一区二区三区4| 91色秘乱一区二区三区| 日本人妻精品久久久久久| 欧洲亚洲欧美日韩综合| 精品国产在线手机在线| 99精品一区二区三区的区| 91中文字幕最新合集| 亚洲一区二区三区五区| 农村胖女人操逼视频| 亚洲欧美成人综合视频| 自拍偷拍 国产资源| 精品人妻每日一部精品| 欧美一级色视频美日韩| 久久热这里这里只有精品| 国产熟妇一区二区三区av| 伊人开心婷婷国产av| 人妻久久无码中文成人| 日本熟妇喷水xxx| 中文字幕最新久久久| 成年人的在线免费视频| 少妇人妻二三区视频| 亚洲精品麻豆免费在线观看| 最近的中文字幕在线mv视频| 亚洲精品国产综合久久久久久久久 | 9色精品视频在线观看| 大学生A级毛片免费视频| 国产极品精品免费视频| 五十路丰满人妻熟妇| 欲乱人妻少妇在线视频裸| 天堂av在线官网中文| 777奇米久久精品一区| 亚洲精品ww久久久久久| 中国熟女@视频91| 操日韩美女视频在线免费看| www日韩a级s片av| 午夜美女少妇福利视频| 青娱乐极品视频青青草| 欧美日韩v中文在线| 欧美区一区二区三视频| 蜜桃专区一区二区在线观看| 亚洲天天干 夜夜操| 亚洲图库另类图片区| yellow在线播放av啊啊啊 | 欧美专区第八页一区在线播放| 亚洲图库另类图片区| aiss午夜免费视频| 婷婷综合亚洲爱久久| 大香蕉福利在线观看| 春色激情网欧美成人| 中文字幕在线乱码一区二区| caoporn蜜桃视频| 男人在床上插女人视频| 亚洲午夜福利中文乱码字幕| 黄片色呦呦视频免费看| 在线观看日韩激情视频| 精产国品久久一二三产区区别| 成人亚洲精品国产精品| 日比视频老公慢点好舒服啊| 国产高清精品一区二区三区| 国产精品黄色的av| 欧美特色aaa大片| 日韩美女精品视频在线观看网站| 在线国产中文字幕视频| 国产大鸡巴大鸡巴操小骚逼小骚逼| 自拍偷拍亚洲欧美在线视频| 黄色av网站免费在线| 日韩精品中文字幕福利| 精品区一区二区三区四区人妻| 人人妻人人爱人人草| 亚洲av成人网在线观看| 最后99天全集在线观看| 蜜桃臀av蜜桃臀av| 天天干天天爱天天色| 国产高清在线在线视频| 欧美一级色视频美日韩| 人人妻人人爱人人草| 免费福利av在线一区二区三区| 日本熟女50视频免费| 亚洲自拍偷拍精品网| 黑人巨大精品欧美视频| 91大屁股国产一区二区| 自拍偷拍亚洲另类色图| 又黄又刺激的午夜小视频| 天天干天天操天天扣| 特大黑人巨大xxxx| 夏目彩春在线中文字幕| 国产成人小视频在线观看无遮挡| 亚洲 欧美 精品 激情 偷拍 | 玩弄人妻熟妇性色av少妇| 亚洲一区二区三区在线高清 | AV无码一区二区三区不卡| wwwxxx一级黄色片| 婷婷久久一区二区字幕网址你懂得| 国产美女一区在线观看| 在线免费观看国产精品黄色| 亚洲一区制服丝袜美腿| 狠狠操操操操操操操操操| 深夜男人福利在线观看| 亚洲欧洲av天堂综合| 扒开让我视频在线观看| 2021国产一区二区| 男生舔女生逼逼的视频| 狠狠躁夜夜躁人人爽天天久天啪| 福利视频一区二区三区筱慧 | 天码人妻一区二区三区在线看 | 在线免费观看黄页视频| 91麻豆精品秘密入口在线观看| 久久久久五月天丁香社区| 最新国产亚洲精品中文在线| 欧美久久久久久三级网| 91香蕉成人app下载| 影音先锋女人av噜噜色| 18禁免费av网站| 黄色片黄色片wyaa| 99精品免费观看视频| 91极品新人『兔兔』精品新作| 亚洲国产第一页在线观看| 边摸边做超爽毛片18禁色戒| 国产麻豆精品人妻av| 2020中文字幕在线播放| 把腿张开让我插进去视频| 日本精品一区二区三区在线视频。| 青青热久免费精品视频在线观看 | 午夜在线观看一区视频| 亚洲视频在线观看高清| 亚洲一区二区三区久久午夜| 久草视频中文字幕在线观看| 在线亚洲天堂色播av电影| 亚洲成人熟妇一区二区三区| 久久久精品精品视频视频| 大陆av手机在线观看| 又粗又硬又猛又黄免费30| 中文字日产幕乱六区蜜桃| 欧美精产国品一二三产品区别大吗| 狠狠地躁夜夜躁日日躁| 人妻激情图片视频小说| 少妇人妻真实精品视频| 中文字幕第三十八页久久| 日韩欧美高清免费在线| 91天堂精品一区二区| 中文字幕无码一区二区免费| 啪啪啪啪啪啪啪啪av| 搡老熟女一区二区在线观看| 熟女人妻在线观看视频| 日韩在线视频观看有码在线| 少妇被强干到高潮视频在线观看 | 91小伙伴中女熟女高潮| 欧美男人大鸡吧插女人视频| 韩国AV无码不卡在线播放| 国产亚洲精品视频合集| 国产成人自拍视频在线免费观看| 99re久久这里都是精品视频| 在线观看视频一区麻豆| 99精品视频之69精品视频 | 久久久久只精品国产三级| 亚洲成人av一区久久| 伊人综合免费在线视频| 黑人大几巴狂插日本少妇| 黄网十四区丁香社区激情五月天| 亚洲综合乱码一区二区| 2020久久躁狠狠躁夜夜躁| 嫩草aⅴ一区二区三区| 久久亚洲天堂中文对白| 国产成人精品亚洲男人的天堂| 自拍偷拍亚洲欧美在线视频| 欧美 亚洲 另类综合| 亚洲成人免费看电影| 日本黄色三级高清视频| 人妻熟女在线一区二区| 天天干天天插天天谢| 首之国产AV医生和护士小芳| 男人天堂最新地址av| 国产又色又刺激在线视频| 无码中文字幕波多野不卡| 男女第一次视频在线观看| 换爱交换乱高清大片| 少妇人妻久久久久视频黄片| 中文字幕人妻一区二区视频 | 快点插进来操我逼啊视频| 天天操天天插天天色| 国产 在线 免费 精品| 欧美第一页在线免费观看视频| 免费在线看的黄片视频| 中文字幕av一区在线观看| 66久久久久久久久久久| 99re国产在线精品| 亚洲熟色妇av日韩熟色妇在线| 天天日天天干天天搡| 天天操天天弄天天射| 国产欧美日韩第三页| 超碰97人人澡人人| 天天操天天插天天色| caoporn蜜桃视频| 午夜dv内射一区区| 亚洲综合另类精品小说| 免费成人av中文字幕| 免费一级黄色av网站| 女蜜桃臀紧身瑜伽裤| 色狠狠av线不卡香蕉一区二区| 午夜久久久久久久99| 日本av熟女在线视频| 久青青草视频手机在线免费观看| 视频二区在线视频观看| 51国产成人精品视频| 大鸡巴插入美女黑黑的阴毛| 久久久精品欧洲亚洲av| 国产V亚洲V天堂无码欠欠| 午夜激情久久不卡一区二区| 丰满少妇翘臀后进式| 亚洲的电影一区二区三区| 国产成人精品福利短视频| 色婷婷综合激情五月免费观看| 国产麻豆剧传媒精品国产av蜜桃| 国产欧美日韩在线观看不卡| 中文字幕熟女人妻久久久| 欧美一区二区三区在线资源 | 色吉吉影音天天干天天操| 黄片三级三级三级在线观看| 欧美亚洲一二三区蜜臀| 一区二区麻豆传媒黄片| 国产刺激激情美女网站| 天天想要天天操天天干| 亚洲一区二区三区uij| 99精品视频之69精品视频| 插小穴高清无码中文字幕| 超pen在线观看视频公开97| 欧美精品一二三视频| 偷拍自拍视频图片免费| 五月激情婷婷久久综合网| 黑人大几巴狂插日本少妇| 国产第一美女一区二区三区四区| 做爰视频毛片下载蜜桃视频1| 日韩成人综艺在线播放| 男人操女人的逼免费视频| 好吊操视频这里只有精品| 偷拍美女一区二区三区| 国产午夜福利av导航| 欧美日韩人妻久久精品高清国产| 啊用力插好舒服视频| 在线观看免费av网址大全| 国产黄色大片在线免费播放| 日本最新一二三区不卡在线| 青青尤物在线观看视频网站| 国产麻豆乱子伦午夜视频观看| 欧洲欧美日韩国产在线| 在线亚洲天堂色播av电影| 亚洲av自拍偷拍综合| 亚洲综合色在线免费观看| 青青青青青操视频在线观看| 亚洲va国产va欧美精品88| 姐姐的朋友2在线观看中文字幕 | 999久久久久999| 欧美爆乳肉感大码在线观看| 中文字幕人妻一区二区视频 | 人妻3p真实偷拍一二区| av在线免费中文字幕| 99的爱精品免费视频| 青青青视频手机在线观看| 色婷婷久久久久swag精品| 亚洲久久午夜av一区二区| 天天干天天日天天谢综合156| 欧美va亚洲va天堂va| 视频一区 二区 三区 综合| 欧美日韩激情啪啪啪| 大鸡巴后入爆操大屁股美女| 午夜频道成人在线91| 青青青青在线视频免费观看| 欧美日韩亚洲国产无线码| 黄色成年网站午夜在线观看| 男人插女人视频网站| 欧美一区二区三区久久久aaa| 亚洲另类综合一区小说| 91试看福利一分钟| 大鸡八强奸视频在线观看| 一区二区三区欧美日韩高清播放| 欧洲欧美日韩国产在线| 青春草视频在线免费播放| 风流唐伯虎电视剧在线观看| 国产综合精品久久久久蜜臀| 青青青青青免费视频| 亚洲国产欧美一区二区三区…| 欧美地区一二三专区| 91精品高清一区二区三区| 日韩美女福利视频网| 国产超码片内射在线| 日本免费午夜视频网站| 五十路人妻熟女av一区二区| 抽查舔水白紧大视频| 国产1区,2区,3区| 亚洲 色图 偷拍 欧美| 视频 一区二区在线观看| free性日本少妇| 青春草视频在线免费播放| 99视频精品全部15| 91免费黄片可看视频| 一区二区三区国产精选在线播放 | 白白操白白色在线免费视频| 国产精品入口麻豆啊啊啊| 午夜在线观看岛国av,com| 国产精品国产精品一区二区| 久久久久久久一区二区三| 欧美交性又色又爽又黄麻豆| 国产日韩精品电影7777| 2022中文字幕在线| 在线观看操大逼视频| 性欧美激情久久久久久久| 人人妻人人爱人人草| 日本欧美视频在线观看三区| 日本三极片中文字幕| 18禁无翼鸟成人在线| 成熟丰满熟妇高潮xx×xx| 91大神福利视频网| 人人爽亚洲av人人爽av| 五十路息与子猛烈交尾视频| 91九色国产porny蝌蚪| 青青在线视频性感少妇和隔壁黑丝| 精品美女在线观看视频在线观看| 黑人进入丰满少妇视频| 一区二区三区四区视频在线播放| 久久国产精品精品美女| 亚洲精品欧美日韩在线播放| 亚洲天堂第一页中文字幕| 亚洲福利午夜久久久精品电影网| 97瑟瑟超碰在线香蕉| 国产欧美日韩在线观看不卡| 亚洲精品 欧美日韩| 2022中文字幕在线| 国产卡一卡二卡三乱码手机| 大陆胖女人与丈夫操b国语高清| 欧美精品资源在线观看| 日本18禁久久久久久| 青青草原色片网站在线观看| 把腿张开让我插进去视频| 久久久久久国产精品| 精品国产午夜视频一区二区| 人人妻人人澡欧美91精品| 在线观看国产网站资源| 91中文字幕免费在线观看| 日本免费视频午夜福利视频| 强行扒开双腿猛烈进入免费版| 绝顶痉挛大潮喷高潮无码| 在线网站你懂得老司机| 青青草原色片网站在线观看| 少妇深喉口爆吞精韩国| 爱爱免费在线观看视频| 国产亚洲欧美另类在线观看| 久久久久久国产精品| 一区二区三区久久中文字幕| 欧美精品欧美极品欧美视频| 一区二区三区久久中文字幕| 不戴胸罩引我诱的隔壁的人妻| 日韩av熟妇在线观看| av久久精品北条麻妃av观看| 女同久久精品秋霞网| 久久热这里这里只有精品| av中文字幕国产在线观看| 中文字幕日韩精品日本| 成人蜜臀午夜久久一区| av大全在线播放免费| 大鸡八强奸视频在线观看| 人妻无码中文字幕专区| 精品一区二区三区欧美| 国产麻豆国语对白露脸剧情| 中文字幕中文字幕人妻| 中文字幕在线永久免费播放| 2020中文字幕在线播放| 97超碰最新免费在线观看| 国产亚洲国产av网站在线| 99精品国产自在现线观看| 极品丝袜一区二区三区| 中文字幕日韩精品日本| 人人在线视频一区二区| 风流唐伯虎电视剧在线观看| 欧美香蕉人妻精品一区二区| 国产视频精品资源网站| 天天操天天干天天插| 亚洲中文字幕乱码区| 啊啊啊想要被插进去视频| 韩国亚洲欧美超一级在线播放视频| 2022天天干天天操| 日韩亚国产欧美三级涩爱| 午夜免费观看精品视频| 黑人解禁人妻叶爱071| 天天干夜夜操天天舔| 亚洲精品亚洲人成在线导航| 免费啪啪啪在线观看视频| 成年午夜影片国产片| 天天夜天天日天天日| 中文字幕无码日韩专区免费| 一色桃子人妻一区二区三区| 大尺度激情四射网站| 色狠狠av线不卡香蕉一区二区| 天天操天天干天天艹| 天天爽夜夜爽人人爽QC| 男人的天堂av日韩亚洲| 青青青青青免费视频| 亚洲男人让女人爽的视频| 2020久久躁狠狠躁夜夜躁| 38av一区二区三区| 91精品啪在线免费| av天堂中文免费在线| 天天操天天弄天天射| 亚洲精品福利网站图片| 污污小视频91在线观看| 天天想要天天操天天干| 1000部国产精品成人观看视频| 久久久91蜜桃精品ad| japanese日本熟妇另类| 青青在线视频性感少妇和隔壁黑丝| 大黑人性xxxxbbbb| 日本高清成人一区二区三区| 后入美女人妻高清在线| 精品久久久久久久久久中文蒉| 日本熟妇丰满厨房55| 密臀av一区在线观看| 国产超码片内射在线| caoporn蜜桃视频| 国产成人午夜精品福利| 久久久久久久精品成人热| 欧美精品亚洲精品日韩在线| 漂亮 人妻被中出中文| 亚洲av日韩精品久久久久久hd| 88成人免费av网站| 亚洲人成精品久久久久久久| 爆乳骚货内射骚货内射在线| 一区二区三区四区视频在线播放| 亚洲麻豆一区二区三区| 黄色片年轻人在线观看| 中文字幕在线永久免费播放| 亚洲免费在线视频网站| 亚洲老熟妇日本老妇| 熟女视频一区,二区,三区| 欧美日韩在线精品一区二区三| 中文字幕之无码色多多| 亚洲av香蕉一区区二区三区犇| 日韩一区二区电国产精品| 亚洲欧洲一区二区在线观看| 成人国产影院在线观看| 大香蕉伊人中文字幕| 亚洲图片欧美校园春色| 亚洲护士一区二区三区| 五十路老熟女码av| 99精品视频之69精品视频| 亚洲 中文 自拍 无码| 国产老熟女伦老熟妇ⅹ| 亚洲 清纯 国产com| 精品国产在线手机在线| 欧美亚洲中文字幕一区二区三区| 中文字幕在线欧美精品| 又色又爽又黄又刺激av网站| 亚洲午夜电影在线观看| 美女骚逼日出水来了| 91精品国产观看免费| 馒头大胆亚洲一区二区| 久久精品久久精品亚洲人| 18禁美女无遮挡免费| 五十路老熟女码av| 精品久久久久久久久久久久人妻 | 国产午夜男女爽爽爽爽爽视频| 国产精品久久9999| 视频 一区二区在线观看| 综合精品久久久久97| 一二三中文乱码亚洲乱码one| 亚洲欧美清纯唯美另类 | 亚洲成人三级在线播放| 久久综合老鸭窝色综合久久| 伊人综合aⅴ在线网| 日韩国产乱码中文字幕| 国产日韩精品电影7777| 无码中文字幕波多野不卡| 亚洲成高清a人片在线观看| 中文字幕在线视频一区二区三区| 五月色婷婷综合开心网4438| 视频久久久久久久人妻| 国产视频网站国产视频| 亚洲熟女综合色一区二区三区四区| 3337p日本欧洲大胆色噜噜| 蜜桃视频入口久久久| 丰满少妇翘臀后进式| 国产女人露脸高潮对白视频| 中文字幕 亚洲av| 国产免费av一区二区凹凸四季| av无限看熟女人妻另类av | 精品区一区二区三区四区人妻| 欧美日韩中文字幕欧美| 亚洲熟妇x久久av久久| 蜜桃视频入口久久久| 欧美成人黄片一区二区三区 | 天码人妻一区二区三区在线看| 亚洲av自拍天堂网| 一本一本久久a久久精品综合不卡| 日本人竟这样玩学生妹| 夜色福利视频在线观看| 欧美日韩高清午夜蜜桃大香蕉| 亚洲精品在线资源站| 久久国产精品精品美女| 国产自拍黄片在线观看| 白嫩白嫩美女极品国产在线观看| 91在线免费观看成人| 视频二区在线视频观看| 粉嫩小穴流水视频在线观看| 日韩写真福利视频在线观看| 爆乳骚货内射骚货内射在线| 一本一本久久a久久精品综合不卡| 99国内精品永久免费视频| 欧美色呦呦最新网址| 激情五月婷婷综合色啪| 五十路av熟女松本翔子| 好吊操视频这里只有精品| 最近中文字幕国产在线| 青青青青操在线观看免费| 93人妻人人揉人人澡人人| 成人区人妻精品一区二视频 | 成人动漫大肉棒插进去视频| 国产乱子伦精品视频潮优女| 天天干天天操天天插天天日| 亚洲成人午夜电影在线观看| 啊啊好慢点插舔我逼啊啊啊视频| 非洲黑人一级特黄片| 欧洲亚洲欧美日韩综合| 国产一区二区三免费视频| 黑人乱偷人妻中文字幕| 天堂v男人视频在线观看| 久久久久久久久久久久久97| 中文字幕在线乱码一区二区| 成人网18免费视频版国产| avjpm亚洲伊人久久| 天天色天天操天天舔| 欧美久久一区二区伊人| av在线资源中文字幕| 亚洲欧洲av天堂综合| 久久精品国产23696| 91国产在线免费播放| 日日摸夜夜添夜夜添毛片性色av| 激情五月婷婷免费视频| 绝色少妇高潮3在线观看| 精品久久久久久久久久久99| av亚洲中文天堂字幕网| 狠狠嗨日韩综合久久| 91麻豆精品秘密入口在线观看 | 中文字幕一区二区三区人妻大片| 中文字幕网站你懂的| 少妇系列一区二区三区视频| 亚洲天堂精品福利成人av| av手机在线免费观看日韩av| 欧美一区二区三区四区性视频| 91免费观看在线网站| 绝顶痉挛大潮喷高潮无码| 中文字幕在线观看极品视频| 成人网18免费视频版国产| 亚洲精品麻豆免费在线观看| 亚洲欧美激情人妻偷拍| 亚洲视频在线观看高清| 人妻少妇性色欲欧美日韩| 久久丁香婷婷六月天| www天堂在线久久| 九色视频在线观看免费| 一级黄色av在线观看| 清纯美女在线观看国产| 五十路熟女人妻一区二区9933| 在线观看av亚洲情色| 亚洲天堂成人在线观看视频网站| 天堂av在线播放免费| 非洲黑人一级特黄片| 欧美精品伦理三区四区| 丰满少妇人妻xxxxx| 欧美成人综合视频一区二区| 少妇人妻久久久久视频黄片| 青青草原网站在线观看| 国产精品福利小视频a| 夜色撩人久久7777| 偷拍自拍亚洲视频在线观看| 19一区二区三区在线播放| 成人30分钟免费视频| 二区中出在线观看老师| 国产chinesehd精品麻豆| 中文人妻AV久久人妻水| 绝顶痉挛大潮喷高潮无码| 亚洲精品av在线观看| 日本一区美女福利视频| 久草视频在线看免费| 欧美国品一二三产区区别| 香蕉91一区二区三区| 成人精品在线观看视频| av在线免费资源站| 亚洲国产欧美国产综合在线 | 2020av天堂网在线观看| 亚洲第17页国产精品| 日韩欧美中文国产在线| 国产三级影院在线观看| 国产高潮无码喷水AV片在线观看| 爆乳骚货内射骚货内射在线| 人妻无码色噜噜狠狠狠狠色| 中文字幕熟女人妻久久久| 亚洲 自拍 色综合图| 国产chinesehd精品麻豆| 护士小嫩嫩又紧又爽20p| 中文字幕无码一区二区免费| 国产成人无码精品久久久电影| 亚洲专区激情在线观看视频| 欧美日韩人妻久久精品高清国产| 久久丁香婷婷六月天| 精品久久久久久久久久中文蒉| 男人操女人逼逼视频网站| 一色桃子人妻一区二区三区| 在线观看免费av网址大全| 国产使劲操在线播放| 第一福利视频在线观看| 香港一级特黄大片在线播放 | 国产aⅴ一线在线观看| 偷拍自拍亚洲视频在线观看| av天堂中文免费在线| 午夜福利人人妻人人澡人人爽| 国内资源最丰富的网站| 国产午夜亚洲精品不卡在线观看| 91国产在线视频免费观看| 国产视频在线视频播放| 97人妻无码AV碰碰视频| 欧美aa一级一区三区四区| 在线观看视频 你懂的| 97瑟瑟超碰在线香蕉| jiuse91九色视频| 久久久久久国产精品| 超碰中文字幕免费观看| 国产一区二区火爆视频| 五月天久久激情视频| 在线免费观看国产精品黄色| 日韩欧美国产一区ab| 97精品成人一区二区三区| 日韩亚洲高清在线观看| 成人av电影免费版| 亚洲熟妇无码一区二区三区| 在线观看操大逼视频| 国产妇女自拍区在线观看| 又粗又长 明星操逼小视频| 在线免费观看视频一二区| 精品黑人一区二区三区久久国产| 一二三区在线观看视频| 精品久久久久久久久久久a√国产| 国产精品人久久久久久| 在线观看视频 你懂的| 亚洲一区二区三区久久受| 亚洲国产成人av在线一区| 自拍偷拍日韩欧美一区二区| 欧亚乱色一区二区三区| 亚洲色偷偷综合亚洲AV伊人| 99热久久这里只有精品8| 五月天久久激情视频| 国产老熟女伦老熟妇ⅹ| 亚洲av日韩精品久久久| 中文字幕在线永久免费播放| 亚洲 图片 欧美 图片| www日韩毛片av| 91免费观看国产免费| 青青草原网站在线观看| 午夜毛片不卡在线看| 亚洲免费福利一区二区三区| 精品久久久久久久久久久99| 免费无码人妻日韩精品一区二区| 高清一区二区欧美系列| 91天堂天天日天天操| 91自产国产精品视频| 亚洲无线观看国产高清在线| 97超碰免费在线视频| 青青青aaaa免费| 99精品国产自在现线观看| 精品首页在线观看视频| 天天操夜夜操天天操天天操| 天天躁夜夜躁日日躁a麻豆| 换爱交换乱高清大片| 93视频一区二区三区| 97国产在线观看高清| 国产高潮无码喷水AV片在线观看 | 成年人中文字幕在线观看| 热久久只有这里有精品| 青草青永久在线视频18| 午夜在线精品偷拍一区二| 五月天色婷婷在线观看视频免费| 快插进小逼里大鸡吧视频| 中国无遮挡白丝袜二区精品| 18禁无翼鸟成人在线| 888亚洲欧美国产va在线播放| 婷婷综合蜜桃av在线| 在线免费观看欧美小视频| 国产精品久久久久久久女人18| 黑人巨大精品欧美视频| 在线视频免费观看网| 免费69视频在线看| 男人的天堂av日韩亚洲| av无限看熟女人妻另类av| 日韩写真福利视频在线观看| 天天日夜夜干天天操| 中文字幕高清免费在线人妻| 一区二区免费高清黄色视频| 中文字幕人妻熟女在线电影| 亚洲欧美在线视频第一页| 这里有精品成人国产99| 日本熟妇色熟妇在线观看| 成人动漫大肉棒插进去视频| 中文字幕高清在线免费播放 | 韩国亚洲欧美超一级在线播放视频 | 岳太深了紧紧的中文字幕| 亚洲高清自偷揄拍自拍| 视频 一区二区在线观看| 午夜场射精嗯嗯啊啊视频| 超级av免费观看一区二区三区| 中文字幕,亚洲人妻| 日韩熟女系列一区二区三区| 直接能看的国产av| 欧美日韩一区二区电影在线观看| 热思思国产99re| 2020久久躁狠狠躁夜夜躁| 日本男女操逼视频免费看| 天天插天天色天天日| 亚洲1卡2卡三卡4卡在线观看 | 日韩欧美制服诱惑一区在线| 黄片色呦呦视频免费看| 国产性生活中老年人视频网站| 75国产综合在线视频| 精品视频国产在线观看| 国产一区二区三免费视频| 中文字幕第一页国产在线| 成人精品视频99第一页| 久久久久久cao我的性感人妻| 久久午夜夜伦痒痒想咳嗽P| 国产三级精品三级在线不卡| 亚洲欧美一区二区三区爱爱动图| 老师让我插进去69AV| 开心 色 六月 婷婷| 高清成人av一区三区| 大黑人性xxxxbbbb| 亚洲另类在线免费观看| 日本黄色三级高清视频| 大鸡巴插入美女黑黑的阴毛| 亚洲区欧美区另类最新章节| 9国产精品久久久久老师 | 欧美在线一二三视频| 中文字幕在线欧美精品| 中文字幕在线一区精品| 亚洲一级特黄特黄黄色录像片| 日噜噜噜夜夜噜噜噜天天噜噜噜| 日韩三级电影华丽的外出| 久久国产精品精品美女| 欧美一区二区三区乱码在线播放| 天天操夜夜骑日日摸| 中文字幕第三十八页久久| 黄色大片免费观看网站| 欧美偷拍亚洲一区二区| 69精品视频一区二区在线观看| 极品丝袜一区二区三区| 国产综合精品久久久久蜜臀| 亚洲成人av一区在线| 日韩精品二区一区久久| 91色九色porny| 欧美一区二区三区久久久aaa| 亚洲一区二区三区精品乱码| 久久麻豆亚洲精品av| 亚洲国产第一页在线观看| 色婷婷久久久久swag精品| 国产精品污污污久久| 日韩写真福利视频在线观看| 中文字幕免费福利视频6| 欧美aa一级一区三区四区| 日本三极片视频网站观看| 亚洲av自拍偷拍综合| 免费费一级特黄真人片| 人妻少妇av在线观看| 中文字幕在线第一页成人| 欧洲黄页网免费观看| 91高清成人在线视频| 国产普通话插插视频| 欧美精产国品一二三产品区别大吗| 久久精品美女免费视频| 欧美成人小视频在线免费看| 午夜大尺度无码福利视频| 在线播放国产黄色av| 欧美视频一区免费在线| 福利一二三在线视频观看| 日本在线一区二区不卡视频| 亚洲一区av中文字幕在线观看| 日韩a级精品一区二区| AV无码一区二区三区不卡| 国产在线自在拍91国语自产精品 | jiuse91九色视频| 日本一道二三区视频久久| 国产亚洲天堂天天一区| chinese国产盗摄一区二区| av天堂中文字幕最新| 亚洲推理片免费看网站| 中文字幕在线视频一区二区三区| 久久久久久97三级| 国产一区av澳门在线观看| 77久久久久国产精产品| 国产精品午夜国产小视频| 丝袜肉丝一区二区三区四区在线看| 看一级特黄a大片日本片黑人| 丰满少妇人妻xxxxx| 97国产在线观看高清| av在线免费中文字幕| 偷拍自拍亚洲美腿丝袜| 青青草精品在线视频观看| 日韩精品电影亚洲一区| 国产实拍勾搭女技师av在线| 夜夜操,天天操,狠狠操| 国产精品入口麻豆啊啊啊| 欧美视频不卡一区四区| 78色精品一区二区三区| 色婷婷综合激情五月免费观看| 亚洲欧美精品综合图片小说 | 国产又色又刺激在线视频| 男人天堂最新地址av| 抽查舔水白紧大视频| 激情伦理欧美日韩中文字幕| 老司机免费视频网站在线看| 亚洲 图片 欧美 图片| 欧美在线一二三视频| 亚洲精品国偷自产在线观看蜜桃| 五十路av熟女松本翔子| 天天日天天干天天要| 一级黄色片夫妻性生活| 国产av国片精品一区二区| 2022精品久久久久久中文字幕| 老司机福利精品视频在线| 精品高跟鞋丝袜一区二区| 日视频免费在线观看| 91 亚洲视频在线观看| 久久久久久久精品老熟妇| 亚洲国产欧美国产综合在线| 国产精品久久久黄网站| 大黑人性xxxxbbbb| 亚洲熟妇久久无码精品| 午夜免费观看精品视频| 91成人精品亚洲国产| 91九色porny国产蝌蚪视频| 鸡巴操逼一级黄色气| 人妻少妇一区二区三区蜜桃| 五色婷婷综合狠狠爱| 蜜桃视频入口久久久| 亚洲国产欧美一区二区三区久久| 91色九色porny| 免费福利av在线一区二区三区| 亚洲精品欧美日韩在线播放| 在线免费91激情四射| 亚洲精品ww久久久久久| 免费av岛国天堂网站| 日韩av熟妇在线观看| 不卡一不卡二不卡三| 美女张开两腿让男人桶av| 人妻少妇精品久久久久久 | 欧美精品黑人性xxxx| 日日操夜夜撸天天干| 后入美女人妻高清在线| 欧美xxx成人在线| 又粗又长 明星操逼小视频| 亚洲av在线观看尤物| 伊人综合免费在线视频| 在线免费观看黄页视频| 精品乱子伦一区二区三区免费播 | 日本阿v视频在线免费观看| 性感美女诱惑福利视频| 精品91高清在线观看 | AV无码一区二区三区不卡| 国产高清97在线观看视频| 天天日天天日天天擦| 性欧美激情久久久久久久| 亚洲最大免费在线观看| 综合页自拍视频在线播放| 日本熟妇一区二区x x| 人妻av无码专区久久绿巨人| 人妻最新视频在线免费观看| 国产白袜脚足J棉袜在线观看| 亚洲另类综合一区小说| 亚洲2021av天堂| 亚洲人妻30pwc| 91在线视频在线精品3| 岛国av高清在线成人在线| 亚洲天堂精品久久久| 成人30分钟免费视频| 日本韩国亚洲综合日韩欧美国产| 色婷婷六月亚洲综合香蕉| 一区二区三区久久久91| 天天干天天爱天天色| 日本福利午夜电影在线观看| 肏插流水妹子在线乐播下载| 日本后入视频在线观看| 亚洲公开视频在线观看| 亚洲欧美精品综合图片小说| 99av国产精品欲麻豆| 亚洲狠狠婷婷综合久久app| av一区二区三区人妻| 91精品啪在线免费| 天天干天天啪天天舔| 91色九色porny| 亚洲欧美自拍另类图片| 国产精品sm调教视频| 亚洲激情av一区二区| 男人和女人激情视频| 美女 午夜 在线视频| 美日韩在线视频免费看| 国产精品一区二区三区蜜臀av | 亚洲欧美日韩视频免费观看| 淫秽激情视频免费观看| 免费在线观看污污视频网站| 日本成人不卡一区二区| 哥哥姐姐综合激情小说| 福利午夜视频在线合集| 视频一区二区综合精品| 91色老99久久九九爱精品| 极品性荡少妇一区二区色欲| 亚洲免费在线视频网站| 日本裸体熟妇区二区欧美| 538精品在线观看视频| 男人在床上插女人视频| 91精品国产观看免费| 在线免费91激情四射 | 伊人情人综合成人久久网小说| 懂色av蜜桃a v| 91大神福利视频网| 黑人解禁人妻叶爱071| 午夜激情久久不卡一区二区 | 日本av在线一区二区三区| 大黑人性xxxxbbbb| 日韩二区视频一线天婷婷五| nagger可以指黑人吗| 日本一二三中文字幕| 国产三级影院在线观看| 99精品视频之69精品视频| 99国内小视频在现欢看| 欧美中国日韩久久精品| 亚洲成人国产综合一区| 天天射夜夜操综合网| 99精品国自产在线人| 亚洲av日韩av网站| 最新国产亚洲精品中文在线| 日本成人一区二区不卡免费在线| 少妇高潮无套内谢麻豆| 亚洲av无码成人精品区辽| 日本人妻精品久久久久久| 快点插进来操我逼啊视频| 男人和女人激情视频| 欧美偷拍自拍色图片| 黑人解禁人妻叶爱071| 3344免费偷拍视频| 亚洲1卡2卡三卡4卡在线观看| 日韩三级电影华丽的外出| 亚洲在线观看中文字幕av| 天天色天天操天天舔| 日本黄在免费看视频| 999久久久久999| 偷拍3456eee| 国产极品美女久久久久久| 亚洲国际青青操综合网站| 精品av国产一区二区三区四区 | 人妻无码中文字幕专区| 国产午夜激情福利小视频在线| 亚洲久久午夜av一区二区| 日日操夜夜撸天天干| 色综合久久无码中文字幕波多| 亚洲区美熟妇久久久久| 青娱乐最新视频在线| tube69日本少妇| 人人爱人人妻人人澡39| 亚洲综合自拍视频一区| 在线不卡成人黄色精品| 黄色片一级美女黄色片| 精品一区二区三区三区88| 自拍偷拍vs一区二区三区| 一区二区在线视频中文字幕| 成年人免费看在线视频| 人妻少妇中文有码精品| 亚洲精品午夜久久久久| 国产又粗又黄又硬又爽| 欧美精品国产综合久久| 超碰97人人澡人人| 视频一区二区在线免费播放| 视频在线免费观看你懂得| 北条麻妃av在线免费观看| 日本一本午夜在线播放| 日本福利午夜电影在线观看| 啊啊好慢点插舔我逼啊啊啊视频| 欧美成人猛片aaaaaaa| 777奇米久久精品一区| 国产高清在线在线视频| 国产精品大陆在线2019不卡| 精品久久久久久久久久久久人妻| 免费看美女脱光衣服的视频| 国产精品人妻66p| 中文字幕日韩91人妻在线| 92福利视频午夜1000看| 无码国产精品一区二区高潮久久4| 亚洲综合自拍视频一区| 亚洲护士一区二区三区| 九一传媒制片厂视频在线免费观看| 黄工厂精品视频在线观看| 黄色中文字幕在线播放| 日本一二三区不卡无| 亚洲国产欧美国产综合在线 | 端庄人妻堕落挣扎沉沦| 日本精品视频不卡一二三| 91在线视频在线精品3| 日日摸夜夜添夜夜添毛片性色av| 国产女人露脸高潮对白视频| 老司机免费福利视频网| 99一区二区在线观看| 欧美国品一二三产区区别| 天天操天天爽天天干| 日韩少妇人妻精品无码专区| 黄色黄色黄片78在线| jiujiure精品视频在线| 午夜免费观看精品视频| 岛国黄色大片在线观看| 2019av在线视频| 91麻豆精品传媒国产黄色片| 99精品一区二区三区的区| 亚洲精品午夜aaa久久| 亚洲国产精品中文字幕网站| 亚洲熟色妇av日韩熟色妇在线 | 硬鸡巴动态操女人逼视频| 3D动漫精品啪啪一区二区下载 | 夜鲁夜鲁狠鲁天天在线| 国产黄色大片在线免费播放| 久久免费看少妇高潮完整版| 日本美女性生活一级片| 亚洲日本一区二区三区| 嫩草aⅴ一区二区三区| 清纯美女在线观看国产| 亚洲欧美国产综合777| 大胆亚洲av日韩av| 亚洲av男人天堂久久| 日韩精品啪啪视频一道免费| 午夜场射精嗯嗯啊啊视频| 66久久久久久久久久久| 日韩人妻在线视频免费| 午夜大尺度无码福利视频| 久久热久久视频在线观看| 天天操天天污天天射| 免费观看国产综合视频| 激情伦理欧美日韩中文字幕| 在线国产精品一区二区三区| 亚洲一区二区三区精品视频在线 | 中文字幕在线观看极品视频| 国产成人精品福利短视频| 欧美性感尤物人妻在线免费看| 93精品视频在线观看| 偷拍自拍亚洲美腿丝袜| 一区二区三区国产精选在线播放| 老鸭窝在线观看一区| 日本熟妇一区二区x x| 午夜极品美女福利视频| 性生活第二下硬不起来| 欧美色婷婷综合在线| 精品91高清在线观看| 成人av天堂丝袜在线观看 | 婷婷综合蜜桃av在线| 日韩加勒比东京热二区| 成人亚洲精品国产精品| 亚洲午夜伦理视频在线| 中文字幕免费在线免费| 搡老妇人老女人老熟女| 欧美在线精品一区二区三区视频| 亚洲另类综合一区小说| 爱有来生高清在线中文字幕| 一二三区在线观看视频| 93人妻人人揉人人澡人人| 国产精品人久久久久久| 不卡一区一区三区在线| 成人av天堂丝袜在线观看| 中文字幕在线免费第一页| 91老师蜜桃臀大屁股| 国产真实乱子伦a视频| 51国产偷自视频在线播放| 男生舔女生逼逼视频| 亚洲一区二区久久久人妻| 亚洲免费国产在线日韩| 国产janese在线播放| 午夜精品福利一区二区三区p| 亚洲男人在线天堂网| huangse网站在线观看| 2020国产在线不卡视频 | 日韩av大胆在线观看| 欧美成人综合视频一区二区| 午夜极品美女福利视频| 亚洲成人熟妇一区二区三区| 国产成人精品av网站| 偷拍自拍福利视频在线观看| 色吉吉影音天天干天天操| 激情小视频国产在线| 一区二区三区国产精选在线播放| 日韩美在线观看视频黄| 大鸡八强奸视频在线观看| 人妻少妇性色欲欧美日韩| 99婷婷在线观看视频| 午夜久久久久久久精品熟女| 精品人妻每日一部精品| 国产精品成久久久久三级蜜臀av| 色秀欧美视频第一页| 中文字幕人妻被公上司喝醉在线| 亚洲中文字幕校园春色| 午夜国产免费福利av| 三级av中文字幕在线观看| 精品老妇女久久9g国产| 果冻传媒av一区二区三区| 在线观看的黄色免费网站| 国产午夜亚洲精品不卡在线观看| 国产成人精品av网站| 91国产在线视频免费观看| 青青草人人妻人人妻| 丁香花免费在线观看中文字幕| 玩弄人妻熟妇性色av少妇| 成人久久精品一区二区三区| 91人妻精品一区二区在线看| 亚洲av无硬久久精品蜜桃| 欧美麻豆av在线播放| 视频在线亚洲一区二区| 综合页自拍视频在线播放| 超级av免费观看一区二区三区| 久久久久91精品推荐99| 亚洲国产欧美国产综合在线| 国产大鸡巴大鸡巴操小骚逼小骚逼 | 人人妻人人澡欧美91精品| 日韩伦理短片在线观看| 亚洲最大黄 嗯色 操 啊| 久久久久久久久久久久久97| 色伦色伦777国产精品| 日韩亚国产欧美三级涩爱| 国产第一美女一区二区三区四区 | 大香蕉大香蕉在线看| 日本精品视频不卡一二三| 新婚人妻聚会被中出| 夜鲁夜鲁狠鲁天天在线| 国产精品久久久久国产三级试频| 亚洲av天堂在线播放| 日韩北条麻妃一区在线| 在线观看的a站 最新| 大肉大捧一进一出好爽在线视频| 精品一线二线三线日本| 久久99久久99精品影院| 亚洲国产在人线放午夜| 中文字幕免费在线免费| 午夜在线观看岛国av,com| chinese国产盗摄一区二区| 中出中文字幕在线观看| 99精品国自产在线人| 男人天堂最新地址av| 久久久精品精品视频视频| 精品suv一区二区69| 538精品在线观看视频| 国产精品久久久黄网站| 国产chinesehd精品麻豆| 午夜毛片不卡免费观看视频| 成人av天堂丝袜在线观看| 少妇人妻100系列| 亚洲2021av天堂| 亚洲中文字幕乱码区| 黄色成年网站午夜在线观看| 91破解版永久免费| 日韩av有码一区二区三区4| 亚洲一区二区激情在线| 免费一级黄色av网站| 男人靠女人的逼视频| 91色九色porny| 天天干天天操天天插天天日| 97人妻无码AV碰碰视频| 这里有精品成人国产99| 最新激情中文字幕视频| 国产又粗又硬又大视频| 亚洲在线免费h观看网站| 超级福利视频在线观看| 超黄超污网站在线观看| 天堂av中文在线最新版| 97精品成人一区二区三区 | av手机在线观播放网站| 自拍偷拍亚洲欧美在线视频| 姐姐的朋友2在线观看中文字幕| 大香蕉日本伊人中文在线| 国产精品日韩欧美一区二区| 久久久超爽一二三av| 涩涩的视频在线观看视频| 天天干狠狠干天天操| 亚洲精品午夜aaa久久| 最近的中文字幕在线mv视频| 欧洲精品第一页欧洲精品亚洲| 亚洲老熟妇日本老妇| 亚洲精品国偷自产在线观看蜜桃| 亚洲中文字幕校园春色| 熟女在线视频一区二区三区| 久久香蕉国产免费天天| 任你操视频免费在线观看| 亚洲国产精品久久久久久6| 日比视频老公慢点好舒服啊| 狍和女人的王色毛片| 天天干天天日天天干天天操| 黄网十四区丁香社区激情五月天 | 日本女人一级免费片| 夜鲁夜鲁狠鲁天天在线| 又大又湿又爽又紧A视频| 亚洲精品无码色午夜福利理论片| 欧美一区二区三区高清不卡tv| 日本熟女50视频免费| 亚洲卡1卡2卡三卡四老狼| 免费在线看的黄片视频| 又色又爽又黄的美女裸体| 黄色片黄色片wyaa| 国内自拍第一页在线观看| 91小伙伴中女熟女高潮| 亚洲 欧美 自拍 偷拍 在线| 在线观看av2025| 午夜精品久久久久久99热| 无忧传媒在线观看视频| 老司机欧美视频在线看| av日韩在线免费播放| 亚洲精品欧美日韩在线播放| 男人靠女人的逼视频| 成人亚洲国产综合精品| 视频一区二区在线免费播放| 99的爱精品免费视频| 亚洲午夜在线视频福利| 久久丁香婷婷六月天| 日韩熟女av天堂系列| 100%美女蜜桃视频| 日本免费一级黄色录像| 亚洲精品高清自拍av| 日韩美女福利视频网| 亚洲成人熟妇一区二区三区| 日韩欧美在线观看不卡一区二区| 狠狠操狠狠操免费视频| 97成人免费在线观看网站| 天天日天天舔天天射进去| 亚洲免费av在线视频| 日本免费午夜视频网站| 免费高清自慰一区二区三区网站| 又色又爽又黄的美女裸体| 超碰97人人澡人人| 国产精彩对白一区二区三区| av一本二本在线观看| av手机在线免费观看日韩av| 国产揄拍高清国内精品对白| 久久久久久久精品成人热| 午夜精品福利一区二区三区p | 久草极品美女视频在线观看| 成人网18免费视频版国产| 青青青青青青草国产| 中文字幕一区的人妻欧美日韩| 伊拉克及约旦宣布关闭领空| 91香蕉成人app下载| 国产精品一区二区av国| 国产精品国产三级国产午| 亚洲最大黄了色网站| 果冻传媒av一区二区三区| 性色av一区二区三区久久久| 最新国产精品拍在线观看| 国产一区成人在线观看视频| 超碰公开大香蕉97| 黑人3p华裔熟女普通话| 色秀欧美视频第一页| 国产成人无码精品久久久电影| sspd152中文字幕在线| 日韩中文字幕精品淫| 国产女孩喷水在线观看| 午夜极品美女福利视频| 久草视频在线一区二区三区资源站 | 老司机99精品视频在线观看| 青青青青青手机视频| 亚洲男人让女人爽的视频| 国产极品美女久久久久久| 中文字幕av第1页中文字幕| 91久久国产成人免费网站| av在线免费资源站| 啊啊好慢点插舔我逼啊啊啊视频| 天天日天天干天天爱| 精品av国产一区二区三区四区 | 小穴多水久久精品免费看| 国产又粗又猛又爽又黄的视频在线| 狍和女人的王色毛片| 又粗又长 明星操逼小视频| 天天躁日日躁狠狠躁av麻豆| 91试看福利一分钟| 天天想要天天操天天干| 狠狠躁狠狠爱网站视频| 自拍偷拍一区二区三区图片| 日本人妻精品久久久久久| 2021久久免费视频| 色综合久久久久久久久中文| 在线成人日韩av电影| 在线播放一区二区三区Av无码| 天天干天天操天天摸天天射| 欧美老鸡巴日小嫩逼| 国产九色91在线观看精品| 成人av久久精品一区二区| 美女张开腿让男生操在线看| 自拍偷拍亚洲欧美在线视频| 2019av在线视频| 国产极品美女久久久久久| 黄色视频成年人免费观看| 国产自拍在线观看成人| 欧美另类z0z变态| av在线免费观看亚洲天堂| 亚洲的电影一区二区三区| 午夜免费观看精品视频| 中文字幕综合一区二区| 亚洲色偷偷综合亚洲AV伊人| 青青青青青青青在线播放视频| 青娱乐最新视频在线| 国产精品自拍视频大全| 精彩视频99免费在线| 日本女人一级免费片| 一级黄色av在线观看| 青青青视频自偷自拍38碰| 操的小逼流水的文章| 天天日夜夜操天天摸| 国产三级影院在线观看| 日韩欧美一级精品在线观看| 夜鲁夜鲁狠鲁天天在线| 自拍偷拍亚洲另类色图| 国产成人精品亚洲男人的天堂| 91色九色porny| 欧美日韩中文字幕欧美| 91传媒一区二区三区| 日韩中文字幕精品淫| 成人亚洲精品国产精品| 亚洲少妇人妻无码精品| 97精品视频在线观看| 日噜噜噜夜夜噜噜噜天天噜噜噜| 91国产在线免费播放| 99婷婷在线观看视频| 久久丁香花五月天色婷婷| 亚洲公开视频在线观看| 国产精品国产三级国产午| 性欧美日本大妈母与子| 97成人免费在线观看网站| 99热这里只有精品中文| 欧美一区二区三区乱码在线播放| 337p日本大胆欧美人| 成人av在线资源网站| 亚洲成人国产av在线| 2020韩国午夜女主播在线| 在线国产日韩欧美视频| 久久精品国产23696| 首之国产AV医生和护士小芳| 97人人模人人爽人人喊| 91精品视频在线观看免费| 亚洲成人av在线一区二区| 亚洲女人的天堂av| 天天干天天爱天天色| 手机看片福利盒子日韩在线播放 | 中国黄片视频一区91| 一个色综合男人天堂| 在线观看av观看av| 一区二区三区四区五区性感视频| 一个色综合男人天堂| 国产精品系列在线观看一区二区 | 免费黄色成人午夜在线网站| 青青青青青青青在线播放视频| 国产又大又黄免费观看| 大陆胖女人与丈夫操b国语高清| 天天操天天干天天日狠狠插| av无限看熟女人妻另类av | 嫩草aⅴ一区二区三区| 视频二区在线视频观看| 黑人巨大的吊bdsm| 久草视频福利在线首页| 亚洲国产在人线放午夜| 日韩av熟妇在线观看| 午夜激情久久不卡一区二区| 啪啪啪啪啪啪啪免费视频| 人人在线视频一区二区| 国产在线一区二区三区麻酥酥| 日本精品一区二区三区在线视频。| 丰满熟女午夜福利视频| 97a片免费在线观看| 亚洲另类图片蜜臀av| 亚洲成人av一区久久| 国产综合视频在线看片| 欧美老鸡巴日小嫩逼| 岛国黄色大片在线观看| 国产精品视频一区在线播放| 人妻丝袜诱惑我操她视频| 丝袜长腿第一页在线| 日韩三级电影华丽的外出| 久久精品久久精品亚洲人| 91色网站免费在线观看| 女生被男生插的视频网站| 欧美黄色录像免费看的| 一区二区三区激情在线| 久久久久久97三级| 欧美男人大鸡吧插女人视频| 在线观看av2025| 国产精品黄页网站视频| 一级A一级a爰片免费免会员 | 涩爱综合久久五月蜜臀| 超pen在线观看视频公开97| 在线网站你懂得老司机| 漂亮 人妻被中出中文| www骚国产精品视频| 国产精品伦理片一区二区| 人妻久久久精品69系列| 999久久久久999| 欧洲黄页网免费观看| 国产极品美女久久久久久| 天天色天天爱天天爽| 成年午夜免费无码区| 日本精品一区二区三区在线视频。 | 亚洲成人午夜电影在线观看| 一区国内二区日韩三区欧美| 欧美viboss性丰满| 天天摸天天日天天操| xxx日本hd高清| 久久久久久久精品老熟妇| 韩国亚洲欧美超一级在线播放视频| 欧美日韩不卡一区不区二区| 午夜频道成人在线91| 成熟熟女国产精品一区| 天天色天天操天天舔| 成人激情文学网人妻| 好了av中文字幕在线| av在线观看网址av| 最新激情中文字幕视频| 91国语爽死我了不卡| 中文字幕av一区在线观看| 国产精品自拍偷拍a| av在线免费观看亚洲天堂| 成年人黄视频在线观看| 91福利在线视频免费观看| 国产在线自在拍91国语自产精品 | 欧美一区二区三区激情啪啪啪 | 久久综合老鸭窝色综合久久| 欧美日本国产自视大全| chinese国产盗摄一区二区| 国产伊人免费在线播放| 天天干天天操天天玩天天射| 性色av一区二区三区久久久| 国产精品黄片免费在线观看| 只有精品亚洲视频在线观看| 一区二区三区蜜臀在线| 搡老熟女一区二区在线观看| 亚洲精品国产综合久久久久久久久| 午夜福利人人妻人人澡人人爽| 三级等保密码要求条款| 中文字幕国产专区欧美激情| 沙月文乃人妻侵犯中文字幕在线| 91传媒一区二区三区| 国产使劲操在线播放| 中文字幕一区二 区二三区四区| av亚洲中文天堂字幕网| 精品一区二区三区三区88| 综合国产成人在线观看| 性感美女福利视频网站| 亚洲另类图片蜜臀av| 亚洲熟女综合色一区二区三区四区| 久久精品美女免费视频| 免费黄页网站4188| 亚洲国产精品中文字幕网站| 日韩人妻xxxxx| 2020久久躁狠狠躁夜夜躁| 中文字幕在线一区精品| 91成人在线观看免费视频| 亚洲综合在线观看免费| 成年午夜影片国产片| 99精品久久久久久久91蜜桃| 成年人午夜黄片视频资源| 东京热男人的av天堂| 水蜜桃一区二区三区在线观看视频 | 成年人黄视频在线观看| 久久热久久视频在线观看| 久久精品亚洲成在人线a| 国产亚洲成人免费在线观看| 欧美日韩一级黄片免费观看| 91极品大一女神正在播放| 色婷婷久久久久swag精品| 国产女人叫床高潮大片视频| 成熟丰满熟妇高潮xx×xx| 99久久99一区二区三区| 98精产国品一二三产区区别| 大香蕉伊人国产在线| 午夜精品一区二区三区更新| 骚货自慰被发现爆操| 日本少妇高清视频xxxxx| 性色av一区二区三区久久久| 黄片色呦呦视频免费看| 丁香花免费在线观看中文字幕| 91大神福利视频网| 亚洲综合一区二区精品久久| 亚洲熟女综合色一区二区三区四区| 欧美性受xx黑人性猛交| gav成人免费播放| 天天摸天天亲天天舔天天操天天爽| 噜噜色噜噜噜久色超碰| 伊人精品福利综合导航| 女警官打开双腿沦为性奴| 国产九色91在线观看精品| 顶级尤物粉嫩小尤物网站| 91国产在线视频免费观看| 免费男阳茎伸入女阳道视频| 偷青青国产精品青青在线观看| 熟女妇女老妇一二三区| 亚洲国产第一页在线观看| 中文字幕在线一区精品| 亚洲精品国产久久久久久| gav成人免费播放| 黄片色呦呦视频免费看| 懂色av之国产精品| 亚洲公开视频在线观看| 黑人大几巴狂插日本少妇| 精品一区二区三四区| 香蕉91一区二区三区| 婷婷五月亚洲综合在线| 人妻少妇性色欲欧美日韩| 久久这里有免费精品| 亚洲久久午夜av一区二区| 中文字幕av第1页中文字幕| 精品久久久久久久久久中文蒉| 日本性感美女三级视频| 蜜桃视频入口久久久| 亚洲乱码中文字幕在线| 精品人妻一二三区久久| 97国产福利小视频合集| 亚洲成av人无码不卡影片一| 性感美女高潮视频久久久| 免费十精品十国产网站| 亚洲熟女女同志女同| 国产精品自拍偷拍a| 2020中文字幕在线播放| 好吊视频—区二区三区| 亚洲精品无码色午夜福利理论片| 1769国产精品视频免费观看| 亚洲午夜伦理视频在线| 午夜久久久久久久99| 11久久久久久久久久久| 天天干天天操天天玩天天射 | 国产变态另类在线观看| 无套猛戳丰满少妇人妻| 天堂中文字幕翔田av| 婷婷久久一区二区字幕网址你懂得| 任你操视频免费在线观看| 岛国青草视频在线观看| 40道精品招牌菜特色| av男人天堂狠狠干| 熟女人妻在线观看视频| 午夜成午夜成年片在线观看| 亚洲少妇人妻无码精品| 男生舔女生逼逼视频| 狠狠躁夜夜躁人人爽天天天天97| 91麻豆精品91久久久久同性| 人妻激情图片视频小说| 日美女屁股黄邑视频| 93精品视频在线观看| 精品人人人妻人人玩日产欧| 亚洲欧美成人综合在线观看| 亚洲蜜臀av一区二区三区九色| 人人在线视频一区二区| 521精品视频在线观看| 国产精彩福利精品视频| av手机在线免费观看日韩av| 国产精品视频欧美一区二区| 成人色综合中文字幕| 一区二区三区四区视频在线播放| 午夜精品亚洲精品五月色| 国产精品国色综合久久| 中文字幕 亚洲av| 超碰中文字幕免费观看| 黑人乱偷人妻中文字幕| 成人av在线资源网站| 熟女在线视频一区二区三区| 黄色av网站免费在线| 特级欧美插插插插插bbbbb| 欧美香蕉人妻精品一区二区| 97国产在线av精品| 91国产在线视频免费观看| 天天躁日日躁狠狠躁av麻豆| 丝袜亚洲另类欧美变态| 超级av免费观看一区二区三区| 午夜毛片不卡在线看| 亚洲av日韩精品久久久| 丁香花免费在线观看中文字幕| 污污小视频91在线观看| 在线制服丝袜中文字幕| 亚洲av男人天堂久久| av手机在线免费观看日韩av| 国产男女视频在线播放| 欧美精品久久久久久影院| 激情人妻校园春色亚洲欧美| 国产在线91观看免费观看| 欧美色呦呦最新网址| 曰本无码人妻丰满熟妇啪啪| 同居了嫂子在线播高清中文| av天堂资源最新版在线看| 国产精品久久久久久久女人18| 伊人情人综合成人久久网小说 | 91麻豆精品久久久久| 一区二区熟女人妻视频| 中文字幕国产专区欧美激情| 天天综合天天综合天天网| 天天操夜夜操天天操天天操 | 成年女人免费播放视频| 午夜精品在线视频一区| 国产日韩av一区二区在线| 狠狠的往里顶撞h百合| 真实国产乱子伦一区二区| 精品人妻一二三区久久| 亚洲1区2区3区精华液| 又粗又长 明星操逼小视频| wwwxxx一级黄色片| 操日韩美女视频在线免费看| 欧美精品一区二区三区xxxx| 久久人人做人人妻人人玩精品vr| 亚洲一级特黄特黄黄色录像片| 四川乱子伦视频国产vip| 亚洲一区二区人妻av| av一区二区三区人妻| 57pao国产一区二区| 2021最新热播中文字幕| 日本性感美女写真视频| 91天堂天天日天天操| 中文字幕人妻av在线观看| 色爱av一区二区三区| 免费观看理论片完整版| 国产成人自拍视频播放| 欧美日韩人妻久久精品高清国产 | 99久久超碰人妻国产| 日本熟妇色熟妇在线观看| 亚洲中文字幕校园春色| 亚洲一级av无码一级久久精品| 天天摸天天亲天天舔天天操天天爽| 亚洲国产精品免费在线观看| 人人妻人人人操人人人爽| 9色精品视频在线观看| 成人资源在线观看免费官网| 国产janese在线播放| 91麻豆精品传媒国产黄色片| 亚洲精品国产综合久久久久久久久| 久久精品国产亚洲精品166m| 欧美专区第八页一区在线播放| 真实国模和老外性视频| 19一区二区三区在线播放| 国产免费av一区二区凹凸四季| 大香蕉日本伊人中文在线| 国产av欧美精品高潮网站| 日噜噜噜夜夜噜噜噜天天噜噜噜| 家庭女教师中文字幕在线播放| 亚洲国产精品黑丝美女| 好太好爽好想要免费| 亚洲欧美一区二区三区爱爱动图| av手机免费在线观看高潮| 自拍偷拍亚洲精品第2页| 久久午夜夜伦痒痒想咳嗽P| 亚洲av色香蕉一区二区三区| 国产精品黄色的av| 国产不卡av在线免费| 1024久久国产精品| 九九热99视频在线观看97| 日韩美在线观看视频黄| 黑人性生活视频免费看| 国产亚洲精品视频合集| 最新国产精品拍在线观看| 欧美成人一二三在线网| 黑人巨大的吊bdsm| tube69日本少妇| 不卡日韩av在线观看| 欧美精产国品一二三区| 家庭女教师中文字幕在线播放| 欧美xxx成人在线| 美女张开两腿让男人桶av| 97香蕉碰碰人妻国产樱花| 很黄很污很色的午夜网站在线观看 | 精品av国产一区二区三区四区| 在线可以看的视频你懂的| 日韩特级黄片高清在线看| 91国偷自产一区二区三区精品| 中文字幕综合一区二区| 91免费福利网91麻豆国产精品| 亚洲人一区二区中文字幕| 久草视频在线看免费| 少妇一区二区三区久久久| 五月天色婷婷在线观看视频免费| 国产久久久精品毛片| 中文字幕av男人天堂| 懂色av蜜桃a v| 91麻豆精品久久久久| 亚洲精品av在线观看| 青青色国产视频在线| 国产精品自偷自拍啪啪啪| 美女吃鸡巴操逼高潮视频| 成人在线欧美日韩国产| 色综合天天综合网国产成人| 宅男噜噜噜666免费观看| 天天躁夜夜躁日日躁a麻豆| 沈阳熟妇28厘米大战黑人| 青青青青青手机视频| 欧美亚洲牲夜夜综合久久| 日本裸体熟妇区二区欧美| 中文字幕在线乱码一区二区| 亚洲人成精品久久久久久久| 久草视频 久草视频2| 欧美精品国产综合久久| 九色精品视频在线播放| 中文字幕视频一区二区在线观看| 午夜成午夜成年片在线观看| 日韩av大胆在线观看| 日本丰满熟妇BBXBBXHD| 午夜激情高清在线观看| 93精品视频在线观看| 三级等保密码要求条款| 一级A一级a爰片免费免会员| 亚洲午夜伦理视频在线 | 中文字幕第1页av一天堂网| 91九色国产熟女一区二区| 农村胖女人操逼视频| 青青热久免费精品视频在线观看 | 人人人妻人人澡人人| 中文字幕熟女人妻久久久| 欧美日韩在线精品一区二区三| 久久综合老鸭窝色综合久久| 社区自拍揄拍尻屁你懂的| 中文字幕在线一区精品| 欧美交性又色又爽又黄麻豆| 新婚人妻聚会被中出| 亚洲伊人久久精品影院一美女洗澡 | 男人操女人逼逼视频网站| 91麻豆精品91久久久久同性| 一区二区三区的久久的蜜桃的视频| 免费在线观看视频啪啪| 免费大片在线观看视频网站| 天天干夜夜操天天舔| av日韩在线免费播放| 美女被肏内射视频网站| 九九热99视频在线观看97| 欧美80老妇人性视频| free性日本少妇| 欧美成人猛片aaaaaaa| 久久99久久99精品影院| 国产三级片久久久久久久| 黑人进入丰满少妇视频| 自拍偷拍一区二区三区图片| 在线观看免费岛国av| 无套猛戳丰满少妇人妻| 亚洲欧美清纯唯美另类| 五月天色婷婷在线观看视频免费| 中文字幕av一区在线观看| 亚洲av色香蕉一区二区三区| 天天干天天啪天天舔| 只有精品亚洲视频在线观看| av网址在线播放大全| 在线观看国产网站资源| 国产亚洲成人免费在线观看| 日本丰满熟妇BBXBBXHD| 在线播放一区二区三区Av无码| 精品乱子伦一区二区三区免费播| 国产密臀av一区二区三| 人人妻人人人操人人人爽| 亚洲美女自偷自拍11页| 亚洲 中文 自拍 另类 欧美| 在线国产日韩欧美视频| 男人插女人视频网站| 国产精品久久久久久美女校花| 999久久久久999| 在线播放国产黄色av| 四川五十路熟女av| 国产大学生援交正在播放| 女生被男生插的视频网站| 97人妻无码AV碰碰视频| 漂亮 人妻被中出中文| 午夜成午夜成年片在线观看| 成人av天堂丝袜在线观看| 懂色av蜜桃a v| 99热99re在线播放| 狠狠躁狠狠爱网站视频| 女同久久精品秋霞网| 人人爱人人妻人人澡39| 国产九色91在线观看精品| 欧美精品 日韩国产| 亚洲av黄色在线网站| 日本少妇人妻xxxxxhd| 中文字幕中文字幕人妻| 色吉吉影音天天干天天操| 美女张开腿让男生操在线看| 亚洲推理片免费看网站| 在线视频精品你懂的| 天天色天天舔天天射天天爽| 日韩北条麻妃一区在线| 日韩精品中文字幕福利| 一区二区三区美女毛片| 亚洲美女美妇久久字幕组| 69精品视频一区二区在线观看| 亚洲综合图片20p| 最近中文2019年在线看| 亚洲男人在线天堂网| 国产精品成久久久久三级蜜臀av | 欧美少妇性一区二区三区| 男人天堂最新地址av| 亚洲av男人的天堂你懂的| 性感美女高潮视频久久久| 久久久久久久精品成人热| 亚洲 色图 偷拍 欧美| 4个黑人操素人视频网站精品91| 风流唐伯虎电视剧在线观看| 亚洲在线一区二区欧美| 国产变态另类在线观看| 人妻少妇中文有码精品| 啪啪啪啪啪啪啪免费视频| 又色又爽又黄的美女裸体| 91麻豆精品秘密入口在线观看| av资源中文字幕在线观看| 经典av尤物一区二区| 熟女在线视频一区二区三区| 天天操天天弄天天射| 国产性感美女福利视频| 免费人成黄页网站在线观看国产| 成人亚洲精品国产精品| 国产麻豆国语对白露脸剧情| 激情图片日韩欧美人妻| 麻豆精品成人免费视频| 99热久久极品热亚洲| 欧美视频综合第一页| 888亚洲欧美国产va在线播放| 在线免费观看国产精品黄色| 狠狠鲁狠狠操天天晚上干干| 人妻少妇性色欲欧美日韩| 精品91自产拍在线观看一区| 日韩美女精品视频在线观看网站| 人妻自拍视频中国大陆| 激情人妻校园春色亚洲欧美| 爱有来生高清在线中文字幕| 亚洲伊人色一综合网| 人妻少妇中文有码精品| 天天日天天添天天爽| 91试看福利一分钟| 久久美欧人妻少妇一区二区三区 | 综合精品久久久久97| 日噜噜噜夜夜噜噜噜天天噜噜噜| 超碰中文字幕免费观看| 国产在线拍揄自揄视频网站| 丝袜亚洲另类欧美变态| 亚洲午夜电影之麻豆| 欧美viboss性丰满| 91国偷自产一区二区三区精品| 人人妻人人人操人人人爽| 日韩午夜福利精品试看| 精品人妻一二三区久久| 黑人性生活视频免费看| 9国产精品久久久久老师 | 亚洲av日韩高清hd| 极品丝袜一区二区三区| 夜夜骑夜夜操夜夜奸| 亚洲国产第一页在线观看| 国产a级毛久久久久精品| 女同久久精品秋霞网| 免费十精品十国产网站| 亚洲成人情色电影在线观看| 综合精品久久久久97| yy6080国产在线视频| 中文字幕之无码色多多| 一级黄色片夫妻性生活| 偷拍自拍视频图片免费| 天天日天天干天天搡| 老司机福利精品免费视频一区二区 | 黄色在线观看免费观看在线| 美女骚逼日出水来了| 国产精品系列在线观看一区二区| 人妻丝袜榨强中文字幕| 午夜av一区二区三区| 亚洲熟女综合色一区二区三区四区| 久久久久久久精品成人热| 韩国黄色一级二级三级| 免费观看理论片完整版| 黄色三级网站免费下载| 97精品综合久久在线| 97国产福利小视频合集| 亚洲区美熟妇久久久久| jiuse91九色视频| huangse网站在线观看| 午夜在线精品偷拍一区二| 亚洲男人的天堂a在线| 国产综合视频在线看片| 天天射,天天操,天天说| 天天日夜夜干天天操| av成人在线观看一区| 99亚洲美女一区二区三区| 2020久久躁狠狠躁夜夜躁| 端庄人妻堕落挣扎沉沦| 日韩av熟妇在线观看| 91香蕉成人app下载| 美女日逼视频免费观看| 亚洲天堂精品福利成人av| 少妇系列一区二区三区视频| 人妻av无码专区久久绿巨人| 国产在线免费观看成人| 亚洲一区av中文字幕在线观看| 韩国亚洲欧美超一级在线播放视频| 日本黄色三级高清视频| 欧美精品免费aaaaaa| 91精品国产综合久久久蜜| 精内国产乱码久久久久久| 曰本无码人妻丰满熟妇啪啪| 日韩熟女av天堂系列| 久久久久久九九99精品| av天堂资源最新版在线看| 中文字幕乱码av资源| 性感美女诱惑福利视频| 欧美另类z0z变态| 午夜精品久久久久久99热| 色婷婷六月亚洲综合香蕉| 东京干手机福利视频| 成人久久精品一区二区三区| 国产精彩福利精品视频| 中文字幕av一区在线观看| 亚洲中文字幕国产日韩| 国产精品国色综合久久| 免费在线看的黄片视频| 日本啪啪啪啪啪啪啪| 1区2区3区4区视频在线观看| huangse网站在线观看| 亚洲av色图18p| 日本免费一级黄色录像| 免费观看丰满少妇做受| 日韩a级黄色小视频| 亚洲国产欧美一区二区三区…| 日本免费视频午夜福利视频| 亚洲午夜电影之麻豆| 国产不卡av在线免费| 日本午夜福利免费视频| 日韩欧美制服诱惑一区在线| 黄色黄色黄片78在线| 欧美天堂av无线av欧美| 成人精品在线观看视频| 巨乳人妻日下部加奈被邻居中出| 亚洲老熟妇日本老妇| 日韩一个色综合导航| 黄色录像鸡巴插进去| 国产在线免费观看成人| 人妻无码中文字幕专区| 在线制服丝袜中文字幕| 欧美黑人巨大性xxxxx猛交| 中文字幕在线乱码一区二区| 岛国免费大片在线观看| 无码国产精品一区二区高潮久久4| 99一区二区在线观看| 在线免费观看国产精品黄色| 欧美性受xx黑人性猛交| 国产麻豆乱子伦午夜视频观看| 国产精品久久久黄网站| 成人综合亚洲欧美一区| 日本中文字幕一二区视频| 国产露脸对白在线观看| 天堂资源网av中文字幕| 天天日天天爽天天爽| av完全免费在线观看av| 国产极品美女久久久久久| 福利片区一区二体验区| 直接观看免费黄网站| 大白屁股精品视频国产| 视频一区 视频二区 视频| 久久精品36亚洲精品束缚| 成人乱码一区二区三区av| 美女av色播在线播放| 天天操天天插天天色| 国产欧美精品一区二区高清 | 日韩精品啪啪视频一道免费| 99热久久这里只有精品8| 欧美中文字幕一区最新网址| 国产日韩一区二区在线看| 婷婷久久一区二区字幕网址你懂得| 亚洲成a人片777777| 亚洲免费在线视频网站| 亚洲国产欧美一区二区丝袜黑人| 欧美日韩高清午夜蜜桃大香蕉| 天堂资源网av中文字幕| 国产在线观看黄色视频| 日韩二区视频一线天婷婷五| 偷拍美女一区二区三区| 国产精品久久久久久久精品视频| 亚洲成人三级在线播放| 天堂va蜜桃一区入口| 亚洲日产av一区二区在线| 天码人妻一区二区三区在线看| 99热这里只有国产精品6| 懂色av蜜桃a v| 狠狠躁夜夜躁人人爽天天天天97| 日韩在线中文字幕色| 亚洲综合在线视频可播放| 99久久成人日韩欧美精品| 自拍偷拍亚洲精品第2页| 精品一区二区三区午夜| 久久综合老鸭窝色综合久久| 欧美日韩一区二区电影在线观看| 69精品视频一区二区在线观看| 成人影片高清在线观看| 亚洲成人av在线一区二区| 开心 色 六月 婷婷| 国产三级影院在线观看| 婷婷色中文亚洲网68| 中文字幕一区二区三区蜜月 | 国产午夜无码福利在线看| 中文字幕高清免费在线人妻| 久久久久久97三级| 免费观看理论片完整版| 91精品国产91青青碰| 久久久超爽一二三av| 青草久久视频在线观看| 九一传媒制片厂视频在线免费观看| 免费费一级特黄真人片| 黑人借宿ntr人妻的沦陷2| 色呦呦视频在线观看视频|