日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

使用数据库实现缓存功能

發布時間:2024/3/24 数据库 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 使用数据库实现缓存功能 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

編寫目的

在某些特殊的項目中,想實現緩存,但是不能使用中間件,存內存又會導致內存大幅度上升,怎么辦呢?

降低預期,將需要緩存的數據存儲在數據庫,如何設計一套數據庫緩存呢。

設計思路

一個KV形式緩存中間件需要有哪些基礎功能?

  • 1、增加緩存(新增數據庫)
  • 2、緩存覆蓋(修改數據庫)
  • 3、緩存過期刪除(刪除數據庫數據)
  • 4、查詢緩存(查詢數據庫)

其實,就是對數據庫的增刪改查。但是緩存的數據一般情況是寫入和查詢比較頻繁的。

  • 查詢優化: 在字段KEY上建立唯一索引
  • 插入優化:使用隊列 + 定時任務異步入庫
  • 緩存覆蓋:使用隊列 + 定時任務異步更新
  • 過期刪除:使用隊列 + 定時任務異步刪除

表設計

主鍵,緩存KEY(唯一索引), 緩存值 , 過期時間

create table data_common_cache (cache_id bigint auto_increment comment '主鍵,生成序列號Id' primary key,cache_key varchar(100) not null comment '緩存的key 長度100 超過100的話通過編碼后縮短',cache_value text default null comment '緩存的值',cache_expire datetime default null comment '過期時間',constraint udx_cache_key unique (cache_key) ) comment '通用緩存表';

功能實現

使用SpringBoot + Mybatis Plus 實現通用緩存功能

依賴引入

<properties><java.version>1.8</java.version><mybatis-plus.version>3.4.0</mybatis-plus.version><mybatis-plus-generator.version>3.3.2</mybatis-plus-generator.version> </properties> <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><optional>true</optional></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><!--mybatis-plus--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>${mybatis-plus.version}</version></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-generator</artifactId><version>${mybatis-plus-generator.version}</version></dependency><!--mybatis-plus模板生成--><dependency><groupId>org.apache.velocity</groupId><artifactId>velocity-engine-core</artifactId><version>2.2</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.35</version></dependency><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>30.0-jre</version></dependency> </dependencies>

配置文件

server:port: 8081spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverjdbc-url: jdbc:mysql://localhost:3306/test_db?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=UTF-8&autoReconnect=trueusername: rootpassword: root

生成entity, mapper

實體類

@Data @EqualsAndHashCode(callSuper = false) @Accessors(chain = true) public class DataCommonCache implements Serializable {private static final long serialVersionUID=1L;/*** 主鍵,生成序列號Id*/@TableId(value = "cache_id", type = IdType.AUTO)private Long cacheId;/*** 緩存的key 長度100 超過100的話通過編碼后縮短*/private String cacheKey;/*** 緩存的值*/private String cacheValue;/*** 過期時間*/private Date cacheExpire; }

mapper, 包含自定義SQL

@Mapper public interface DataCommonCacheMapper extends BaseMapper<DataCommonCache> {/*** 根據緩存key查詢緩存ID 如果ID為空 表示緩存不存在 不為空表示緩存存在* @param cacheKey 緩存key* @return 緩存的ID, 過期時間 為空表示緩存不存在*/DataCommonCache selectIdByKey(@Param("cacheKey") String cacheKey);/*** 根據緩存key查詢緩存ID 如果ID為空 表示緩存不存在 不為空表示緩存存在* @param cacheKey 緩存key* @return 緩存的ID, 過期時間,緩存值 為空表示緩存不存在*/DataCommonCache selectByKey(@Param("cacheKey") String cacheKey);/*** 根據緩存key查詢緩存ID 如果ID為空 表示緩存不存在 不為空表示緩存存在* @param cacheKey 緩存key* @return 緩存的ID 為空表示*/String selectValueByKey(@Param("cacheKey") String cacheKey);/*** 根據緩存key刪除數據* @param cacheKey 緩存key*/int deleteByCacheKey(@Param("cacheKey") String cacheKey); }

mapper.xml

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.itdl.mapper.DataCommonCacheMapper"><delete id="deleteByCacheKey" parameterType="java.lang.String">delete from data_common_cache where cache_key = #{cacheKey}</delete><!--根據緩存key獲取緩存信息,主要包含緩存ID和過期時間 結果為空表示沒有數據--><select id="selectIdByKey" parameterType="string" resultType="com.itdl.entity.DataCommonCache">select cache_id, cache_expire from data_common_cache where cache_key = #{cacheKey} limit 1</select><!--包含緩存值--><select id="selectByKey" parameterType="string" resultType="com.itdl.entity.DataCommonCache">select cache_id, cache_value, cache_expire from data_common_cache where cache_key = #{cacheKey} limit 1</select><!--根據緩存的key獲取緩存的值--><select id="selectValueByKey" parameterType="string" resultType="java.lang.String">select cache_value from data_common_cache where cache_key = #{cacheKey} limit 1</select> </mapper>

整合MybatisPlus

整合MybatisPlus用于增刪改差, 并實現了MybtaisPlus真正的批量新增和批量修改

數據源配置類DatasourceConfig

包含了數據源的配置和SqlSessionFactory配置,且注入了MybatisPlus的配置

/*** @Description 數據庫相關配置* @Author itdl* @Date 2022/08/10 09:20*/ @Configuration @MapperScan(basePackages = "com.itdl.mapper", sqlSessionFactoryRef = "sqlSessionFactory") public class DatasourceConfig {@Bean(name = "dataSource")@ConfigurationProperties(prefix = "spring.datasource")public DataSource dataSource() throws SQLException {return DataSourceBuilder.create().build();}@Bean("easySqlInjector")public EasySqlInjector easySqlInjector() {return new EasySqlInjector();}@Beanpublic GlobalConfig globalConfig(EasySqlInjector easySqlInjector){GlobalConfig globalConfig = new GlobalConfig();globalConfig.setSqlInjector(easySqlInjector);return globalConfig;}@Bean(name = "sqlSessionFactory")public SqlSessionFactory sqlSessionFactory(@Qualifier("dataSource") DataSource dataSource, GlobalConfig globalConfig) throws Exception {MybatisSqlSessionFactoryBean sessionFactoryBean = new MybatisSqlSessionFactoryBean();sessionFactoryBean.setDataSource(dataSource);sessionFactoryBean.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath*:mapper/**/*.xml"));sessionFactoryBean.setPlugins(new PaginationInterceptor());//添加自定義sql注入接口sessionFactoryBean.setGlobalConfig(globalConfig);//添加自定義sql注入接口return sessionFactoryBean.getObject();}}

Mybatis 批量插入/更新配置

public class EasySqlInjector extends DefaultSqlInjector {@Overridepublic List<AbstractMethod> getMethodList(Class<?> mapperClass) {List<AbstractMethod> methodList = super.getMethodList(mapperClass);methodList.add(new InsertBatchSomeColumn());methodList.add(new UpdateBatchMethod());return methodList;}}/*** 批量更新方法實現,條件為主鍵,選擇性更新*/ @Slf4j public class UpdateBatchMethod extends AbstractMethod {@Overridepublic MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {String sql = "<script>\n<foreach collection=\"list\" item=\"item\" separator=\";\">\nupdate %s %s where %s=#{%s} %s\n</foreach>\n</script>";String additional = tableInfo.isWithVersion() ? tableInfo.getVersionFieldInfo().getVersionOli("item", "item.") : "" + tableInfo.getLogicDeleteSql(true, true);String setSql = sqlSet(false, false, tableInfo, false, "item", "item.");String sqlResult = String.format(sql, tableInfo.getTableName(), setSql, tableInfo.getKeyColumn(), "item." + tableInfo.getKeyProperty(), additional);//log.debug("sqlResult----->{}", sqlResult);SqlSource sqlSource = languageDriver.createSqlSource(configuration, sqlResult, modelClass);// 第三個參數必須和RootMapper的自定義方法名一致return this.addUpdateMappedStatement(mapperClass, modelClass, "updateBatch", sqlSource);} }

緩存實現

實現思路

  • 1、配置一個可調度的線程池,用于異步隊列的調度
  • 2、編寫一個基礎調度父類,實現調度的基本邏輯
  • 3、編寫緩存插入,覆蓋,刪除的調度邏輯
  • 4、將調度邏輯整合為一個緩存工具類
  • 5、使用Controller接口測試緩存增刪改查

配置可調度的線程池

/*** @Description 通用配置及* @Author itdl* @Date 2022/08/09 17:57*/ @Configuration public class CommonConfig {@Bean("scheduledThreadPoolExecutor")public ScheduledThreadPoolExecutor scheduledThreadPoolExecutor() {//線程名String threadNameStr = "統一可調度線程-%d";//線程工廠類就是將一個線程的執行單元包裝成為一個線程對象,比如線程的名稱,線程的優先級,線程是否是守護線程等線程;// guava為了我們方便的創建出一個ThreadFactory對象,我們可以使用ThreadFactoryBuilder對象自行創建一個線程.ThreadFactory threadNameVal = new ThreadFactoryBuilder().setNameFormat(threadNameStr).build();// 單線程池return new ScheduledThreadPoolExecutor(// 核心線程池4,// 最大線程池threadNameVal,// 使用策略為拋出異常new ThreadPoolExecutor.AbortPolicy());} }

編寫可調度的公共父類,實現調度的基本邏輯

@Slf4j public abstract class BaseCacheHelper<T> {@Resourceprivate ScheduledThreadPoolExecutor scheduledThreadPoolExecutor;// 隊列private final BlockingQueue<T> QUEUE = new ArrayBlockingQueue<>(1024);// listener執行次數 計數器private final AtomicInteger EXECUTE_COUNT = new AtomicInteger();// 事件集合private final List<T> eventStorageList = Collections.synchronizedList(new ArrayList<>());/*** 判斷隊列是否為空*/public boolean checkQueueIsEmpty() {return QUEUE.isEmpty();}/*** 入隊方法* @param datas 批量入隊*/public void producer(List<T> datas) {for (T data : datas) {producer(data);}}/*** 入隊方法* @param data 單個入隊*/public void producer(T data) {try {if (QUEUE.contains(data)){return;}// 入隊 滿了則等待QUEUE.put(data);} catch (InterruptedException e) {e.printStackTrace();}log.info("================>>>通用隊列:{}:當前隊列存在數據:{}", this.getClass().getName(), QUEUE.size());}@PostConstructpublic void consumer() {scheduledThreadPoolExecutor.scheduleAtFixedRate(() -> {try {// 隊列數量達到指定消費批次數量if (EXECUTE_COUNT.get() >= getBatchSize()) {doConsumer();} else {while (EXECUTE_COUNT.get() < getBatchSize() && QUEUE.size() != 0) {// 加入事件final T take = QUEUE.take();eventStorageList.add(take);EXECUTE_COUNT.incrementAndGet();}// 隊列為空了 同樣需要處理,及時沒有滿if (EXECUTE_COUNT.get() < getBatchSize() && QUEUE.size() == 0) {doConsumer();}}} catch (InterruptedException e) {e.printStackTrace();}}, 3000, getPeriodTime(), TimeUnit.MILLISECONDS);}/*** 消費數據*/protected void doConsumer() {// 這里面開始真正的寫磁盤if (ObjectUtils.isEmpty(eventStorageList)) {return;}// 批處理final StopWatch stopWatch = new StopWatch();stopWatch.start();log.info("=========>>>>消費數據{}條", eventStorageList.size());for (T t : eventStorageList) {StopWatch subStopWatch = new StopWatch();subStopWatch.start();// 處理每一個消費者的邏輯 用于子類實現doHandleOne(t);subStopWatch.stop();}// 重置數據EXECUTE_COUNT.set(0);eventStorageList.clear();stopWatch.stop();log.info("=========>>>>通用隊列:{}:消費完成,總耗時:{}s<<<<=========", this.getClass().getName(), String.format("%.4f", stopWatch.getTotalTimeSeconds()));}/*** 消費一條數據** @param data 處理數據*/protected abstract void doHandleOne(T data);/*** 批次大小 默認每次消費100條** @return 此次大小*/protected Integer getBatchSize() {return 100;}/*** 批次大小 執行完任務后 間隔多久再執行 單位 毫秒 默認5秒** @return 此次大小*/protected Integer getPeriodTime() {return 1000;} }

增刪改調度任務實現

@Slf4j @Component public class DbCacheHelper{@Slf4j@Componentpublic static class InsertCache extends BaseCacheHelper<DataCommonCache>{@Autowiredprivate DataCommonCacheMapper dataCommonCacheMapper;@Overrideprotected void doHandleOne(DataCommonCache data) {final String cacheKey = data.getCacheKey();log.info("=====================開始插入緩存數據cacheKey:{}===========================", cacheKey);try {dataCommonCacheMapper.insert(data);} catch (Exception e) {log.error("=======>>>>插入緩存數據失敗:{}", e.getMessage());e.printStackTrace();}log.info("=====================完成插入緩存數據cacheKey:{}===========================", cacheKey);}}@Slf4j@Componentpublic static class UpdateCache extends BaseCacheHelper<DataCommonCache>{@Autowiredprivate DataCommonCacheMapper dataCommonCacheMapper;@Overrideprotected void doHandleOne(DataCommonCache data) {final String cacheKey = data.getCacheKey();log.info("=====================開始覆蓋寫入緩存數據cacheKey:{}===========================", cacheKey);try {dataCommonCacheMapper.updateById(data);} catch (Exception e) {log.error("=======>>>>覆蓋寫入緩存數據失敗:{}", e.getMessage());e.printStackTrace();}log.info("=====================完成覆蓋寫入緩存數據cacheKey:{}===========================", cacheKey);}}@Slf4j@Componentpublic static class DeleteCache extends BaseCacheHelper<String>{@Autowiredprivate DataCommonCacheMapper dataCommonCacheMapper;@Overrideprotected void doHandleOne(String cacheKey) {log.info("=====================開始刪除緩存數據cacheKey:{}===========================", cacheKey);try {dataCommonCacheMapper.deleteByCacheKey(cacheKey);} catch (Exception e) {log.error("=======>>>>刪除緩存數據失敗:{}", e.getMessage());e.printStackTrace();}log.info("=====================完成刪除寫入緩存數據cacheKey:{}===========================", cacheKey);}} }

緩存工具類編寫

在工具類里面實現緩存的邏輯

新增緩存思路

  • 1、根據緩存key查詢緩存ID和過期時間
  • 2、結果為空,表示沒有緩存,發送數據到緩存隊列,等待新增緩存隊列任務調度
  • 3、結果不為空,繼續判斷過期時間,過期時間不為空,并且已經過期了,則發送到過期刪除隊列,等待調度
  • 4、沒有過期,真正查詢緩存的值, 比較值是是否更新,更新了發送更新數據到更新隊列,沒更新則不管

查詢緩存思路

  • 1、根據緩存key查詢數據(包含緩存值)
  • 2、結果為空,表示緩存不存在,直接返回null
  • 3、結果不為空,判斷是否過期,過期則發送過期刪除到刪除隊列
  • 4、返回查詢結果

刪除緩存思路

  • 1、根據緩存key查詢數據(不包含緩存值)
  • 2、為空則不需要刪除,不為空發送到刪除隊列,等待調度

代碼實現

@Component @Slf4j public class DbCacheUtil {@Autowiredprivate DataCommonCacheMapper dataCommonCacheMapper;@Autowiredprivate DbCacheHelper.InsertCache insertCache;@Autowiredprivate DbCacheHelper.UpdateCache updateCache;@Autowiredprivate DbCacheHelper.DeleteCache deleteCache;/*** 插入緩存數據* @param cacheKey 緩存key* @param cacheValue 緩存值* @param ttl 單位毫秒 緩存失效時間 小于0表示永不過期*/public synchronized void putCache(String cacheKey, String cacheValue, long ttl){// 根據緩存key查詢緩存 ID/過期時間等final DataCommonCache cache = dataCommonCacheMapper.selectIdByKey(cacheKey);if (cache == null){// 新增數據DataCommonCache commonCache = buildInsertData(cacheKey, cacheValue, ttl);// 發送給入庫隊列insertCache.producer(commonCache);return;}// 緩存設置了過期時間 并且緩存國企時間比當前時間小(過期了)if (cache.getCacheExpire() != null && cache.getCacheExpire().getTime() < System.currentTimeMillis()){// 發送刪除過期Key隊列deleteCache.producer(cacheKey);return;}// 都不是 表示需要覆蓋緩存 也就是更新緩存// 先判斷緩存的值是否和數據庫的值一致 一致則無需覆蓋final String cacheValueResult = dataCommonCacheMapper.selectValueByKey(cacheKey);if (StringUtils.equals(cacheValueResult, cacheValue)){log.info("=============>>>>緩存key:{}的value與數據庫一致,無需覆蓋", cacheValue);return;}// 發送一個覆蓋的請求final DataCommonCache dataCommonCache = buildInsertData(cacheKey, cacheValue, ttl);dataCommonCache.setCacheId(cache.getCacheId());updateCache.producer(dataCommonCache);}/*** 根據緩存從數據庫查詢* @param cacheKey 緩存key* @return 緩存值cacheValue 這里返回的值可能是已過期的 知道過期key刪除之后才會返回新的數據*/public synchronized String getCache(String cacheKey){// 根據緩存key查詢緩存 ID/過期時間等final DataCommonCache cache = dataCommonCacheMapper.selectByKey(cacheKey);if (cache == null){log.info("===========緩存不存在, 請請先調用putCache緩存===========");return null;}// 緩存設置了過期時間 并且緩存國企時間比當前時間小(過期了)if (cache.getCacheExpire() != null && cache.getCacheExpire().getTime() < System.currentTimeMillis()){// 發送刪除過期Key隊列deleteCache.producer(cacheKey);// 等待異步線程處理刪除過期,但是這里還是返回緩存數據,從而減少數據庫的壓力,直到緩存刪除后再次查詢到結果在返回}log.info("================命中緩存cacheKey為:{}=================", cacheKey);// 不為空,返回數據庫return cache.getCacheValue();}/*** 根據key刪除緩存* @param cacheKey 緩存key*/public synchronized void deleteCache(String cacheKey){// 根據緩存key查詢緩存 ID/過期時間等final DataCommonCache cache = dataCommonCacheMapper.selectIdByKey(cacheKey);if (cache == null){log.info("===========緩存不存在 無需刪除===========");return;}// 發送刪除消息到隊列deleteCache.producer(cacheKey);}private DataCommonCache buildInsertData(String cacheKey, String cacheValue, long ttl) {final DataCommonCache commonCache = new DataCommonCache();commonCache.setCacheKey(cacheKey);commonCache.setCacheValue(cacheValue);// 失效時間為當前是時間 + ttl時間Date expireTime = null;if (ttl > 0){expireTime = new Date(System.currentTimeMillis() + ttl);}commonCache.setCacheExpire(expireTime);return commonCache;} }

緩存測試接口

@RestController @RequestMapping("/dbCache") public class DbCacheController {@Autowiredprivate DbCacheUtil dbCacheUtil;/**緩存時間設置為5分鐘, 可以自行設置*/private static final Long ttl = 300 * 1000L;@GetMapping("/test/putCache")public String putCache(@RequestParam("cacheKey") String cacheKey, @RequestParam("cacheValue") String cacheValue){dbCacheUtil.putCache(cacheKey, cacheValue, ttl);return "success";}@GetMapping("/test/getCache")public String getCache(@RequestParam("cacheKey") String cacheKey){return dbCacheUtil.getCache(cacheKey);}@GetMapping("/test/deleteCache")public String deleteCache(@RequestParam("cacheKey") String cacheKey){dbCacheUtil.deleteCache(cacheKey);return "success";} }

接口測試

新增接口:http://localhost:8081/dbCache/test/putCache?cacheKey=test_name&cacheValue=張三

查詢接口:http://localhost:8081/dbCache/test/getCache?cacheKey=test_name

刪除接口:http://localhost:8081/dbCache/test/deleteCache?cacheKey=test_name

測試結果

2022-08-10 09:31:36.699 INFO 19572 --- [nio-8081-exec-2] com.itdl.cache.util.DbCacheUtil : ===========緩存不存在, 請請先調用putCache緩存=========== 2022-08-10 09:31:39.815 INFO 19572 --- [nio-8081-exec-3] com.itdl.cache.BaseCacheHelper : ================>>>通用隊列:com.itdl.cache.DbCacheHelper$InsertCache:當前隊列存在數據:1 2022-08-10 09:31:40.812 INFO 19572 --- [ 統一可調度線程-1] com.itdl.cache.BaseCacheHelper : =========>>>>消費數據1條 2022-08-10 09:31:40.813 INFO 19572 --- [ 統一可調度線程-1] c.itdl.cache.DbCacheHelper$InsertCache : =====================開始插入緩存數據cacheKey:test_name=========================== 2022-08-10 09:31:40.851 INFO 19572 --- [ 統一可調度線程-1] c.itdl.cache.DbCacheHelper$InsertCache : =====================完成插入緩存數據cacheKey:test_name=========================== 2022-08-10 09:31:40.852 INFO 19572 --- [ 統一可調度線程-1] com.itdl.cache.BaseCacheHelper : =========>>>>通用隊列:com.itdl.cache.DbCacheHelper$InsertCache:消費完成,總耗時:0.0383s<<<<========= 2022-08-10 09:31:42.296 INFO 19572 --- [nio-8081-exec-4] com.itdl.cache.util.DbCacheUtil : ================命中緩存cacheKey為:test_name================= 2022-08-10 10:18:51.256 INFO 19572 --- [nio-8081-exec-8] com.itdl.cache.BaseCacheHelper : ================>>>通用隊列:com.itdl.cache.DbCacheHelper$DeleteCache:當前隊列存在數據:1 2022-08-10 10:18:51.882 INFO 19572 --- [ 統一可調度線程-1] com.itdl.cache.BaseCacheHelper : =========>>>>消費數據1條 2022-08-10 10:18:51.882 INFO 19572 --- [ 統一可調度線程-1] c.itdl.cache.DbCacheHelper$DeleteCache : =====================開始刪除緩存數據cacheKey:test_name=========================== 2022-08-10 10:18:51.890 INFO 19572 --- [ 統一可調度線程-1] c.itdl.cache.DbCacheHelper$DeleteCache : =====================完成刪除寫入緩存數據cacheKey:test_name=========================== 2022-08-10 10:18:51.890 INFO 19572 --- [ 統一可調度線程-1] com.itdl.cache.BaseCacheHelper : =========>>>>通用隊列:com.itdl.cache.DbCacheHelper$DeleteCache:消費完成,總耗時:0.0079s<<<<========= 2022-08-10 10:19:01.817 INFO 19572 --- [nio-8081-exec-9] com.itdl.cache.util.DbCacheUtil : ===========緩存不存在, 請請先調用putCache緩存===========

項目地址

https://github.com/HedongLin123/db-cache-demo.git

總結

以上是生活随笔為你收集整理的使用数据库实现缓存功能的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

婷婷中文在线 | 久久精品www人人爽人人 | 五月婷婷激情综合网 | 久久tv| 亚洲美女视频在线 | 免费合欢视频成人app | 四季av综合网站 | 久久国产亚洲精品 | 91视频久久久 | 91av视频导航 | 国产精品视频在线观看 | 久久视频这里有精品 | 国产裸体视频网站 | va视频在线观看 | 亚洲1区 在线| 久久精品79国产精品 | 国产精品色婷婷视频 | 色99之美女主播在线视频 | 91一区啪爱嗯打偷拍欧美 | 人人插人人做 | 久久久免费电影 | 狠狠干狠狠色 | 亚洲国产精品久久久久 | 一级黄色在线视频 | 国产成人免费在线观看 | 国产精品成人久久久 | 国产福利专区 | 国产96在线| 色婷婷丁香 | 99精品在线看 | 懂色av一区二区三区蜜臀 | 国产特级毛片aaaaaaa高清 | 国产系列 在线观看 | 波多野结衣视频在线 | 国产视频美女 | 1000部国产精品成人观看 | 国产偷v国产偷∨精品视频 在线草 | 日韩激情在线 | 久草久热 | 天天干天天做 | 免费av成人在线 | 国产精品理论片在线播放 | 国产美女视频网站 | 国产免费黄视频在线观看 | 91完整版在线观看 | 成人九九视频 | 免费在线看成人av | 亚洲伊人婷婷 | 国产久草在线观看 | 国产永久网站 | 免费黄色小网站 | 久久66热这里只有精品 | 激情婷婷综合网 | 尤物九九久久国产精品的分类 | 天天操狠狠操网站 | 亚洲精品欧美精品 | 中文超碰字幕 | a黄色大片 | 日韩免费在线观看视频 | 精品一区二区在线观看 | 91精品专区 | 超碰97国产精品人人cao | 狠狠色噜噜狠狠狠狠2021天天 | 亚洲精品高清一区二区三区四区 | av高清一区 | 精品久久久久久久久久久久久久久久 | 日韩欧美国产精品 | 久一在线 | www.69xx| 国产又粗又硬又长又爽的视频 | 在线观看av网站 | 精品电影一区二区 | jizzjizzjizz亚洲| 久草视频免费在线播放 | 国产视频一区二区三区在线 | 成人动漫一区二区 | 色婷婷综合久久久 | 欧美日韩国产一区二区在线观看 | 91成人精品| 国产91学生粉嫩喷水 | 国产精品无 | 亚洲在线网址 | 综合影视 | 91日韩免费 | 精品福利在线视频 | 中文字幕在线观看2018 | 午夜少妇 | av免费电影在线观看 | 91av视频在线观看 | 玖玖爱国产在线 | 西西www4444大胆视频 | 亚洲欧美在线视频免费 | 99久久免费看 | 久久久久成人精品亚洲国产 | 中文字幕在线观看第一区 | 日韩高清无线码2023 | 亚洲亚洲精品在线观看 | 国产黄| 久草观看 | 久久久精品国产一区二区电影四季 | 一区二区三区在线免费观看视频 | 日日夜夜中文字幕 | 欧美另类视频 | 亚洲乱码中文字幕综合 | 久久国产高清视频 | 中文字幕av免费 | 色偷偷人人澡久久超碰69 | 91在线免费观看国产 | 免费在线a| 中文字幕在线字幕中文 | 五月婷婷影院 | 日韩欧美一区二区在线播放 | 在线视频18在线视频4k | 中文字幕在线久一本久 | 日本在线成人 | 国产二级视频 | 日日综合网 | 国产99久久久国产精品 | 国产精品免费在线观看视频 | 99热最新精品 | 久草视频中文 | 少妇bbb搡bbbb搡bbbb | 日本中文乱码卡一卡二新区 | 97超级碰碰碰碰久久久久 | 免费视频网 | 激情电影影院 | 偷拍区另类综合在线 | 最新中文字幕在线观看视频 | 国产黑丝袜在线 | 在线观看免费黄视频 | 草久草久 | 狠狠狠狠狠狠狠 | 国产精品久久久电影 | 一区二区中文字幕在线观看 | 欧美黑人性爽 | 人人揉人人揉人人揉人人揉97 | 五月婷婷激情六月 | 国产剧在线观看片 | 天堂网av 在线 | 国产精品欧美一区二区 | 超碰成人网 | 免费看的视频 | 中文不卡视频 | 国产区av在线 | 亚洲国产精品一区二区尤物区 | 波多野结衣小视频 | 国产91免费看 | www.伊人网 | 久久久久久美女 | 日韩精品久久一区二区 | 日韩va在线观看 | www日日 | 国产精品一区二区久久久 | 日韩av片无码一区二区不卡电影 | 精品女同一区二区三区在线观看 | 亚洲伊人av | av在线永久免费观看 | 国产精品乱码久久久久 | 国产一区二区电影在线观看 | 日韩激情免费视频 | 欧美日韩高清国产 | 国产日韩视频在线播放 | 免费视频久久久 | 日本大尺码专区mv | 婷婷色网视频在线播放 | 久久久久免费视频 | 成人精品国产免费网站 | 婷婷中文在线 | 久久精品一二三区 | 日韩一区二区免费视频 | 国产福利网站 | 亚洲一区免费在线 | 91x色| 亚洲视频 在线观看 | 欧美精品国产综合久久 | 九九免费精品 | 国产精品国产三级国产专区53 | www.国产在线观看 | 久久成人精品电影 | 日日爽视频 | 日日操夜夜操狠狠操 | 久久人人爽人人爽人人片 | 人人爱人人射 | 久久精品视频18 | 日韩精品在线视频 | 日本久久综合网 | 在线色亚洲 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 欧美成人亚洲 | 综合网色 | 免费h精品视频在线播放 | 天天干天天射天天操 | 亚洲人成网站精品片在线观看 | 国产精品免费看久久久8精臀av | 精品国产自 | 免费在线看v | 超碰97免费观看 | av不卡网站 | 成人在线小视频 | 免费观看丰满少妇做爰 | 韩日三级av| 欧美一区在线观看视频 | 亚洲撸撸 | 波多野结衣视频一区 | 久久99精品国产99久久 | 天天插天天射 | 久久久麻豆精品一区二区 | 午夜体验区 | 日韩在线观看第一页 | 国产原创91 | 超碰人在线| 91丨九色丨高潮丰满 | 久久永久免费视频 | 激情久久网 | 不卡的av在线播放 | 综合网中文字幕 | 国产美女免费看 | 毛片激情永久免费 | 久草精品视频 | 久久午夜精品影院一区 | 久久免费成人网 | 天天色视频 | 黄色小网站免费看 | 久久精品播放 | 色婷婷五 | 久久99热精品这里久久精品 | 日韩精品一区二区三区视频播放 | 中文字幕av一区二区三区四区 | 久久久精品在线观看 | 亚洲精品中文在线观看 | 韩国精品一区二区三区六区色诱 | 波多野结衣视频一区 | 亚洲国产午夜精品 | 天天操天天射天天添 | 婷婷精品国产欧美精品亚洲人人爽 | 亚洲 欧美日韩 国产 中文 | 特级aaa毛片| 久久久国产电影 | 五月激情久久久 | 激情综合网在线观看 | 波多野结衣在线视频免费观看 | 狠狠操操操 | 丁香高清视频在线看看 | av丝袜天堂 | 久热免费在线观看 | 伊人伊成久久人综合网小说 | 在线免费观看视频一区 | 中国精品一区二区 | 国产在线播放一区二区三区 | 视频在线精品 | 国产一级免费观看 | 欧美三级免费 | 日韩videos | 国产精品久久一卡二卡 | 久草在线| 操天天操 | 日本中文字幕在线观看 | 久久99精品国产99久久6尤 | 96精品在线 | 国产精品久久久久久69 | 操高跟美女| 国产国产人免费人成免费视频 | av中文字幕剧情 | 亚洲无吗天堂 | 九色精品免费永久在线 | 国产精品va在线观看入 | 精品久久久久久亚洲综合网 | 天天草天天色 | 国产精品成人一区二区三区 | 最近中文字幕免费大全 | 国产传媒中文字幕 | 美女av电影 | 久久久久久久电影 | 欧美中文字幕第一页 | 黄色av一级 | 黄色在线观看免费 | 欧美日韩久久久 | 人人澡人人澡人人 | 久久综合九色综合久99 | 欧美一级久久久久 | 日日麻批40分钟视频免费观看 | 国产成人精品av在线 | 成人资源网 | 亚洲精品www| 亚洲精品福利在线 | 免费观看国产精品视频 | 国产小视频福利在线 | 九九电影在线 | 久久久久久久免费 | 在线免费观看黄色 | 久久久久国产精品www | 九色91在线| 天天综合网~永久入口 | 亚洲第一区在线播放 | 亚洲成人第一区 | 国产亚洲午夜高清国产拍精品 | av网站手机在线观看 | 国产精品久久久久永久免费看 | 久久免费精品 | 综合久色| 国产亚洲欧美精品久久久久久 | 97超碰超碰久久福利超碰 | 国产精品综合av一区二区国产馆 | 国产 一区二区三区 在线 | 国产精品永久久久久久久www | 成人黄色在线 | 欧美激情综合五月色丁香 | 特级黄色视频毛片 | 欧美一级专区免费大片 | 夜夜躁日日躁 | 亚洲欧美日韩中文在线 | 日女人免费视频 | 免费av大片 | 91视频在线观看免费 | 久久精品国产亚洲a | 亚洲精品乱码久久久久久9色 | 天天操天天操天天 | 97视频免费 | 97视频在线免费播放 | 久久久国产影院 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 久久综合久久综合这里只有精品 | 亚洲免费观看视频 | 亚洲区另类春色综合小说 | 色噜噜日韩精品一区二区三区视频 | 黄网站免费看 | 免费看的av片| 999国产| 成年人在线电影 | 欧美日韩精品免费观看视频 | 午夜免费视频网站 | 久久久久久久久影视 | av中文字幕第一页 | 九九九九免费视频 | 亚洲激情在线观看 | 66av99精品福利视频在线 | 日韩久久久久久久久 | 91av99| 成人小视频在线观看免费 | 国产私拍在线 | 99久久婷婷国产一区二区三区 | 国产精品九九久久99视频 | 超碰在线亚洲 | 伊人天堂网 | 天天综合区| 日韩免费av网址 | 九九九九热精品免费视频点播观看 | 伊人视频 | 处女av在线 | 少妇视频在线播放 | 久久久精品国产一区二区电影四季 | 91插插视频 | 国产91免费在线观看 | av资源网在线播放 | 久久久黄视频 | 久久国产精品99精国产 | 久久桃花网 | 国产中文字幕在线看 | 久久在线 | 最近日本字幕mv免费观看在线 | 偷拍福利视频一区二区三区 | 久久久久久久久久久成人 | 中文字幕欧美日韩va免费视频 | 九九热视频在线免费观看 | 午夜精品福利一区二区三区蜜桃 | 四虎影院在线观看av | 五月天精品视频 | 在线观看视频91 | 天天草天天干天天射 | 国产专区视频在线观看 | 国产精品白浆 | 国产资源免费在线观看 | 又湿又紧又大又爽a视频国产 | 免费视频一级片 | 97超碰资源站 | 久久婷婷五月综合色丁香 | 激情欧美国产 | 最近日韩中文字幕中文 | 色欧美88888久久久久久影院 | 美女一二三区 | 911精品视频 | 久久国产精品免费一区二区三区 | 搡bbbb搡bbb视频 | 四虎影视精品成人 | 国产精品久久久影视 | 亚洲成人免费在线观看 | 伊人国产在线播放 | 911精品美国片911久久久 | 偷拍福利视频一区二区三区 | 97国产精品视频 | 女人18片 | 久久久黄视频 | 97视频人人澡人人爽 | 一区二区不卡在线观看 | 亚洲精色| 亚洲男人天堂2018 | 激情久久久久久久久久久久久久久久 | 成人一区二区三区在线 | 久久久久免费电影 | 久久久久久高潮国产精品视 | 精品久久久久久亚洲 | 久久久国产日韩 | 婷香五月 | 国产黄在线 | 在线免费观看黄 | 国产在线精品视频 | 国产精品破处视频 | 免费黄色在线网站 | www一起操 | 99精品视频在线观看视频 | 中文在线最新版天堂 | 欧美少妇影院 | bbbbb女女女女女bbbbb国产 | 国产精品久久久久久久久久白浆 | 麻豆91在线播放 | 一本大道久久精品懂色aⅴ 五月婷社区 | 亚洲aaa毛片 | 精品高清视频 | bayu135国产精品视频 | 中文字幕成人网 | 91精品一区二区三区久久久久久 | 欧美激情另类文学 | 久久人人爽人人爽人人片av免费 | 国产糖心vlog在线观看 | 不卡av在线免费观看 | 国产青春久久久国产毛片 | 美女精品网站 | 久热免费在线 | 天天干天天摸天天操 | 免费成视频 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 欧洲一区精品 | 91看成人 | 国产一区二区不卡视频 | 五月天堂色 | 日韩一二三区不卡 | 国产一在线精品一区在线观看 | 一区二区三区四区五区在线视频 | 中文字幕乱在线伦视频中文字幕乱码在线 | 96精品高清视频在线观看软件特色 | 欧美性精品 | 人人爽网站| 亚洲欧美少妇 | 人人澡人人舔 | 日韩av一区二区在线影视 | 中文字幕有码在线播放 | .国产精品成人自产拍在线观看6 | 亚洲日韩精品欧美一区二区 | 国产精品高潮呻吟久久av无 | 国产精品24小时在线观看 | 国产精品久久久久9999吃药 | 成人av影院在线观看 | 国产不卡在线观看视频 | 丁香九月激情 | 日韩成年视频 | 成人免费观看网址 | 狠狠色丁香婷婷综合 | 人人天天夜夜 | 成人av高清在线观看 | 免费午夜视频在线观看 | wwxxxx日本 | 91在线国产观看 | 亚洲丝袜一区 | 俺要去色综合狠狠 | 日韩欧美精品在线视频 | 亚洲精品中文字幕在线观看 | 中文字幕在线国产 | 91九色视频在线 | 日日日日干 | 亚洲男男gaygay无套 | 黄色av一区| 中文字幕影片免费在线观看 | 日韩午夜小视频 | wwxxxx日本| 人人爽人人乐 | 久久精品人人做人人综合老师 | 国产成人精品一二三区 | 久久天天躁狠狠躁亚洲综合公司 | 成人小电影在线看 | 成人av一区二区兰花在线播放 | 亚洲精品在线观看视频 | 亚洲欧美色婷婷 | 日韩av免费大片 | 成人黄色国产 | 成人av资源 | 亚洲一区二区三区四区精品 | 久久久久久激情 | 久草在线高清 | 国产专区免费 | 又黄又爽又湿又无遮挡的在线视频 | 中文字幕在线观看网站 | 啪啪动态视频 | 日韩精品一区二区三区水蜜桃 | 九九99 | 美女网站视频免费都是黄 | 国产精彩视频一区二区 | 亚洲精品ww| 亚洲欧美日韩在线一区二区 | 午夜视频在线观看欧美 | 在线观看中文 | 92av视频| 成人免费观看视频大全 | 精品麻豆 | 天天色综合三 | 免费色网站 | 色综合久久中文字幕综合网 | 久久久国产精品人人片99精片欧美一 | 美女福利视频在线 | 国产无限资源在线观看 | 97在线观看免费高清完整版在线观看 | 国产精品久久久区三区天天噜 | 中文在线字幕免费观看 | 免费看的黄色录像 | 在线小视频你懂的 | 成年人免费在线播放 | 色七七亚洲影院 | 亚洲国产精品999 | 天天躁天天狠天天透 | 在线观看免费版高清版 | 激情久久网 | 97超碰人人 | 三级黄色网址 | 婷婷综合 | 91视频xxxx| 久久久免费精品视频 | 日韩免费在线观看视频 | 国产精品免费久久 | 综合精品在线 | 亚洲高清国产视频 | 中文字幕精品一区二区三区电影 | 国产视频2区 | 成人在线观看免费视频 | 成人黄色电影在线 | 97超在线视频 | 91喷水| 香蕉国产91 | 国产中文字幕一区二区 | 在线三级av | 国产在线精品福利 | 一级性av | 国产91全国探花系列在线播放 | 国产婷婷久久 | 国产成人不卡 | 亚洲成aⅴ人片久久青草影院 | 最近中文字幕 | 婷婷色社区 | 亚洲精品欧美精品 | 在线看小早川怜子av | 成人av高清在线观看 | 丁香婷婷深情五月亚洲 | av解说在线| 正在播放一区 | 天天草天天爽 | 精品国产一区二区三区久久久蜜臀 | 日韩免费不卡av | 狠狠狠色丁香综合久久天下网 | 一区二区视频在线播放 | 中文字幕乱在线伦视频中文字幕乱码在线 | 久久一区二区三区超碰国产精品 | av激情五月 | 在线免费观看成人 | 免费av网站在线看 | 欧美国产日韩在线视频 | 色网站免费在线观看 | 久久精品屋 | 人人草网站 | 五月天六月婷 | 91看片看淫黄大片 | 日韩精品一区二区三区不卡 | 日韩欧美精品一区 | 欧美在线18 | 99在线观看免费视频精品观看 | 国产精品精品国产 | 成人超碰97| 国产在线毛片 | 久草视频手机在线 | 黄色精品久久 | 91麻豆精品国产91久久久久久 | 免费福利片2019潦草影视午夜 | 欧美另类69 | 在线午夜av | 丁香婷婷深情五月亚洲 | 在线看av的网址 | 91看片看淫黄大片 | 欧美污污网站 | 最近的中文字幕大全免费版 | 99九九热只有国产精品 | 悠悠av资源片 | 婷婷综合影院 | 欧美一二区在线 | 亚洲成a人片在线观看网站口工 | 国产精品视频永久免费播放 | 狠狠干 狠狠操 | 日日日日干 | 国产视频欧美视频 | 国产一级片视频 | 久热免费在线观看 | 国产一区久久 | 一级黄色片在线 | 国产精品伦一区二区三区视频 | 超碰人人国产 | 日韩中字在线 | 中文字幕在线不卡国产视频 | 在线免费观看成人 | 免费的黄色的网站 | 在线观看中文字幕亚洲 | 9在线观看免费高清完整版在线观看明 | 97在线观看免费高清完整版在线观看 | 99久精品| 国产成人精品免高潮在线观看 | 中文字幕中文字幕在线中文字幕三区 | 手机版av在线 | 久久国产精品免费一区二区三区 | 国产理论片在线观看 | 国产黑丝一区二区三区 | 久久一级电影 | 99资源网| 99热这里只有精品国产首页 | japanesefreesexvideo高潮| 五月婷香蕉久色在线看 | 精品亚洲一区二区三区 | 国内免费久久久久久久久久久 | 综合国产在线观看 | 91豆麻精品91久久久久久 | 亚洲一级片在线看 | 精品国产伦一区二区三区观看体验 | 久久久久免费网 | 午夜男人影院 | 久久国产精品视频免费看 | 中文字幕你懂的 | 色吧久久 | 91精品视频免费 | 国产精品成人国产乱一区 | 日日干 天天干 | 五月天六月丁香 | 久久免费的精品国产v∧ | 一区二区激情 | 精品伊人久久久 | 在线国产视频 | 国产福利一区二区在线 | 免费看的黄网站软件 | 在线观看亚洲电影 | 亚洲精品黄色 | 欧美性生活小视频 | 亚洲国产精品激情在线观看 | 992tv又爽又黄的免费视频 | 懂色av一区二区三区蜜臀 | 免费网站看av片 | 亚洲精品久久久久中文字幕m男 | 乱子伦av | 中文字幕人成乱码在线观看 | 亚洲第二色 | 久久成人国产精品 | 日本丶国产丶欧美色综合 | 亚洲涩涩涩涩涩涩 | 五月天久久综合网 | 精品超碰 | 亚洲精品国产精品99久久 | 在线观看视频黄色 | 久久精品视频日本 | 97久久精品午夜一区二区 | 久久er99热精品一区二区三区 | 91av社区| 九九热视频在线免费观看 | 人人干人人艹 | 国产高清免费观看 | 青青河边草观看完整版高清 | 91福利免费 | 免费福利视频网站 | 国产伦精品一区二区三区免费 | 超碰免费av| 超碰97人 | 日韩欧美在线影院 | www久草| www蜜桃视频 | 日韩精品无 | 国产精品久久久久久久久蜜臀 | 免费h在线观看 | 日韩网站在线播放 | 在线免费观看视频你懂的 | 欧美国产高清 | 中文在线免费一区三区 | 亚洲精品动漫成人3d无尽在线 | 天堂av在线7| 国产精品第一页在线观看 | 九九九国产 | wwxxx日本| 99久久精品久久久久久动态片 | 久久精品网站视频 | 国产中文字幕视频在线 | 狠狠狠狠狠狠干 | 午夜美女网站 | 免费男女羞羞的视频网站中文字幕 | 在线观看韩国av | 亚洲精品乱码久久久久久高潮 | 狠狠的干 | 亚洲精品国精品久久99热一 | 日韩视频一区二区在线 | 精品美女在线视频 | 欧美日韩一区二区在线 | 欧美日韩成人 | 欧美日韩一级在线 | 91亚色视频在线观看 | 久久一视频 | 欧美日韩中文国产 | 日韩av电影国产 | 国产一区二区三区在线免费观看 | 91最新网址 | 国产精品永久久久久久久久久 | 狠狠色丁香婷婷 | japanese黑人亚洲人4k | 蜜桃av人人夜夜澡人人爽 | 天天做天天射 | 夜夜躁日日躁狠狠久久av | 免费三级影片 | 久久乐九色婷婷综合色狠狠182 | 一区二区三区在线影院 | 欧美日韩91 | 婷婷九九 | 日本久久电影 | 中文字幕 二区 | 精品国精品自拍自在线 | 婷婷精品在线视频 | 综合天天色 | 五月天精品视频 | 97精品在线视频 | 日韩欧美91 | av黄色国产| 五月婷av| av网站在线免费观看 | 手机看片久久 | 97av.com | 五月婷婷丁香激情 | 国产精品 亚洲精品 | 国产一区二区精品久久 | 精品伊人久久久 | 深爱激情综合网 | 欧美一区免费在线观看 | 日韩精品在线免费观看 | 午夜精品麻豆 | 国产又粗又长又硬免费视频 | 国产精品video爽爽爽爽 | 国产黄色av网站 | 久久综合九色欧美综合狠狠 | 免费色视频网站 | 国产午夜三级一区二区三 | av网站播放 | 麻豆影视在线免费观看 | 久久久久久久久久久电影 | 亚洲成人av片在线观看 | 日韩大片免费观看 | 91探花国产综合在线精品 | 日韩高清黄色 | 免费观看v片在线观看 | 国产成人精品一区二区 | 九九免费在线视频 | 麻豆一区二区三区视频 | 日韩电影一区二区在线观看 | 久久久久免费精品国产 | 亚洲国产wwwccc36天堂 | 日韩精品中文字幕在线不卡尤物 | 亚洲视频精选 | 国产视频欧美视频 | 五月天国产精品 | 日韩亚洲精品电影 | 一区二区精 | 亚洲成人精品国产 | 天天操综合 | 欧美中文字幕第一页 | 国产女人40精品一区毛片视频 | 激情网五月婷婷 | 天天综合网在线观看 | 国产大片黄色 | 在线你懂 | 亚洲成人精品国产 | 中文字幕乱码电影 | 在线精品一区二区 | 精品亚洲视频在线观看 | 中日韩欧美精彩视频 | 国产 色 | 91探花视频 | 欧美日在线| 蜜臀av性久久久久蜜臀aⅴ涩爱 | 国产电影黄色av | 激情综合啪啪 | bbbbb女女女女女bbbbb国产 | 国产精品不卡一区 | 日本视频高清 | 日韩精品视频在线观看网址 | 久久99这里只有精品 | 精品视频成人 | 中文字幕日本在线 | 波多野结衣视频一区二区三区 | 美女天天操 | 久久夜夜爽 | 亚洲欧美视频一区二区三区 | 狠狠色狠狠色综合日日小说 | 骄小bbw搡bbbb揉bbbb | 免费视频久久久 | 日本爱爱免费 | 日本黄色免费看 | 天堂在线一区二区 | 午夜久久影视 | 日韩视频免费在线观看 | 国产精品久久久久9999 | 国内99视频 | 久草在线欧美 | 中文字幕丝袜一区二区 | 国产精品久久久久久久免费观看 | 欧美资源在线观看 | 久久这里只有精品9 | 成人久久久精品国产乱码一区二区 | 久久国产精品久久久 | 国产免费资源 | 色综合夜色一区 | 免费午夜在线视频 | 521色香蕉网站在线观看 | 91九色成人| 黄色免费电影网站 | 在线观看日本高清mv视频 | 国产在线p | 久久综合亚洲鲁鲁五月久久 | 久久久久国产成人精品亚洲午夜 | 久久精品国产免费看久久精品 | 日日干综合| 亚洲精品www久久久久久 | 国产九色在线播放九色 | 中国一区二区视频 | 99爱精品视频 | a在线观看视频 | 久久精品99久久久久久2456 | 精精国产xxxx视频在线播放 | av免费片 | 免费福利视频网站 | 久久久久久毛片精品免费不卡 | www色com | 亚洲清纯国产 | 久久夜色精品国产欧美一区麻豆 | www久久精品 | 国产美女网站在线观看 | 中文字幕乱码电影 | 久久久久综合网 | 精品v亚洲v欧美v高清v | 成人黄色片免费 | 午夜国产一区二区三区四区 | 亚a在线 | 国产黄色网 | 色婷婷在线观看视频 | 精品久久电影 | 在线免费高清一区二区三区 | 天天操比| 日韩欧美高清在线观看 | 国产精品久久久久9999吃药 | 久久人人爽爽 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 99久久精品国产一区二区三区 | 国产美女视频免费 | 精品一区二区6 | 午夜国产一区 | 国产区在线 | 亚洲精品毛片一级91精品 | 国产夫妻av在线 | 美女很黄免费网站 | 操处女逼| 亚洲精品2区 | 国产99中文字幕 | 精品久久久久久久久久久久久久久久久久 | 99久久日韩精品视频免费在线观看 | 免费高清在线一区 | 91av电影在线 | 91最新在线 | 97在线播放 | 日韩免费大片 | 国产成人一区二区三区 | 亚洲国产电影在线观看 | 国产精品理论片在线播放 | 国产精品免费观看网站 | 色综合久久久久久中文网 | 日日干干夜夜 | 91香蕉视频720p | 日韩精品电影在线播放 | 日韩一片| 国产专区视频在线观看 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 免费看国产一级片 | 成人小视频在线观看免费 | 午夜精品一区二区国产 | 国产在线观看a | 91大片网站 | 99精彩视频在线观看免费 | 久久伦理 | 偷拍视频一区 | 日韩一区二区免费视频 | 欧美性色网站 | 99精品视频在线看 | 精品视频免费久久久看 | 亚洲欧美日韩在线一区二区 | 亚洲精品视频免费在线观看 | 欧美色精品天天在线观看视频 | 免费看国产精品 | 在线黄频| 玖玖国产精品视频 | 中文字幕资源网在线观看 | 在线影视 一区 二区 三区 | 久久精品资源 | 国产精品二区在线观看 | 久久国产综合视频 | 国产理论在线 | 婷婷成人亚洲综合国产xv88 | 娇妻呻吟一区二区三区 | 激情五月综合 | 综合久久影院 | 国产欧美最新羞羞视频在线观看 | 99久久99久国产黄毛片 | 五月天激情在线 | 午夜色场 | 亚洲激情久久 | 国产精品久久一区二区无卡 | 欧美一级艳片视频免费观看 | 香蕉在线观看视频 | 国产免费高清视频 | 国产精品黄 | 99热这里有 | 日韩av一区二区在线 | 日本久久久久久 | 综合久久精品 | 亚洲午夜久久久久久久久久久 | 五月婷婷天堂 | 欧美永久视频 | a午夜在线| 波多野结衣在线观看视频 | 91污污视频在线观看 | 中文字幕黄网 | 六月丁香激情网 | 一区二区三区在线免费播放 | 日本高清免费中文字幕 | 在线观看亚洲精品视频 | 日韩黄色中文字幕 | 人人射人人插 | 在线综合 亚洲 欧美在线视频 | 日本免费一二三区 | aa一级片| 精品五月天 | 伊色综合久久之综合久久 | 中文字幕一区二区三区视频 | 欧美日韩一区二区三区视频 | 国产高清久久久 | 天天色天天色天天色 | 日韩视频中文字幕在线观看 | a级片久久久| av中文字幕剧情 | 麻豆传媒视频在线 | 美女视频黄频大全免费 | 亚洲美女视频在线 | 国产精品青草综合久久久久99 | 国产一级黄色片免费看 | 激情中文在线 | 夜夜躁狠狠躁 | 国产黑丝一区二区三区 | 在线亚洲精品 | 免费视频xnxx com | 午夜久久福利影院 | 欧美激情第一区 | 色人久久 | 国产精品国产三级在线专区 | 综合色久 | 999电影免费在线观看2020 | av在线看片 | 成年人在线免费看视频 | 久久伊人精品天天 | 综合激情网...| 精品久久久免费 | 久久久精品欧美 | 亚洲资源在线观看 | 欧美另类高清 | 中文字幕欧美日韩va免费视频 | 色九九在线 | 亚洲三级精品 | 国产高清av | 久久精品99国产精品日本 | 丁香九月婷婷 | 天天操狠狠操夜夜操 | 久久久人人人 | 国产福利91精品一区二区三区 | 一区二区欧美在线观看 | 97精品超碰一区二区三区 | 91av在线播放视频 | 98福利在线 | 丁香激情五月 | 国产精品久久久久久一二三四五 | 91视频这里只有精品 | 欧美日韩69 | 中文在线天堂资源 | 国产精品永久免费在线 | 天堂av色婷婷一区二区三区 | 91精品国产成人 | 视频在线观看一区 | 欧美成人h版在线观看 |