国产无遮挡裸体免费直播视频,久久精品国产蜜臀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

最新評論

经典国语激情内射视频| 亚洲午夜电影之麻豆| 日韩成人综艺在线播放| 可以在线观看的av中文字幕| 日本熟妇喷水xxx| 在线免费观看视频一二区| 日韩人妻xxxxx| 夜夜嗨av蜜臀av| 99精品国自产在线人| 最新中文字幕免费视频| 中文字幕一区二区三区人妻大片 | 亚洲 人妻 激情 中文| 91人妻精品一区二区在线看| 日韩成人综艺在线播放| 色偷偷伊人大杳蕉综合网 | 老鸭窝日韩精品视频观看| 91精品综合久久久久3d动漫| 1000部国产精品成人观看视频| 人妻丰满熟妇综合网| 又粗又硬又猛又黄免费30| 亚洲国产成人在线一区| 日本免费视频午夜福利视频| 亚洲av男人的天堂你懂的| 欧美成人一二三在线网| 日本韩国在线观看一区二区| 日本少妇高清视频xxxxx| 男人在床上插女人视频| 精品成人啪啪18免费蜜臀| 在线观看操大逼视频| 4个黑人操素人视频网站精品91| 综合激情网激情五月天| 超级碰碰在线视频免费观看| 一区二区三区 自拍偷拍| 自拍偷拍一区二区三区图片| 黄页网视频在线免费观看| 亚洲男人在线天堂网| 国产又粗又硬又大视频| 大骚逼91抽插出水视频| 内射久久久久综合网| 国产精品手机在线看片| 二区中出在线观看老师| 不卡一不卡二不卡三| 午夜福利人人妻人人澡人人爽| 天天想要天天操天天干| 亚洲国产美女一区二区三区软件| 少妇被强干到高潮视频在线观看| 欧美韩国日本国产亚洲| 亚洲码av无色中文| 亚洲av无硬久久精品蜜桃| 狍和女人的王色毛片| 亚洲成人三级在线播放| 黄色视频成年人免费观看| 国产又粗又黄又硬又爽| 免费在线播放a级片| 1区2区3区4区视频在线观看| 夜色福利视频在线观看| 欧美成人综合色在线噜噜| 视频 一区二区在线观看| 国产露脸对白在线观看| 红杏久久av人妻一区| 成人蜜臀午夜久久一区| 国产清纯美女al在线| 中文字幕人妻av在线观看| 午夜的视频在线观看| 真实国产乱子伦一区二区| av网址国产在线观看| 热久久只有这里有精品| 国产又粗又硬又大视频| 端庄人妻堕落挣扎沉沦| 色97视频在线播放| 偷拍3456eee| 国产av福利网址大全| 插逼视频双插洞国产操逼插洞| 精品久久久久久久久久久a√国产| 啊慢点鸡巴太大了啊舒服视频| 精品一区二区三区午夜| 黄片大全在线观看观看| 最新欧美一二三视频| 中文字幕综合一区二区| 内射久久久久综合网| 国产精品视频欧美一区二区| 日本熟妇一区二区x x| 成人亚洲精品国产精品| 韩国女主播精品视频网站| 欧美viboss性丰满| 夏目彩春在线中文字幕| 欧洲日韩亚洲一区二区三区| 天天操天天操天天碰| 国产又粗又硬又猛的毛片视频| 老司机福利精品免费视频一区二区 | 亚洲免费成人a v| 亚洲精品乱码久久久本| 不卡日韩av在线观看| 亚洲男人让女人爽的视频| 天天干天天日天天干天天操| 亚洲 中文字幕在线 日韩| 天天日天天干天天要| AV无码一区二区三区不卡| 99re6热在线精品| 中文字幕一区二区亚洲一区| 又色又爽又黄又刺激av网站| av在线观看网址av| 欧美成一区二区三区四区| 少妇一区二区三区久久久| 精品高跟鞋丝袜一区二区| 北条麻妃肉色丝袜视频| 快插进小逼里大鸡吧视频| 18禁美女无遮挡免费| 欧美va不卡视频在线观看| 日本免费视频午夜福利视频| 亚洲码av无色中文| 九色视频在线观看免费| 青青青青青操视频在线观看| 噜噜色噜噜噜久色超碰| 欧美在线一二三视频| 福利一二三在线视频观看| 伊拉克及约旦宣布关闭领空| 日本一二三中文字幕| 99国内小视频在现欢看| 伊人成人综合开心网| 亚洲中文字幕人妻一区| 亚洲精品精品国产综合| 日韩精品啪啪视频一道免费| 偷青青国产精品青青在线观看| 最新中文字幕免费视频| 国产成人一区二区三区电影网站| 9色在线视频免费观看| 99热这里只有精品中文| 欧美xxx成人在线| 男人的天堂一区二区在线观看| 伊人综合免费在线视频| 亚洲欧美在线视频第一页| eeuss鲁片一区二区三区| 免费成人av中文字幕| av天堂中文免费在线| 麻豆性色视频在线观看| 伊人成人在线综合网| 午夜精品福利91av| v888av在线观看视频| 久久久久久cao我的性感人妻| 熟女人妻在线观看视频| 在线免费91激情四射| 免费看国产又粗又猛又爽又黄视频| 最新国产精品网址在线观看| 午夜久久久久久久精品熟女| 免费看国产av网站| 日韩熟女av天堂系列| 中文字幕奴隷色的舞台50| 日本午夜福利免费视频| 欧美黄片精彩在线免费观看| av一区二区三区人妻| 亚洲1069综合男同| 99精品国产aⅴ在线观看| 国内自拍第一页在线观看| 日本性感美女视频网站| 韩国爱爱视频中文字幕| 在线可以看的视频你懂的| 欧美日韩不卡一区不区二区| 免费观看污视频网站| 男人在床上插女人视频| 亚洲 清纯 国产com| 同居了嫂子在线播高清中文| 偷拍自拍视频图片免费| 中文字母永久播放1区2区3区| 18禁美女黄网站色大片下载| 午夜精品一区二区三区城中村| 中文字幕日韩精品就在这里| 亚洲在线一区二区欧美| 熟女人妻在线中出观看完整版| 我想看操逼黄色大片| 日韩影片一区二区三区不卡免费| 91国产资源在线视频| 好吊操视频这里只有精品| 一本久久精品一区二区| 白白操白白色在线免费视频 | 啊啊好慢点插舔我逼啊啊啊视频| 自拍偷拍vs一区二区三区| 午夜在线观看一区视频| 在线免费观看国产精品黄色| 中文字幕日韩无敌亚洲精品| 啊啊好慢点插舔我逼啊啊啊视频| 香港一级特黄大片在线播放| 超污视频在线观看污污污| 全国亚洲男人的天堂| 女警官打开双腿沦为性奴| 在线观看免费视频色97| 视频一区二区三区高清在线| 亚洲变态另类色图天堂网| 一区二区三区视频,福利一区二区| 99热久久这里只有精品| 成人午夜电影在线观看 久久| 日韩精品激情在线观看| 91色网站免费在线观看| 丝袜长腿第一页在线| 成人亚洲精品国产精品| 国产成人精品亚洲男人的天堂| 国产丰满熟女成人视频| 一区二区三区av高清免费| 日本成人一区二区不卡免费在线| 东京热男人的av天堂| 亚洲老熟妇日本老妇| 天天干天天插天天谢| 性生活第二下硬不起来| 好男人视频在线免费观看网站| 激情色图一区二区三区| 懂色av之国产精品| 久久免看30视频口爆视频| 欧美一区二区三区高清不卡tv| 亚洲午夜电影之麻豆| 2021国产一区二区| 自拍偷拍日韩欧美一区二区| 91大神福利视频网| 1024久久国产精品| 扒开腿挺进肉嫩小18禁视频| 社区自拍揄拍尻屁你懂的| 亚洲图片欧美校园春色| 日视频免费在线观看| 亚洲超碰97人人做人人爱| 午夜在线精品偷拍一区二| 天天日天天天天天天天天天天| 亚洲粉嫩av一区二区三区| 北条麻妃高跟丝袜啪啪| 中文字幕在线欧美精品| 午夜精品福利一区二区三区p| 日本熟女精品一区二区三区| 免费高清自慰一区二区三区网站| 天堂va蜜桃一区入口| 亚洲av日韩精品久久久久久hd| 天天干天天日天天谢综合156| 国产变态另类在线观看| 国产欧美日韩第三页| 久久亚洲天堂中文对白| 91中文字幕免费在线观看| 亚洲一区av中文字幕在线观看| 国产精品久久久久久久久福交| 国产va在线观看精品| 日本性感美女三级视频| 国产乱子伦一二三区| 天天日天天干天天爱| 国产精品一二三不卡带免费视频| 99re6热在线精品| 专门看国产熟妇的网站| 亚洲在线免费h观看网站| 91久久精品色伊人6882| 国产97视频在线精品| 亚洲成人av在线一区二区| 中文字幕人妻三级在线观看| 少妇高潮无套内谢麻豆| 最新日韩av传媒在线| 久久h视频在线观看| 亚洲一区久久免费视频| 国产精品一区二区av国| 欧美女同性恋免费a| 久草视频福利在线首页| 66久久久久久久久久久| 2012中文字幕在线高清| 天天干天天操天天玩天天射 | 亚洲麻豆一区二区三区| 五月激情婷婷久久综合网| 黄色视频成年人免费观看| 精品美女福利在线观看| 夜鲁夜鲁狠鲁天天在线| 久久www免费人成一看片| 天天日天天摸天天爱| 天天爽夜夜爽人人爽QC| 日韩二区视频一线天婷婷五| 日韩av大胆在线观看| 大香蕉大香蕉大香蕉大香蕉大香蕉| 91综合久久亚洲综合| 97精品视频在线观看| 最新97国产在线视频| 日韩二区视频一线天婷婷五| 夜女神免费福利视频| 色哟哟在线网站入口| 日视频免费在线观看| 99精品国产免费久久| 2020久久躁狠狠躁夜夜躁 | 精品亚洲中文字幕av| 班长撕开乳罩揉我胸好爽| 熟女人妻一区二区精品视频| 日韩近亲视频在线观看| 日韩北条麻妃一区在线| 自拍偷拍亚洲另类色图| 欧美一级片免费在线成人观看| 亚洲成人av在线一区二区| 色综合久久五月色婷婷综合| 热99re69精品8在线播放| 亚洲中文字字幕乱码| 久久久制服丝袜中文字幕| 国产亚洲成人免费在线观看 | 狠狠操狠狠操免费视频| 亚国产成人精品久久久| 成人网18免费视频版国产| 欧美日韩高清午夜蜜桃大香蕉| 成人区人妻精品一区二视频 | 国产又大又黄免费观看| 国产1区,2区,3区| 国产精品人妻66p| 社区自拍揄拍尻屁你懂的| 天天射,天天操,天天说| 国产日本精品久久久久久久| 三级黄色亚洲成人av| 日日夜夜精品一二三| 成人国产小视频在线观看| 在线视频国产欧美日韩| 亚洲国产欧美一区二区丝袜黑人| 日韩人妻xxxxx| 93精品视频在线观看| 在线观看视频 你懂的| 日韩欧美高清免费在线| 国产黄色高清资源在线免费观看| 天天躁日日躁狠狠躁躁欧美av| 五月精品丁香久久久久福利社| 美女av色播在线播放| 中文字幕高清在线免费播放| 在线视频国产欧美日韩| 日本一区二区三区免费小视频| 热久久只有这里有精品| 又色又爽又黄的美女裸体| av网站色偷偷婷婷网男人的天堂| 日本xx片在线观看| 91老熟女连续高潮对白| 成人亚洲精品国产精品 | 在线观看av2025| 综合一区二区三区蜜臀| av资源中文字幕在线观看| 92福利视频午夜1000看 | 啪啪啪啪啪啪啪啪啪啪黄色| 精品欧美一区二区vr在线观看 | 污污小视频91在线观看| 国产一区二区三免费视频| 中文字幕人妻被公上司喝醉在线| 亚洲 清纯 国产com| 亚洲丝袜老师诱惑在线观看| 大胆亚洲av日韩av| 18禁美女黄网站色大片下载| 自拍偷拍 国产资源| 亚国产成人精品久久久| 免费十精品十国产网站| 秋霞午夜av福利经典影视| 福利一二三在线视频观看| 亚洲天堂有码中文字幕视频| 国产成人一区二区三区电影网站| 国产精品视频欧美一区二区| 香蕉片在线观看av| 老有所依在线观看完整版| 91精品国产麻豆国产| 天天做天天干天天舔| 久久免看30视频口爆视频| 日韩一区二区电国产精品| 精品91自产拍在线观看一区| 久草视频在线一区二区三区资源站 | 国内资源最丰富的网站| 亚洲高清免费在线观看视频| 亚洲 欧美 自拍 偷拍 在线| 欧美视频中文一区二区三区| 色97视频在线播放| 日韩美女搞黄视频免费| 中文字幕日韩精品日本| 果冻传媒av一区二区三区| 超碰97免费人妻麻豆| 久草免费人妻视频在线| 日韩黄色片在线观看网站| 精品av久久久久久久| 天天日天天做天天日天天做| 激情伦理欧美日韩中文字幕| 在线观看亚洲人成免费网址| 亚洲精品久久视频婷婷| 馒头大胆亚洲一区二区| 午夜美女少妇福利视频| 天天日夜夜干天天操| 亚洲人妻av毛片在线| 性色蜜臀av一区二区三区| 2022国产综合在线干| 中国黄片视频一区91| 老师让我插进去69AV| 熟妇一区二区三区高清版| 在线观看日韩激情视频| 欧美一级片免费在线成人观看| 精品亚洲在线免费观看| 黄工厂精品视频在线观看| 久久99久久99精品影院| 国产精品亚洲在线观看| 青青草在观免费国产精品| 美女在线观看日本亚洲一区| 97人妻夜夜爽二区欧美极品| 亚洲国产精品久久久久蜜桃| 天天干天天操天天玩天天射| 欧美精产国品一二三产品区别大吗| 亚洲一区二区三区五区| 55夜色66夜色国产精品站| 亚洲无码一区在线影院| 亚洲一区二区三区在线高清| 国产精品精品精品999| a v欧美一区=区三区| 国产剧情演绎系列丝袜高跟| 日本免费午夜视频网站| 日韩中文字幕在线播放第二页| 熟女视频一区,二区,三区| 一区二区三区在线视频福利| 天天艹天天干天天操| 亚洲在线观看中文字幕av| 久久尻中国美女视频| 天天日天天敢天天干| h国产小视频福利在线观看| 在线观看免费视频色97| 九九热99视频在线观看97| 日本18禁久久久久久| 夜夜骑夜夜操夜夜奸| 亚洲1区2区3区精华液| av乱码一区二区三区| 夜夜骑夜夜操夜夜奸| 北条麻妃肉色丝袜视频| 91国内精品自线在拍白富美| 成人精品视频99第一页| 午夜影院在线观看视频羞羞羞| 91精品一区二区三区站长推荐| 亚洲综合色在线免费观看| 日韩一区二区电国产精品| 岛国一区二区三区视频在线| 姐姐的朋友2在线观看中文字幕| 久久久久久久精品老熟妇| 久久久久久97三级| 欧美日韩v中文在线| 狠狠躁狠狠爱网站视频| 国产综合高清在线观看| 亚洲综合乱码一区二区| 亚洲天天干 夜夜操| 天天日夜夜操天天摸 | 男人操女人逼逼视频网站| 亚洲av第国产精品| 国产又粗又黄又硬又爽| 国产视频精品资源网站| 亚洲成av人无码不卡影片一| 免费无毒热热热热热热久| 换爱交换乱高清大片| 一本久久精品一区二区| 果冻传媒av一区二区三区| 午夜青青草原网在线观看| 国产自拍黄片在线观看| 天天干天天插天天谢| 亚洲在线免费h观看网站| 国产一级精品综合av| 成人30分钟免费视频| 日本五十路熟新垣里子| 国产内射中出在线观看| 免费在线观看视频啪啪| 欧洲亚洲欧美日韩综合| 天天干天天操天天插天天日| 99精品一区二区三区的区| 亚洲av色图18p| 激情人妻校园春色亚洲欧美| 91国内精品自线在拍白富美| 日本高清成人一区二区三区 | 日本女大学生的黄色小视频| 免费观看污视频网站| 19一区二区三区在线播放| 人妻久久久精品69系列| av日韩在线观看大全| 超级碰碰在线视频免费观看| 欧美成人精品在线观看| 97资源人妻免费在线视频| 97精品人妻一区二区三区精品| 亚洲av无码成人精品区辽| 视频一区 视频二区 视频| 亚洲男人让女人爽的视频| 久久这里只有精品热视频 | 免费成人va在线观看| 日本少妇精品免费视频| 国产精品视频欧美一区二区| 日韩欧美一级黄片亚洲| 欧美一级视频一区二区| 男人操女人逼逼视频网站| 丰满的继坶3中文在线观看| 欧美一区二区三区高清不卡tv | 成人免费做爰高潮视频| 亚洲激情偷拍一区二区| 久久久91蜜桃精品ad| 91精品啪在线免费| 美女视频福利免费看| 亚洲码av无色中文| 国产在线观看黄色视频| 一区二区三区久久久91| 老熟妇xxxhd老熟女| 社区自拍揄拍尻屁你懂的| 秋霞午夜av福利经典影视| 在线免费观看欧美小视频| 亚洲精品久久视频婷婷| 久久久久久久99精品| 国产a级毛久久久久精品| 亚洲va天堂va国产va久| 亚洲精品 欧美日韩| 天堂v男人视频在线观看| 午夜精品福利一区二区三区p| 中文字幕av一区在线观看| 国产女人叫床高潮大片视频| 视频在线免费观看你懂得| 小穴多水久久精品免费看| 91超碰青青中文字幕| 国产一区av澳门在线观看| 漂亮 人妻被中出中文| av中文字幕在线观看第三页| 99热久久极品热亚洲| 55夜色66夜色国产精品站| 日本韩国免费福利精品| 欧美在线精品一区二区三区视频| 午夜毛片不卡免费观看视频| 护士小嫩嫩又紧又爽20p| 三级黄色亚洲成人av| 3D动漫精品啪啪一区二区下载| 都市激情校园春色狠狠| 日本五十路熟新垣里子| av破解版在线观看| 99久久99久国产黄毛片| 成熟丰满熟妇高潮xx×xx| 护士特殊服务久久久久久久| 97人人模人人爽人人喊| 边摸边做超爽毛片18禁色戒 | 国产97在线视频观看| 国产黑丝高跟鞋视频在线播放 | weyvv5国产成人精品的视频| 骚货自慰被发现爆操| 亚洲午夜精品小视频| 日韩人妻xxxxx| 老司机福利精品视频在线| 青青尤物在线观看视频网站| 无忧传媒在线观看视频| 日韩精品中文字幕播放| 青草亚洲视频在线观看| 大鸡吧插逼逼视频免费看| 性感美女诱惑福利视频| 九色视频在线观看免费| 岳太深了紧紧的中文字幕| 日韩无码国产精品强奸乱伦| 9色在线视频免费观看| tube69日本少妇| 男人天堂最新地址av| 无忧传媒在线观看视频| 热久久只有这里有精品| 亚洲国产欧美一区二区丝袜黑人| 免费高清自慰一区二区三区网站 | 人妻少妇中文有码精品| 国产成人精品一区在线观看| 天码人妻一区二区三区在线看| 99精品国自产在线人| 亚欧在线视频你懂的| 777奇米久久精品一区| 日本午夜爽爽爽爽爽视频在线观看| 肏插流水妹子在线乐播下载| 中文字幕在线免费第一页| 日韩熟女系列一区二区三区| 一区二区三区国产精选在线播放| 中文字幕高清免费在线人妻| 2021久久免费视频| 亚洲天堂成人在线观看视频网站| 777奇米久久精品一区| 天天干天天日天天谢综合156| 午夜国产免费福利av| 国产夫妻视频在线观看免费| 久久久精品999精品日本 | 大鸡巴操b视频在线| 国产福利在线视频一区| 9l人妻人人爽人人爽| 伊人精品福利综合导航| 91色秘乱一区二区三区| 亚洲综合另类精品小说| 国产不卡av在线免费| 人妻激情图片视频小说| 黄片色呦呦视频免费看| 亚洲高清自偷揄拍自拍| 人妻少妇一区二区三区蜜桃| 国产女人露脸高潮对白视频| 欧美韩国日本国产亚洲| 精品人妻每日一部精品| 中文字幕日韩91人妻在线| 超鹏97历史在线观看| 欧洲亚洲欧美日韩综合| 蜜臀av久久久久久久| 蜜桃色婷婷久久久福利在线| 日本午夜福利免费视频| 欧美黄色录像免费看的| 久久热久久视频在线观看| 国产精品自拍偷拍a| 91中文字幕免费在线观看| 馒头大胆亚洲一区二区| 精品少妇一二三视频在线| 在线视频免费观看网| 国产91嫩草久久成人在线视频| 熟女人妻一区二区精品视频| 成年午夜影片国产片| 日本av在线一区二区三区| av天堂中文免费在线| 国产又粗又猛又爽又黄的视频在线 | 91久久人澡人人添人人爽乱| 欧美乱妇无乱码一区二区| 国产又粗又硬又猛的毛片视频| av老司机亚洲一区二区| 18禁美女羞羞免费网站| 日韩av免费观看一区| 精品成人午夜免费看| 在线网站你懂得老司机| 日韩欧美国产精品91| 国产福利小视频免费观看| 在线观看免费av网址大全| 国产成人精品一区在线观看| 国产九色91在线视频| 久久这里只有精品热视频| 亚洲熟色妇av日韩熟色妇在线| 日韩欧美高清免费在线| av大全在线播放免费| 色综合天天综合网国产成人| 后入美女人妻高清在线| 超碰97免费人妻麻豆| 日韩精品电影亚洲一区| 天天日天天天天天天天天天天| 中文字幕av一区在线观看| 亚洲精品在线资源站| 2020韩国午夜女主播在线| 一级a看免费观看网站| 婷婷久久久久深爱网| 国产精品黄色的av| av成人在线观看一区| 99热久久极品热亚洲| 蜜臀av久久久久久久| 在线制服丝袜中文字幕| 免费在线黄色观看网站| 早川濑里奈av黑人番号| 欧美日韩亚洲国产无线码| 18禁免费av网站| 香港三日本三韩国三欧美三级| 国产亚洲视频在线观看| 国产精品久久久久久美女校花| 亚洲自拍偷拍精品网| 91九色porny国产蝌蚪视频| 中文字幕在线免费第一页| 亚洲无线观看国产高清在线| 欧美va不卡视频在线观看| 第一福利视频在线观看| 少妇人妻真实精品视频| 夜夜嗨av蜜臀av| 日韩美女搞黄视频免费| 国产高清女主播在线| 亚洲欧美国产综合777| 中文字幕在线乱码一区二区| 亚洲天堂成人在线观看视频网站| 玖玖一区二区在线观看| 久久艹在线观看视频| 日本美女性生活一级片| 91啪国自产中文字幕在线| 日本性感美女三级视频| 粉嫩小穴流水视频在线观看| 欧美日韩中文字幕欧美| 最新激情中文字幕视频| 免费岛国喷水视频在线观看| 中文字幕国产专区欧美激情| 丝袜美腿欧美另类 中文字幕| 人妻久久久精品69系列| 日本人竟这样玩学生妹| 日韩美女精品视频在线观看网站 | 9久在线视频只有精品| 国产精品大陆在线2019不卡| 国产精品黄页网站视频| 可以在线观看的av中文字幕 | av成人在线观看一区| 91久久精品色伊人6882| 日本高清成人一区二区三区| 亚洲少妇人妻无码精品| 黄色中文字幕在线播放| 欧美一区二区三区久久久aaa| 中文字幕1卡1区2区3区| 亚洲av第国产精品| 亚洲国产精品久久久久久6| 狠狠嗨日韩综合久久| 免费无码人妻日韩精品一区二区 | 丰满熟女午夜福利视频| 日本五十路熟新垣里子| 国产黄色片蝌蚪九色91| 日本xx片在线观看| 啪啪啪18禁一区二区三区| 亚洲精品福利网站图片| 亚洲 国产 成人 在线| 精品久久久久久久久久久久人妻 | 最新欧美一二三视频 | 欧洲国产成人精品91铁牛tv| 天天日天天爽天天爽| 午夜激情久久不卡一区二区| 青青草成人福利电影| 日韩成人性色生活片| 午夜91一区二区三区| 在线观看视频 你懂的| 2022精品久久久久久中文字幕| 国产精品久久久黄网站| 亚洲丝袜老师诱惑在线观看| 端庄人妻堕落挣扎沉沦| 精品黑人巨大在线一区| 国产精品系列在线观看一区二区| 在线观看日韩激情视频| 午夜精品一区二区三区4| chinese国产盗摄一区二区| 欧美一级片免费在线成人观看| 久久精品在线观看一区二区| av在线观看网址av| 18禁美女羞羞免费网站| japanese日本熟妇另类| asmr福利视频在线观看| 亚洲国产最大av综合| av天堂中文免费在线| 久久尻中国美女视频| 国产视频网站一区二区三区| 美女张开两腿让男人桶av| 91大神福利视频网| 欧美爆乳肉感大码在线观看| 一二三中文乱码亚洲乱码one| 制丝袜业一区二区三区| www日韩毛片av| 欧美精品中文字幕久久二区| 2022国产精品视频| 久久www免费人成一看片| gav成人免费播放| 特级无码毛片免费视频播放| 亚洲免费av在线视频| 91国内精品久久久久精品一| 丝袜肉丝一区二区三区四区在线看| 9久在线视频只有精品| 亚洲自拍偷拍综合色| 欧美日韩熟女一区二区三区| 人妻少妇性色欲欧美日韩| 中文字幕在线观看国产片| 黄色成年网站午夜在线观看| 亚洲精品午夜aaa久久| 国产精品一二三不卡带免费视频| 午夜精品福利一区二区三区p | 99的爱精品免费视频| 欧美精品亚洲精品日韩在线| 天堂中文字幕翔田av| 亚洲天堂精品福利成人av| 一区二区麻豆传媒黄片| 色婷婷六月亚洲综合香蕉| 都市家庭人妻激情自拍视频| 日本av熟女在线视频| 秋霞午夜av福利经典影视| 在线可以看的视频你懂的| 日日夜夜精品一二三| 五色婷婷综合狠狠爱| 99精品国产aⅴ在线观看| 久久这里只有精彩视频免费| 91超碰青青中文字幕| 日韩欧美一级黄片亚洲| 精品久久久久久久久久久a√国产| av在线播放国产不卡| 亚洲午夜在线视频福利| 快插进小逼里大鸡吧视频| 热久久只有这里有精品| 啊啊好大好爽啊啊操我啊啊视频 | 99国内小视频在现欢看| 国产精品自偷自拍啪啪啪| 亚洲熟色妇av日韩熟色妇在线| 亚洲欧美色一区二区| 国产va精品免费观看| 精品视频中文字幕在线播放| 国产中文精品在线观看| 女生自摸在线观看一区二区三区| 大香蕉大香蕉在线有码 av| 成人综合亚洲欧美一区| av中文字幕电影在线看| 不卡精品视频在线观看| 男人在床上插女人视频| 亚洲精品午夜久久久久| 亚洲粉嫩av一区二区三区| 国产日韩精品免费在线| 97人妻无码AV碰碰视频| 51精品视频免费在线观看| 亚洲国产免费av一区二区三区| 天天躁日日躁狠狠躁躁欧美av| av天堂中文字幕最新| 日日夜夜精品一二三| 国内自拍第一页在线观看| 精品美女久久久久久| 欧美亚洲牲夜夜综合久久| 精品久久久久久久久久久久人妻| 国产伦精品一区二区三区竹菊| 3344免费偷拍视频| 男女啪啪视频免费在线观看| 精品久久久久久久久久久久人妻| 亚洲欧美色一区二区| 国产成人精品福利短视频| 特级欧美插插插插插bbbbb| 国产一区二区三免费视频| 51精品视频免费在线观看| 福利视频一区二区三区筱慧 | 午夜青青草原网在线观看| 亚洲久久午夜av一区二区| 2022中文字幕在线| 亚洲精品成人网久久久久久小说| 超pen在线观看视频公开97| 欧美视频不卡一区四区| 日本三极片中文字幕| 中文字幕av第1页中文字幕| 大胆亚洲av日韩av| 91小伙伴中女熟女高潮| 超碰中文字幕免费观看| 亚洲熟色妇av日韩熟色妇在线| AV天堂一区二区免费试看| 69精品视频一区二区在线观看| 老鸭窝在线观看一区| 一区二区三区久久久91| 一区二区麻豆传媒黄片 | 精品美女久久久久久| 亚洲高清免费在线观看视频| 78色精品一区二区三区| 播放日本一区二区三区电影| 久久精品亚洲成在人线a| 日曰摸日日碰夜夜爽歪歪| 中文亚洲欧美日韩无线码| 久草视频 久草视频2| 99热国产精品666| 亚洲国产欧美一区二区丝袜黑人| 亚洲成人熟妇一区二区三区| 三级av中文字幕在线观看| 日本在线不卡免费视频| 成人18禁网站在线播放| 老司机免费视频网站在线看| av中文字幕国产在线观看| 黑人3p华裔熟女普通话| av中文字幕在线导航| 天天干天天搞天天摸| 黄色资源视频网站日韩| 亚洲精品色在线观看视频| 91精品激情五月婷婷在线| 国产成人精品av网站| 中国黄片视频一区91| 中文字幕人妻三级在线观看| 不卡精品视频在线观看| 久久这里只有精品热视频 | 日韩av熟妇在线观看| 欧美老妇精品另类不卡片| 欧美美女人体视频一区| 日本少妇人妻xxxxx18| 人妻爱爱 中文字幕| 欧美乱妇无乱码一区二区| 日韩在线中文字幕色| 在线观看黄色成年人网站| 午夜在线观看一区视频| 中文字幕一区二区三区人妻大片 | 最新中文字幕免费视频| 少妇人妻真实精品视频| 天堂中文字幕翔田av| 中文字幕—97超碰网| 欧美精品 日韩国产| 欧美视频一区免费在线| 午夜毛片不卡免费观看视频| 日韩剧情片电影在线收看| 国产精品女邻居小骚货| 高潮喷水在线视频观看| 亚洲一区二区久久久人妻| 中文字幕综合一区二区| 久久久制服丝袜中文字幕| 日日爽天天干夜夜操| 国产揄拍高清国内精品对白 | 大鸡巴后入爆操大屁股美女| 亚洲av自拍天堂网| 欧美熟妇一区二区三区仙踪林| 日本美女成人在线视频| 日本又色又爽又黄又粗| 99婷婷在线观看视频| 91精品激情五月婷婷在线| 男生用鸡操女生视频动漫| 农村胖女人操逼视频| 99精品视频之69精品视频| 大香蕉伊人中文字幕| 国产又粗又硬又猛的毛片视频| 中文字幕 亚洲av| 亚洲少妇高潮免费观看| 欧美第一页在线免费观看视频| 人妻少妇精品久久久久久| 中文字母永久播放1区2区3区 | 人妻另类专区欧美制服| 国产日韩av一区二区在线| 青青草原网站在线观看| 亚洲熟女久久久36d| 中国黄片视频一区91| heyzo蜜桃熟女人妻| 国产一区二区火爆视频| 老司机免费福利视频网| 日韩中文字幕精品淫| 久碰精品少妇中文字幕av | 精品suv一区二区69| 日本午夜久久女同精女女| 黄工厂精品视频在线观看| 国产三级影院在线观看| 国产高清在线在线视频| 一区二区三区毛片国产一区| 美女小视频网站在线| 精品一区二区三区在线观看| 最近的中文字幕在线mv视频| 国产视频一区在线观看| 社区自拍揄拍尻屁你懂的| 亚洲欧美精品综合图片小说| 中文字幕日韩精品日本| 亚洲欧美人精品高清| 日日爽天天干夜夜操| 青青青青在线视频免费观看| 青春草视频在线免费播放| 免费福利av在线一区二区三区| 婷婷综合亚洲爱久久| 国产品国产三级国产普通话三级| 粉嫩av懂色av蜜臀av| 伊人网中文字幕在线视频| 99精品国产aⅴ在线观看| 亚洲自拍偷拍综合色| 久草视频在线看免费| 丰满少妇人妻xxxxx| 视频二区在线视频观看| 91传媒一区二区三区| 亚洲高清视频在线不卡| 国语对白xxxx乱大交| 亚洲精品乱码久久久久久密桃明| 亚洲中文字幕乱码区| 亚洲 中文 自拍 另类 欧美| 国产一区二区久久久裸臀| 欧美在线一二三视频| 九色视频在线观看免费| 欧美日韩熟女一区二区三区| 91av精品视频在线| av手机免费在线观看高潮| 国产精品一二三不卡带免费视频| 老司机99精品视频在线观看| 天天爽夜夜爽人人爽QC| 大鸡八强奸视频在线观看| av大全在线播放免费| 国产片免费观看在线观看| 国产卡一卡二卡三乱码手机| 一二三中文乱码亚洲乱码one| 2022国产精品视频| 青青青青视频在线播放| 国产第一美女一区二区三区四区| 国产午夜激情福利小视频在线| 成人激情文学网人妻| 天天干狠狠干天天操| 黑人性生活视频免费看| 欧美久久久久久三级网| 亚洲国产成人最新资源| 精彩视频99免费在线| 国产精品国产三级国产午| 亚洲2021av天堂| 亚洲av无码成人精品区辽| 欧洲精品第一页欧洲精品亚洲| 在线观看日韩激情视频| 黄色片一级美女黄色片| 97少妇精品在线观看| 欧洲国产成人精品91铁牛tv| av在线观看网址av| 这里只有精品双飞在线播放| 亚洲 欧美 精品 激情 偷拍| 国产91久久精品一区二区字幕| 首之国产AV医生和护士小芳| 在线观看免费岛国av| 亚洲欧美综合在线探花| 欧美日本在线观看一区二区| 三上悠亚和黑人665番号| 国产成人精品一区在线观看 | 天天摸天天干天天操科普| 18禁美女黄网站色大片下载| 9久在线视频只有精品| 久久久久五月天丁香社区| 国产精品三级三级三级| 男人靠女人的逼视频| 国产极品精品免费视频| 日曰摸日日碰夜夜爽歪歪| 强行扒开双腿猛烈进入免费版| 免费在线福利小视频| 男女之间激情网午夜在线| 免费无码人妻日韩精品一区二区 | 日本午夜久久女同精女女| 玖玖一区二区在线观看| 香蕉av影视在线观看| 91av精品视频在线| 精品一区二区三区三区色爱| 中文字幕一区的人妻欧美日韩| 人妻少妇亚洲一区二区| 国产自拍在线观看成人| 早川濑里奈av黑人番号| 色秀欧美视频第一页| 亚洲成a人片777777| 日韩写真福利视频在线观看| 黑人变态深video特大巨大| 免费岛国喷水视频在线观看| 男人的天堂一区二区在线观看| 爱有来生高清在线中文字幕| 亚洲一区av中文字幕在线观看| 99热碰碰热精品a中文| 中文字幕人妻三级在线观看| 久久艹在线观看视频| 中文字幕日韩人妻在线三区| 日韩av有码一区二区三区4 | 免费人成黄页网站在线观看国产 | 久久精品在线观看一区二区| 欧美久久久久久三级网| 欧洲国产成人精品91铁牛tv| 美女av色播在线播放| 91天堂精品一区二区| 高清一区二区欧美系列| jul—619中文字幕在线| 国产janese在线播放| 国产精品系列在线观看一区二区| 欧美在线一二三视频| 社区自拍揄拍尻屁你懂的| 亚洲另类在线免费观看| 国产中文精品在线观看| 国产亚洲欧美45p| 中字幕人妻熟女人妻a62v网| 五十路熟女人妻一区二| 成年午夜免费无码区| 日韩人妻xxxxx| 搡老妇人老女人老熟女| 秋霞午夜av福利经典影视| 亚洲成人午夜电影在线观看| 中文字幕综合一区二区| 一二三中文乱码亚洲乱码one| 成人福利视频免费在线| aiss午夜免费视频| 精品一区二区三区欧美| 亚洲成人av在线一区二区| 日韩成人免费电影二区| 自拍偷拍vs一区二区三区| 在线免费观看99视频| 国产白袜脚足J棉袜在线观看| 中文字幕第一页国产在线| 国产精品精品精品999| 亚洲精品国产久久久久久| 懂色av之国产精品| 大香蕉大香蕉在线有码 av| 在线免费观看黄页视频| 熟女在线视频一区二区三区| 夜女神免费福利视频| 在线观看视频网站麻豆| 久久久久久久精品成人热| 午夜美女少妇福利视频| 日本精品一区二区三区在线视频。| 97国产在线av精品| tube69日本少妇| 国产在线一区二区三区麻酥酥| 色婷婷久久久久swag精品| 午夜在线精品偷拍一区二| 夏目彩春在线中文字幕| 干逼又爽又黄又免费的视频| 国产美女精品福利在线| av中文字幕电影在线看| 久草视频在线一区二区三区资源站| 亚洲精品国产久久久久久| 成人av亚洲一区二区| 久久免看30视频口爆视频| 青青青aaaa免费| 国产在线91观看免费观看| 玩弄人妻熟妇性色av少妇| 中国产一级黄片免费视频播放| av在线shipin| 99精品免费久久久久久久久a| 18禁美女黄网站色大片下载| 免费在线福利小视频| 欧美精品伦理三区四区| 男人操女人的逼免费视频| 人人妻人人爱人人草| 美女 午夜 在线视频| 亚洲最大免费在线观看| 后入美女人妻高清在线| 日韩美av高清在线| 精品久久久久久久久久久久人妻 | 2018在线福利视频| 97a片免费在线观看| 女同互舔一区二区三区| 亚洲精品三级av在线免费观看| 午夜精品在线视频一区| 精品视频中文字幕在线播放| 51精品视频免费在线观看| av中文字幕国产在线观看| 国产一级麻豆精品免费| 91国偷自产一区二区三区精品| 91中文字幕免费在线观看| 成年女人免费播放视频| 九色视频在线观看免费| 777奇米久久精品一区| 日韩av有码一区二区三区4| 国产熟妇一区二区三区av | 国际av大片在线免费观看| 91she九色精品国产| 日韩精品啪啪视频一道免费| 韩国女主播精品视频网站| 亚洲伊人av天堂有码在线| 欧美成人精品在线观看| 国语对白xxxx乱大交| 最新的中文字幕 亚洲| 午夜精彩视频免费一区| 五十路熟女av天堂| 免费岛国喷水视频在线观看| 不戴胸罩引我诱的隔壁的人妻 | 久青青草视频手机在线免费观看| 在线免费91激情四射| 91麻豆精品秘密入口在线观看| 亚洲午夜伦理视频在线| 亚洲综合一区成人在线| 中文字幕AV在线免费看 | 欧美久久一区二区伊人| 自拍偷拍亚洲欧美在线视频| 日本特级片中文字幕| 日韩欧美在线观看不卡一区二区 | 国产午夜无码福利在线看| 2018最新中文字幕在线观看| 黄片大全在线观看观看| 又大又湿又爽又紧A视频| 搡老妇人老女人老熟女| 狠狠的往里顶撞h百合| 男人天堂最新地址av| 欲乱人妻少妇在线视频裸| 国产精品一二三不卡带免费视频| 成人在线欧美日韩国产| 不戴胸罩引我诱的隔壁的人妻| 久久久噜噜噜久久熟女av| 2021久久免费视频| 久久三久久三久久三久久| 免费国产性生活视频| 日韩少妇人妻精品无码专区| 人人妻人人澡人人爽人人dvl| 中文字幕,亚洲人妻| 免费成人va在线观看| 欧美在线精品一区二区三区视频| 天堂va蜜桃一区入口| 免费看国产又粗又猛又爽又黄视频| 粗大的内捧猛烈进出爽大牛汉子| 青青草人人妻人人妻| wwwxxx一级黄色片| 开心 色 六月 婷婷| 沈阳熟妇28厘米大战黑人| 不卡一区一区三区在线| 亚洲变态另类色图天堂网| 91www一区二区三区| 伊拉克及约旦宣布关闭领空| 成年人的在线免费视频| 成人久久精品一区二区三区| 中文字幕人妻被公上司喝醉在线| 亚洲精品久久视频婷婷| 中文字幕 人妻精品| 视频二区在线视频观看| 中文字幕人妻熟女在线电影| 精品人妻一二三区久久| 操日韩美女视频在线免费看| 初美沙希中文字幕在线| 国产日韩一区二区在线看| 国产高清精品极品美女| 综合国产成人在线观看| 午夜91一区二区三区| 人妻丝袜诱惑我操她视频| 男大肉棒猛烈插女免费视频| 欧美乱妇无乱码一区二区| 涩爱综合久久五月蜜臀| 亚洲另类图片蜜臀av| 少妇人妻100系列| 青娱乐蜜桃臀av色| 91精品啪在线免费| 色吉吉影音天天干天天操 | 爱爱免费在线观看视频| 巨乳人妻日下部加奈被邻居中出 | 啊慢点鸡巴太大了啊舒服视频| 同居了嫂子在线播高清中文| 91天堂天天日天天操| 好吊操视频这里只有精品| 成人蜜臀午夜久久一区| av一本二本在线观看| 99热国产精品666| 韩国男女黄色在线观看| 日韩av免费观看一区| 午夜激情久久不卡一区二区| 亚洲国产精品中文字幕网站| 成人区人妻精品一区二视频 | 男生舔女生逼逼的视频| 亚洲av香蕉一区区二区三区犇| 2020中文字幕在线播放| 欧美精品伦理三区四区| 五月精品丁香久久久久福利社| 视频一区 二区 三区 综合| 99的爱精品免费视频| 在线免费观看亚洲精品电影| 性感美女福利视频网站| 亚洲一区自拍高清免费视频| 国产一区二区久久久裸臀| 97超碰人人搞人人| 成人30分钟免费视频| 欧美乱妇无乱码一区二区| 亚洲男人在线天堂网| 精品一区二区三四区| 男人的网址你懂的亚洲欧洲av| 风流唐伯虎电视剧在线观看| 成人久久精品一区二区三区| av天堂中文字幕最新| 99视频精品全部15| 国产不卡av在线免费| 黑人3p华裔熟女普通话| 中文字幕免费福利视频6| 日本真人性生活视频免费看| 97精品成人一区二区三区 | 大鸡巴插入美女黑黑的阴毛| 天天操天天爽天天干| 亚洲av一妻不如妾| 日本av高清免费网站| 中文字幕亚洲中文字幕| 在线不卡成人黄色精品| 免费成人va在线观看| 亚洲人妻视频在线网| 毛片av在线免费看| 国产精品久久综合久久| 韩国女主播精品视频网站| 男人操女人的逼免费视频| 国产一区av澳门在线观看| 日韩av有码一区二区三区4| 国产一级麻豆精品免费| 国产精品人妻一区二区三区网站 | 夜夜操,天天操,狠狠操| 免费男阳茎伸入女阳道视频| 成人av久久精品一区二区| 91破解版永久免费| 国产精品人久久久久久| 午夜精品一区二区三区更新| 亚洲高清视频在线不卡| 亚洲国产第一页在线观看| 亚洲福利午夜久久久精品电影网| 午夜福利人人妻人人澡人人爽| 青青草精品在线视频观看| 精品国产亚洲av一淫| 中文字幕综合一区二区| 亚洲成a人片777777| 在线观看视频污一区| 亚洲男人让女人爽的视频| 一区二区在线观看少妇| 国产精品入口麻豆啊啊啊| 无套猛戳丰满少妇人妻 | 亚洲免费视频欧洲免费视频| 亚洲激情av一区二区| 中文字幕av男人天堂| 精品首页在线观看视频| 熟女人妻一区二区精品视频| 国产高潮无码喷水AV片在线观看| 日本少妇的秘密免费视频| 亚洲人妻av毛片在线| 99视频精品全部15| 可以免费看的www视频你懂的| 日韩无码国产精品强奸乱伦| 黑人大几巴狂插日本少妇| 国产亚洲天堂天天一区| 国产刺激激情美女网站| 国产精品久久综合久久| av中文字幕国产在线观看| 啊啊啊视频试看人妻| 777奇米久久精品一区| 99热国产精品666| 亚洲国产成人最新资源| 欧美性受xx黑人性猛交| 国产污污污污网站在线| 2020久久躁狠狠躁夜夜躁| 日本高清成人一区二区三区| 日本一二三中文字幕| 国产黑丝高跟鞋视频在线播放| 天堂av在线播放免费| 黑人解禁人妻叶爱071| 夜夜操,天天操,狠狠操| 亚洲免费av在线视频| 一区二区三区激情在线| 国产午夜福利av导航| 青青草原网站在线观看| 天天操天天干天天日狠狠插| 97国产福利小视频合集| 中字幕人妻熟女人妻a62v网| 一区二区三区在线视频福利| 蜜臀成人av在线播放| 亚洲国产欧美一区二区三区久久 | 大鸡巴操b视频在线| 日韩av大胆在线观看| 亚洲av可乐操首页| 视频二区在线视频观看| 11久久久久久久久久久| 欧美aa一级一区三区四区| 国产九色91在线视频| 一二三中文乱码亚洲乱码one| 2o22av在线视频| 国产女人被做到高潮免费视频| 美女av色播在线播放| 婷婷色国产黑丝少妇勾搭AV| 91小伙伴中女熟女高潮| 搡老熟女一区二区在线观看| 视频一区二区在线免费播放| 馒头大胆亚洲一区二区| 在线免费观看靠比视频的网站 | 丝袜长腿第一页在线| 久草视频 久草视频2| 亚洲av无码成人精品区辽| 国产亚洲欧美视频网站| 一区二区三区毛片国产一区| 综合一区二区三区蜜臀| 一区二区三区久久中文字幕| 97年大学生大白天操逼| 蜜桃视频入口久久久| 91天堂精品一区二区| 任我爽精品视频在线播放| 韩国爱爱视频中文字幕| 99久久成人日韩欧美精品| 大香蕉日本伊人中文在线| 国产乱弄免费视频观看| 色狠狠av线不卡香蕉一区二区 | 免费在线福利小视频| 天天摸天天日天天操| 任你操视频免费在线观看| 国内资源最丰富的网站| 中文字幕日韩91人妻在线| 欧美一区二区三区久久久aaa| 日韩美女精品视频在线观看网站 | 青青草成人福利电影| 欧美亚洲国产成人免费在线| 2017亚洲男人天堂| 国产精品久久9999| 亚洲av日韩av网站| 欧美特级特黄a大片免费| 无忧传媒在线观看视频| 久久久麻豆精亚洲av麻花| 亚洲 欧美 自拍 偷拍 在线| 老司机午夜精品视频资源| 欧亚日韩一区二区三区观看视频| 中国产一级黄片免费视频播放| 日韩a级精品一区二区| 无码国产精品一区二区高潮久久4| 蜜臀av久久久久蜜臀av麻豆| 五十路熟女人妻一区二区9933| 亚洲伊人久久精品影院一美女洗澡 | av视屏免费在线播放| 欧美亚洲国产成人免费在线 | 全国亚洲男人的天堂| 一区二区三区 自拍偷拍| 男生舔女生逼逼的视频| 高清一区二区欧美系列| 午夜青青草原网在线观看| 久久久噜噜噜久久熟女av| 欧美精品中文字幕久久二区| 另类av十亚洲av| 亚洲av午夜免费观看| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 天天操天天爽天天干| av老司机精品在线观看| 久久久91蜜桃精品ad| 亚洲av日韩精品久久久久久hd| 亚洲一区二区三区久久午夜| 又粗又硬又猛又黄免费30| 久久丁香婷婷六月天| 亚洲激情,偷拍视频| 人妻丰满熟妇综合网| 日本精品一区二区三区在线视频。| 特一级特级黄色网片| 国产美女精品福利在线| 韩国黄色一级二级三级| 插逼视频双插洞国产操逼插洞 | 美日韩在线视频免费看| 亚洲中文字幕人妻一区| 亚洲欧美精品综合图片小说| 沙月文乃人妻侵犯中文字幕在线| 日本xx片在线观看| gogo国模私拍视频| www久久久久久久久久久| 亚洲国产40页第21页| 最新国产精品网址在线观看| 亚洲综合自拍视频一区| 污污小视频91在线观看| 午夜毛片不卡在线看| 性色av一区二区三区久久久| 中文字幕在线欧美精品| 久久热这里这里只有精品| 天天干天天操天天扣| 99热碰碰热精品a中文| 五月天色婷婷在线观看视频免费| 亚洲欧美福利在线观看| 天天干天天插天天谢| 人人妻人人爽人人添夜| 真实国模和老外性视频| 91久久综合男人天堂| 天天色天天操天天舔| 在线不卡日韩视频播放| 少妇人妻真实精品视频| 快点插进来操我逼啊视频| h国产小视频福利在线观看| 亚洲综合一区二区精品久久| 三上悠亚和黑人665番号| 2018在线福利视频| 免费观看理论片完整版| 2020久久躁狠狠躁夜夜躁| 日本性感美女三级视频| 男生用鸡操女生视频动漫| 沈阳熟妇28厘米大战黑人| 国产大学生援交正在播放| 成人精品视频99第一页| 国产va精品免费观看| huangse网站在线观看| 中文字幕一区的人妻欧美日韩| 久久久久91精品推荐99| 亚洲精品亚洲人成在线导航| 91免费黄片可看视频| 日日操夜夜撸天天干| 东京干手机福利视频| 黑人3p华裔熟女普通话| 国产亚洲精品视频合集| 91人妻人人做人人爽在线| 国产乱子伦一二三区| 美女张开腿让男生操在线看| 丰满的子国产在线观看| 久久精品国产亚洲精品166m| 亚洲欧美一区二区三区爱爱动图| 亚洲精品国品乱码久久久久| 日本av高清免费网站| 最新国产精品网址在线观看| 天天日天天敢天天干| 岛国一区二区三区视频在线| 人人妻人人人操人人人爽| 成人综合亚洲欧美一区| 国内资源最丰富的网站| 国产午夜激情福利小视频在线| 天天干狠狠干天天操| 东游记中文字幕版哪里可以看到| 瑟瑟视频在线观看免费视频| 国产亚洲欧美视频网站| 成人av电影免费版| 免费无码人妻日韩精品一区二区| 欧美精品欧美极品欧美视频| 国产在线免费观看成人| 国产精品国产三级国产精东| 在线免费观看靠比视频的网站| 欧美色婷婷综合在线| av在线播放国产不卡| 免费十精品十国产网站| 国产精彩对白一区二区三区| 久久久精品999精品日本| 久草福利电影在线观看| 青青青艹视频在线观看| aⅴ精产国品一二三产品| 国产在线免费观看成人| 国产麻豆剧传媒精品国产av蜜桃| 91大神福利视频网| 日韩加勒比东京热二区| 男人靠女人的逼视频| 1024久久国产精品| 在线免费91激情四射| 视频一区二区三区高清在线| 最新日韩av传媒在线| 欧美在线偷拍视频免费看 | 国产午夜亚洲精品不卡在线观看| 国产福利小视频二区| 性感美女福利视频网站| 在线播放国产黄色av| 亚洲丝袜老师诱惑在线观看| 91福利视频免费在线观看| 综合色区亚洲熟妇shxstz| 亚洲 中文 自拍 无码| 欧美黄片精彩在线免费观看| 色哟哟在线网站入口| 欧美一区二区三区乱码在线播放| 在线新三级黄伊人网| 任我爽精品视频在线播放| 91‖亚洲‖国产熟女| 超碰97人人做人人爱| 欧美亚洲中文字幕一区二区三区| 亚洲青青操骚货在线视频| 成人精品在线观看视频| www天堂在线久久| 2021国产一区二区| 男人天堂最新地址av| 播放日本一区二区三区电影| 亚洲无线观看国产高清在线| 日韩国产乱码中文字幕| 日韩亚国产欧美三级涩爱| 男人操女人的逼免费视频| 51精品视频免费在线观看| 精品乱子伦一区二区三区免费播| 啊啊好大好爽啊啊操我啊啊视频 | 日本免费午夜视频网站| 一区二区三区日本伦理| 亚洲一区二区三区五区| 午夜久久久久久久99| 午夜激情精品福利视频| 色av色婷婷人妻久久久精品高清| 和邻居少妇愉情中文字幕| 91国产在线免费播放| 激情五月婷婷免费视频| 中文字幕乱码av资源| 天天日天天日天天射天天干 | 黄色中文字幕在线播放| 三级av中文字幕在线观看| 100%美女蜜桃视频| 国产精品一区二区久久久av| av森泽佳奈在线观看| 亚洲一区二区久久久人妻| 欧美老妇精品另类不卡片| 自拍偷拍日韩欧美一区二区| 中文亚洲欧美日韩无线码| 天天日天天干天天干天天日| 色哟哟在线网站入口| 55夜色66夜色国产精品站| 中文字幕网站你懂的| 无码日韩人妻精品久久| 午夜精品一区二区三区城中村| 欧美黄片精彩在线免费观看 | 婷婷六月天中文字幕| 欧美老鸡巴日小嫩逼| 亚洲综合另类欧美久久| 亚洲最大黄 嗯色 操 啊| 偷拍自拍亚洲美腿丝袜| 国产成人一区二区三区电影网站 | 少妇露脸深喉口爆吞精| 国产午夜无码福利在线看| 水蜜桃国产一区二区三区| 男人的网址你懂的亚洲欧洲av | 91高清成人在线视频| 福利午夜视频在线合集| 国产精品黄片免费在线观看| 成年女人免费播放视频| 国产在线观看黄色视频| 亚洲av成人免费网站| 岛国av高清在线成人在线| 国产在线观看黄色视频| 东游记中文字幕版哪里可以看到| 99热99re在线播放| 日韩av中文在线免费观看| 国产亚洲视频在线观看| 人妻丝袜诱惑我操她视频| 天天干天天日天天谢综合156| 日本少妇人妻xxxxx18| 高清成人av一区三区| 亚洲激情唯美亚洲激情图片| 激情综合治理六月婷婷| 黄工厂精品视频在线观看| 亚洲高清视频在线不卡| 97黄网站在线观看| 午夜福利资源综合激情午夜福利资| 成熟熟女国产精品一区| 久久这里只有精彩视频免费| 在线免费观看黄页视频| 日韩a级精品一区二区| 日本女人一级免费片| 大鸡巴插入美女黑黑的阴毛| 日本韩国免费一区二区三区视频| 青青草视频手机免费在线观看| 午夜在线观看一区视频| 91中文字幕免费在线观看| 日本少妇人妻xxxxxhd| 国产性色生活片毛片春晓精品| 中文字母永久播放1区2区3区| 在线免费观看日本伦理| 亚洲国产欧美一区二区三区…| 日本熟女50视频免费| 欧美久久久久久三级网| jiujiure精品视频在线| 四川五十路熟女av| 午夜福利人人妻人人澡人人爽| 人妻爱爱 中文字幕| 1024久久国产精品| 啪啪啪操人视频在线播放| 自拍偷拍亚洲精品第2页| 欧美激情精品在线观看| 国产免费高清视频视频| 日韩一区二区电国产精品| 快插进小逼里大鸡吧视频| 丝袜国产专区在线观看| 92福利视频午夜1000看 | 天天日天天操天天摸天天舔| 最新国产亚洲精品中文在线| 男人天堂色男人av| 青青青国产片免费观看视频| 午夜在线一区二区免费| 国产91精品拍在线观看| 啪啪啪啪啪啪啪免费视频| 日韩欧美中文国产在线| 国产真实乱子伦a视频| 天堂va蜜桃一区入口| 中国视频一区二区三区| 国产自拍在线观看成人| 国产又粗又硬又大视频| 在线观看av观看av| 国产精品自拍视频大全| sejizz在线视频| 亚洲中文精品人人免费| 久久精品在线观看一区二区| 硬鸡巴动态操女人逼视频| 老司机福利精品免费视频一区二区| 大黑人性xxxxbbbb| 午夜青青草原网在线观看| av在线观看网址av| av乱码一区二区三区| 2o22av在线视频| 熟女91pooyn熟女| 伊人开心婷婷国产av| 开心 色 六月 婷婷| 天天日天天操天天摸天天舔 | 日本少妇精品免费视频| 久久精品在线观看一区二区| 宅男噜噜噜666免费观看| 青草亚洲视频在线观看| 免费大片在线观看视频网站| 人妻少妇一区二区三区蜜桃| 91色老99久久九九爱精品| 操的小逼流水的文章| 成人性黑人一级av| 亚洲av自拍偷拍综合| 污污小视频91在线观看| 亚洲成人三级在线播放| 亚洲va天堂va国产va久| 日本午夜爽爽爽爽爽视频在线观看 | 亚洲av一妻不如妾| 亚洲av色图18p| 在线免费观看亚洲精品电影| 久久机热/这里只有| 这里只有精品双飞在线播放| 天天摸天天日天天操| 日韩欧美国产一区ab| 青青草亚洲国产精品视频| 国产精品一区二区三区蜜臀av | 久久丁香婷婷六月天| 伊人综合免费在线视频| 啊啊好大好爽啊啊操我啊啊视频 | 国产av自拍偷拍盛宴| 伊人开心婷婷国产av | 粉嫩av蜜乳av蜜臀| 国产黄色高清资源在线免费观看| 福利片区一区二体验区| 91精品视频在线观看免费| 视频啪啪啪免费观看| 美女在线观看日本亚洲一区| 2019av在线视频| 少妇人妻久久久久视频黄片| 亚洲av无女神免非久久| 91人妻精品一区二区久久| 精品国产乱码一区二区三区乱| 狠狠地躁夜夜躁日日躁| 99精品国自产在线人| 亚洲一区二区三区偷拍女厕91| 日本av高清免费网站| 91久久综合男人天堂| 亚洲av无女神免非久久| 亚洲欧美一区二区三区爱爱动图| 亚洲成人av在线一区二区| 超碰公开大香蕉97| 色婷婷综合激情五月免费观看| 骚货自慰被发现爆操| 色爱av一区二区三区| 日韩欧美高清免费在线| 精品人妻一二三区久久| 国产综合视频在线看片| 色av色婷婷人妻久久久精品高清| 啊慢点鸡巴太大了啊舒服视频| 日本av熟女在线视频| 国产在线一区二区三区麻酥酥| 亚洲国产欧美一区二区三区…| 精品高跟鞋丝袜一区二区| 青娱乐蜜桃臀av色| 欧美黑人性猛交xxxxⅹooo| 麻豆性色视频在线观看| 91精品国产观看免费| 99热99re在线播放| 久久这里只有精品热视频| 人人人妻人人澡人人| 97黄网站在线观看| 天码人妻一区二区三区在线看 | 92福利视频午夜1000看| 在线免费观看视频一二区| 极品丝袜一区二区三区| 黄片大全在线观看观看| 免费成人va在线观看| 人妻丝袜精品中文字幕| 欧美在线偷拍视频免费看| 91久久人澡人人添人人爽乱| 亚洲熟女综合色一区二区三区四区 | 亚洲男人的天堂a在线| 天天日天天干天天要| 神马午夜在线观看视频| 大陆胖女人与丈夫操b国语高清 | 免费人成黄页网站在线观看国产| 日韩精品二区一区久久| 福利视频一区二区三区筱慧 | 2022精品久久久久久中文字幕| 熟女妇女老妇一二三区| 亚洲va国产va欧美va在线| 午夜精品福利一区二区三区p| 极品粉嫩小泬白浆20p主播 | 同居了嫂子在线播高清中文| 欧美熟妇一区二区三区仙踪林| 亚洲av色图18p| 快点插进来操我逼啊视频| 女同性ⅹxx女同hd| 天天色天天爱天天爽| 在线观看操大逼视频| 日日夜夜精品一二三| 国产精品精品精品999| 中文字幕人妻三级在线观看| 一区二区三区另类在线 | 日韩无码国产精品强奸乱伦| 亚洲成人午夜电影在线观看| 国产成人自拍视频在线免费观看| 2022中文字幕在线| 中文字幕亚洲久久久| 亚洲一区二区三区五区| 日本啪啪啪啪啪啪啪| 欧美性感尤物人妻在线免费看| 大白屁股精品视频国产| av在线shipin| 91亚洲国产成人精品性色| 久久久超爽一二三av| 亚洲成人午夜电影在线观看| 亚洲国产成人av在线一区| 亚洲伊人久久精品影院一美女洗澡 | 亚洲成人精品女人久久久| 曰本无码人妻丰满熟妇啪啪| 天天干天天操天天玩天天射| weyvv5国产成人精品的视频| 国产熟妇人妻ⅹxxxx麻豆| 中文字幕一区二区人妻电影冢本 | 日本性感美女视频网站| 亚洲另类综合一区小说| 东京热男人的av天堂| 日日操夜夜撸天天干| 99热99这里精品6国产| 美女av色播在线播放| 91自产国产精品视频| 三上悠亚和黑人665番号| 91国产在线视频免费观看| 黄色大片男人操女人逼| 亚洲人妻视频在线网| 熟妇一区二区三区高清版| 亚洲中文字字幕乱码| 亚欧在线视频你懂的| 欧洲日韩亚洲一区二区三区| 中文字幕一区的人妻欧美日韩| 免费在线观看污污视频网站| 天天色天天舔天天射天天爽| 国产欧美精品一区二区高清| 夜夜骑夜夜操夜夜奸| 午夜精品久久久久久99热| 天天操,天天干,天天射| 2018最新中文字幕在线观看| 天天射夜夜操综合网| 91九色国产porny蝌蚪| 狠狠嗨日韩综合久久| 五月天中文字幕内射| 在线新三级黄伊人网| 四虎永久在线精品免费区二区| 日韩少妇人妻精品无码专区| 动漫精品视频在线观看| 男人靠女人的逼视频| 操操网操操伊剧情片中文字幕网| 欧洲国产成人精品91铁牛tv| 日韩av免费观看一区| 亚洲最大黄了色网站| 欧美在线精品一区二区三区视频 | 午夜精品一区二区三区4| 和邻居少妇愉情中文字幕| 精品久久久久久久久久中文蒉| 亚洲第一黄色在线观看| 欧美一级片免费在线成人观看| 岛国av高清在线成人在线| 啪啪啪啪啪啪啪啪av| 亚洲第一伊人天堂网| 75国产综合在线视频| 成人综合亚洲欧美一区| 欧美日韩一级黄片免费观看| 特大黑人巨大xxxx| 久久精品亚洲成在人线a| 日本特级片中文字幕| 欧美国产亚洲中英文字幕| 99re6热在线精品| 亚洲一区av中文字幕在线观看| 91自产国产精品视频| av在线免费观看亚洲天堂| av中文字幕网址在线| 亚洲无码一区在线影院| 欧美视频一区免费在线| 性欧美日本大妈母与子| 午夜精品一区二区三区城中村| 国产一区二区视频观看| av一本二本在线观看| 秋霞午夜av福利经典影视| 国产亚州色婷婷久久99精品| 亚洲av琪琪男人的天堂| 最新国产精品网址在线观看| 一色桃子人妻一区二区三区| 亚洲一级av大片免费观看| 日韩中文字幕精品淫| 国产一区二区久久久裸臀| 日本少妇人妻xxxxx18| 无忧传媒在线观看视频| 换爱交换乱高清大片| 免费看美女脱光衣服的视频| 色伦色伦777国产精品| 国产熟妇乱妇熟色T区| 亚洲中文精品字幕在线观看| 亚洲av日韩av网站| 亚洲区美熟妇久久久久| 黄片三级三级三级在线观看| 青青青国产片免费观看视频| 日本一区二区三区免费小视频| 黄色视频成年人免费观看| av久久精品北条麻妃av观看| 懂色av蜜桃a v| 国产夫妻视频在线观看免费| 老师让我插进去69AV| 日韩av中文在线免费观看| 日本一区美女福利视频| 在线免费观看av日韩| 亚洲高清免费在线观看视频| 视频一区二区三区高清在线| 中文字幕日韩精品日本| 亚洲综合一区二区精品久久| 插逼视频双插洞国产操逼插洞| 欧美一区二区三区在线资源| tube69日本少妇| 国产品国产三级国产普通话三级| 欧美一区二区三区四区性视频| 欧美偷拍自拍色图片| 国产麻豆精品人妻av| 黑人性生活视频免费看| 日本www中文字幕| 999九九久久久精品| 亚洲精品乱码久久久久久密桃明| 亚洲精品在线资源站| 2021国产一区二区| 国产精品视频男人的天堂| 亚洲欧洲一区二区在线观看| 国产福利小视频免费观看| 自拍偷区二区三区麻豆| 精品91高清在线观看 | 日本www中文字幕| 日本一二三中文字幕| 中国产一级黄片免费视频播放| 国产视频网站一区二区三区| 天天操天天射天天操天天天| 99热久久这里只有精品| 亚洲高清免费在线观看视频| 亚洲国际青青操综合网站| 偷拍自拍福利视频在线观看| 久草极品美女视频在线观看| 久久h视频在线观看| 天天干天天操天天玩天天射 | 天天操天天干天天插| 婷婷综合蜜桃av在线| 女同性ⅹxx女同h偷拍| 亚洲国产成人在线一区| 欧洲精品第一页欧洲精品亚洲| 人妻丝袜榨强中文字幕| 91传媒一区二区三区| 亚洲综合在线视频可播放| 国产剧情演绎系列丝袜高跟| 美女在线观看日本亚洲一区| 国产视频网站一区二区三区| 国产 在线 免费 精品| 天天干天天啪天天舔| 无码中文字幕波多野不卡| 国产janese在线播放| 免费福利av在线一区二区三区| 一区二区三区美女毛片| 91片黄在线观看喷潮| 亚洲一级 片内射视正片| 天天干天天插天天谢| 任我爽精品视频在线播放| 国产精彩对白一区二区三区| 99热99这里精品6国产| 欧美成一区二区三区四区| 美女福利写真在线观看视频| 国产一区二区视频观看| 色偷偷伊人大杳蕉综合网| gay gay男男瑟瑟在线网站| 日本熟妇一区二区x x| 天天艹天天干天天操| 青青青青青操视频在线观看| 91国偷自产一区二区三区精品| 久久午夜夜伦痒痒想咳嗽P| 成人午夜电影在线观看 久久| 亚洲精品午夜aaa久久| 91在线免费观看成人| 在线免费观看欧美小视频| 九色porny九色9l自拍视频| 韩国男女黄色在线观看| 国产一区二区三免费视频| 亚洲精品在线资源站| 在线免费观看日本片| 午夜在线一区二区免费| 男生用鸡操女生视频动漫| 欧美亚洲少妇福利视频| 国产一级精品综合av| 青青操免费日综合视频观看| 2020av天堂网在线观看| 懂色av蜜桃a v| 中国熟女@视频91| 亚洲综合乱码一区二区| 日韩人妻丝袜中文字幕| 免费黄高清无码国产| 国产大鸡巴大鸡巴操小骚逼小骚逼| 日本美女成人在线视频| 69精品视频一区二区在线观看| 一本一本久久a久久精品综合不卡| 噜噜色噜噜噜久色超碰| 淫秽激情视频免费观看| 性欧美日本大妈母与子| 亚洲免费在线视频网站| 欧美另类一区二区视频| 丰满的子国产在线观看| 99久久超碰人妻国产| 国产欧美日韩第三页| 亚欧在线视频你懂的| 精品日产卡一卡二卡国色天香 | 日韩加勒比东京热二区| 99热这里只有国产精品6| 一本一本久久a久久精品综合不卡| 中文字母永久播放1区2区3区| 中文字幕免费福利视频6| 亚洲av日韩精品久久久| 日韩欧美一级精品在线观看| 久久麻豆亚洲精品av| 亚洲成人国产av在线| 成人久久精品一区二区三区| 久久精品在线观看一区二区| 91中文字幕免费在线观看| 蜜桃精品久久久一区二区| 青青青国产免费视频| 精品av久久久久久久| 涩爱综合久久五月蜜臀| 欧美中国日韩久久精品| 国产午夜福利av导航| 成熟熟女国产精品一区| 北条麻妃高跟丝袜啪啪| avjpm亚洲伊人久久| 青青青aaaa免费| 国产麻豆剧果冻传媒app| 国产一区av澳门在线观看| 欧洲国产成人精品91铁牛tv| 人人妻人人澡欧美91精品| 自拍偷拍日韩欧美亚洲| 视频 一区二区在线观看| 五色婷婷综合狠狠爱| 久草视频在线一区二区三区资源站 | 日韩人妻xxxxx| 岛国黄色大片在线观看| 精内国产乱码久久久久久| 久久www免费人成一看片| 亚洲一级美女啪啪啪| 少妇人妻100系列| 午夜精品在线视频一区| 黄色无码鸡吧操逼视频| 欧美亚洲免费视频观看| 大陆av手机在线观看| 91精品国产高清自在线看香蕉网| 97年大学生大白天操逼| 日本人妻欲求不满中文字幕| 亚洲少妇高潮免费观看| 国产午夜福利av导航| 人妻久久久精品69系列| 中文字幕—97超碰网| 国产日韩精品免费在线| 东京热男人的av天堂| 99热久久这里只有精品| 青青操免费日综合视频观看| 337p日本大胆欧美人| 丰满少妇翘臀后进式| 秋霞午夜av福利经典影视| 久久美欧人妻少妇一区二区三区 | 岛国黄色大片在线观看| 视频在线亚洲一区二区| 97国产精品97久久| 国产精品中文av在线播放| 黑人变态深video特大巨大| av线天堂在线观看| 乱亲女秽乱长久久久| 天堂v男人视频在线观看| 欧美亚洲免费视频观看| 婷婷激情四射在线观看视频| 国产福利小视频二区| 啪啪啪啪啪啪啪啪啪啪黄色| 国产综合视频在线看片| 97精品成人一区二区三区| 狠狠嗨日韩综合久久| 老司机福利精品免费视频一区二区| 成人综合亚洲欧美一区| 色婷婷综合激情五月免费观看| 亚洲熟色妇av日韩熟色妇在线| 色花堂在线av中文字幕九九| 熟女人妻一区二区精品视频| 日本xx片在线观看| 国产性色生活片毛片春晓精品 | 在线观看免费岛国av| 粉嫩av蜜乳av蜜臀| 中文字幕人妻一区二区视频| av老司机精品在线观看| 在线视频这里只有精品自拍| 日本特级片中文字幕| 蜜臀av久久久久蜜臀av麻豆| 成人免费做爰高潮视频| 天码人妻一区二区三区在线看 | 国产精品久久久久国产三级试频| 美女操逼免费短视频下载链接| 日本午夜福利免费视频| 黄网十四区丁香社区激情五月天| 国产日韩欧美视频在线导航| 欧美老妇精品另类不卡片| 国产视频网站一区二区三区| 中文字幕第1页av一天堂网| 亚洲狠狠婷婷综合久久app| 亚洲 自拍 色综合图| 国产麻豆国语对白露脸剧情| 真实国模和老外性视频| 无码国产精品一区二区高潮久久4| 亚洲高清免费在线观看视频| 国产白嫩美女一区二区| 亚洲午夜伦理视频在线| 国产视频在线视频播放| 国产成人午夜精品福利| 国产黄色高清资源在线免费观看| 插小穴高清无码中文字幕| 久久久制服丝袜中文字幕| 久久久极品久久蜜桃| 久久久久久cao我的性感人妻| 岛国免费大片在线观看| 天天摸天天干天天操科普| 亚洲免费福利一区二区三区| 3337p日本欧洲大胆色噜噜| 91chinese在线视频| 久久久精品精品视频视频| 日本少妇的秘密免费视频| av俺也去在线播放| 做爰视频毛片下载蜜桃视频1| 91麻豆精品秘密入口在线观看| 啪啪啪18禁一区二区三区| 五十路熟女人妻一区二| 91快播视频在线观看| 人妻自拍视频中国大陆| 五十路熟女av天堂| 国产精品久久久久国产三级试频| 天天操,天天干,天天射| 国产日韩一区二区在线看| 天天夜天天日天天日| 久久久久久9999久久久久| 日韩a级黄色小视频| 国产亚洲欧美45p| 日韩欧美制服诱惑一区在线| 天堂av在线播放免费| 亚洲码av无色中文| 亚洲精品午夜久久久久| 国产乱子伦精品视频潮优女| 久久精品亚洲成在人线a| 视频在线免费观看你懂得| 一区二区三区日韩久久| 成年人黄视频在线观看| 免费黄色成人午夜在线网站| 精品视频国产在线观看| 午夜激情精品福利视频| 色哟哟国产精品入口| 日韩欧美亚洲熟女人妻| 中文字幕乱码av资源| 亚洲午夜在线视频福利| 国产污污污污网站在线| jiuse91九色视频| 天天射夜夜操综合网| 在线免费91激情四射| 日本裸体熟妇区二区欧美| 国产免费av一区二区凹凸四季| 三级等保密码要求条款| 国内自拍第一页在线观看| 欧美viboss性丰满| 成年人黄色片免费网站| 五十路在线观看完整版| 亚洲中文字幕乱码区| 亚洲码av无色中文| 亚洲高清国产拍青青草原| 日韩中文字幕在线播放第二页| 新婚人妻聚会被中出| 欧美视频一区免费在线| 美女在线观看日本亚洲一区| av男人天堂狠狠干| 久久久久久久久久一区二区三区| 日本熟妇丰满厨房55| 国产精品三级三级三级| 黑人大几巴狂插日本少妇| 免费看国产又粗又猛又爽又黄视频| 99av国产精品欲麻豆| 亚洲精品麻豆免费在线观看| 99精品视频之69精品视频 | 亚洲一区二区三区久久午夜| 欧美一区二区三区激情啪啪啪| 天天干天天爱天天色| 亚洲av日韩av第一区二区三区| 成人av电影免费版| 绝顶痉挛大潮喷高潮无码| 国产精品视频欧美一区二区| 男生舔女生逼逼视频| 日本性感美女视频网站| 欧美特色aaa大片| 成年午夜免费无码区| 中文字幕AV在线免费看 | 极品丝袜一区二区三区| 色av色婷婷人妻久久久精品高清| 亚洲欧美激情人妻偷拍| 骚逼被大屌狂草视频免费看| 日本精品一区二区三区在线视频。| 亚洲熟妇x久久av久久| 久久久精品精品视频视频| 天堂av在线播放免费| 绯色av蜜臀vs少妇| 亚洲一区二区三区偷拍女厕91| 99精品视频之69精品视频| 91色九色porny| 亚洲国产免费av一区二区三区| 欧美激情精品在线观看| 黑人解禁人妻叶爱071| 精品一区二区三区三区88| 老司机免费视频网站在线看| 欧美色婷婷综合在线| 丝袜长腿第一页在线| 在线观看免费av网址大全| 99精品国产免费久久| 黄色男人的天堂视频| 亚洲国产精品久久久久久6| 自拍偷拍亚洲欧美在线视频| 亚洲精品国产久久久久久| av一区二区三区人妻| 在线播放国产黄色av| 免费观看国产综合视频| 国产精品女邻居小骚货| 男大肉棒猛烈插女免费视频| 2022国产精品视频| 77久久久久国产精产品| 51国产偷自视频在线播放| 成人亚洲国产综合精品| aⅴ精产国品一二三产品| 午夜免费观看精品视频| 国产精品欧美日韩区二区| 黑人性生活视频免费看| 日本后入视频在线观看 | nagger可以指黑人吗| 成人性爱在线看四区| 国产av自拍偷拍盛宴| 国产精品系列在线观看一区二区| 黄网十四区丁香社区激情五月天| 成年人啪啪视频在线观看| 亚洲在线免费h观看网站| 99久久99久国产黄毛片| 久久永久免费精品人妻专区| 91亚洲精品干熟女蜜桃频道| 亚洲1069综合男同| 亚洲午夜电影之麻豆| 天天射夜夜操综合网| 色噜噜噜噜18禁止观看| 日韩av有码一区二区三区4| av中文字幕国产在线观看| 成人18禁网站在线播放| 男生用鸡操女生视频动漫| 国产精品久久久久久久女人18| 18禁污污污app下载| 亚洲av日韩高清hd| 美洲精品一二三产区区别| 婷婷久久久综合中文字幕| 新97超碰在线观看| 午夜成午夜成年片在线观看| 又粗又硬又猛又黄免费30| 欧美日韩精品永久免费网址| 成人蜜桃美臀九一一区二区三区| 中文 成人 在线 视频| 十八禁在线观看地址免费| 天天射夜夜操综合网| 亚洲中文字幕人妻一区| 日韩三级电影华丽的外出| 97年大学生大白天操逼| 在线视频国产欧美日韩| 欧美日韩国产一区二区三区三州 | 亚洲av黄色在线网站| 自拍偷拍亚洲精品第2页| 老有所依在线观看完整版| 全国亚洲男人的天堂| 国产精品久久综合久久| 成熟丰满熟妇高潮xx×xx| 亚洲专区激情在线观看视频| 亚洲av日韩av第一区二区三区| 啪啪啪啪啪啪啪啪av| 亚洲伊人av天堂有码在线| 夜夜嗨av蜜臀av| 888欧美视频在线| 日韩人妻在线视频免费| 五十路熟女av天堂| 北条麻妃高跟丝袜啪啪| 在线视频自拍第三页| 青青在线视频性感少妇和隔壁黑丝 | 91亚洲手机在线视频播放| 天天插天天色天天日| 中文亚洲欧美日韩无线码| 不卡一区一区三区在线| 天天干天天操天天扣| 丁香花免费在线观看中文字幕| 天天操天天射天天操天天天| 91国产在线视频免费观看| 亚洲精品中文字幕下载| 91综合久久亚洲综合| 最新91九色国产在线观看| 亚洲国产美女一区二区三区软件| 自拍偷拍日韩欧美亚洲| 在线观看视频一区麻豆| 日韩中文字幕福利av| 九色视频在线观看免费| 欧美一级视频一区二区| 国产高潮无码喷水AV片在线观看| 中文字幕高清在线免费播放| 精品亚洲中文字幕av| 岛国一区二区三区视频在线| 91精品国产麻豆国产| 亚洲另类综合一区小说| 午夜蜜桃一区二区三区| 99热99这里精品6国产| 青青青青青青青青青青草青青| 欧美性受xx黑人性猛交| 日本韩国免费一区二区三区视频 | 一区二区三区日韩久久| 日比视频老公慢点好舒服啊| 丝袜长腿第一页在线| 成人sm视频在线观看| 亚洲国产欧美国产综合在线| 好吊操视频这里只有精品| 成人在线欧美日韩国产| 国产精品入口麻豆啊啊啊 | 91精品国产高清自在线看香蕉网| nagger可以指黑人吗| 人妻激情图片视频小说| 91国产在线视频免费观看| 91 亚洲视频在线观看| 日本人妻精品久久久久久| 做爰视频毛片下载蜜桃视频1| 大屁股熟女一区二区三区| 性色蜜臀av一区二区三区| 99精品免费久久久久久久久a| 91精品国产91久久自产久强| 国产成人精品av网站| 亚洲嫩模一区二区三区| 中文字幕免费福利视频6| 视频一区二区三区高清在线| 日韩中文字幕在线播放第二页| 在线免费观看欧美小视频| 97超碰人人搞人人| 中文乱理伦片在线观看| 18禁精品网站久久| av大全在线播放免费| 亚洲综合另类精品小说| 性欧美激情久久久久久久| 久草视频首页在线观看| 好男人视频在线免费观看网站| 大香蕉伊人中文字幕| 动漫美女的小穴视频| 久久精品亚洲成在人线a| 男大肉棒猛烈插女免费视频| 国产午夜亚洲精品麻豆| 一区二区三区四区视频在线播放| 国产精品视频欧美一区二区| 欧美老鸡巴日小嫩逼| 高清一区二区欧美系列| 狠狠躁夜夜躁人人爽天天天天97| 人人超碰国字幕观看97| 欧美黑人与人妻精品| 男女啪啪啪啪啪的网站| 午夜精品一区二区三区福利视频| 亚洲免费av在线视频| 亚洲国际青青操综合网站| 免费看国产av网站| 青青青青青青青在线播放视频| 一区二区三区麻豆福利视频| 亚洲图库另类图片区| 五月精品丁香久久久久福利社| 久久久久久性虐视频| 日曰摸日日碰夜夜爽歪歪| 久久久久久久精品老熟妇| 婷婷久久一区二区字幕网址你懂得| 亚洲区欧美区另类最新章节| 岛国一区二区三区视频在线| 亚洲综合乱码一区二区| 亚洲最大免费在线观看| av中文字幕电影在线看| 最新91精品视频在线| 欧美男人大鸡吧插女人视频| 午夜精品在线视频一区| 国产麻豆剧果冻传媒app| 美女视频福利免费看| 男人插女人视频网站| 综合精品久久久久97| 孕妇奶水仑乱A级毛片免费看| 少妇系列一区二区三区视频| 日本少妇人妻xxxxx18| av老司机精品在线观看| 啊慢点鸡巴太大了啊舒服视频| 在线免费观看视频一二区| 啊啊啊想要被插进去视频| 日韩美女综合中文字幕pp| 一区二区三区av高清免费| 日韩黄色片在线观看网站| 久久精品亚洲国产av香蕉| 蜜臀av久久久久蜜臀av麻豆| 日本欧美视频在线观看三区| 老司机免费福利视频网| 中国黄色av一级片| 沈阳熟妇28厘米大战黑人| 国产精品亚洲а∨天堂免| 欧美老妇精品另类不卡片| 亚洲成人激情av在线| 北条麻妃肉色丝袜视频| 一区二区三区久久中文字幕| 欧美少妇性一区二区三区| 日韩三级电影华丽的外出| 丝袜长腿第一页在线| 亚洲熟女女同志女同| 天天爽夜夜爽人人爽QC| 天天射夜夜操综合网| 一级黄片大鸡巴插入美女| 夜夜躁狠狠躁日日躁麻豆内射 | 国产成人精品av网站| 亚洲图库另类图片区| 一色桃子人妻一区二区三区| 视频 一区二区在线观看| 青青草视频手机免费在线观看| 亚洲午夜高清在线观看| 国产美女一区在线观看| 亚洲一区二区三区五区| 75国产综合在线视频| 欧美韩国日本国产亚洲| wwwxxx一级黄色片| 国产福利小视频二区| av大全在线播放免费| 青青青青青免费视频| 亚洲熟妇x久久av久久| 大鸡吧插逼逼视频免费看| 亚洲伊人久久精品影院一美女洗澡| av视网站在线观看| 99热久久极品热亚洲| 日本熟妇一区二区x x| 亚洲护士一区二区三区| 91人妻精品一区二区在线看| 久久免看30视频口爆视频| 亚洲精品欧美日韩在线播放| 成人av亚洲一区二区| 熟女人妻一区二区精品视频| 国产一区二区视频观看| 亚洲第一黄色在线观看| 五十路息与子猛烈交尾视频| 偷青青国产精品青青在线观看| 国产精品国产三级国产精东| 日韩美女搞黄视频免费| 专门看国产熟妇的网站| h国产小视频福利在线观看| 久久国产精品精品美女| 在线观看欧美黄片一区二区三区| 熟女妇女老妇一二三区| 黑人进入丰满少妇视频| 国产欧美精品免费观看视频| 不卡精品视频在线观看| 少妇人妻真实精品视频| av俺也去在线播放| 欧美亚洲偷拍自拍色图| 国产精品视频欧美一区二区| 亚洲精品一区二区三区老狼| 日韩av熟妇在线观看| 国产普通话插插视频| 农村胖女人操逼视频| 国产亚洲成人免费在线观看| 国产一级精品综合av| 日韩二区视频一线天婷婷五| 日本免费视频午夜福利视频| 欧美成人黄片一区二区三区| 免费十精品十国产网站| 中文字幕亚洲久久久| 不卡精品视频在线观看| 91she九色精品国产| 亚洲午夜福利中文乱码字幕| 99热国产精品666| 国产精选一区在线播放| 日本一区二区三区免费小视频| 小泽玛利亚视频在线观看| 精品亚洲在线免费观看| 免费福利av在线一区二区三区| 久久丁香花五月天色婷婷| 中文字幕日韩精品就在这里| 毛片av在线免费看| 天天想要天天操天天干| 五十路老熟女码av| 把腿张开让我插进去视频| 欧美亚洲自偷自拍 在线| 亚洲公开视频在线观看| 久久这里只有精品热视频| 中文字幕人妻三级在线观看| 午夜婷婷在线观看视频| 亚洲日本一区二区三区| 天天插天天色天天日| 91九色国产熟女一区二区| av天堂中文免费在线| 大屁股肉感人妻中文字幕在线| 免费在线看的黄网站| 91综合久久亚洲综合| 四川乱子伦视频国产vip| 欧美女同性恋免费a| 蜜桃精品久久久一区二区| 自拍偷拍日韩欧美亚洲| 五月色婷婷综合开心网4438| 精品一区二区三四区| 天天干夜夜操天天舔| 亚洲女人的天堂av| 精品乱子伦一区二区三区免费播 | 天天摸天天亲天天舔天天操天天爽| 99精品国自产在线人| 天天想要天天操天天干| 亚洲黄色av网站免费播放| 无套猛戳丰满少妇人妻| 久久精品国产23696| 四川五十路熟女av| 国产之丝袜脚在线一区二区三区| 精品一区二区三区三区色爱| 日本一道二三区视频久久 | 在线国产精品一区二区三区| 亚洲免费成人a v| 亚洲 欧美 自拍 偷拍 在线| 青青青aaaa免费| 人妻熟女在线一区二区| 蜜臀av久久久久蜜臀av麻豆| 日韩精品电影亚洲一区| 国产第一美女一区二区三区四区| 亚洲av日韩精品久久久| 在线播放国产黄色av| 午夜国产福利在线观看| 手机看片福利盒子日韩在线播放| 午夜在线观看岛国av,com|