Redis與SSM框架整合應用之一
我們在建設和應用網際網路架構時,往往需要考慮高併發、高效能的要求,為也提高系統的響應速度,往往需要採用快取技術,在這裡我使用的是Redis快取技術,把一些變動頻率較低的資料放在快取中,提高系統訪問速度,下面主要講解Redis在SSM框架中如何去整合和實現。
一、搭建Redis環境
在這裡我是在阿里雲伺服器上搭建了一個Redis伺服器,首先去https://redis.io/download下載Tar包,這裡我下載的是redis-4.0.2.tar.gz ,然後上傳到伺服器中,通過下面命令進行解壓
tar -zxvf redis-4.0.2.tar.gz
進行解壓之後,再執行下面的命令:
設定redis以支援遠端登入
vi redis-4.0.2/redis.conf
將bind 127.0.0.1這句話用井號註釋掉,這樣就能支援遠端連線了
此外,還需要給redis.conf新增配置以支援redis作為守護程序一直跑在後臺
設定 daemonize yes
再設定redis的保護模式為No,預設是Yes,不同IP的伺服器都可以訪問使用
protected-mode no
安裝redis
去到解壓後的目錄裡
cd redis-4.0.2
make //安裝redis
啟動redis服務
src/redis-server redis.conf
redis連線測試
通過redis-cli連線到redis伺服器
src/redis-cli
當輸入ping 得到pong的迴應之後,證明redis配置已經完成
重啟Redis
共三個步驟:先找到Redis程序,然後Kill掉,再啟動,如下圖:
對就的命令:
ps -ef |grep redis
kill -9 程序ID
src/redis-server redis.conf start
二、在工程中新建Redis配置檔案
工程中需要新建兩個配置檔案:redis.properties、spring-redis.xml
redis.properties內容如下:
redis.hostname=47.94.3.11 redis.port=6379 redis.database=0 redis.pool.maxActive=600 redis.pool.maxIdle=300 redis.pool.maxWait=3000 redis.pool.testOnBorrow=true
spring-redis.xml的內容如下:
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.2.xsd">
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxTotal" value="${redis.pool.maxActive}" />
<property name="maxIdle" value="${redis.pool.maxIdle}" />
<property name="maxWaitMillis" value="${redis.pool.maxWait}" />
<property name="testOnBorrow" value="${redis.pool.testOnBorrow}" />
</bean>
<bean id="jedisWritePool" class="com.imooc.myo2o.cache.JedisPoolWriper"
depends-on="jedisPoolConfig">
<constructor-arg index="0" ref="jedisPoolConfig" />
<constructor-arg index="1" value="${redis.hostname}" />
<constructor-arg index="2" value="${redis.port}" type="int" />
</bean>
<bean id="jedisKeys" class="com.imooc.myo2o.cache.JedisUtil$Keys"
scope="singleton">
<constructor-arg ref="jedisUtil"></constructor-arg>
</bean>
<bean id="jedisStrings" class="com.imooc.myo2o.cache.JedisUtil$Strings"
scope="singleton">
<constructor-arg ref="jedisUtil"></constructor-arg>
</bean>
<bean id="jedisLists" class="com.imooc.myo2o.cache.JedisUtil$Lists"
scope="singleton">
<constructor-arg ref="jedisUtil"></constructor-arg>
</bean>
<bean id="jedisSets" class="com.imooc.myo2o.cache.JedisUtil$Sets"
scope="singleton">
<constructor-arg ref="jedisUtil"></constructor-arg>
</bean>
<bean id="jedisHash" class="com.imooc.myo2o.cache.JedisUtil$Hash"
scope="singleton">
<constructor-arg ref="jedisUtil"></constructor-arg>
</bean>
<bean id="jedisUtil" class="com.imooc.myo2o.cache.JedisUtil"
scope="singleton">
<property name="jedisPool">
<ref bean="jedisWritePool" />
</property>
</bean>
</beans>
注意:通過這兩個檔案把redis的基本配置裝載到jedis客戶端(jedisWritePool)進行管理,其中jedisWritePool是自己寫的類,下面詳細介紹;通過配置把jedisKeys、jedisStrings等類設定單例模式,便於統一維護Redis的鍵值對。
三、在web.xml中設定spring-redis.xml,通過DispacherServlet容器進行載入入記憶體中
web.xml的配置如下:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" metadata-complete="true" version="3.1">
<servlet>
<servlet-name>Kaptcha</servlet-name>
<servlet-class>com.google.code.kaptcha.servlet.KaptchaServlet</servlet-class>
<init-param>
<param-name>kaptcha.border</param-name>
<param-value>no</param-value>
</init-param>
<init-param>
<param-name>kaptcha.textproducer.font.color</param-name>
<param-value>red</param-value>
</init-param>
<init-param>
<param-name>kaptcha.image.width</param-name>
<param-value>135</param-value>
</init-param>
<init-param>
<param-name>kaptcha.textproducer.char.string</param-name>
<param-value>ACDEFHKPRSTWX345679</param-value>
</init-param>
<init-param>
<param-name>kaptcha.image.height</param-name>
<param-value>50</param-value>
</init-param>
<init-param>
<param-name>kaptcha.textproducer.font.size</param-name>
<param-value>43</param-value>
</init-param>
<init-param>
<param-name>kaptcha.noise.color</param-name>
<param-value>black</param-value>
</init-param>
<init-param>
<param-name>kaptcha.textproducer.char.length</param-name>
<param-value>4</param-value>
</init-param>
<init-param>
<param-name>kaptcha.textproducer.font.names</param-name>
<param-value>Arial</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>Kaptcha</servlet-name>
<url-pattern>/Kaptcha</url-pattern>
</servlet-mapping>
<servlet>
<servlet-name>seckill-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring/spring-*.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>seckill-dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
四、編寫redis連線池類(jedisWritePool)管理連線,編寫redis操作類(JedisUtil)操作Redis資料庫
jedisWritePool類程式碼如下:
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
/**
* 強指定redis的JedisPool介面建構函式,這樣才能在centos成功建立jedispool
*
* @author xiangze
*
*/
public class JedisPoolWriper {
private JedisPool jedisPool;
public JedisPoolWriper(final JedisPoolConfig poolConfig, final String host,
final int port) {
try {
jedisPool = new JedisPool(poolConfig, host, port);
} catch (Exception e) {
e.printStackTrace();
}
}
public JedisPool getJedisPool() {
return jedisPool;
}
public void setJedisPool(JedisPool jedisPool) {
this.jedisPool = jedisPool;
}
}
JedisUtil類程式碼如下:
import java.util.List;
import java.util.Map;
import java.util.Set;
import redis.clients.jedis.BinaryClient.LIST_POSITION;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.SortingParams;
import redis.clients.util.SafeEncoder;
public class JedisUtil {
/**
* 快取生存時間
*/
private final int expire = 60000;
/** 操作Key的方法 */
public Keys KEYS;
/** 對儲存結構為String型別的操作 */
public Strings STRINGS;
/** 對儲存結構為List型別的操作 */
public Lists LISTS;
/** 對儲存結構為Set型別的操作 */
public Sets SETS;
/** 對儲存結構為HashMap型別的操作 */
public Hash HASH;
private JedisPool jedisPool;
public JedisPool getJedisPool() {
return jedisPool;
}
public void setJedisPool(JedisPoolWriper jedisPoolWriper) {
this.jedisPool = jedisPoolWriper.getJedisPool();
}
public JedisPool getPool() {
return jedisPool;
}
/**
* 從jedis連線池中獲取獲取jedis物件
*
* @return
*/
public Jedis getJedis() {
return jedisPool.getResource();
}
/**
* 設定過期時間
*
* @author ruan 2013-4-11
* @param key
* @param seconds
*/
public void expire(String key, int seconds) {
if (seconds <= 0) {
return;
}
Jedis jedis = getJedis();
jedis.expire(key, seconds);
jedis.close();
}
/**
* 設定預設過期時間
*
* @author ruan 2013-4-11
* @param key
*/
public void expire(String key) {
expire(key, expire);
}
// *******************************************Keys*******************************************//
public class Keys {
/**
* 清空所有key
*/
public String flushAll() {
Jedis jedis = getJedis();
String stata = jedis.flushAll();
jedis.close();
return stata;
}
/**
* 更改key
*
* @param String
* oldkey
* @param String
* newkey
* @return 狀態碼
* */
public String rename(String oldkey, String newkey) {
return rename(SafeEncoder.encode(oldkey),
SafeEncoder.encode(newkey));
}
/**
* 更改key,僅當新key不存在時才執行
*
* @param String
* oldkey
* @param String
* newkey
* @return 狀態碼
* */
public long renamenx(String oldkey, String newkey) {
Jedis jedis = getJedis();
long status = jedis.renamenx(oldkey, newkey);
jedis.close();
return status;
}
/**
* 更改key
*
* @param String
* oldkey
* @param String
* newkey
* @return 狀態碼
* */
public String rename(byte[] oldkey, byte[] newkey) {
Jedis jedis = getJedis();
String status = jedis.rename(oldkey, newkey);
jedis.close();
return status;
}
/**
* 設定key的過期時間,以秒為單位
*
* @param String
* key
* @param 時間
* ,已秒為單位
* @return 影響的記錄數
* */
public long expired(String key, int seconds) {
Jedis jedis = getJedis();
long count = jedis.expire(key, seconds);
jedis.close();
return count;
}
/**
* 設定key的過期時間,它是距曆元(即格林威治標準時間 1970 年 1 月 1 日的 00:00:00,格里高利曆)的偏移量。
*
* @param String
* key
* @param 時間
* ,已秒為單位
* @return 影響的記錄數
* */
public long expireAt(String key, long timestamp) {
Jedis jedis = getJedis();
long count = jedis.expireAt(key, timestamp);
jedis.close();
return count;
}
/**
* 查詢key的過期時間
*
* @param String
* key
* @return 以秒為單位的時間表示
* */
public long ttl(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
long len = sjedis.ttl(key);
sjedis.close();
return len;
}
/**
* 取消對key過期時間的設定
*
* @param key
* @return 影響的記錄數
* */
public long persist(String key) {
Jedis jedis = getJedis();
long count = jedis.persist(key);
jedis.close();
return count;
}
/**
* 刪除keys對應的記錄,可以是多個key
*
* @param String
* ... keys
* @return 刪除的記錄數
* */
public long del(String... keys) {
Jedis jedis = getJedis();
long count = jedis.del(keys);
jedis.close();
return count;
}
/**
* 刪除keys對應的記錄,可以是多個key
*
* @param String
* ... keys
* @return 刪除的記錄數
* */
public long del(byte[]... keys) {
Jedis jedis = getJedis();
long count = jedis.del(keys);
jedis.close();
return count;
}
/**
* 判斷key是否存在
*
* @param String
* key
* @return boolean
* */
public boolean exists(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
boolean exis = sjedis.exists(key);
sjedis.close();
return exis;
}
/**
* 對List,Set,SortSet進行排序,如果集合資料較大應避免使用這個方法
*
* @param String
* key
* @return List<String> 集合的全部記錄
* **/
public List<String> sort(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
List<String> list = sjedis.sort(key);
sjedis.close();
return list;
}
/**
* 對List,Set,SortSet進行排序或limit
*
* @param String
* key
* @param SortingParams
* parame 定義排序型別或limit的起止位置.
* @return List<String> 全部或部分記錄
* **/
public List<String> sort(String key, SortingParams parame) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
List<String> list = sjedis.sort(key, parame);
sjedis.close();
return list;
}
/**
* 返回指定key儲存的型別
*
* @param String
* key
* @return String string|list|set|zset|hash
* **/
public String type(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
String type = sjedis.type(key);
sjedis.close();
return type;
}
/**
* 查詢所有匹配給定的模式的鍵
*
* @param String
* key的表示式,*表示多個,?表示一個
* */
public Set<String> keys(String pattern) {
Jedis jedis = getJedis();
Set<String> set = jedis.keys(pattern);
jedis.close();
return set;
}
}
// *******************************************Sets*******************************************//
public class Sets {
/**
* 向Set新增一條記錄,如果member已存在返回0,否則返回1
*
* @param String
* key
* @param String
* member
* @return 操作碼,0或1
* */
public long sadd(String key, String member) {
Jedis jedis = getJedis();
long s = jedis.sadd(key, member);
jedis.close();
return s;
}
public long sadd(byte[] key, byte[] member) {
Jedis jedis = getJedis();
long s = jedis.sadd(key, member);
jedis.close();
return s;
}
/**
* 獲取給定key中元素個數
*
* @param String
* key
* @return 元素個數
* */
public long scard(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
long len = sjedis.scard(key);
sjedis.close();
return len;
}
/**
* 返回從第一組和所有的給定集合之間的差異的成員
*
* @param String
* ... keys
* @return 差異的成員集合
* */
public Set<String> sdiff(String... keys) {
Jedis jedis = getJedis();
Set<String> set = jedis.sdiff(keys);
jedis.close();
return set;
}
/**
* 這個命令等於sdiff,但返回的不是結果集,而是將結果集儲存在新的集合中,如果目標已存在,則覆蓋。
*
* @param String
* newkey 新結果集的key
* @param String
* ... keys 比較的集合
* @return 新集合中的記錄數
* **/
public long sdiffstore(String newkey, String... keys) {
Jedis jedis = getJedis();
long s = jedis.sdiffstore(newkey, keys);
jedis.close();
return s;
}
/**
* 返回給定集合交集的成員,如果其中一個集合為不存在或為空,則返回空Set
*
* @param String
* ... keys
* @return 交整合員的集合
* **/
public Set<String> sinter(String... keys) {
Jedis jedis = getJedis();
Set<String> set = jedis.sinter(keys);
jedis.close();
return set;
}
/**
* 這個命令等於sinter,但返回的不是結果集,而是將結果集儲存在新的集合中,如果目標已存在,則覆蓋。
*
* @param String
* newkey 新結果集的key
* @param String
* ... keys 比較的集合
* @return 新集合中的記錄數
* **/
public long sinterstore(String newkey, String... keys) {
Jedis jedis = getJedis();
long s = jedis.sinterstore(newkey, keys);
jedis.close();
return s;
}
/**
* 確定一個給定的值是否存在
*
* @param String
* key
* @param String
* member 要判斷的值
* @return 存在返回1,不存在返回0
* **/
public boolean sismember(String key, String member) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
boolean s = sjedis.sismember(key, member);
sjedis.close();
return s;
}
/**
* 返回集合中的所有成員
*
* @param String
* key
* @return 成員集合
* */
public Set<String> smembers(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
Set<String> set = sjedis.smembers(key);
sjedis.close();
return set;
}
public Set<byte[]> smembers(byte[] key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
Set<byte[]> set = sjedis.smembers(key);
sjedis.close();
return set;
}
/**
* 將成員從源集合移出放入目標集合 <br/>
* 如果源集合不存在或不包哈指定成員,不進行任何操作,返回0<br/>
* 否則該成員從源集合上刪除,並新增到目標集合,如果目標集合中成員已存在,則只在源集合進行刪除
*
* @param String
* srckey 源集合
* @param String
* dstkey 目標集合
* @param String
* member 源集合中的成員
* @return 狀態碼,1成功,0失敗
* */
public long smove(String srckey, String dstkey, String member) {
Jedis jedis = getJedis();
long s = jedis.smove(srckey, dstkey, member);
jedis.close();
return s;
}
/**
* 從集合中刪除成員
*
* @param String
* key
* @return 被刪除的成員
* */
public String spop(String key) {
Jedis jedis = getJedis();
String s = jedis.spop(key);
jedis.close();
return s;
}
/**
* 從集合中刪除指定成員
*
* @param String
* key
* @param String
* member 要刪除的成員
* @return 狀態碼,成功返回1,成員不存在返回0
* */
public long srem(String key, String member) {
Jedis jedis = getJedis();
long s = jedis.srem(key, member);
jedis.close();
return s;
}
/**
* 合併多個集合並返回合併後的結果,合併後的結果集合並不儲存<br/>
*
* @param String
* ... keys
* @return 合併後的結果集合
* @see sunionstore
* */
public Set<String> sunion(String... keys) {
Jedis jedis = getJedis();
Set<String> set = jedis.sunion(keys);
jedis.close();
return set;
}
/**
* 合併多個集合並將合併後的結果集儲存在指定的新集合中,如果新集合已經存在則覆蓋
*
* @param String
* newkey 新集合的key
* @param String
* ... keys 要合併的集合
* **/
public long sunionstore(String newkey, String... keys) {
Jedis jedis = getJedis();
long s = jedis.sunionstore(newkey, keys);
jedis.close();
return s;
}
}
// *******************************************Hash*******************************************//
public class Hash {
/**
* 從hash中刪除指定的儲存
*
* @param String
* key
* @param String
* fieid 儲存的名字
* @return 狀態碼,1成功,0失敗
* */
public long hdel(String key, String fieid) {
Jedis jedis = getJedis();
long s = jedis.hdel(key, fieid);
jedis.close();
return s;
}
public long hdel(String key) {
Jedis jedis = getJedis();
long s = jedis.del(key);
jedis.close();
return s;
}
/**
* 測試hash中指定的儲存是否存在
*
* @param String
* key
* @param String
* fieid 儲存的名字
* @return 1存在,0不存在
* */
public boolean hexists(String key, String fieid) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
boolean s = sjedis.hexists(key, fieid);
sjedis.close();
return s;
}
/**
* 返回hash中指定儲存位置的值
*
* @param String
* key
* @param String
* fieid 儲存的名字
* @return 儲存對應的值
* */
public String hget(String key, String fieid) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
String s = sjedis.hget(key, fieid);
sjedis.close();
return s;
}
public byte[] hget(byte[] key, byte[] fieid) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
byte[] s = sjedis.hget(key, fieid);
sjedis.close();
return s;
}
/**
* 以Map的形式返回hash中的儲存和值
*
* @param String
* key
* @return Map<Strinig,String>
* */
public Map<String, String> hgetAll(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
Map<String, String> map = sjedis.hgetAll(key);
sjedis.close();
return map;
}
/**
* 新增一個對應關係
*
* @param String
* key
* @param String
* fieid
* @param String
* value
* @return 狀態碼 1成功,0失敗,fieid已存在將更新,也返回0
* **/
public long hset(String key, String fieid, String value) {
Jedis jedis = getJedis();
long s = jedis.hset(key, fieid, value);
jedis.close();
return s;
}
public long hset(String key, String fieid, byte[] value) {
Jedis jedis = getJedis();
long s = jedis.hset(key.getBytes(), fieid.getBytes(), value);
jedis.close();
return s;
}
/**
* 新增對應關係,只有在fieid不存在時才執行
*
* @param String
* key
* @param String
* fieid
* @param String
* value
* @return 狀態碼 1成功,0失敗fieid已存
* **/
public long hsetnx(String key, String fieid, String value) {
Jedis jedis = getJedis();
long s = jedis.hsetnx(key, fieid, value);
jedis.close();
return s;
}
/**
* 獲取hash中value的集合
*
* @param String
* key
* @return List<String>
* */
public List<String> hvals(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
List<String> list = sjedis.hvals(key);
sjedis.close();
return list;
}
/**
* 在指定的儲存位置加上指定的數字,儲存位置的值必須可轉為數字型別
*
* @param String
* key
* @param String
* fieid 儲存位置
* @param String
* long value 要增加的值,可以是負數
* @return 增加指定數字後,儲存位置的值
* */
public long hincrby(String key, String fieid, long value) {
Jedis jedis = getJedis();
long s = jedis.hincrBy(key, fieid, value);
jedis.close();
return s;
}
/**
* 返回指定hash中的所有儲存名字,類似Map中的keySet方法
*
* @param String
* key
* @return Set<String> 儲存名稱的集合
* */
public Set<String> hkeys(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
Set<String> set = sjedis.hkeys(key);
sjedis.close();
return set;
}
/**
* 獲取hash中儲存的個數,類似Map中size方法
*
* @param String
* key
* @return long 儲存的個數
* */
public long hlen(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
long len = sjedis.hlen(key);
sjedis.close();
return len;
}
/**
* 根據多個key,獲取對應的value,返回List,如果指定的key不存在,List對應位置為null
*
* @param String
* key
* @param String
* ... fieids 儲存位置
* @return List<String>
* */
public List<String> hmget(String key, String... fieids) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
List<String> list = sjedis.hmget(key, fieids);
sjedis.close();
return list;
}
public List<byte[]> hmget(byte[] key, byte[]... fieids) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
List<byte[]> list = sjedis.hmget(key, fieids);
sjedis.close();
return list;
}
/**
* 新增對應關係,如果對應關係已存在,則覆蓋
*
* @param Strin
* key
* @param Map
* <String,String> 對應關係
* @return 狀態,成功返回OK
* */
public String hmset(String key, Map<String, String> map) {
Jedis jedis = getJedis();
String s = jedis.hmset(key, map);
jedis.close();
return s;
}
/**
* 新增對應關係,如果對應關係已存在,則覆蓋
*
* @param Strin
* key
* @param Map
* <String,String> 對應關係
* @return 狀態,成功返回OK
* */
public String hmset(byte[] key, Map<byte[], byte[]> map) {
Jedis jedis = getJedis();
String s = jedis.hmset(key, map);
jedis.close();
return s;
}
}
// *******************************************Strings*******************************************//
public class Strings {
/**
* 根據key獲取記錄
*
* @param String
* key
* @return 值
* */
public String get(String key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
String value = sjedis.get(key);
sjedis.close();
return value;
}
/**
* 根據key獲取記錄
*
* @param byte[] key
* @return 值
* */
public byte[] get(byte[] key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
byte[] value = sjedis.get(key);
sjedis.close();
return value;
}
/**
* 新增有過期時間的記錄
*
* @param String
* key
* @param int seconds 過期時間,以秒為單位
* @param String
* value
* @return String 操作狀態
* */
public String setEx(String key, int seconds, String value) {
Jedis jedis = getJedis();
String str = jedis.setex(key, seconds, value);
jedis.close();
return str;
}
/**
* 新增有過期時間的記錄
*
* @param String
* key
* @param int seconds 過期時間,以秒為單位
* @param String
* value
* @return String 操作狀態
* */
public String setEx(byte[] key, int seconds, byte[] value) {
Jedis jedis = getJedis();
String str = jedis.setex(key, seconds, value);
jedis.close();
return str;
}
/**
* 新增一條記錄,僅當給定的key不存在時才插入
*
* @param String
* key
* @param String
* value
* @return long 狀態碼,1插入成功且key不存在,0未插入,key存在
* */
public long setnx(String key, String value) {
Jedis jedis = getJedis();
long str = jedis.setnx(key, value);
jedis.close();
return str;
}
/**
* 新增記錄,如果記錄已存在將覆蓋原有的value
*
* @param String
* key
* @param String
* value
* @return 狀態碼
* */
public String set(String key, String value) {
return set(SafeEncoder.encode(key), SafeEncoder.encode(value));
}
/**
* 新增記錄,如果記錄已存在將覆蓋原有的value
*
* @param String
* key
* @param String
* value
* @return 狀態碼
* */
public String set(String key, byte[] value) {
return set(SafeEncoder.encode(key), value);
}
/**
* 新增記錄,如果記錄已存在將覆蓋原有的value
*
* @param byte[] key
* @param byte[] value
* @return 狀態碼
* */
public String set(byte[] key, byte[] value) {
Jedis jedis = getJedis();
String status = jedis.set(key, value);
jedis.close();
return status;
}
/**
* 從指定位置開始插入資料,插入的資料會覆蓋指定位置以後的資料<br/>
* 例:String str1="123456789";<br/>
* 對str1操作後setRange(key,4,0000),str1="123400009";
*
* @param String
* key
* @param long offset
* @param String
* value
* @return long value的長度
* */
public long setRange(String key, long offset, String value) {
Jedis jedis = getJedis();
long len = jedis.setrange(key, offset, value);
jedis.close();
return len;
}
/**
* 在指定的key中追加value
*
* @param String
* key
* @param String
* value
* @return long 追加後value的長度
* **/
public long append(String key, String value) {
Jedis jedis = getJedis();
long len = jedis.append(key, value);
jedis.close();
return len;
}
/**
* 將key對應的value減去指定的值,只有value可以轉為數字時該方法才可用
*
* @param String
* key
* @param long number 要減去的值
* @return long 減指定值後的值
* */
public long decrBy(String key, long number) {
Jedis jedis = getJedis();
long len = jedis.decrBy(key, number);
jedis.close();
return len;
}
/**
* <b>可以作為獲取唯一id的方法</b><br/>
* 將key對應的value加上指定的值,只有value可以轉為數字時該方法才可用
*
* @param String
* key
* @param long number 要減去的值
* @return long 相加後的值
* */
public long incrBy(String key, long number) {
Jedis jedis = getJedis();
long len = jedis.incrBy(key, number);
jedis.close();
return len;
}
/**
* 對指定key對應的value進行擷取
*
* @param String
* key
* @param long startOffset 開始位置(包含)
* @param long endOffset 結束位置(包含)
* @return String 擷取的值
* */
public String getrange(String key, long startOffset, long endOffset) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
String value = sjedis.getrange(key, startOffset, endOffset);
sjedis.close();
return value;
}
/**
* 獲取並設定指定key對應的value<br/>
* 如果key存在返回之前的value,否則返回null
*
* @param String
* key
* @param String
* value
* @return String 原始value或null
* */
public String getSet(String key, String value) {
Jedis jedis = getJedis();
String str = jedis.getSet(key, value);
jedis.close();
return str;
}
/**
* 批量獲取記錄,如果指定的key不存在返回List的對應位置將是null
*
* @param String
* keys
* @return List<String> 值得集合
* */
public List<String> mget(String... keys) {
Jedis jedis = getJedis();
List<String> str = jedis.mget(keys);
jedis.close();
return str;
}
/**
* 批量儲存記錄
*
* @param String
* keysvalues 例:keysvalues="key1","value1","key2","value2";
* @return String 狀態碼
* */
public String mset(String... keysvalues) {
Jedis jedis = getJedis();
String str = jedis.mset(keysvalues);
jedis.close();
return str;
}
/**
* 獲取key對應的值的長度
*
* @param String
* key
* @return value值得長度
* */
public long strlen(String key) {
Jedis jedis = getJedis();
long len = jedis.strlen(key);
jedis.close();
return len;
}
}
// *******************************************Lists*******************************************//
public class Lists {
/**
* List長度
*
* @param String
* key
* @return 長度
* */
public long llen(String key) {
return llen(SafeEncoder.encode(key));
}
/**
* List長度
*
* @param byte[] key
* @return 長度
* */
public long llen(byte[] key) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
long count = sjedis.llen(key);
sjedis.close();
return count;
}
/**
* 覆蓋操作,將覆蓋List中指定位置的值
*
* @param byte[] key
* @param int index 位置
* @param byte[] value 值
* @return 狀態碼
* */
public String lset(byte[] key, int index, byte[] value) {
Jedis jedis = getJedis();
String status = jedis.lset(key, index, value);
jedis.close();
return status;
}
/**
* 覆蓋操作,將覆蓋List中指定位置的值
*
* @param key
* @param int index 位置
* @param String
* value 值
* @return 狀態碼
* */
public String lset(String key, int index, String value) {
return lset(SafeEncoder.encode(key), index,
SafeEncoder.encode(value));
}
/**
* 在value的相對位置插入記錄
*
* @param key
* @param LIST_POSITION
* 前面插入或後面插入
* @param String
* pivot 相對位置的內容
* @param String
* value 插入的內容
* @return 記錄總數
* */
public long linsert(String key, LIST_POSITION where, String pivot,
String value) {
return linsert(SafeEncoder.encode(key), where,
SafeEncoder.encode(pivot), SafeEncoder.encode(value));
}
/**
* 在指定位置插入記錄
*
* @param String
* key
* @param LIST_POSITION
* 前面插入或後面插入
* @param byte[] pivot 相對位置的內容
* @param byte[] value 插入的內容
* @return 記錄總數
* */
public long linsert(byte[] key, LIST_POSITION where, byte[] pivot,
byte[] value) {
Jedis jedis = getJedis();
long count = jedis.linsert(key, where, pivot, value);
jedis.close();
return count;
}
/**
* 獲取List中指定位置的值
*
* @param String
* key
* @param int index 位置
* @return 值
* **/
public String lindex(String key, int index) {
return SafeEncoder.encode(lindex(SafeEncoder.encode(key), index));
}
/**
* 獲取List中指定位置的值
*
* @param byte[] key
* @param int index 位置
* @return 值
* **/
public byte[] lindex(byte[] key, int index) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
byte[] value = sjedis.lindex(key, index);
sjedis.close();
return value;
}
/**
* 將List中的第一條記錄移出List
*
* @param String
* key
* @return 移出的記錄
* */
public String lpop(String key) {
return SafeEncoder.encode(lpop(SafeEncoder.encode(key)));
}
/**
* 將List中的第一條記錄移出List
*
* @param byte[] key
* @return 移出的記錄
* */
public byte[] lpop(byte[] key) {
Jedis jedis = getJedis();
byte[] value = jedis.lpop(key);
jedis.close();
return value;
}
/**
* 將List中最後第一條記錄移出List
*
* @param byte[] key
* @return 移出的記錄
* */
public String rpop(String key) {
Jedis jedis = getJedis();
String value = jedis.rpop(key);
jedis.close();
return value;
}
/**
* 向List尾部追加記錄
*
* @param String
* key
* @param String
* value
* @return 記錄總數
* */
public long lpush(String key, String value) {
return lpush(SafeEncoder.encode(key), SafeEncoder.encode(value));
}
/**
* 向List頭部追加記錄
*
* @param String
* key
* @param String
* value
* @return 記錄總數
* */
public long rpush(String key, String value) {
Jedis jedis = getJedis();
long count = jedis.rpush(key, value);
jedis.close();
return count;
}
/**
* 向List頭部追加記錄
*
* @param String
* key
* @param String
* value
* @return 記錄總數
* */
public long rpush(byte[] key, byte[] value) {
Jedis jedis = getJedis();
long count = jedis.rpush(key, value);
jedis.close();
return count;
}
/**
* 向List中追加記錄
*
* @param byte[] key
* @param byte[] value
* @return 記錄總數
* */
public long lpush(byte[] key, byte[] value) {
Jedis jedis = getJedis();
long count = jedis.lpush(key, value);
jedis.close();
return count;
}
/**
* 獲取指定範圍的記錄,可以做為分頁使用
*
* @param String
* key
* @param long start
* @param long end
* @return List
* */
public List<String> lrange(String key, long start, long end) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
List<String> list = sjedis.lrange(key, start, end);
sjedis.close();
return list;
}
/**
* 獲取指定範圍的記錄,可以做為分頁使用
*
* @param byte[] key
* @param int start
* @param int end 如果為負數,則尾部開始計算
* @return List
* */
public List<byte[]> lrange(byte[] key, int start, int end) {
// ShardedJedis sjedis = getShardedJedis();
Jedis sjedis = getJedis();
List<byte[]> list = sjedis.lrange(key, start, end);
sjedis.close();
return list;
}
/**
* 刪除List中c條記錄,被刪除的記錄值為value
*
* @param byte[] key
* @param int c 要刪除的數量,如果為負數則從List的尾部檢查並刪除符合的記錄
* @param byte[] value 要匹配的值
* @return 刪除後的List中的記錄數
* */
public long lrem(byte[] key, int c, byte[] value) {
Jedis jedis = getJedis();
long count = jedis.lrem(key, c, value);
jedis.close();
return count;
}
/**
* 刪除List中c條記錄,被刪除的記錄值為value
*
* @param String
* key
* @param int c 要刪除的數量,如果為負數則從List的尾部檢查並刪除符合的記錄
* @param String
* value 要匹配的值
* @return 刪除後的List中的記錄數
* */
public long lrem(String key, int c, String value) {
return lrem(SafeEncoder.encode(key), c, SafeEncoder.encode(value));
}
/**
* 算是刪除吧,只保留start與end之間的記錄
*
* @param byte[] key
* @param int start 記錄的開始位置(0表示第一條記錄)
* @param int end 記錄的結束位置(如果為-1則表示最後一個,-2,-3以此類推)
* @return 執行狀態碼
* */
public String ltrim(byte[] key, int start, int end) {
Jedis jedis = getJedis();
String str = jedis.ltrim(key, start, end);
jedis.close();
return str;
}
/**
* 算是刪除吧,只保留start與end之間的記錄
*
* @param String
* key
* @param int start 記錄的開始位置(0表示第一條記錄)
* @param int end 記錄的結束位置(如果為-1則表示最後一個,-2,-3以此類推)
* @return 執行狀態碼
* */
public String ltrim(String key, int start, int end) {
return ltrim(SafeEncoder.encode(key), start, end);
}
}
}
五、通過以上四步Redis配置已經完成,就可以在程式中使用Redis的快取技術了,下面我貼一些使用的部分程式碼:
private static String AREALISTKEY = "arealist";
@Override
public List<Area> getAreaList() throws JsonParseException,
JsonMappingException, IOException {
String key = AREALISTKEY;
List<Area> areaList = null;
ObjectMapper mapper = new ObjectMapper();
if (!jedisKeys.exists(key)) {
areaList = areaDao.queryArea();
String jsonString = mapper.writeValueAsString(areaList);
jedisStrings.set(key, jsonString);
} else {
String jsonString = jedisStrings.get(key);
JavaType javaType = mapper.getTypeFactory()
.constructParametricType(ArrayList.class, Area.class);
areaList = mapper.readValue(jsonString, javaType);
}
return areaList;
}
說明:上面的程式碼是先判斷Redis快取中有資料,如果沒有就從資料庫中提取,並加入快取,如果有的話,就直接使用快取的資料;
上面的例子程式碼是說明了怎麼使用Redis快取中提取資料,對於Redis資料與資料庫資料如何保持一致,如何去實現,在後續章節會奉獻上,謝謝!!
相關推薦
Redis與SSM框架整合應用之一
我們在建設和應用網際網路架構時,往往需要考慮高併發、高效能的要求,為也提高系統的響應速度,往往需要採用快取技術,在這裡我使用的是Redis快取技術,把一些變動頻率較低的資料放在快取中,提高系統訪問速度,下面主要講解Redis在SSM框架中如何去整合和實現。 一
java 一款可以與ssm框架完美整合的web報表控件
cnblogs clas tar req pap 整合 大型 自定義報表 環境 碩正套件運行於客戶端(瀏覽器),與應用服務器(Application Server)技術無關,所以能完全用於J2EE、 ASP.Net、php等技術開發的Web應用產品中。 碩正套件部署
分分鐘 整合 activiti與ssm框架
整合Activiti框架 Spring框架叫做專案(資源)的管家。如果待整合專案中,有Spring框架,那麼主要就是和“Spring框架”做整合。把Activiti框架的“核心類”交給Spring管理; Activiti的核心類,引擎配置物件,引擎物件,三大服務物件
Java高併發秒殺系統API之SSM框架整合swagger與AdminLTE
初衷與整理描述 Java高併發秒殺系統API是來源於網上教程的一個Java專案,也是我接觸Java的第一個專案。本來是一枚c#碼農,公司計劃部分業務轉java,於是我利用業務時間自學Java才有了本文,本來接觸之初聽別人說,c#要轉java很容易,我也信
SSM框架整合Redis資料庫【Redis·4】
最近專案中引進redis用來存放圖片或者一些不常修改的資料,以減輕程式及資料庫壓力。記錄下配置過程。 框架:SpringMVC+Mybatis 版本: Spring4.0 Mybatis3.0
SSM框架整合
logs xdp 提交 ros post提交數據 log htm get http 收集的資料 http://www.cnblogs.com/codeRose/p/6617578.html 1.http://www.cnblogs.com/verlen11/p/5349
ssm框架整合配置文件
web-inf qwidget apps 連接 client undle style med ide <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframew
WDCP面板Web環境安裝redis與phpredis擴展應用方法
upload dir targe clas 擴展 content 人人 linux nbsp 根據網友的要求需要在WDCP面板環境中安裝人人商城程序,但是這個程序需要支持redis與phpredis擴展。根據老蔣認知,WDCP默認搭建普通網站肯定是沒有問題的,但具體是不是支
Spring MVC擴展和 SSM框架整合
運行 步驟 請求參數 body 控制 ice 系統工具 表示 produces 1.使用@ResponseBody 實現數據輸出 DAO層、Service層 改造Controller層 改造View層 部署運行 2.JSON數據的傳遞處理 改造Controller層
ssm框架整合-過程總結(第三次周總結)
項目 功能實現 SSM框架 模板 .com 完成 eight 幫助 spa 本周主要是完成前端界面和後端的整合。 猶豫前後端的工作完成程度不一致,只實現了部分整合。 登錄界面。 可能自己最近沒有把重心放在短學期的項目上,導致我們工作的總體進度都要比別慢。 雖然我們只是
SSM框架整合遇到的問題
框架整合 ring spring art 項目 cti iba alibaba 整合 1.Maven中Dubbo集成spring2.5以上版本 所項目中dubbo集成spring4.x,配置pom時需要註意排除spring的依賴,我這裏用的是tomcat,所以把jboss
SSM框架整合(實現從數據庫到頁面展示)
patch beans response 由於 spring容器 void 不用 html show SSM框架整合(實現從數據庫到頁面展示) 首先創建一個spring-web項目,然後需要配置環境dtd文件的引入,環境配置,jar包引入。 首先讓我
eclipse SSM框架整合
ext 3.0 ron context maven 能力 aid setname servlet 作為一個java小白,一直一來都是默默自學,視頻、書籍、博客看了不少,但是動手能力一直都很弱。今天試著搭SSM的框架,發現的問題真是很多。spring、springmvc、my
Maven-SSM框架整合
jstl 導入 ring test 編碼格式 append main ani pat 1、創建Maven項目 配置pom.xml依賴 <!-- 允許創建jsp頁面 --> <dependency> <g
【Java】Spring MVC 擴展和SSM框架整合
nco span con odin typealias eal nag key ping 開發web項目通常很多地方需要使用ajax請求來完成相應的功能,比如表單交互或者是復雜的UI設計中數據的傳遞等等。對於返回結果,我們一般使用JSON對象來表示,那麽Spring MVC
springboot --- 之SSM框架整合
aso character org default ica row ffi order ont 1.pom依賴: 即:spring-boot的基本jar ---- 內置springmvc和spring Thymeleaf jar 熱部署 jar ---方便二次加載 ct
ssm框架整合入門系列——一個簡單的用戶管理系統
ner gmv per 搭建 eclips batis bat rest 查詢 ssm框架整合入門系列 系列目標:搭建一個簡單的用戶管理(crud)系統 功能點: 分頁 數據庫校驗(jquery前端校驗+JSR303後端校驗 ajax Rest峰哥的URL;使用HTTP
ssm框架整合入門系列——maven工程引入jar包
sta -- mybatis 插入 ati code 插入圖片 uri 1.3 maven工程引入jar包 Spring SpringMVC MyBatis 數據庫連接池,驅動包 其他(jstl、servlet、junit) 打開ssm-crud項目的pom.xml
Java框架-SpringMVC統一異常處理、ssm框架整合
1. SpringMVC中異常處理 1.1 各層處理異常原則即實現方法 1.1.1 各層處理異常原則 dao:不處理,拋異常; service:不處理,拋異常; controller/servlet:必須處理,否則錯誤資訊將直接在瀏覽器顯示給使用者看。 1.1.2 異
ssm框架整合入門系列——基礎模組mybatis逆向工程
基礎模組mybatis逆向工程 使用mybatis逆向工程生成對應的bean,mappper mybatis文件地址:http://www.mybatis.org/mybatis-3 我們在mybatis-config.xml下配置: mybatis-config.xm