1. 程式人生 > >Redis與SSM框架整合應用之一

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資料與資料庫資料如何保持一致,如何去實現,在後續章節會奉獻上,謝謝!!

相關推薦

RedisSSM框架整合應用之一

       我們在建設和應用網際網路架構時,往往需要考慮高併發、高效能的要求,為也提高系統的響應速度,往往需要採用快取技術,在這裡我使用的是Redis快取技術,把一些變動頻率較低的資料放在快取中,提高系統訪問速度,下面主要講解Redis在SSM框架中如何去整合和實現。 一

java 一款可以ssm框架完美整合的web報表控件

cnblogs clas tar req pap 整合 大型 自定義報表 環境   碩正套件運行於客戶端(瀏覽器),與應用服務器(Application Server)技術無關,所以能完全用於J2EE、  ASP.Net、php等技術開發的Web應用產品中。  碩正套件部署

分分鐘 整合 activitissm框架

整合Activiti框架  Spring框架叫做專案(資源)的管家。如果待整合專案中,有Spring框架,那麼主要就是和“Spring框架”做整合。把Activiti框架的“核心類”交給Spring管理; Activiti的核心類,引擎配置物件,引擎物件,三大服務物件

Java高併發秒殺系統API之SSM框架整合swaggerAdminLTE

初衷與整理描述 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環境安裝redisphpredis擴展應用方法

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