How to use Springboot to integrate Redis is guaranteed. No more nonsense, let’s move our hands, to some sense of achievement!!
First, Redis installation
Install Redis under Windows
- Download: github.com/MSOpenTech/… .
Redis version has 32 bit and 64 bit, believe everyone’s computer system is 64 bit bar. I can’t help it. Cry haw 😰
- Start: open the Redis installation directory, enter CMD in the text bar, press Enter will pop up a CMD window
Enter the following command:
redis-server.exe redis.windows.conf
Copy the code
If the following image appears, redis has started successfully
Second, integrate Redis
Now let’s get started.
👉 Project structure diagram
👉 Importing dependencies
<! --junit-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<! --redis-->
<! Redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<exclusions>
<exclusion>
<groupId>io.lettuce</groupId>
<artifactId>lettuce-core</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.68</version>
</dependency>
Copy the code
👉 Write a configuration file
Here I put the configuration files in the resource/config directory for convenience, but the configuration is also available in the appliation.yml file
The specific placement position is shown in the figure below:
Host =127.0.0.1 # port=6380 # if there is a password redis. Password =123456 Redis. timeout=10000 # Redis. maxIdle=10 # Maximum number of database connections in the connection pool. MaxTotal #redis. MaxActive =600 # Control how many jedis instances can be allocated to a pool MaxTotal =300 # Max connection wait time. If this time is exceeded, an exception will be received. If the value is -1, there is no limit. Redis. MaxWaitMillis = 3000 # connect the minimum free time 1800000 milliseconds (30 minutes) by default redis. MinEvictableIdleTimeMillis = 300000 # every time the maximum number of release connections, 3 by default Redis. NumTestsPerEvictionRun = 1024 # from scanning time interval (ms) if is negative, do not run out of threads, Default - 1 redis. Whether timeBetweenEvictionRunsMillis = 30000 # were taken out from the pool before the connection test, if the test failed, then remove connection from the pool and try to take out another redis. TestOnBorrow = true # Check validity when idle, False by default redis. TestWhileIdle = true # redis cluster configuration. Spring. Redis cluster. The nodes = 127.0.0.1:6380127.00 0.1:6381127.00 0.1:6379 # redirection maximum number of redirects (meaning: the maximum number of redirects, such as the first failed, connected to the second, the second failed to connect to the third, The reconnect the maximum number of) spring.. Redis cluster. The Max - redirects = 3 # redis sentry mode.. Sentinel nodes = 10.122.34.111:26379,10.122. 36.111:26379Copy the code
👉 Configuration class RedisConfig
package com.gome.redis.config;
import com.alibaba.fastjson.support.spring.GenericFastJsonRedisSerializer;
import com.gome.redis.util.RedisUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import org.springframework.data.redis.connection.*;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.GenericToStringSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import redis.clients.jedis.JedisPoolConfig;
import javax.annotation.PostConstruct;
import java.util.HashSet;
import java.util.Set;
@Configuration
@PropertySource("classpath:config/redis.properties")
//@ConfigurationProperties(prefix =redis )
public class RedisConfig {
@Value("${redis.name}")
private String hostName;
@Value("${redis.host}")
private String host;
@Value("${redis.port}")
private int port;
@Value("${redis.password}")
private String password;
@Value("${redis.timeout}")
private int timeout;
@Value("${redis.maxIdle}")
private Integer maxIdle;
@Value("${redis.maxTotal}")
private Integer maxTotal;
@Value("${redis.maxWaitMillis}")
private Integer maxWaitMillis;
@Value("${redis.minEvictableIdleTimeMillis}")
private Integer minEvictableIdleTimeMillis;
@Value("${redis.numTestsPerEvictionRun}")
private Integer numTestsPerEvictionRun;
@Value("${redis.timeBetweenEvictionRunsMillis}")
private long timeBetweenEvictionRunsMillis;
@Value("${redis.testOnBorrow}")
private boolean testOnBorrow;
@Value("${redis.testWhileIdle}")
private boolean testWhileIdle;
@Value("${spring.redis.cluster.nodes}")
private String clusterNodes;
@Value("${spring.redis.cluster.max-redirects}")
private Integer mmaxRedirectsac;
@Value("${redis.sentinel.nodes}")
private String sentinelHosts;
@PostConstruct
public void init(a){
System.out.println(host);
System.out.println(port);
}
/** * JedisPoolConfig Connection pool **@return* /
@Bean(name="jedis.pool.config")
public JedisPoolConfig jedisPoolConfig(a) {
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
// Maximum free number
jedisPoolConfig.setMaxIdle(maxIdle);
// The maximum number of database connections in the connection pool
jedisPoolConfig.setMaxTotal(maxTotal);
// Maximum connection waiting time
jedisPoolConfig.setMaxWaitMillis(maxWaitMillis);
// The minimum idle time to expel connections is 1800000 milliseconds (30 minutes) by default
jedisPoolConfig.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);
// The maximum number of evicts per eviction check is 1/abs(n). The default value is 3
jedisPoolConfig.setNumTestsPerEvictionRun(numTestsPerEvictionRun);
// Eviction scan interval (milliseconds) If negative, the eviction thread will not run, default -1
jedisPoolConfig.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
// Whether to check before removing the connection from the pool, and if the check fails, remove the connection from the pool and try to remove another one
jedisPoolConfig.setTestOnBorrow(testOnBorrow);
// Check validity when idle. Default is false
jedisPoolConfig.setTestWhileIdle(testWhileIdle);
return jedisPoolConfig;
}
/** * Redis@return* /
@Bean("redis.standalone.config")
public RedisStandaloneConfiguration redisStandaloneConfiguration(a){
RedisStandaloneConfiguration config = new RedisStandaloneConfiguration();
config.setDatabase(0);
config.setHostName(host);
config.setPort(port);
config.setPassword(password);
return config;
}
/** * Cluster redis configuration *@return* /
/*@Bean("redis.cluster.config") public RedisClusterConfiguration redisClusterConfiguration(){ RedisClusterConfiguration redisClusterConfiguration = new RedisClusterConfiguration(); String[] serverHost=clusterNodes.split(","); If (serverhost. length<1){throw new RuntimeException(" Please set redis server configuration information "); } Set
ipNode = new HashSet<>(); for (String ipAndPorts : serverHost) { String[] ipAndPost=ipAndPorts.split(":"); ipNode.add(new RedisNode(ipAndPost[0].trim(), Integer.valueOf(ipAndPost[1]))); } redisClusterConfiguration.setClusterNodes(ipNode); redisClusterConfiguration.setPassword(password); redisClusterConfiguration.setMaxRedirects(mmaxRedirectsac); return redisClusterConfiguration; } * /
/*@Bean("redis.sentine.congif") public RedisSentinelConfiguration sentinelConfiguration(){ RedisSentinelConfiguration redisSentinelConfiguration = new RedisSentinelConfiguration(); RedisNode RedisNode = new RedisNode(host, port); redisNode.setName(hostName); redisSentinelConfiguration.master(redisNode); [] senHost= sentinelhosts.split (","); If (senhost. length <1) {throw new RuntimeException(" Please set redis server configuration information "); } Set
redisNodeSet = new HashSet<>(); for (String s : senHost) { String[] ipAndPost=s.split(":"); redisNodeSet.add(new RedisNode(ipAndPost[0].trim(), Integer.valueOf(ipAndPost[1]))); } redisSentinelConfiguration.setSentinels(redisNodeSet); return redisSentinelConfiguration; } * /
/** * factory *@return* /
@Bean(name = "jedis.standalone.factory")
public JedisConnectionFactory JedisStandaloneConnectionFactory(RedisStandaloneConfiguration config) {
return new JedisConnectionFactory(config);
}
/** * Cluster version factory *@param config
* @param jedisPoolConfig
* @return* /
/*@Bean(name = "jedis.cluster.factory") public JedisConnectionFactory JedisClusterConnectionFactory(RedisClusterConfiguration config,JedisPoolConfig jedisPoolConfig) { return new JedisConnectionFactory(config,jedisPoolConfig); } * /
/** ** *@param config
* @param jedisPoolConfig
* @return* /
/*@Bean(name = "jedis.sentine.factory") public JedisConnectionFactory JedisSentineConnectionFactory(RedisSentinelConfiguration config,JedisPoolConfig jedisPoolConfig) { return new JedisConnectionFactory(config,jedisPoolConfig); } * /
/** * Instantiate the RedisTemplate object * using the standalone version@Qualifier("jedis.standalone.factory"); Using cluster Edition@Qualifier("jedis.cluster.factory")
* @return* /
@Bean(name = "redis.template")
@Autowired
public RedisTemplate<String, Object> functionDomainRedisTemplate(@Qualifier("jedis.standalone.factory") JedisConnectionFactory jedisConnectionFactory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
initDomainRedisTemplate(redisTemplate, jedisConnectionFactory);
return redisTemplate;
}
/** * Set the serialization of data stored in Redis and enable transaction **@param redisTemplate
* @param factory
*/
private void initDomainRedisTemplate(RedisTemplate<String, Object> redisTemplate, JedisConnectionFactory factory) {
/ / use GenericFastJsonRedisSerializer replace the default serialization
GenericFastJsonRedisSerializer genericFastJsonRedisSerializer = new GenericFastJsonRedisSerializer();
// Set the serialization rules for key and value
redisTemplate.setKeySerializer(new GenericToStringSerializer<>(Object.class));
redisTemplate.setValueSerializer(genericFastJsonRedisSerializer);
// Set the hashKey and hashValue serialization rules
redisTemplate.setHashKeySerializer(new GenericToStringSerializer<>(Object.class));
redisTemplate.setHashValueSerializer(genericFastJsonRedisSerializer);
// Start the transaction
redisTemplate.setEnableTransactionSupport(true);
redisTemplate.setConnectionFactory(factory);
// Initialize the method after the call, without which an exception will be thrown
redisTemplate.afterPropertiesSet();
}
/** * Injection wrap RedisTemplate **@return RedisUtil
* @throws
* @Title: redisUtil
* @autor lpl
* @dateDecember 21, 2017 */
@Bean(name = "redisUtil")
public RedisUtil redisUtil(RedisTemplate<String, Object> redisTemplate) {
RedisUtil redisUtil = new RedisUtil();
redisUtil.setRedisTemplate(redisTemplate);
returnredisUtil; }}Copy the code
Note: The standalone, cluster, and Sentinel configurations are written together here. Comment out the cluster and sentinel config and Factory for standalone versions. The specific operation is as the above code. @Qualifier(“jedis.standalone. Factory “) Here change the name of the corresponding Factory bean object.
👉 RedisUtil
RedisUtil encapsulates some common operations on Redis as follows:
package com.gome.redis.util;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.TimeUnit;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.util.CollectionUtils;
public class RedisUtil {
private RedisTemplate<String, Object> redisTemplate;
public void setRedisTemplate(RedisTemplate<String, Object> redisTemplate) {
this.redisTemplate = redisTemplate;
}
/ * = = = = = = = = = = = = = = = = = = = = = = = = = = = = expiration time = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = * /
/** * specifies the cache expiration time *@paramThe key key *@paramTime Time (seconds) *@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; }}/** * Get expiration time by key *@paramThe key key cannot be NULL *@returnTime (s) returns 0 for permanently valid */
public long getExpire(String key){
return redisTemplate.getExpire(key,TimeUnit.SECONDS);
}
/** * Check whether the key exists *@paramThe key key *@returnTrue Exists false Does not exist */
public boolean exsit(String key){
try {
return redisTemplate.hasKey(key);
} catch (Exception e) {
e.printStackTrace();
return false; }}/** * delete cache *@paramKey can pass one value or more */
@SuppressWarnings("unchecked")
public void del(String ... key){
if(key! =null&&key.length>0) {if(key.length==1){
redisTemplate.delete(key[0]);
}else{ redisTemplate.delete((Collection<String>) CollectionUtils.arrayToList(key)); }}}//============================String=============================
/** * Common cache fetch *@paramThe key key *@returnValue * /
public Object get(String key){
return key==null?null:redisTemplate.opsForValue().get(key);
}
/** * Normal cache into *@paramThe key key *@paramThe value value *@returnTrue Successful false failed */
public boolean set(String key,Object value) {
try {
redisTemplate.opsForValue().set(key, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false; }}/** * Normal cache is placed and set time *@paramThe key key *@paramThe value value *@paramTime Time (s) Time must be greater than 0. If time is less than or equal to 0, the value is set indefinitely *@returnTrue Successful false failed */
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; }}/** * key increases by *@param key
* @return* /
public long incr(String key){
return redisTemplate.opsForValue().increment(key, 1L);
}
/** * increment *@paramThe key key *@paramVal is incremented by a number (greater than 0) *@return* /
public long incr(String key, long val){
if(val<0) {throw new RuntimeException("The increasing factor must be greater than zero.");
}
return redisTemplate.opsForValue().increment(key, val);
}
/** * decrements *@paramThe key key *@paramVal is reduced by a number (less than 0) *@return* /
public long decr(String key, long val){
if(val<0) {throw new RuntimeException("The decrement factor must be greater than zero.");
}
return redisTemplate.opsForValue().increment(key, -val);
}
//================================hash=================================
/**
* HashGet
* @paramThe key key cannot be NULL *@paramItem items cannot be null *@returnValue * /
public Object hget(String key,String item){
return redisTemplate.opsForHash().get(key, item);
}
/** * get all keys * corresponding to the hashKey@paramThe key key *@returnCorresponding multiple key values */
public Map<Object,Object> hmget(String key){
return redisTemplate.opsForHash().entries(key);
}
/**
* HashSet
* @paramThe key key *@paramMap corresponds to multiple key values *@returnTrue Successful false failed */
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 and set the time *@paramThe key key *@paramMap corresponds to multiple key values *@paramTime Time (seconds) *@returnTrue Successful false failed */
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; }}/** * puts data into a hash table, or creates * if none exists@paramThe key key *@paramItem item *@paramThe value value *@returnTrue Successful false failed */
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; }}/** * puts data into a hash table, or creates * if none exists@paramThe key key *@paramItem item *@paramThe value value *@paramTime Time (s) Note: If the existing hash table has time, the original time * will be replaced@returnTrue Successful false failed */
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; }}/** * Delete the value * from the hash table@paramThe key key cannot be NULL *@paramItem items can be more than null */
public void hdel(String key, Object... item){
redisTemplate.opsForHash().delete(key,item);
}
/** * Determines whether the value of the item * exists in the hash table@paramThe key key cannot be NULL *@paramItem items cannot be null *@returnTrue Exists false Does not exist */
public boolean hHasKey(String key, String item){
return redisTemplate.opsForHash().hasKey(key, item);
}
/** * hash increments that do not exist create one and return the new value *@paramThe key key *@paramItem item *@paramBy is going to be increased by how much (greater than 0) star@return* /
public double hincr(String key, String item,double by){
return redisTemplate.opsForHash().increment(key, item, by);
}
/** * hash decrement *@paramThe key key *@paramItem item *@paramI'm going to subtract by (less than 0) star@return* /
public double hdecr(String key, String item,double by){
return redisTemplate.opsForHash().increment(key, item,-by);
}
//============================set=============================
/** * Get all values in the Set based on key *@paramThe key key *@return* /
public Set<Object> sGet(String key){
try {
return redisTemplate.opsForSet().members(key);
} catch (Exception e) {
e.printStackTrace();
return null; }}/** * select * from a set based on value@paramThe key key *@paramThe value value *@returnTrue Exists false Does not exist */
public boolean sHasKey(String key,Object value){
try {
return redisTemplate.opsForSet().isMember(key, value);
} catch (Exception e) {
e.printStackTrace();
return false; }}/** * Put the data into the set cache *@paramThe key key *@paramValues can be multiple *@returnNumber of successes */
public long sSet(String key, Object... values) {
try {
return redisTemplate.opsForSet().add(key, values);
} catch (Exception e) {
e.printStackTrace();
return 0; }}/** * Put set data into cache *@paramThe key key *@paramTime Time (seconds) *@paramValues can be multiple *@returnNumber of successes */
public long sSetAndTime(String key,longtime,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; }}/** * Get the length of the set cache *@paramThe key key *@return* /
public long sGetSetSize(String key){
try {
return redisTemplate.opsForSet().size(key);
} catch (Exception e) {
e.printStackTrace();
return 0; }}/** * removes * from value@paramThe key key *@paramValues can be multiple *@returnNumber of removals */
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=================================
/** * retrieve the contents of the list cache *@paramThe key key *@paramStart to *@paramEnd End 0 to -1 represent all values *@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; }}/** * Get the length of the list cache *@paramThe key key *@return* /
public long lGetListSize(String key){
try {
return redisTemplate.opsForList().size(key);
} catch (Exception e) {
e.printStackTrace();
return 0; }}/** * Get the value * from the list by index@paramThe key key *@paramIndex index>=0, 0, 1, second element, and so on; When index<0, -1, the end of the table, the next-to-last element of -2, and so on@return* /
public Object lGetIndex(String key,long index){
try {
return redisTemplate.opsForList().index(key, index);
} catch (Exception e) {
e.printStackTrace();
return null; }}/** * put the list in the cache *@paramThe key key *@paramThe value value *@return* /
public boolean lSet(String key, Object value) {
try {
redisTemplate.opsForList().rightPush(key, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false; }}/** * put the list in the cache *@paramThe key key *@paramThe value value *@paramTime Time (seconds) *@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; }}/** * put the list in the cache *@paramThe key key *@paramThe value value *@return* /
public boolean lSet(String key, List<Object> value) {
try {
redisTemplate.opsForList().rightPushAll(key, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false; }}/** * put the list in the cache *@paramThe key key *@paramThe value value *@paramTime Time (seconds) *@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; }}/** * Modify a list of data according to the index *@paramThe key key *@paramThe index index *@paramThe value 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; }}/** * remove N values to value *@paramThe key key *@paramCount removes how many *@paramThe value value *@returnNumber of removals */
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; }}}Copy the code
👀 use
public class RedisApplicationTests extends BaseJunit {
@Autowired
@Qualifier("redisUtil")
private RedisUtil redisUtil;
@Test
public void contextLoads(a) {
boolean c = redisUtil.set("c"."1212".10);
System.out.println(redisUtil.expire("c".50));
System.out.println(redisUtil.getExpire("c"));
}
@Test
public void isOk(a){
/** * There are often scenarios where counters are needed for business requirements: a mobile phone number is limited to 5 SMS messages per day, an interface is limited to how many requests per minute, an interface is limited to how many calls per day, and so on. Using Redis Incr increment command can easily achieve this requirement. * /
String userId = "c";
}
/** * Whether to deny service *@return* /
private boolean denialOfService(String userId){
long count = redisUtil.incr(userId);
if(count<=10) {return false;
}
return true;
}
Copy the code
Note :BaseJunit is a self-encapsulated class. The specific code is as follows:
@RunWith(SpringRunner.class)
@SpringBootTest(classes = RedisApplication.class)
public class BaseJunit {}Copy the code
Well, it’s time to say goodbye again. I’m Sheik The programmer! Feel free to leave a message if you have any questions and I will recover as soon as possible. Welcome to progress together, the world and I love you too.