背景
隨著Web專案的復雜程度逐漸增加,可能會涉及諸如高并發、海量資料查詢的的業務場景也逐漸增多;若頻繁的操作資料庫,會觸發資料庫的I/O瓶頸,因此需要加入快取,盡量減少直接操作資料庫的頻率和次數;同時在分布式系統中,分布式鎖等應用場景也需要依賴redis等快取資料庫;redis作為nosql資料庫的代表,擁有廣泛的應用場景;
這里介紹下Spring集成redis,實作快取:
準備作業:
1.引入依賴;
<!-- jedis 客戶端 -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.8.2</version>
</dependency>
<!-- spring data redis -->
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
<version>1.7.11.RELEASE</version>
</dependency>
2.定義 redis.proerties 檔案,配置連接池相關引數;
# redis configuration
# 連接池配置
redis.maxTotal=30
redis.maxIdle=10
redis.softMinEvictableIdleTimeMillis=10000
redis.blockWhenExhausted=true
redis.maxWaitMillis=1500
redis.testOnBorrow=false
redis.testWhileIdle=true
redis.timeBetweenEvictionRunsMillis=30000
redis.numTestsPerEvictionRun=1024
redis.minEvictableIdleTimeMillis=180000
# 單機配置
redis.host=169.254.244.131
redis.port=6379
# 自己選擇是否開啟密碼
redis.password=123456
# 集群配置
redis.host1=169.254.244.131
redis.port1=7001
redis.host2=169.254.244.131
redis.port2=7002
redis.host3=169.254.244.131
redis.port3=7003
redis.host4=169.254.244.131
redis.port4=7004
redis.host5=169.254.244.131
redis.port5=7005
redis.host6=169.254.244.131
redis.port6=7006
3.連接池配置引入spring背景關系中;
<!--加載屬性檔案-->
<bean >
<property name="locations">
<list>
<value>classpath:redis.properties</value>
</list>
</property>
<!-- 在多個spring組態檔中都配置了屬性檔案加載 必須設定為true -->
<property name="ignoreUnresolvablePlaceholders" value="https://www.cnblogs.com/herokevin/p/true"/>
</bean>
單機版
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 連接池配置 -->
<bean id="jedisPoolConfig" >
<!-- 最大連接數 -->
<property name="maxTotal" value="https://www.cnblogs.com/herokevin/p/${redis.maxTotal}" />
<!-- 最大空閑連接數 -->
<property name="maxIdle" value="https://www.cnblogs.com/herokevin/p/${redis.maxIdle}" />
<!-- 連接空閑多久后釋放, 當空閑時間>該值且空閑連接>最大空閑連接數時直接釋放 -->
<property name="softMinEvictableIdleTimeMillis" value="https://www.cnblogs.com/herokevin/p/${redis.softMinEvictableIdleTimeMillis}" />
<!-- 連接用盡后,呼叫者是否需要等待 設定為true時,maxWaitMillis才會起作用 -->
<property name="blockWhenExhausted" value="https://www.cnblogs.com/herokevin/p/${redis.blockWhenExhausted}" />
<!-- 連接用盡后,呼叫者的最大等待時間,-1表示永不超時 -->
<property name="maxWaitMillis" value="https://www.cnblogs.com/herokevin/p/${redis.maxWaitMillis}" />
<!-- 向連接池獲取連接時是否進行有效性檢測,無效連接會被移除,業務量大時建議關閉 -->
<property name="testOnBorrow" value="https://www.cnblogs.com/herokevin/p/${redis.testOnBorrow}" />
<!-- 開啟空閑資源監測,建議開啟 -->
<property name="testWhileIdle" value="https://www.cnblogs.com/herokevin/p/${redis.testWhileIdle}" />
<!-- 空閑資源檢測周期 -->
<property name="timeBetweenEvictionRunsMillis" value="https://www.cnblogs.com/herokevin/p/${redis.timeBetweenEvictionRunsMillis}" />
<!-- 空閑資源檢測時,每次的采樣數量 設定為-1表示對所有連接做空閑檢測 -->
<property name="numTestsPerEvictionRun" value="https://www.cnblogs.com/herokevin/p/${redis.numTestsPerEvictionRun}" />
<!-- 連接池中資源最小空閑時間,達到值后空閑連接將被移除 -->
<property name="minEvictableIdleTimeMillis" value="https://www.cnblogs.com/herokevin/p/${redis.minEvictableIdleTimeMillis}" />
</bean>
<!-- 連接工廠 -->
<bean id="jedisConnectionFactory" >
<property name="poolConfig" ref="jedisPoolConfig" />
<property name="hostName" value="https://www.cnblogs.com/herokevin/p/${redis.host}" />
<property name="port" value="https://www.cnblogs.com/herokevin/p/${redis.port}" />
<property name="password" value="https://www.cnblogs.com/herokevin/p/${redis.password}" />
</bean>
<!-- redis快取 jackon序列化 -->
<bean id="redisJacksonTemplate" >
<property name="connectionFactory" ref="jedisConnectionFactory" />
<!--如果不配置Serializer,那么存盤的時候預設使用String,如果用User型別存盤,那么會提示錯誤User can't cast to String!! -->
<property name="keySerializer">
<bean />
</property>
<property name="valueSerializer">
<bean />
</property>
<property name="hashKeySerializer">
<bean />
</property>
<property name="hashValueSerializer">
<bean />
</property>
<!-- 事務支持 默認關閉,若開啟事務,會出現錯誤,需要手動解決 -->
<property name="enableTransactionSupport" value="https://www.cnblogs.com/herokevin/p/false" />
</bean>
</beans>
通過將 RedisTemplate 注入到 spring bean 中即可操作 redis;
集群版
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 連接池配置 -->
<bean id="jedisPoolConfig" >
<!-- 最大連接數 -->
<property name="maxTotal" value="https://www.cnblogs.com/herokevin/p/${redis.maxTotal}" />
<!-- 最大空閑連接數 -->
<property name="maxIdle" value="https://www.cnblogs.com/herokevin/p/${redis.maxIdle}" />
<!-- 連接空閑多久后釋放, 當空閑時間>該值且空閑連接>最大空閑連接數時直接釋放 -->
<property name="softMinEvictableIdleTimeMillis" value="https://www.cnblogs.com/herokevin/p/${redis.softMinEvictableIdleTimeMillis}" />
<!-- 連接用盡后,呼叫者是否需要等待 設定為true時,maxWaitMillis才會起作用 -->
<property name="blockWhenExhausted" value="https://www.cnblogs.com/herokevin/p/${redis.blockWhenExhausted}" />
<!-- 連接用盡后,呼叫者的最大等待時間,-1表示永不超時 -->
<property name="maxWaitMillis" value="https://www.cnblogs.com/herokevin/p/${redis.maxWaitMillis}" />
<!-- 向連接池獲取連接時是否進行有效性檢測,無效連接會被移除,業務量大時建議關閉 -->
<property name="testOnBorrow" value="https://www.cnblogs.com/herokevin/p/${redis.testOnBorrow}" />
<!-- 開啟空閑資源監測,建議開啟 -->
<property name="testWhileIdle" value="https://www.cnblogs.com/herokevin/p/${redis.testWhileIdle}" />
<!-- 空閑資源檢測周期 -->
<property name="timeBetweenEvictionRunsMillis" value="https://www.cnblogs.com/herokevin/p/${redis.timeBetweenEvictionRunsMillis}" />
<!-- 空閑資源檢測時,每次的采樣數量 設定為-1表示對所有連接做空閑檢測 -->
<property name="numTestsPerEvictionRun" value="https://www.cnblogs.com/herokevin/p/${redis.numTestsPerEvictionRun}" />
<!-- 連接池中資源最小空閑時間,達到值后空閑連接將被移除 -->
<property name="minEvictableIdleTimeMillis" value="https://www.cnblogs.com/herokevin/p/${redis.minEvictableIdleTimeMillis}" />
</bean>
<!-- 集群配置 -->
<bean id="redisClusterConfig" >
<property name="maxRedirects" value="https://www.cnblogs.com/herokevin/p/3" />
<!-- 節點配置 -->
<property name="clusterNodes">
<set>
<bean >
<constructor-arg name="host" value="https://www.cnblogs.com/herokevin/p/${redis.host1}" />
<constructor-arg name="port" value="https://www.cnblogs.com/herokevin/p/${redis.port1}" />
</bean>
<bean >
<constructor-arg name="host" value="https://www.cnblogs.com/herokevin/p/${redis.host2}" />
<constructor-arg name="port" value="https://www.cnblogs.com/herokevin/p/${redis.port2}" />
</bean>
<bean >
<constructor-arg name="host" value="https://www.cnblogs.com/herokevin/p/${redis.host3}" />
<constructor-arg name="port" value="https://www.cnblogs.com/herokevin/p/${redis.port3}" />
</bean>
<bean >
<constructor-arg name="host" value="https://www.cnblogs.com/herokevin/p/${redis.host4}" />
<constructor-arg name="port" value="https://www.cnblogs.com/herokevin/p/${redis.port4}" />
</bean>
<bean >
<constructor-arg name="host" value="https://www.cnblogs.com/herokevin/p/${redis.host5}" />
<constructor-arg name="port" value="https://www.cnblogs.com/herokevin/p/${redis.port5}" />
</bean>
<bean >
<constructor-arg name="host" value="https://www.cnblogs.com/herokevin/p/${redis.host6}" />
<constructor-arg name="port" value="https://www.cnblogs.com/herokevin/p/${redis.port6}" />
</bean>
</set>
</property>
</bean>
<!-- 連接工廠 -->
<bean id="jedisConnectionFactory" >
<!-- 集群配置 -->
<constructor-arg index="0" ref="redisClusterConfig" />
<!-- 連接池配置 -->
<constructor-arg index="1" ref="jedisPoolConfig" />
</bean>
<!-- redis快取 jackon序列化 -->
<bean id="redisJacksonTemplate" >
<property name="connectionFactory" ref="jedisConnectionFactory" />
<!--如果不配置Serializer,那么存盤的時候預設使用String,如果用User型別存盤,那么會提示錯誤User can't cast to String!! -->
<property name="keySerializer">
<bean />
</property>
<property name="valueSerializer">
<bean />
</property>
<property name="hashKeySerializer">
<bean />
</property>
<property name="hashValueSerializer">
<bean />
</property>
<!-- 事務支持 默認關閉,若開啟事務,會出現錯誤,需要手動解決 -->
<property name="enableTransactionSupport" value="https://www.cnblogs.com/herokevin/p/false" />
</bean>
</beans>
通過將 RedisTemplate 注入到 spring bean 中即可對 redis集群進行操作;
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/415900.html
標籤:Java
上一篇:ThreadLocal
