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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > javascript >内容正文

javascript

【第二十三篇】Spring Boot集成redis

發(fā)布時(shí)間:2024/1/18 javascript 66 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【第二十三篇】Spring Boot集成redis 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1.1 簡(jiǎn)介

REmote DIctionary Server(Redis)是一個(gè)由Salvatore Sanfilippo寫(xiě)的key-value存儲(chǔ)系統(tǒng)。

Redis是一個(gè)開(kāi)源的使用ANSI C語(yǔ)言編寫(xiě)、遵守BSD協(xié)議、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫(kù),并提供多種語(yǔ)言的API。

它通常被稱(chēng)為數(shù)據(jù)結(jié)構(gòu)服務(wù)器,因?yàn)橹?#xff08;value)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets)和 有序集合(sorted sets)等類(lèi)型。

reids的優(yōu)點(diǎn)

  • 異常快 - Redis非???#xff0c;每秒可執(zhí)行大約110000次的設(shè)置(SET)操作,每秒大約可執(zhí)行81000次的讀取/獲取(GET)操作。
  • 支持豐富的數(shù)據(jù)類(lèi)型 - Redis支持開(kāi)發(fā)人員常用的大多數(shù)數(shù)據(jù)類(lèi)型,例如列表,集合,排序集和散列等等。這使得Redis很容易被用來(lái)解決各種問(wèn)題,因?yàn)槲覀冎滥男﹩?wèn)題可以更好使用地哪些數(shù)據(jù)類(lèi)型來(lái)處理解決。
  • 操作具有原子性 - 所有Redis操作都是原子操作,這確保如果兩個(gè)客戶(hù)端并發(fā)訪問(wèn),Redis服務(wù)器能接收更新的值。
  • 多實(shí)用工具 -Redis是一個(gè)多實(shí)用工具,可用于多種用例,如:緩存,消息隊(duì)列(Redis本地支持發(fā)布/訂閱),應(yīng)用程序中的任何短期數(shù)據(jù),例如,web應(yīng)用程序中的會(huì)話,網(wǎng)頁(yè)命中計(jì)數(shù)等。

1.2 Redis 安裝

1.2.1 Linux安裝

本課程是在vmvare 虛擬機(jī)中來(lái)安裝的 redis (centos 7),學(xué)習(xí)的時(shí)候如果有自己的阿里云服務(wù)器,也可以在阿里云中來(lái)安裝redis,都可以。只要能 ping 的通云主機(jī)或者虛擬機(jī)的 ip,然后在虛擬機(jī)或者云主機(jī)中放行對(duì)應(yīng)的端口(或者關(guān)掉防火墻)即可訪問(wèn) redis。下面來(lái)介紹一下 redis 的安裝過(guò)程:

1.2.1.1 安裝 gcc 編譯

因?yàn)楹竺姘惭bredis的時(shí)候需要編譯,所以事先得先安裝gcc編譯。阿里云主機(jī)已經(jīng)默認(rèn)安裝了 gcc,如果是自己安裝的虛擬機(jī),那么需要先安裝一下gcc:

yum install gcc-c++

1.2.1.2 下載redis

有兩種方式下載安裝包,一種是去官網(wǎng)上下載(https://redis.io),然后將安裝包拷到 centos中,另種方法是直接使用 wget來(lái)下載:

wget http://download.redis.io/releases/redis-3.2.8.tar.gz

如果沒(méi)有安裝過(guò) wget,可以通過(guò)如下命令安裝:

yum install wget

1.2.1.3 解壓安裝

解壓安裝包:

tar –vzxf redis-3.2.8.tar.gz

然后將解壓的文件夾redis-3.2.8放到 /usr/local/下,一般安裝軟件都放在/usr/local下。然后進(jìn)入 /usr/local/redis-3.2.8/文件夾下,執(zhí)行 make 命令即可完成安裝。
【注】如果 make失敗,可以嘗試如下命令:

make MALLOC=libc make install

1.2.1.4 修改配置文件

安裝成功之后,需要修改一下配置文件,包括允許接入的ip,允許后臺(tái)執(zhí)行,設(shè)置密碼等等。
打開(kāi)redis配置文件:vi redis.conf
在命令模式下輸入/bind來(lái)查找 bind配置,按n來(lái)查找下一個(gè),找到配置后,將 bind配置成 0.0.0.0,允許任意服務(wù)器來(lái)訪問(wèn)redis,即:

bind 0.0.0.0

使用同樣的方法,將 daemonize改成yes(默認(rèn)為no),允許redis在后臺(tái)執(zhí)行。
將 requirepass注釋打開(kāi),并設(shè)置密碼為 123456(密碼自己設(shè)置)。

1.2.1.5 啟動(dòng)redis

在redis-3.2.8目錄下,指定剛剛修改好的配置文件redis.conf來(lái)啟動(dòng) redis:

redis-server ./redis.conf

再啟動(dòng)redis 客戶(hù)端:

redis-cli

由于我們?cè)O(shè)置了密碼,在啟動(dòng)客戶(hù)端之后,輸入 auth 123456即可登錄進(jìn)入客戶(hù)端。
然后我們來(lái)測(cè)試一下,往 redis中插入一個(gè)數(shù)據(jù):

set name CSDN

然后來(lái)獲取 name

get name

如果正常獲取到 CSDN,則說(shuō)明沒(méi)有問(wèn)題。

1.2.2 Windows安裝

下載地址:https://github.com/MSOpenTech/redis/releases
Redis 支持 32位和64位。這個(gè)需要根據(jù)你系統(tǒng)平臺(tái)的實(shí)際情況選擇,這里我們下載 Redis-x64-xxx.zip壓縮包到C盤(pán),解壓后,將文件夾重新命名為redis。

打開(kāi)一個(gè) cmd窗口 使用cd命令切換目錄到C:\redis
運(yùn)行 redis-server.exe redis.windows.conf
如果想方便的話,可以把redis的路徑加到系統(tǒng)的環(huán)境變量里,這樣就省得再輸路徑了,后面的那個(gè) redis.windows.conf可以省略,如果省略,會(huì)啟用默認(rèn)的。輸入之后,會(huì)顯示如下界面:

1.3 集成redis

Spring Boot對(duì) redis的支持已經(jīng)非常完善了,豐富的api 已經(jīng)足夠我們?nèi)粘5拈_(kāi)發(fā)。

有兩個(gè)redis模板:RedisTemplate和 StringRedisTemplate。
RedisTemplate提供給我們操作對(duì)象,操作對(duì)象的時(shí)候,我們通常是以 json 格式存儲(chǔ),但在存儲(chǔ)的時(shí)候,會(huì)使用 Redis默認(rèn)的內(nèi)部序列化器;導(dǎo)致我們存進(jìn)里面的是亂碼之類(lèi)的東西。當(dāng)然了,我們可以自己定義序列化。
StringRedisTemplate主要給我們提供字符串操作,我們可以將實(shí)體類(lèi)等轉(zhuǎn)成json 字符串即可,在取出來(lái)后,也可以轉(zhuǎn)成相應(yīng)的對(duì)象,所以很有必要導(dǎo)入fastjson 的原因。

1.3.1 添加依賴(lài)

  • 如果你的spring boot的版本號(hào)是1.4.0 到1.5.0之間,添加redis的jar包的時(shí)候 添加成 spring-boot-starter-data-redis 和 spring-boot-starter-redis 都是都可以的。
  • 但是如果你的spring boot的版本號(hào) 是1.4.0以前 也就是1.3.8 版本以前,添加redis的jar包 就必須是spring-boot-starter-redis 的jar包。
  • 如果你的spring boot的版本號(hào)在1.5.0以后的,添加redis的jar包就必須是spring-boot-starter-data-redis。

1.3.2 SpringBoot 1.4 整合redis

1.3.2.1 依賴(lài)

采用的是spring-boot-starter-redis,也可以添加成spring-boot-starter-data-redis

<!--集成redis--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-redis</artifactId><version>1.4.1.RELEASE</version> </dependency> <dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.3</version> </dependency> <dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId> </dependency>

1.3.2.2 添加配置

spring.redis.host=127.0.0.1 #Redis服務(wù)器連接端口 spring.redis.port=6379 #Redis服務(wù)器連接密碼(默認(rèn)為空) spring.redis.password= #連接池最大連接數(shù)(使用負(fù)值表示沒(méi)有限制) spring.redis.pool.max-active=8 #連接池最大阻塞等待時(shí)間(使用負(fù)值表示沒(méi)有限制) spring.redis.pool.max-wait=-1 #連接池中的最大空閑連接 spring.redis.pool.max-idle=8 #連接池中的最小空閑連接 spring.redis.pool.min-idle=0 #連接超時(shí)時(shí)間(毫秒) spring.redis.timeout=30000

1.3.2.3 配置類(lèi)RedisConfig

@RefreshScope
動(dòng)態(tài)配置刷新的我們要配置一個(gè)@RefreshScope在類(lèi)上才可以實(shí)現(xiàn)對(duì)象屬性的的動(dòng)態(tài)更新。
我們來(lái)總結(jié)下@RefreshScope實(shí)現(xiàn)流程

1、需要?jiǎng)討B(tài)刷新的類(lèi)標(biāo)注@RefreshScope 注解
2、@RefreshScope 注解標(biāo)注了@Scope注解,并默認(rèn)了ScopedProxyMode.TARGET_CLASS; 屬性,此屬性的功能就是在創(chuàng)建一個(gè)代理,在每次調(diào)用的時(shí)候都用它來(lái)調(diào)用GenericScope get方法來(lái)獲取對(duì)象
3、如屬性發(fā)生變更會(huì)調(diào)用 ContextRefresher refresh() -》RefreshScope refreshAll()進(jìn)行緩存清理方法調(diào)用,并發(fā)送刷新事件通知 -》GenericScope真正的 清理方法destroy()實(shí)現(xiàn)清理緩存
4、在下一次使用對(duì)象的時(shí)候,會(huì)調(diào)用GenericScope get(String name, ObjectFactory<?> objectFactory)方法創(chuàng)建一個(gè)新的對(duì)象,并存入緩存中,此時(shí)新對(duì)象因?yàn)镾pring的裝配機(jī)制就是新的屬性了。

@Configuration @EnableCaching @RefreshScope public class RedisConfig extends CachingConfigurerSupport{@Value("${spring.redis.host}")private String host;@Value("${spring.redis.port}")private int port;@Value("${spring.redis.timeout}")private int timeout;@Value("${spring.redis.password}")private String password;@Value("${spring.redis.pool.max-active}")private int maxActive;@Value("${spring.redis.pool.max-wait}")private int maxWait;@Value("${spring.redis.pool.max-idle}")private int maxIdle;@Value("${spring.redis.pool.min-idle}")private int minIdle;@RefreshScope@Beanpublic KeyGenerator wiselyKeyGenerator(){return new KeyGenerator() {@Overridepublic Object generate(Object target, Method method, Object... params) {StringBuilder sb = new StringBuilder();sb.append(target.getClass().getName());sb.append(method.getName());for (Object obj : params) {sb.append(obj.toString());}return sb.toString();}};}@RefreshScope@Beanpublic JedisConnectionFactory redisConnectionFactory() {JedisConnectionFactory factory = new JedisConnectionFactory();factory.setHostName(host);factory.setPort(port);factory.setTimeout(timeout); //設(shè)置連接超時(shí)時(shí)間factory.setPassword(password);factory.getPoolConfig().setMaxIdle(maxIdle);factory.getPoolConfig().setMinIdle(minIdle);factory.getPoolConfig().setMaxTotal(maxActive);factory.getPoolConfig().setMaxWaitMillis(maxWait);return factory;}@RefreshScope@Beanpublic CacheManager cacheManager(RedisTemplate redisTemplate) {RedisCacheManager cacheManager = new RedisCacheManager(redisTemplate);// Number of seconds before expiration. Defaults to unlimited (0)cacheManager.setDefaultExpiration(10); //設(shè)置key-value超時(shí)時(shí)間return cacheManager;}@RefreshScope@Beanpublic RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {StringRedisTemplate template = new StringRedisTemplate(factory);setSerializer(template); //設(shè)置序列化工具,這樣ReportBean不需要實(shí)現(xiàn)Serializable接口template.afterPropertiesSet();return template;}@RefreshScopeprivate void setSerializer(StringRedisTemplate template) {Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);ObjectMapper om = new ObjectMapper();om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(om);template.setValueSerializer(jackson2JsonRedisSerializer);} }

1.3.2.4 RedisUtils類(lèi)

import java.io.Serializable; import java.util.List; import java.util.Set; import java.util.concurrent.TimeUnit; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.HashOperations; import org.springframework.data.redis.core.ListOperations; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.core.SetOperations; import org.springframework.data.redis.core.ValueOperations; import org.springframework.data.redis.core.ZSetOperations; import org.springframework.stereotype.Service; @Service public class RedisUtils {@Autowiredprivate RedisTemplate redisTemplate;/*** 寫(xiě)入緩存* @param key* @param value* @return*/public boolean set(final String key, Object value) {boolean result = false;try {ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();operations.set(key, value);result = true;} catch (Exception e) {e.printStackTrace();}return result;}/*** 寫(xiě)入緩存設(shè)置時(shí)效時(shí)間* @param key* @param value* @return*/public boolean set(final String key, Object value, Long expireTime ,TimeUnit timeUnit) {boolean result = false;try {ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();operations.set(key, value);redisTemplate.expire(key, expireTime, timeUnit);result = true;} catch (Exception e) {e.printStackTrace();}return result;}/*** 批量刪除對(duì)應(yīng)的value* @param keys*/public void remove(final String... keys) {for (String key : keys) {remove(key);}}/*** 批量刪除key* @param pattern*/public void removePattern(final String pattern) {Set<Serializable> keys = redisTemplate.keys(pattern);if (keys.size() > 0){redisTemplate.delete(keys);}}/*** 刪除對(duì)應(yīng)的value* @param key*/public void remove(final String key) {if (exists(key)) {redisTemplate.delete(key);}}/*** 判斷緩存中是否有對(duì)應(yīng)的value* @param key* @return*/public boolean exists(final String key) {return redisTemplate.hasKey(key);}/*** 讀取緩存* @param key* @return*/public Object get(final String key) {Object result = null;ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();result = operations.get(key);return result;}/*** 哈希 添加* @param key* @param hashKey* @param value*/public void hmSet(String key, Object hashKey, Object value){HashOperations<String, Object, Object> hash = redisTemplate.opsForHash();hash.put(key,hashKey,value);}/*** 哈希獲取數(shù)據(jù)* @param key* @param hashKey* @return*/public Object hmGet(String key, Object hashKey){HashOperations<String, Object, Object> hash = redisTemplate.opsForHash();return hash.get(key,hashKey);}/*** 列表添加* @param k* @param v*/public void lPush(String k,Object v){ListOperations<String, Object> list = redisTemplate.opsForList();list.rightPush(k,v);}/*** 列表獲取* @param k* @param l* @param l1* @return*/public List<Object> lRange(String k, long l, long l1){ListOperations<String, Object> list = redisTemplate.opsForList();return list.range(k,l,l1);}/*** 集合添加* @param key* @param value*/public void add(String key,Object value){SetOperations<String, Object> set = redisTemplate.opsForSet();set.add(key,value);}/*** 集合獲取* @param key* @return*/public Set<Object> setMembers(String key){SetOperations<String, Object> set = redisTemplate.opsForSet();return set.members(key);}/*** 有序集合添加* @param key* @param value* @param scoure*/public void zAdd(String key,Object value,double scoure){ZSetOperations<String, Object> zset = redisTemplate.opsForZSet();zset.add(key,value,scoure);}/*** 有序集合獲取* @param key* @param scoure* @param scoure1* @return*/public Set<Object> rangeByScore(String key,double scoure,double scoure1){ZSetOperations<String, Object> zset = redisTemplate.opsForZSet();return zset.rangeByScore(key, scoure, scoure1);}

1.3.2.5 測(cè)試controller

@RestController public class SpringBootController {public static final Logger log = LoggerFactory.getLogger(SpringBootController.class);@AutowiredTestService testService;@Autowiredprivate RedisUtils redisUtils;@RequestMapping(value = "/hello/{id}")public String hello(@PathVariable(value = "id") String id){//查詢(xún)緩存中是否存在boolean hasKey = redisUtils.exists(id);String str = "";if(hasKey){//獲取緩存Object object = redisUtils.get(id);log.info("從緩存獲取的數(shù)據(jù)"+ object);str = object.toString();}else{//從數(shù)據(jù)庫(kù)中獲取信息log.info("從數(shù)據(jù)庫(kù)中獲取數(shù)據(jù)");str = testService.test();//數(shù)據(jù)插入緩存(set中的參數(shù)含義:key值,user對(duì)象,緩存存在時(shí)間10(long類(lèi)型),時(shí)間單位)redisUtils.set(id,str,10L,TimeUnit.MINUTES);log.info("數(shù)據(jù)插入緩存" + str);}return str;} }

通過(guò)控制臺(tái)輸出,我們可以看到是從數(shù)據(jù)庫(kù)中獲取的數(shù)據(jù),并且存入了redis緩存中。

可以看到,第二次是從緩存中讀取的,我們?cè)囋嚥粩嗨⑿聻g覽器
可以看到,之后都是從緩存中獲取的。

1.3.3 SpringBoot 2.x整合redis

1.3.3.1 依賴(lài)

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.7.RELEASE</version><relativePath/> <!-- lookup parent from repository --> </parent> ......... <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId> </dependency>

1.3.3.2 application.yml中加入redis依賴(lài)

spring:datasource:url: jdbc:mysql://localhost:3306/spring_cache?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMTdriver-class-name: com.mysql.cj.jdbc.Driverusername: rootpassword: 123456redis:host: 39.107.250.174port: 6379database: 0timeout: 1000s # 數(shù)據(jù)庫(kù)連接超時(shí)時(shí)間,2.0 中該參數(shù)的類(lèi)型為Duration,這里在配置的時(shí)候需要指明單位# 連接池配置,2.0中直接使用jedis或者lettuce配置連接池jedis:pool:# 最大空閑連接數(shù)max-idle: 500# 最小空閑連接數(shù)min-idle: 50# 等待可用連接的最大時(shí)間,負(fù)數(shù)為不限制max-wait: -1# 最大活躍連接數(shù),負(fù)數(shù)為不限制max-active: -1cache:redis:time-to-live: -1 #毫秒#以下可忽略 mybatis:configuration:#開(kāi)啟駝峰命名map-underscore-to-camel-case: true logging:level:com.scitc.cache.mapper : debug

1.3.3.3 redis配置類(lèi)

package com.scitc.cache.config;import com.fasterxml.jackson.annotation.JsonAutoDetect; import com.fasterxml.jackson.annotation.PropertyAccessor; import com.fasterxml.jackson.databind.ObjectMapper; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Value; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.cache.CacheManager; import org.springframework.cache.annotation.CachingConfigurerSupport; import org.springframework.cache.annotation.EnableCaching; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.data.redis.cache.RedisCacheConfiguration; import org.springframework.data.redis.cache.RedisCacheManager; import org.springframework.data.redis.connection.RedisConnectionFactory; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer; import org.springframework.data.redis.serializer.RedisSerializationContext; import org.springframework.data.redis.serializer.RedisSerializer; import org.springframework.data.redis.serializer.StringRedisSerializer;import java.time.Duration;@Configuration @EnableCaching//啟用緩存,這個(gè)注解很重要; //繼承CachingConfigurerSupport,為了自定義生成KEY的策略??梢圆焕^承。 public class RedisConfig extends CachingConfigurerSupport {@Value("${spring.cache.redis.time-to-live}")private Duration timeToLive = Duration.ZERO;@Bean(name = "redisTemplate")public RedisTemplate<String,Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {RedisTemplate<String, Object> template = new RedisTemplate<>();template.setConnectionFactory(redisConnectionFactory);//使用Jackson2JsonRedisSerializer來(lái)序列化和反序列化redis的value值Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<>(Object.class);ObjectMapper mapper = new ObjectMapper();mapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);mapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(mapper);template.setValueSerializer(jackson2JsonRedisSerializer);StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();//使用StringRedisSerializer來(lái)序列化和反序列化redis的key值template.setKeySerializer(stringRedisSerializer);template.setKeySerializer(stringRedisSerializer);// hash的key也采用String的序列化方式template.setHashKeySerializer(stringRedisSerializer);// value序列化方式采用jacksontemplate.setValueSerializer(jackson2JsonRedisSerializer);// hash的value序列化方式采用jacksontemplate.setHashValueSerializer(jackson2JsonRedisSerializer);template.afterPropertiesSet();return template;}@Beanpublic CacheManager cacheManager(RedisConnectionFactory factory) {RedisSerializer<String> redisSerializer = new StringRedisSerializer();Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);//解決查詢(xún)緩存轉(zhuǎn)換異常的問(wèn)題ObjectMapper om = new ObjectMapper();om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(om);// 配置序列化(解決亂碼的問(wèn)題)RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig().entryTtl(timeToLive).serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer)).serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer)).disableCachingNullValues();RedisCacheManager cacheManager = RedisCacheManager.builder(factory).cacheDefaults(config).build();return cacheManager;}}

然后我發(fā)現(xiàn)有好幾篇文章配置 CacheManager采用的是如下配置:

@Beanpublic CacheManager cacheManager(RedisConnectionFactory factory) {// 生成一個(gè)默認(rèn)配置,通過(guò)config對(duì)象即可對(duì)緩存進(jìn)行自定義配置RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig();// 設(shè)置緩存的默認(rèn)過(guò)期時(shí)間,也是使用Duration設(shè)置config = config.entryTtl(Duration.ofMinutes(1)).disableCachingNullValues(); // 不緩存空值// 設(shè)置一個(gè)初始化的緩存空間set集合Set<String> cacheNames = new HashSet<>();cacheNames.add("my-redis-cache1");cacheNames.add("my-redis-cache2");// 對(duì)每個(gè)緩存空間應(yīng)用不同的配置Map<String, RedisCacheConfiguration> configMap = new HashMap<>();configMap.put("my-redis-cache1", config);configMap.put("my-redis-cache2", config.entryTtl(Duration.ofSeconds(120)));// 使用自定義的緩存配置初始化一個(gè)cacheManagerRedisCacheManager cacheManager = RedisCacheManager.builder(factory).initialCacheNames(cacheNames) // 注意這兩句的調(diào)用順序,一定要先調(diào)用該方法設(shè)置初始化的緩存名,再初始化相關(guān)的配置.withInitialCacheConfigurations(configMap).build();return cacheManager;}

但經(jīng)過(guò)我使用測(cè)試發(fā)現(xiàn),他在redis中保存的數(shù)據(jù)是這樣的,并不是json

后面又找到一篇文章,重新配置 CacheManager (就是我直接貼出來(lái)的完整配置代碼)
經(jīng)過(guò)測(cè)試訪問(wèn)保存的數(shù)據(jù)格式為 json(下方有圖片)

到此配置完成,正常運(yùn)行

1.3.3.4 RedisUtils工具類(lèi)

package com.scitc.cache.utils;import java.util.List; import java.util.Map; import java.util.Set; import java.util.concurrent.TimeUnit;import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Component; import org.springframework.util.CollectionUtils;@Component public class RedisUtil {@Autowiredprivate RedisTemplate<String, Object> redisTemplate;/*** 指定緩存失效時(shí)間* @param key 鍵* @param time 時(shí)間(秒)* @return*/public boolean expire(String key,long time){try {if(time>0){redisTemplate.expire(key, time, TimeUnit.SECONDS);}return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 根據(jù)key 獲取過(guò)期時(shí)間* @param key 鍵 不能為null* @return 時(shí)間(秒) 返回0代表為永久有效*/public long getExpire(String key){return redisTemplate.getExpire(key,TimeUnit.SECONDS);}/*** 判斷key是否存在* @param key 鍵* @return true 存在 false不存在*/public boolean hasKey(String key){try {return redisTemplate.hasKey(key);} catch (Exception e) {e.printStackTrace();return false;}}/*** 刪除緩存* @param key 可以傳一個(gè)值 或多個(gè)*/@SuppressWarnings("unchecked")public void del(String ... key){if(key!=null&&key.length>0){if(key.length==1){redisTemplate.delete(key[0]);}else{redisTemplate.delete(CollectionUtils.arrayToList(key));}}}//============================String=============================/*** 普通緩存獲取* @param key 鍵* @return 值*/public Object get(String key){return key==null?null:redisTemplate.opsForValue().get(key);}/*** 普通緩存放入* @param key 鍵* @param value 值* @return true成功 false失敗*/public boolean set(String key,Object value) {try {redisTemplate.opsForValue().set(key, value);return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 普通緩存放入并設(shè)置時(shí)間* @param key 鍵* @param value 值* @param time 時(shí)間(秒) time要大于0 如果time小于等于0 將設(shè)置無(wú)限期* @return true成功 false 失敗*/public boolean set(String key,Object value,long time){try {if(time>0){redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);}else{set(key, value);}return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 遞增* @param key 鍵* @param by 要增加幾(大于0)* @return*/public long incr(String key, long delta){if(delta<0){throw new RuntimeException("遞增因子必須大于0");}return redisTemplate.opsForValue().increment(key, delta);}/*** 遞減* @param key 鍵* @param by 要減少幾(小于0)* @return*/public long decr(String key, long delta){if(delta<0){throw new RuntimeException("遞減因子必須大于0");}return redisTemplate.opsForValue().increment(key, -delta);}//================================Map=================================/*** HashGet* @param key 鍵 不能為null* @param item 項(xiàng) 不能為null* @return 值*/public Object hget(String key,String item){return redisTemplate.opsForHash().get(key, item);}/*** 獲取hashKey對(duì)應(yīng)的所有鍵值* @param key 鍵* @return 對(duì)應(yīng)的多個(gè)鍵值*/public Map<Object,Object> hmget(String key){return redisTemplate.opsForHash().entries(key);}/*** HashSet* @param key 鍵* @param map 對(duì)應(yīng)多個(gè)鍵值* @return true 成功 false 失敗*/public boolean hmset(String key, Map<String,Object> map){try {redisTemplate.opsForHash().putAll(key, map);return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** HashSet 并設(shè)置時(shí)間* @param key 鍵* @param map 對(duì)應(yīng)多個(gè)鍵值* @param time 時(shí)間(秒)* @return true成功 false失敗*/public boolean hmset(String key, Map<String,Object> map, long time){try {redisTemplate.opsForHash().putAll(key, map);if(time>0){expire(key, time);}return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 向一張hash表中放入數(shù)據(jù),如果不存在將創(chuàng)建* @param key 鍵* @param item 項(xiàng)* @param value 值* @return true 成功 false失敗*/public boolean hset(String key,String item,Object value) {try {redisTemplate.opsForHash().put(key, item, value);return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 向一張hash表中放入數(shù)據(jù),如果不存在將創(chuàng)建* @param key 鍵* @param item 項(xiàng)* @param value 值* @param time 時(shí)間(秒) 注意:如果已存在的hash表有時(shí)間,這里將會(huì)替換原有的時(shí)間* @return true 成功 false失敗*/public boolean hset(String key,String item,Object value,long time) {try {redisTemplate.opsForHash().put(key, item, value);if(time>0){expire(key, time);}return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 刪除hash表中的值* @param key 鍵 不能為null* @param item 項(xiàng) 可以使多個(gè) 不能為null*/public void hdel(String key, Object... item){redisTemplate.opsForHash().delete(key,item);}/*** 判斷hash表中是否有該項(xiàng)的值* @param key 鍵 不能為null* @param item 項(xiàng) 不能為null* @return true 存在 false不存在*/public boolean hHasKey(String key, String item){return redisTemplate.opsForHash().hasKey(key, item);}/*** hash遞增 如果不存在,就會(huì)創(chuàng)建一個(gè) 并把新增后的值返回* @param key 鍵* @param item 項(xiàng)* @param by 要增加幾(大于0)* @return*/public double hincr(String key, String item,double by){return redisTemplate.opsForHash().increment(key, item, by);}/*** hash遞減* @param key 鍵* @param item 項(xiàng)* @param by 要減少記(小于0)* @return*/public double hdecr(String key, String item,double by){return redisTemplate.opsForHash().increment(key, item,-by);}//============================set=============================/*** 根據(jù)key獲取Set中的所有值* @param key 鍵* @return*/public Set<Object> sGet(String key){try {return redisTemplate.opsForSet().members(key);} catch (Exception e) {e.printStackTrace();return null;}}/*** 根據(jù)value從一個(gè)set中查詢(xún),是否存在* @param key 鍵* @param value 值* @return true 存在 false不存在*/public boolean sHasKey(String key,Object value){try {return redisTemplate.opsForSet().isMember(key, value);} catch (Exception e) {e.printStackTrace();return false;}}/*** 將數(shù)據(jù)放入set緩存* @param key 鍵* @param values 值 可以是多個(gè)* @return 成功個(gè)數(shù)*/public long sSet(String key, Object...values) {try {return redisTemplate.opsForSet().add(key, values);} catch (Exception e) {e.printStackTrace();return 0;}}/*** 將set數(shù)據(jù)放入緩存* @param key 鍵* @param time 時(shí)間(秒)* @param values 值 可以是多個(gè)* @return 成功個(gè)數(shù)*/public long sSetAndTime(String key,long time,Object...values) {try {Long count = redisTemplate.opsForSet().add(key, values);if(time>0) expire(key, time);return count;} catch (Exception e) {e.printStackTrace();return 0;}}/*** 獲取set緩存的長(zhǎng)度* @param key 鍵* @return*/public long sGetSetSize(String key){try {return redisTemplate.opsForSet().size(key);} catch (Exception e) {e.printStackTrace();return 0;}}/*** 移除值為value的* @param key 鍵* @param values 值 可以是多個(gè)* @return 移除的個(gè)數(shù)*/public long setRemove(String key, Object ...values) {try {Long count = redisTemplate.opsForSet().remove(key, values);return count;} catch (Exception e) {e.printStackTrace();return 0;}}//===============================list=================================/*** 獲取list緩存的內(nèi)容* @param key 鍵* @param start 開(kāi)始* @param end 結(jié)束 0 到 -1代表所有值* @return*/public List<Object> lGet(String key,long start, long end){try {return redisTemplate.opsForList().range(key, start, end);} catch (Exception e) {e.printStackTrace();return null;}}/*** 獲取list緩存的長(zhǎng)度* @param key 鍵* @return*/public long lGetListSize(String key){try {return redisTemplate.opsForList().size(key);} catch (Exception e) {e.printStackTrace();return 0;}}/*** 通過(guò)索引 獲取list中的值* @param key 鍵* @param index 索引 index>=0時(shí), 0 表頭,1 第二個(gè)元素,依次類(lèi)推;index<0時(shí),-1,表尾,-2倒數(shù)第二個(gè)元素,依次類(lèi)推* @return*/public Object lGetIndex(String key,long index){try {return redisTemplate.opsForList().index(key, index);} catch (Exception e) {e.printStackTrace();return null;}}/*** 將list放入緩存* @param key 鍵* @param value 值* @param time 時(shí)間(秒)* @return*/public boolean lSet(String key, Object value) {try {redisTemplate.opsForList().rightPush(key, value);return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 將list放入緩存* @param key 鍵* @param value 值* @param time 時(shí)間(秒)* @return*/public boolean lSet(String key, Object value, long time) {try {redisTemplate.opsForList().rightPush(key, value);if (time > 0) expire(key, time);return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 將list放入緩存* @param key 鍵* @param value 值* @param time 時(shí)間(秒)* @return*/public boolean lSet(String key, List<Object> value) {try {redisTemplate.opsForList().rightPushAll(key, value);return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 將list放入緩存* @param key 鍵* @param value 值* @param time 時(shí)間(秒)* @return*/public boolean lSet(String key, List<Object> value, long time) {try {redisTemplate.opsForList().rightPushAll(key, value);if (time > 0) expire(key, time);return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 根據(jù)索引修改list中的某條數(shù)據(jù)* @param key 鍵* @param index 索引* @param value 值* @return*/public boolean lUpdateIndex(String key, long index,Object value) {try {redisTemplate.opsForList().set(key, index, value);return true;} catch (Exception e) {e.printStackTrace();return false;}}/*** 移除N個(gè)值為value* @param key 鍵* @param count 移除多少個(gè)* @param value 值* @return 移除的個(gè)數(shù)*/public long lRemove(String key,long count,Object value) {try {Long remove = redisTemplate.opsForList().remove(key, count, value);return remove;} catch (Exception e) {e.printStackTrace();return 0;}} }

1.3.3.5 自己遇到的問(wèn)題

發(fā)現(xiàn)了個(gè)問(wèn)題(不是配置文件的問(wèn)題),我的對(duì)象實(shí)體類(lèi)是這樣的

@Data public class Employee implements Serializable {private Integer id;private String lastName;private String email;private Integer gender; //性別 1男 0女 // private Integer userId;private Integer dId; }

在json數(shù)據(jù)中多了一個(gè)did,

這次userId居然不重復(fù),后面把dId換成了uId,依舊重復(fù)。。。

最開(kāi)始不知道集成redis怎么在業(yè)務(wù)中使用,根據(jù)自己理解發(fā)現(xiàn),當(dāng)你配置了redis,SpringBoot會(huì)自動(dòng)把緩存加到redis中,并不使用默認(rèn)的

@Cacheable(value = {"emp"},key = "#id")public Employee getEmp(Integer id){log.info("查詢(xún)" + id + "號(hào)員工");Employee employee = employeeMapper.getEmpById(id);return employee;}

因?yàn)榕渲昧藃edis所以使用redis緩存不使用默認(rèn)的

總結(jié)

以上是生活随笔為你收集整理的【第二十三篇】Spring Boot集成redis的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

久久久久9999亚洲精品 | 99在线观看精品 | 黄色91免费观看 | 一区二区三区电影大全 | 91社区国产高清 | 狠狠网 | 超级碰视频 | 在线观看精品黄av片免费 | 国产精品一区二区久久精品爱涩 | 欧美精品一二 | 天天色天 | 欧美日本啪啪无遮挡网站 | 欧美日韩精品久久久 | 成人黄色在线观看视频 | 99在线观看免费视频精品观看 | 婷婷综合成人 | 国产精品久久久久久久久久 | 天天爱天天爽 | 男女啪啪网站 | 免费日韩 精品中文字幕视频在线 | 国产精品剧情在线亚洲 | 天天草天天操 | 狠狠狠色丁香婷婷综合激情 | 国产在线无| 91九色性视频 | 最近日本韩国中文字幕 | 日韩四虎 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 男女视频国产 | 国产成人精品亚洲日本在线观看 | 成人毛片在线观看 | 久久综合婷婷 | 欧美 激情 国产 91 在线 | 免费高清在线视频一区· | 在线视频观看亚洲 | 国产一级高清视频 | 狠狠色婷婷丁香六月 | 欧美久久99| 西西4444www大胆视频 | 欧美成人中文字幕 | 91成人在线观看高潮 | 97超碰国产在线 | 精品成人a区在线观看 | 国产成人a v电影 | 国产精品中文字幕在线播放 | 欧美日韩在线观看一区 | 国内精品福利视频 | 99电影456麻豆| 国产免费又粗又猛又爽 | 亚洲h色精品 | 国产高清视频在线免费观看 | 福利视频 | 中国一级片在线观看 | 国产精品第7页 | 中文字幕一区二区在线播放 | 中文字幕中文字幕在线中文字幕三区 | 69av国产| 欧美性爽爽 | 日韩精品一区二区三区丰满 | 天天天射 | 国产大片黄色 | 日韩影片在线观看 | 日韩在线播放av | 天天草综合 | 国产精品久久久久久久久岛 | 久久久久麻豆v国产 | 天天爽天天碰狠狠添 | 亚洲污视频 | 人人爽人人香蕉 | 天天射天天射天天 | 国产 欧美 日本 | 亚洲最大成人免费网站 | 97福利 | 国产免费人成xvideos视频 | aav在线 | 久久国产精品99久久久久久丝袜 | 波多野结衣网址 | 国产人免费人成免费视频 | 日批网站在线观看 | 激情黄色av | 亚洲成人国产 | 久久av电影 | 成人观看视频 | 五月婷婷丁香六月 | 国产成人a v电影 | 欧美久久电影 | 中文字幕在线视频一区二区三区 | 国产精品成人av在线 | 在线观看国产日韩欧美 | 日韩视频一 | 亚洲精品国产精品国产 | 日日干天天爽 | 国产亚洲精品久久久久久久久久 | 99精品乱码国产在线观看 | 黄色免费大片 | 九9热这里真品2 | 国产黑丝袜在线 | 天天夜夜狠狠操 | 国产三级香港三韩国三级 | 97狠狠操 | 一级黄色av| 成人9ⅰ免费影视网站 | 91超碰在线播放 | 亚洲欧美视频在线播放 | 久久在线影院 | 欧美成人影音 | 五月婷婷开心中文字幕 | 亚洲作爱视频 | 五月婷婷在线播放 | 国产精品久久久久免费观看 | 九九热re| 国产精品一区二区62 | 五月婷婷香蕉 | 色综合综合 | 探花系列在线 | 欧美一级久久久 | 久久午夜网 | 国产淫a| 久草香蕉在线视频 | 国产精品免费一区二区三区在线观看 | 99视频在线观看免费 | 久草在线综合 | 亚洲精品乱码久久久久久高潮 | 日韩性片 | 99在线播放 | 日韩免费视频一区二区 | 久久视频免费在线 | 亚洲国产精品成人va在线观看 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 一本大道久久精品懂色aⅴ 五月婷社区 | 韩国在线视频一区 | 精品国产理论 | 91九色精品女同系列 | 色综合网在线 | 国产成人专区 | 欧美成人h版电影 | 国产精品网在线观看 | 中文字幕在线播放一区二区 | www.色午夜.com | 国产麻豆视频 | 91丨九色丨首页 | 久久久久国产精品免费网站 | 99久久这里有精品 | 97福利视频 | www看片网站 | 在线观看国产日韩 | 免费在线观看av网址 | 成人国产电影在线观看 | 免费看短 | 久久精品国产美女 | 五月婷婷综合久久 | 中文字幕888 | 精品国产午夜 | 国产91精品高清一区二区三区 | 最近2019好看的中文字幕免费 | 91精品国产99久久久久久红楼 | 国产在线理论片 | 99热最新地址 | 91麻豆文化传媒在线观看 | 亚洲视频在线观看免费 | 久久美女免费视频 | 国产成人免费在线 | 国产视频精品久久 | 国产 在线 高清 精品 | 国产免费成人 | 91亚洲精品久久久久图片蜜桃 | 欧美贵妇性狂欢 | 天堂av免费 | 国产精品久久久久av福利动漫 | 国产精品免费视频一区二区 | 丁香激情综合久久伊人久久 | 欧美性久久久久久 | 成人免费视频在线观看 | 国产一线在线 | 天天操天天综合网 | 色瓜| 久久久久久久久久久久99 | 亚洲成人精品av | 91超碰免费在线 | adn—256中文在线观看 | 欧美日韩精品综合 | 国产小视频福利在线 | 69xxxx欧美 | 91丨九色丨国产丨porny精品 | 亚洲精品高清在线观看 | 蜜臀av.com | 国产一区二区精品久久 | 欧美午夜精品久久久久久浪潮 | 狠狠色狠狠色终合网 | 91麻豆国产福利在线观看 | 成人av网址大全 | 久久激情视频 久久 | 国产一区免费观看 | 成人黄色小视频 | 狠狠操电影网 | 亚洲欧美日韩在线一区二区 | 午夜手机看片 | 久草爱视频 | 色狠狠操 | 日韩视频免费在线观看 | 人人狠狠 | 亚洲一区 影院 | 在线观看国产成人av片 | 少妇视频在线播放 | 992tv人人网tv亚洲精品 | 国产成人在线观看 | 亚洲国产中文在线 | 国内精品久久久久久久影视麻豆 | 亚洲精品国产欧美在线观看 | 亚洲精品国产成人av在线 | 日日夜夜精品视频天天综合网 | 国产免费亚洲 | 国产视频美女 | 超碰97在线人人 | 国产成人精品久久亚洲高清不卡 | 99精品久久久久久久久久综合 | 91视频观看免费 | 天天色天天射天天综合网 | 美女网站一区 | 午夜久久电影网 | 91成人精品一区在线播放 | 天天干天天操天天操 | 国产精品成人a免费观看 | 日韩欧美在线中文字幕 | 亚洲激情中文 | 91精品国 | 99视频在线观看视频 | 欧美日韩国产亚洲乱码字幕 | 五月情婷婷 | 国产日韩精品在线 | 国产精品女同一区二区三区久久夜 | 午夜精品一区二区三区在线视频 | 免费成人在线视频网站 | 成人黄性视频 | 国产va饥渴难耐女保洁员在线观看 | 亚洲精品黄网站 | 日韩 国产| 国产成人精品国内自产拍免费看 | 激情久久影院 | 色婷婷精品大在线视频 | 免费视频a | 国产精品va在线播放 | 国产福利在线免费观看 | 日韩电影在线观看一区二区三区 | 麻豆视频在线 | 99久久99久久免费精品蜜臀 | 欧美成人性战久久 | 精品xxx| 又爽又黄又刺激的视频 | 国产高清视频 | 国产精品网站 | 日本爱爱免费视频 | 五月婷婷毛片 | 久久精品久久精品久久精品 | 日韩中文三级 | 欧美性大战| 国产在线观看免费 | 久久午夜精品影院一区 | 热re99久久精品国产66热 | 婷婷成人亚洲综合国产xv88 | 二区三区毛片 | 色5月婷婷| 久久视频免费观看 | 麻豆视频网址 | 色视频在线观看免费 | 国产精品理论片 | 日韩三区在线观看 | 天天干天天干天天 | 天天射天天 | 欧美性色黄 | 久久一区二区三区国产精品 | 免费黄色一区 | 免费看一级特黄a大片 | 97精品国产91久久久久久久 | 久久成年视频 | 国产精品久久久久久久免费观看 | 99久久99精品 | 国产精品毛片一区 | 国产日本三级 | 久久精品欧美一 | 999国内精品永久免费视频 | 国产一级在线视频 | 欧美激情综合五月色丁香小说 | 日韩女同一区二区三区在线观看 | 免费韩国av| 国产一及片 | 国产精品久久久久久一区二区 | 九七视频在线观看 | 97在线精品视频 | 久草电影免费在线观看 | 日韩精品中文字幕在线观看 | 亚洲精品国精品久久99热一 | 黄色网址av | 久久xxxx| 午夜天天操 | 色欧美88888久久久久久影院 | 欧美黄色高清 | 五月婷婷六月丁香激情 | 久久免费av电影 | 91精品国产自产91精品 | 免费日韩 精品中文字幕视频在线 | www色com| 毛片视频网址 | 精品三级av | 中日韩在线| 国产一区精品在线观看 | 日韩专区在线观看 | 99久e精品热线免费 99国产精品久久久久久久久久 | 日韩欧美在线国产 | 欧美一区成人 | 婷婷色网 | 亚洲精品视频 | 在线视频一二三 | 最新国产精品久久精品 | 免费在线播放黄色 | 一区二区视频在线免费观看 | 日韩一区二区免费在线观看 | 久久久精品国产一区二区三区 | 国产小视频在线免费观看视频 | 婷婷色网视频在线播放 | 不卡中文字幕在线 | 视频福利在线观看 | 色婷婷天天干 | 成年人免费看片 | 国产精品美女免费看 | av一级片在线观看 | 国产麻豆剧传媒免费观看 | 中文字幕 国产 一区 | 亚洲精品乱码久久久久久蜜桃91 | 国产99自拍| 97国产精品视频 | av福利在线看 | 欧美福利视频一区 | 麻豆91视频| 日本久久久久久 | 久久久久欠精品国产毛片国产毛生 | 91麻豆精品国产自产 | 久热香蕉视频 | 久久视频国产精品免费视频在线 | 99c视频在线 | 久久99爱视频 | 久久毛片网 | 成片视频免费观看 | 国产资源在线视频 | 国产一级片在线播放 | 国产一区播放 | 欧美日韩在线精品一区二区 | 久久久久女人精品毛片九一 | 色综合久久久久久久久五月 | 超碰97人| 亚洲一区二区三区毛片 | 久久tv视频 | 久久手机看片 | 婷婷国产精品 | 99视频+国产日韩欧美 | 97视频在线免费观看 | 精品免费视频123区 午夜久久成人 | 黄色毛片一级 | 黄色aa久久 | www.狠狠插.com | 丁香花在线观看视频在线 | 国产一区二区三区高清播放 | 一本色道久久精品 | 18+视频网站链接 | 久久色网站 | 久久免费精品一区二区三区 | 九九色在线观看 | 亚洲三级毛片 | 久久免费毛片视频 | 九九久久精品 | 亚洲免费av一区二区 | av天天澡天天爽天天av | 青草草在线视频 | 一区二区三区在线免费播放 | 欧美日韩精品在线观看视频 | wwwwww国产 | 欧洲亚洲精品 | 午夜久久影视 | 成人黄大片| av网站免费看 | 久久久久久久久久久影视 | 99久久精品免费看国产免费软件 | 综合久久精品 | 国产一级黄大片 | 久久字幕 | 玖玖视频国产 | 国产无限资源在线观看 | 在线色吧 | 亚洲高清资源 | 成人黄色大片 | 欧美va天堂va视频va在线 | adn—256中文在线观看 | 99精品在线免费视频 | 欧美整片sss| 日韩免费视频线观看 | 五月天综合激情网 | 中文字幕亚洲综合久久五月天色无吗'' | 成人中文字幕在线 | 久久亚洲精品国产亚洲老地址 | 亚洲三级在线播放 | 国产国语在线 | 日本精品久久久久中文字幕 | 久久精品直播 | 夜夜夜夜操 | 超碰97人人在线 | 五月激情av | 日韩欧美在线不卡 | 精品福利在线观看 | 欧美一区二区视频97 | 国产午夜精品av一区二区 | 麻豆传媒一区二区 | 91一区二区三区在线观看 | 国产精品一区二区免费视频 | 天堂网一区二区 | 永久免费毛片在线观看 | 日本乱码在线 | 成人毛片网 | 欧美另类调教 | 欧美色图亚洲图片 | 99久久久国产精品美女 | 人人射人人澡 | 久久精品视频2 | 国产精品美女视频 | 美女在线免费视频 | 国产一级片直播 | 午夜美女福利直播 | 日日日网| 欧美久久久久久久久久久久久 | 亚洲精品网页 | 欧美日韩天堂 | 午夜精品一区二区国产 | 最新免费av在线 | 国产老妇av | 国产一区二区电影在线观看 | 色综合天天综合 | 国产一区二区在线观看免费 | 亚洲亚洲精品在线观看 | 婷婷精品在线视频 | 91在线播放视频 | 天天干,夜夜爽 | 欧美性成人 | 久久精品久久久久电影 | 一区电影 | 国产精品夜夜夜一区二区三区尤 | 日韩网站在线 | 一级成人免费视频 | 久久色视频 | 91成人观看 | 69亚洲乱 | 国产精品99久久久久久人免费 | 亚洲国产日韩一区 | 92av视频| 在线看v片成人 | 麻豆国产露脸在线观看 | 色婷婷av在线 | 精品麻豆入口免费 | 婷婷99| 性色va| 久草爱视频 | www免费视频com━ | 五月婷激情 | 天堂网在线视频 | 开心激情婷婷 | 韩日视频在线 | 91av大全| 毛片网站在线看 | 亚洲年轻女教师毛茸茸 | 欧美日韩精品在线播放 | www.久久视频 | 日韩免费电影一区二区三区 | 99视 | 久久精品日本啪啪涩涩 | 五月婷网站 | 人人爽影院| 色婷婷狠狠五月综合天色拍 | 亚洲精品一区二区久 | 亚州精品在线视频 | 狠狠狠色丁香综合久久天下网 | 国产精品淫 | 色播亚洲婷婷 | 干干日日| 午夜精品久久久久久99热明星 | 欧美久久久久久久 | 免费观看性生活大片3 | www.亚洲精品| 中文字幕免费高清av | 亚洲黄色免费在线 | 欧美精品视 | 欧美一级裸体视频 | 男女拍拍免费视频 | 精品99在线视频 | 精品国产一区二区三区男人吃奶 | 久久中文字幕导航 | 国产首页| 人人玩人人添人人澡97 | 精品在线不卡 | 天堂资源在线观看视频 | 特级免费毛片 | 国产破处在线播放 | 色先锋资源网 | 成人av.com| 国产一区二区三区网站 | 亚洲丝袜一区二区 | 超碰久热 | 9热精品| 国产精品成人一区二区 | 免费看片成年人 | 色欧美88888久久久久久影院 | 久久草精品 | 91视频免费 | 午夜精品麻豆 | 国产精品久久久久久麻豆一区 | 国产 日韩 在线 亚洲 字幕 中文 | 国产999视频在线观看 | 精品国产乱码久久久久久1区2匹 | 国产精品永久免费 | 免费观看不卡av | 久久久久免费观看 | 高潮久久久久久久久 | 国产一级高清视频 | sesese图片| 在线视频你懂得 | 玖操| 久久丝袜视频 | 日韩乱色精品一区二区 | 高潮毛片无遮挡高清免费 | 日韩簧片在线观看 | 热久久精品在线 | 青青河边草观看完整版高清 | 午夜 免费 | 久久免费视频精品 | 国产精品自拍av | 亚洲乱码精品久久久久 | 99精品视频免费在线观看 | 91成人网在线播放 | 欧美性黑人 | 欧美日韩高清一区二区 | 狠狠操欧美| 亚洲精品视频在线看 | 国产一级片在线播放 | 91在线观看黄 | 91在线小视频| 综合色亚洲| 最近的中文字幕大全免费版 | 操操操日日| 韩国av三级| 国产免费国产 | 国产精品久久久久久爽爽爽 | 激情av五月婷婷 | 福利视频第一页 | 国产不卡一| 国产又粗又猛又黄 | 成年人免费看的视频 | 日韩免费看片 | 丁香九月激情 | 久久综合九色综合97_ 久久久 | 国产精品久久二区 | 中文字幕文字幕一区二区 | 国产精品女 | 久久婷婷一区二区三区 | 国产又粗又猛又爽又黄的视频先 | 久久夜色精品国产欧美一区麻豆 | 中文字幕在线看片 | 亚洲aⅴ在线观看 | 日韩大陆欧美高清视频区 | 久久免费av电影 | 黄色一级在线观看 | 日本三级全黄少妇三2023 | 91最新地址永久入口 | 国产性xxxx| 久久国产欧美日韩精品 | 免费网站污 | 日韩有码第一页 | 日韩www在线 | 国产一区视频在线观看免费 | 欧美一区二区在线免费观看 | 日韩午夜视频在线观看 | 午夜视频不卡 | 国产 在线 高清 精品 | 中午字幕在线观看 | 精品久久久久久久久久岛国gif | 欧美va在线观看 | 天天射天天干 | 久久久麻豆精品一区二区 | 福利久久久 | 国产黄色成人av | 亚洲成人av在线电影 | 91pony九色丨交换 | 在线免费av网站 | 中文字幕乱码电影 | 这里只有精品视频在线 | 色在线网站 | 亚洲免费永久精品国产 | 免费在线观看黄色网 | 亚洲aⅴ在线观看 | 色天天综合久久久久综合片 | 九九热有精品 | 天天曰天天爽 | 亚洲天堂视频在线 | 伊人久久婷婷 | 激情视频在线观看网址 | 久久久视屏| 一级黄色片网站 | 狠狠色综合网站久久久久久久 | 亚洲免费在线观看视频 | 伊人手机在线 | 日本少妇久久久 | 波多野结衣理论片 | 精品一区二区三区电影 | 成人黄色在线电影 | 久久另类视频 | 9免费视频 | 色丁香久久 | 久久老司机精品视频 | 国产精品私人影院 | 人人澡人 | 国产精品一区在线播放 | 欧美激情第一页xxx 午夜性福利 | 国产一级免费电影 | 91香蕉视频在线 | 天天干天天干天天 | 久久综合九色综合97_ 久久久 | 婷婷视频导航 | 欧美在线资源 | 在线亚洲高清视频 | 日韩成人高清在线 | 亚洲最大av网 | 插插插色综合 | 日本婷婷色 | 六月久久婷婷 | 韩国三级一区 | 国产黄色片免费看 | 91在线观看视频网站 | 国产精品毛片一区视频 | 国产免费片| 免费av在线网| 国产亚洲永久域名 | 久久国产影院 | 国产精品黄网站在线观看 | 成人试看120秒 | 亚洲精品视频在线观看免费 | 色综合久久综合中文综合网 | 久久综合毛片 | 亚洲黄色av | 97人人模人人爽人人喊网 | 中文字幕乱在线伦视频中文字幕乱码在线 | 91资源在线观看 | 天天操天天爽天天干 | 69视频国产 | freejavvideo日本免费 | 999久久久国产精品 高清av免费观看 | 国产成人黄色av | 最近中文字幕在线播放 | 99视频精品视频高清免费 | 97干com| 毛片在线播放网址 | 久久久久激情电影 | 天天射天天操天天干 | 国产精品色| 日韩免费在线网站 | 国产你懂的在线 | 三级动态视频在线观看 | 97在线免费观看 | 欧美日韩免费视频 | 国产91影院 | 国产精品18久久久久vr手机版特色 | 奇米影视四色8888 | 91九色最新地址 | 亚洲精品乱码白浆高清久久久久久 | 91在线观| 中文字幕精品一区二区精品 | 亚洲免费在线观看视频 | 波多野结衣在线中文字幕 | 日韩av电影国产 | 麻豆影视网站 | 日日干日日操 | 免费国产亚洲视频 | 亚洲成人影音 | 最近免费中文视频 | 国产精品影音先锋 | 在线观看中文av | 插综合网| 在线观看www视频 | 国产免费高清 | 狠狠色丁香婷婷综合欧美 | а中文在线天堂 | 亚州精品视频 | 国产成人精品一区二区三区免费 | 国产精品四虎 | 久久a国产| 激情欧美国产 | 亚在线播放中文视频 | 亚洲精品一区二区在线观看 | 99久久精品免费一区 | av网站地址 | 久久久久9999亚洲精品 | 亚洲成人在线免费 | 久久蜜桃av | 日韩欧美电影网 | 日韩av专区 | av在线永久免费观看 | 日韩在线大片 | 国产成人av | 国产麻豆精品95视频 | 国产精品久久久久高潮 | 99中文字幕视频 | 怡红院av久久久久久久 | 美女视频免费一区二区 | 中文字幕第一页在线视频 | 亚洲韩国一区二区三区 | 视频一区二区三区视频 | 日韩大片在线免费观看 | av网址aaa| 国产原厂视频在线观看 | 这里只有精品视频在线观看 | 国产在线综合视频 | 成人免费视频网站 | 色婷婷久久久综合中文字幕 | 免费观看一区二区三区视频 | 免费观看的黄色片 | 日韩在线三区 | 爱爱一区| 成人av一区二区在线观看 | 国产精品ssss在线亚洲 | 波多野结衣视频一区 | 中文字幕婷婷 | 狠狠色丁香久久婷婷综 | 激情综合网五月 | 国产69精品久久99不卡的观看体验 | 成人在线观看影院 | 四虎在线免费观看 | 最新国产精品拍自在线播放 | av在线免费观看网站 | 欧美精品三级在线观看 | 日韩有码网站 | 欧美一级在线看 | 国产精品精品国产婷婷这里av | 青青草华人在线视频 | 免费久久99精品国产婷婷六月 | 一级黄色片在线 | 欧美精品久久久久久久 | 免费日韩一区 | 99av在线视频| 麻豆一区在线观看 | 色之综合网 | 国产四虎在线 | 久久综合狠狠综合久久综合88 | 国产精品久久久久婷婷 | 国产高清av在线播放 | 在线黄色国产电影 | 狠狠的干 | 精品二区视频 | 69精品在线观看 | 久久综合狠狠综合 | 国产精品久久电影观看 | 波多野结衣在线观看一区二区三区 | 中文字幕日韩高清 | 激情欧美在线观看 | 人人爽人人爱 | 制服丝袜在线91 | 婷婷视频在线播放 | 精品国产乱码久久久久久久 | 亚洲精品一区二区精华 | 亚洲精品一区二区在线观看 | 又黄又爽的免费高潮视频 | 精品你懂的 | 99国产情侣在线播放 | 亚洲精品系列 | 久久伊人八月婷婷综合激情 | 欧美极度另类性三渗透 | 国产九九在线 | 国产精品18久久久久久久网站 | 亚洲欧美国产精品18p | 国产成人久久av977小说 | 免费在线观看一级片 | 久久99热国产 | 久久久免费 | 欧美一区二区精美视频 | 就要干b| 中文字幕一区二区三区四区久久 | 91精品国产99久久久久久红楼 | 久久综合九色99 | 精品国产视频在线观看 | 久久久91精品国产一区二区精品 | 久久久www成人免费毛片麻豆 | 男女免费av| 精品一区精品二区 | 久久精品9 | 在线观看v片 | 国产香蕉视频在线观看 | 玖玖视频 | 97视频免费在线观看 | 色综合久久88色综合天天人守婷 | 精品国产观看 | 成年人视频在线免费观看 | 成人免费视频视频在线观看 免费 | 国产区网址 | 中文字幕激情 | 天天狠狠操 | 国产精品青草综合久久久久99 | 国产亚洲精品久久网站 | 精品在线一区二区 | 韩国av免费观看 | 99免费视频 | 国内精品久久久久久久影视麻豆 | 国产精品久久久久久欧美 | 日韩中文字幕网站 | 国产99久久久国产精品免费二区 | 亚洲欧美视频一区二区三区 | 在线观看av免费观看 | 亚洲国产偷| 久久久久久久综合色一本 | 国产这里只有精品 | 成人免费看视频 | 国产婷婷 | 天堂va在线观看 | 日韩理论在线视频 | 国产高清在线a视频大全 | 96精品高清视频在线观看软件特色 | 国产欧美精品xxxx另类 | 成人网444ppp| 国产精选视频 | 天天干,天天操,天天射 | 国产精品欧美久久久久天天影视 | 一区二区不卡在线观看 | 久草网站在线观看 | 91精品一区国产高清在线gif | 青草视频免费观看 | 久久免费在线观看 | 五月激情姐姐 | 亚洲精品在线观看免费 | 日韩影片在线观看 | 最近中文字幕免费视频 | 中文字幕在线网 | 96亚洲精品久久久蜜桃 | 久久99最新地址 | 中文字幕日韩精品有码视频 | 久久久av免费 | 日韩电影在线观看中文字幕 | 在线观看岛国 | 亚洲一二三区精品 | 精品国产精品久久一区免费式 | 久草视频在线新免费 | 日韩精品专区在线影院重磅 | 日韩在线不卡视频 | 色就色,综合激情 | 中文字幕在线乱 | 九七在线视频 | 97超碰在线久草超碰在线观看 | 亚洲第二色 | 激情久久网 | 久久av中文字幕片 | 久久这里只有精品视频首页 | av电影免费看 | 日韩精品免费一区 | 成人免费在线视频观看 | 天天操比 | 久草资源在线观看 | 欧美日韩在线第一页 | 国产五月色婷婷六月丁香视频 | 极品嫩模被强到高潮呻吟91 | 日韩av黄 | 久草男人天堂 | 精品视频网站 | 久久久国产精品视频 | 欧美激情综合色综合啪啪五月 | 国产拍揄自揄精品视频麻豆 | 国产主播大尺度精品福利免费 | 久久99亚洲精品久久 | 久久无码av一区二区三区电影网 | 日本精a在线观看 | 在线看日韩| 成人精品99 | 午夜av影院| 免费观看一级特黄欧美大片 | 美女在线观看网站 | 最新成人在线 | 97精品国自产拍在线观看 | av天天澡天天爽天天av | 国产高清不卡一区二区三区 | www免费在线观看 | 97成人精品视频在线观看 | 在线视频精品 | av品善网| 色网站视频 | 免费中文字幕视频 | 欧美一区视频 | 综合天天| 综合亚洲视频 | 国内精品久久久久久久 | 69国产精品视频 | 五月婷婷激情六月 | 色在线网| 欧美激情在线看 | 成人午夜电影免费在线观看 | 日本字幕网 | 日日爽天天 | 国产色婷婷 | 91网在线 | 玖玖国产精品视频 | 日韩电影在线观看一区二区三区 | 国产黄色免费在线观看 | 一区二区三区在线看 | 午夜av在线电影 | 黄色av影视 | 日韩av手机在线看 | 在线免费观看黄色大片 | 黄污网 | 天天操夜夜拍 | 久久久国产精品久久久 | 亚洲欧美经典 | 免费看成年人 | 天天干天天拍天天操天天拍 | 激情小说 五月 | 国产伦理久久精品久久久久_ | 区一区二区三区中文字幕 | 国产精品一区电影 | 亚洲国产免费网站 | 成人免费网站视频 | 正在播放一区二区 | 天天干天天做天天爱 | 在线精品亚洲 | 国产精品视频永久免费播放 | 免费看十八岁美女 | 国产字幕在线观看 | 日韩电影久久 | 91视频在线国产 | 成人一级在线观看 | 最近2019年日本中文免费字幕 | 超碰人人射| 色综合天天狠天天透天天伊人 | 麻豆视传媒官网免费观看 | 久久亚洲热 | 四虎在线观看网址 | 99在线免费观看 | 国产资源网 | 精品免费一区 | 国产精品欧美久久久久天天影视 | 日韩av资源站 | 黄色录像av | 亚洲午夜久久久久 | 国产中文字幕视频在线 | .精品久久久麻豆国产精品 亚洲va欧美 | 国产精品自产拍在线观看中文 | 亚洲a成人v| 欧美一级性生活片 | 久久人人97超碰国产公开结果 | 中文字幕在线视频一区二区 | 久草在线资源观看 | 99热国产在线| 黄色三级网站在线观看 | 在线а√天堂中文官网 | 国产成人精品日本亚洲999 | 久久免费av电影 | 99热这里只有精品免费 | 精品视频 | 日日夜夜天天 | 六月丁香激情综合 | 色婷婷狠狠18 | 国产精品免费不卡 | 91亚洲视频在线观看 | 五月婷婷操 | 西西444www | 麻豆观看 | 九九在线国产视频 | 久久九九免费 | 欧美夫妻性生活电影 | 久久精品久久精品久久精品 | 国产一级二级三级视频 | 三级黄色网址 | 麻豆视频观看 | 国产精品视频地址 | 国产精品九九九九九 | 久久9999久久免费精品国产 | 夜夜操狠狠干 | 日韩黄在线观看 | 在线国产精品视频 | 日韩高清一区在线 | 在线观看亚洲视频 | 欧美aa一级 | 日韩av一区二区在线播放 | 九月婷婷综合网 | 久99久精品视频免费观看 | 一本之道乱码区 | 91日韩精品一区 | 日韩深夜在线观看 | 日韩在线视频网 | 黄色三级网站在线观看 | www.在线观看av| 三上悠亚一区二区在线观看 | 日日干美女 | 免费看国产视频 | 国模吧一区| 91精品视频一区二区三区 | 片黄色毛片黄色毛片 | 国内精品免费久久影院 | 中文字幕91 | 一区二区三区在线观看免费 |