婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > windows環境下Redis+Spring緩存實例講解

windows環境下Redis+Spring緩存實例講解

熱門標簽:西藏教育智能外呼系統價格 百度商家地圖標注怎么做 地圖標注如何即時生效 竹間科技AI電銷機器人 最簡單的百度地圖標注 地圖標注費用 太原營銷外呼系統 玄武湖地圖標注 小紅書怎么地圖標注店

一、Redis了解

1.1、Redis介紹:

redis是一個key-value存儲系統。和Memcached類似,它支持存儲的value類型相對更多,包括string(字符串)、list(鏈表)、set(集合)、zset(sorted set –有序集合)和hash(哈希類型)。這些數據類型都支持push/pop、add/remove及取交集并集和差集及更豐富的操作,而且這些操作都是原子性的。在此基礎上,redis支持各種不同方式的排序。與memcached一樣,為了保證效率,數據都是緩存在內存中。區別的是redis會周期性的把更新的數據寫入磁盤或者把修改操作寫入追加的記錄文件,并且在此基礎上實現了master-slave(主從)同步。

Redis數據庫完全在內存中,使用磁盤僅用于持久性。相比許多鍵值數據存儲,Redis擁有一套較為豐富的數據類型。Redis可以將數據復制到任意數量的從服務器。

1.2、Redis優點:

(1)異常快速:Redis的速度非常快,每秒能執行約11萬集合,每秒約81000+條記錄。

(2)支持豐富的數據類型:Redis支持最大多數開發人員已經知道像列表,集合,有序集合,散列數據類型。這使得它非常容易解決各種各樣的問題,因為我們知道哪些問題是可以處理通過它的數據類型更好。

(3)操作都是原子性:所有Redis操作是原子的,這保證了如果兩個客戶端同時訪問的Redis服務器將獲得更新后的值。

(4)多功能實用工具:Redis是一個多實用的工具,可以在多個用例如緩存,消息,隊列使用(Redis原生支持發布/訂閱),任何短暫的數據,應用程序,如Web應用程序會話,網頁命中計數等。

1.3、Redis缺點:

(1)單線程

(2)耗內存

二、64位windows下Redis安裝

Redis官方是不支持windows的,但是Microsoft Open Tech group 在 GitHub上開發了一個Win64的版本,下載地址:https://github.com/MSOpenTech/redis/releases。注意只支持64位哈。

小寶鴿是下載了Redis-x64-3.0.500.msi進行安裝。安裝過程中全部采取默認即可。

安裝完成之后可能已經幫你開啟了Redis對應的服務,博主的就是如此。查看資源管理如下,說明已經開啟:

已經開啟了對應服務的,我們讓它保持,下面例子需要用到。如果沒有開啟的,我們命令開啟,進入Redis的安裝目錄(博主的是C:\Program Files\Redis),然后如下命令開啟:

redis-server  redis.windows.conf

OK,下面我們進行實例。

三、詳細實例

本工程采用的環境:Eclipse + maven + spring + junit

3.1、添加相關依賴(spring+junit+redis依賴),pom.xml:

project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 modelVersion>4.0.0/modelVersion>
 groupId>com.luo/groupId>
 artifactId>redis_project/artifactId>
 version>0.0.1-SNAPSHOT/version>
 
 properties>
  !-- spring版本號 -->
  spring.version>3.2.8.RELEASE/spring.version>
  !-- junit版本號 -->
  junit.version>4.10/junit.version>
 /properties>
 
 dependencies>
  !-- 添加Spring依賴 -->
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-core/artifactId>
   version>${spring.version}/version>
  /dependency>
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-webmvc/artifactId>
   version>${spring.version}/version>
  /dependency>
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-context/artifactId>
   version>${spring.version}/version>
  /dependency>
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-context-support/artifactId>
   version>${spring.version}/version>
  /dependency>
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-aop/artifactId>
   version>${spring.version}/version>
  /dependency>
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-aspects/artifactId>
   version>${spring.version}/version>
  /dependency>
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-tx/artifactId>
   version>${spring.version}/version>
  /dependency>
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-jdbc/artifactId>
   version>${spring.version}/version>
  /dependency>
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-web/artifactId>
   version>${spring.version}/version>
  /dependency>
 
  !--單元測試依賴 -->
  dependency>
   groupId>junit/groupId>
   artifactId>junit/artifactId>
   version>${junit.version}/version>
   scope>test/scope>
  /dependency>
 
  !--spring單元測試依賴 -->
  dependency>
   groupId>org.springframework/groupId>
   artifactId>spring-test/artifactId>
   version>${spring.version}/version>
   scope>test/scope>
  /dependency>
 
  !-- Redis 相關依賴 -->
  dependency>
   groupId>org.springframework.data/groupId>
   artifactId>spring-data-redis/artifactId>
   version>1.6.1.RELEASE/version>
  /dependency>
  dependency>
   groupId>redis.clients/groupId>
   artifactId>jedis/artifactId>
   version>2.7.3/version>
  /dependency>
 
 /dependencies>
/project>

3.2、spring配置文件application.xml:

?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:context="http://www.springframework.org/schema/context"
 xmlns:aop="http://www.springframework.org/schema/aop"
 xsi:schemaLocation=" 
 
http://www.springframework.org/schema/beans
 
 
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
 
 
http://www.springframework.org/schema/aop
 
 
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
 
 
http://www.springframework.org/schema/context
 
 
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
 
 !-- 自動掃描注解的bean -->
 context:component-scan base-package="com.luo.service" />
 
 !-- 引入properties配置文件 --> 
 bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  property name="locations">
   list>
    value>classpath:properties/*.properties/value>
    !--要是有多個配置文件,只需在這里繼續添加即可 -->
   /list>
  /property>
 /bean>
 
 !-- jedis 配置 -->
 bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig" >
   property name="maxIdle" value="${redis.maxIdle}" />
   property name="maxWaitMillis" value="${redis.maxWait}" />
   property name="testOnBorrow" value="${redis.testOnBorrow}" />
 /bean >
 
 !-- redis服務器中心 -->
 bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" >
   property name="poolConfig" ref="poolConfig" />
   property name="port" value="${redis.port}" />
   property name="hostName" value="${redis.host}" />
   !-- property name="password" value="${redis.password}" /> -->
   property name="timeout" value="${redis.timeout}" >/property>
 /bean >
 bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate" >
   property name="connectionFactory" ref="connectionFactory" />
   property name="keySerializer" >
    bean class="org.springframework.data.redis.serializer.StringRedisSerializer" />
   /property>
   property name="valueSerializer" >
    bean class="org.springframework.data.redis.serializer.JdkSerializationRedisSerializer" />
   /property>
 /bean >
 
 !-- cache配置 -->
 bean id="methodCacheInterceptor" class="com.luo.redis.cache.MethodCacheInterceptor" >
   property name="redisTemplate" ref="redisTemplate" />
 /bean >
 
 !-- aop配置切點跟通知 -->
 bean id="methodCachePointCut" class="org.springframework.aop.support.RegexpMethodPointcutAdvisor">
  property name="advice" ref="methodCacheInterceptor"/>
  property name="pattern" value=".*ServiceImpl.*getTimestamp"/>
 /bean>
 bean id="redisTestService" class="com.luo.service.impl.RedisTestServiceImpl">
 /bean>
 bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator"/>
 
/beans>

3.3、Redis配置參數,redis.properties:

#redis中心
#綁定的主機地址
redis.host=127.0.0.1
#指定Redis監聽端口,默認端口為6379
redis.port=6379
#授權密碼(本例子沒有使用)
redis.password=123456 
#最大空閑數:空閑鏈接數大于maxIdle時,將進行回收
redis.maxIdle=100 
#最大連接數:能夠同時建立的“最大鏈接個數”
redis.maxActive=300 
#最大等待時間:單位ms
redis.maxWait=1000 
#使用連接時,檢測連接是否成功 
redis.testOnBorrow=true
#當客戶端閑置多長時間后關閉連接,如果指定為0,表示關閉該功能
redis.timeout=10000

3.4、添加接口及對應實現RedisTestService.Java和RedisTestServiceImpl.java:

package com.luo.service;
 
public interface RedisTestService {
 public String getTimestamp(String param);
}
package com.luo.service.impl;
 
import org.springframework.stereotype.Service;
import com.luo.service.RedisTestService;
 
@Service
public class RedisTestServiceImpl implements RedisTestService {
 
 public String getTimestamp(String param) {
  Long timestamp = System.currentTimeMillis();
  return timestamp.toString();
 }
 
}


3.5、本例采用spring aop切面方式進行緩存,配置已在上面spring配置文件中,對應實現為MethodCacheInterceptor.java:

package com.luo.redis.cache;
 
import java.io.Serializable;
import java.util.concurrent.TimeUnit;
import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
 
public class MethodCacheInterceptor implements MethodInterceptor {
 
 private RedisTemplateSerializable, Object> redisTemplate;
 private Long defaultCacheExpireTime = 10l; // 緩存默認的過期時間,這里設置了10秒
 
 public Object invoke(MethodInvocation invocation) throws Throwable {
  Object value = null;
 
  String targetName = invocation.getThis().getClass().getName();
  String methodName = invocation.getMethod().getName();
 
  Object[] arguments = invocation.getArguments();
  String key = getCacheKey(targetName, methodName, arguments);
 
  try {
   // 判斷是否有緩存
   if (exists(key)) {
    return getCache(key);
   }
   // 寫入緩存
   value = invocation.proceed();
   if (value != null) {
    final String tkey = key;
    final Object tvalue = value;
    new Thread(new Runnable() {
     public void run() {
      setCache(tkey, tvalue, defaultCacheExpireTime);
     }
    }).start();
   }
  } catch (Exception e) {
   e.printStackTrace();
   if (value == null) {
    return invocation.proceed();
   }
  }
  return value;
 }
 
 /**
  * 創建緩存key
  *
  * @param targetName
  * @param methodName
  * @param arguments
  */
 private String getCacheKey(String targetName, String methodName,
   Object[] arguments) {
  StringBuffer sbu = new StringBuffer();
  sbu.append(targetName).append("_").append(methodName);
  if ((arguments != null)  (arguments.length != 0)) {
   for (int i = 0; i  arguments.length; i++) {
    sbu.append("_").append(arguments[i]);
   }
  }
  return sbu.toString();
 }
 
 /**
  * 判斷緩存中是否有對應的value
  * 
  * @param key
  * @return
  */
 public boolean exists(final String key) {
  return redisTemplate.hasKey(key);
 }
 
 /**
  * 讀取緩存
  * 
  * @param key
  * @return
  */
 public Object getCache(final String key) {
  Object result = null;
  ValueOperationsSerializable, Object> operations = redisTemplate
    .opsForValue();
  result = operations.get(key);
  return result;
 }
 
 /**
  * 寫入緩存
  * 
  * @param key
  * @param value
  * @return
  */
 public boolean setCache(final String key, Object value, Long expireTime) {
  boolean result = false;
  try {
   ValueOperationsSerializable, Object> operations = redisTemplate
     .opsForValue();
   operations.set(key, value);
   redisTemplate.expire(key, expireTime, TimeUnit.SECONDS);
   result = true;
  } catch (Exception e) {
   e.printStackTrace();
  }
  return result;
 }
 
 public void setRedisTemplate(
   RedisTemplateSerializable, Object> redisTemplate) {
  this.redisTemplate = redisTemplate;
 }
}


3.6、單元測試相關類:

package com.luo.baseTest;
 
import org.junit.runner.RunWith; 
import org.springframework.test.context.ContextConfiguration; 
import org.springframework.test.context.junit4.AbstractJUnit4SpringContextTests; 
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; 
 
//指定bean注入的配置文件 
@ContextConfiguration(locations = { "classpath:application.xml" }) 
//使用標準的JUnit @RunWith注釋來告訴JUnit使用Spring TestRunner 
@RunWith(SpringJUnit4ClassRunner.class) 
public class SpringTestCase extends AbstractJUnit4SpringContextTests {
 
}
package com.luo.service;
 
import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired;
 
import com.luo.baseTest.SpringTestCase;
 
public class RedisTestServiceTest extends SpringTestCase {
 
 @Autowired 
 private RedisTestService redisTestService;
 
 @Test 
 public void getTimestampTest() throws InterruptedException{ 
  System.out.println("第一次調用:" + redisTestService.getTimestamp("param"));
  Thread.sleep(2000);
  System.out.println("2秒之后調用:" + redisTestService.getTimestamp("param"));
  Thread.sleep(11000);
  System.out.println("再過11秒之后調用:" + redisTestService.getTimestamp("param"));
 } 
}

3.7、運行結果:

四、源碼下載:redis-project(jb51.net).rar

以上就是本文的全部內容,希望對大家的學習有所幫助。

您可能感興趣的文章:
  • 圖文詳解Windows下使用Redis緩存工具的方法
  • window手動操作清理redis緩存的技巧總結

標簽:唐山 林芝 景德鎮 揚州 香港 贛州 澳門 廣東

巨人網絡通訊聲明:本文標題《windows環境下Redis+Spring緩存實例講解》,本文關鍵詞  windows,環境,下,Redis+Spring,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《windows環境下Redis+Spring緩存實例講解》相關的同類信息!
  • 本頁收集關于windows環境下Redis+Spring緩存實例講解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91久久精品日日躁夜夜躁欧美| 成人h动漫精品一区二区| 国产一区二区h| 欧美视频一二三区| 欧美激情一区二区三区蜜桃视频| 亚洲成人自拍网| 91影视在线播放| 一区二区中文视频| 国产成人亚洲综合a∨婷婷 | 亚洲精品免费一二三区| 久久9热精品视频| 4438亚洲最大| 日韩精品一二三| 欧美日韩久久久久久| 亚洲特级片在线| 91原创在线视频| 国产亚洲欧美日韩俺去了| 极品少妇一区二区| 欧美r级电影在线观看| 精品一区二区三区香蕉蜜桃| 欧美高清一级片在线| 久久97超碰色| 久久久久久久综合色一本| 国产精品综合一区二区| 中文字幕第一区二区| 在线影院国内精品| 日本91福利区| 欧美精品一区二区三区久久久| 久久精品999| 亚洲欧洲制服丝袜| 在线不卡的av| 高清久久久久久| 亚洲一区二区三区四区五区黄| 制服丝袜亚洲色图| 成人午夜看片网址| 日本伊人色综合网| 国产亚洲va综合人人澡精品| 91天堂素人约啪| 蜜臀av亚洲一区中文字幕| 国产精品免费aⅴ片在线观看| 91麻豆精品一区二区三区| 午夜精品福利在线| 国产精品毛片久久久久久| 欧美日韩高清影院| 成年人网站91| 国产一区二区精品在线观看| 夜夜精品浪潮av一区二区三区| 日韩三级在线免费观看| 一本久久a久久精品亚洲| 久久99精品久久久久婷婷| 国产日韩欧美高清| 久久综合色8888| 91精品国产综合久久蜜臀| 成人免费看视频| 国产福利一区二区三区视频在线 | 成人一区二区三区在线观看 | 亚洲成人1区2区| 亚洲欧美激情视频在线观看一区二区三区 | 国产精品影视在线| 国产一区二区导航在线播放| 日本va欧美va精品| 日本不卡一区二区| 日韩电影在线看| 日韩经典中文字幕一区| 日韩精品免费专区| 视频一区在线播放| 久久精品国产免费| 国产一区二区在线观看视频| 久久国产精品99精品国产| 久久99国产乱子伦精品免费| 免费高清视频精品| 国产又黄又大久久| 91丨porny丨首页| 欧美色综合天天久久综合精品| 欧美日韩黄色一区二区| 日韩欧美国产wwwww| 久久久久久日产精品| 亚洲欧美aⅴ...| 日韩精品电影一区亚洲| 国内成人自拍视频| 91麻豆精品视频| 欧美一区二区精品在线| 久久综合九色综合欧美亚洲| 国产精品久久久久永久免费观看 | 蜜桃精品视频在线观看| 国产成人aaa| 欧美剧情片在线观看| 国产精品欧美精品| 国产剧情在线观看一区二区| 色菇凉天天综合网| 国产欧美精品在线观看| 精品国产成人系列| 欧美国产欧美综合| 麻豆极品一区二区三区| 日本丶国产丶欧美色综合| 久久久久久免费| 精品中文字幕一区二区| 欧美亚洲精品一区| 久久精品夜色噜噜亚洲a∨| 一区二区在线看| 91麻豆文化传媒在线观看| 亚洲精品在线观看网站| 久久精品国产99久久6| 在线电影一区二区三区| 亚洲午夜视频在线观看| 色综合咪咪久久| 日本一区二区不卡视频| 国产乱理伦片在线观看夜一区| 日韩欧美国产精品一区| 麻豆国产精品一区二区三区 | 色哟哟一区二区在线观看 | 国产精品麻豆视频| www.成人在线| 亚洲一区二区三区激情| 欧美在线视频日韩| 美腿丝袜亚洲色图| 久久精品视频免费| 成人国产一区二区三区精品| 色综合久久天天| 国产婷婷色一区二区三区在线| 精品一区二区三区免费视频| 精品国产乱码久久久久久久| 精品在线观看免费| 专区另类欧美日韩| 在线一区二区观看| 久久精品国产**网站演员| 国产午夜精品在线观看| 欧美色图激情小说| 国产成人高清在线| 综合久久给合久久狠狠狠97色| 欧美网站大全在线观看| 日韩电影免费一区| 中文字幕av一区二区三区免费看| 色狠狠av一区二区三区| 国产乱妇无码大片在线观看| 亚洲品质自拍视频| 国产日韩av一区二区| 欧美年轻男男videosbes| caoporm超碰国产精品| 日本三级韩国三级欧美三级| 综合久久久久久久| 亚洲精品在线一区二区| 91精品国产综合久久久久久久| 粉嫩欧美一区二区三区高清影视| 亚洲成人精品影院| 亚洲精品免费看| 亚洲码国产岛国毛片在线| 中文字幕久久午夜不卡| 91精品国产91综合久久蜜臀| 欧美色精品在线视频| 成人av在线播放网址| 国产夫妻精品视频| 韩国成人精品a∨在线观看| 免费高清视频精品| 麻豆91小视频| 久久国产剧场电影| 日av在线不卡| 韩日av一区二区| 国产91精品欧美| 国产成人高清在线| 91亚洲精品久久久蜜桃| 91猫先生在线| 欧美日韩高清一区二区| 欧美一区二区视频免费观看| 日韩一区二区三| 久久只精品国产| 亚洲品质自拍视频网站| 亚洲va韩国va欧美va| 久久成人久久鬼色| 成人激情免费网站| 色视频成人在线观看免| 欧美一区二区三区精品| 国产午夜亚洲精品午夜鲁丝片| 国产精品久久久久影院老司 | 国产精品美日韩| 偷偷要91色婷婷| 成人综合婷婷国产精品久久蜜臀 | 国产91对白在线观看九色| 成人h动漫精品一区二| 欧美丰满少妇xxxbbb| 日本一区二区不卡视频| 亚洲一级电影视频| 国产成人av电影在线| 日韩一区二区三区三四区视频在线观看| 国产亚洲一本大道中文在线| 五月综合激情婷婷六月色窝| 国产福利91精品一区| 日韩免费观看2025年上映的电影 | 国产精品久久免费看| 麻豆一区二区在线| 欧美日韩国产综合视频在线观看| 精品久久人人做人人爱| 亚州成人在线电影| 欧美影院午夜播放| **欧美大码日韩| 国产精品1024久久| 91精品免费观看| 日韩激情一二三区| 欧美一卡二卡在线| 美女视频免费一区|