Spring + Redis ( 简单使用)
1、Redis 的 Java API
Java 中 使用 Redis 工具,要先去 maven 仓库中,下载 jedis jar包
jedis 依赖
- <dependency>
- <groupId>redis.clients</groupId>
- <artifactId>jedis</artifactId>
- <version>2.9.0</version>
- </dependency>
使用

- //连接 Redis
- Jedis jedis = new Jedis("localhost", 6379);
- //如果需要密码
- //jedis.auth("");
- //记录操作次数
- int i = 0;
- try {
- long start = System.currentTimeMillis();
- while (true) {
- long end = System.currentTimeMillis();
- //当 大于等于 1000毫秒(1秒)时,结束
- if (end - start >= 1000) {
- break;
- }
- i++;
- jedis.set("testId" + i, i + " ");
- }
- } finally {
- //关闭 Redis
- jedis.close();
- }
- //打印1秒内对 Redis 的操作次数
- System.out.println("Redis每秒操作:" + i + "次");

结果:
- Redis每秒操作:1753次
使用 流水线技术( 连接池 ),提高速度。

- //配置 连接池
- JedisPoolConfig config = new JedisPoolConfig();
- //最大空闲数
- config.setMaxIdle(50);
- //最大连接数
- config.setMaxTotal(100);
- //最大等待数 毫秒数
- config.setMaxWaitMillis(20000);
- //创建 连接池
- JedisPool pool = new JedisPool(config,"localhost");
- //从连接池中获取单个连接
- Jedis jedis = pool.getResource();
- //如果需要密码
- //jedis.auth("");
- //记录操作次数
- int i = 0;
- try {
- long start = System.currentTimeMillis();
- while (true) {
- long end = System.currentTimeMillis();
- //当 大于等于 1000毫秒(1秒)时,结束
- if (end - start >= 1000) {
- break;
- }
- i++;
- jedis.set("testId" + i, i + " ");
- }
- } finally {
- //关闭 Redis
- jedis.close();
- }
- //打印1秒内对 Redis 的操作次数
- System.out.println("Redis每秒操作:" + i + "次");

运行结果:
- Redis每秒操作:5022次
2、Spring 中 使用 Redis
在Spring中使用Redis,除了需要jedis.jar外,还需要 spring-data-redis.jar 的依赖架包
spring-data-redis.jar 依赖包
- <dependency>
- <groupId>org.springframework.data</groupId>
- <artifactId>spring-data-redis</artifactId>
- <version>2.1.3.RELEASE</version>
- </dependency>
注解配置
配置连接池
配置Spring所提供的连接工厂
JredisConnectionFactory
JedisConnectionFactory
LettuceConnectionFactory
SrpConnectionFactory
配置Spring RedisTemplate
Spring所提供的连接工厂,无论 如何它们都是接口 RedisConnectionFacory 的实现类
使用 JedisConnectionFactory 较为广泛。

- @Configuration//声明当前类 是配置类
- public class SpringRedisConfig {
- //配置连接池
- @Bean
- JedisPoolConfig poolConfig(){
- //配置连接池
- JedisPoolConfig config = new JedisPoolConfig();
- //最大空闲数
- config.setMaxIdle(50);
- //最大等待时间
- config.setMaxWaitMillis(20000);
- //最大连接数
- config.setMaxTotal(100);
- return config;
- }
- //配置 redis 连接工厂
- @Bean
- RedisConnectionFactory connectionFactory(){
- JedisConnectionFactory connectionFactory = new JedisConnectionFactory(poolConfig());
- return connectionFactory;
- }
- //配置 Spring RedisTemplate
- @Bean
- StringRedisTemplate redisTemplate(){
- return new StringRedisTemplate(connectionFactory());
- }
- }

测试示例:

- public static void main(String[] args) {
- //扫描 spring 注解
- AnnotationConfigApplicationContext bean = new AnnotationConfigApplicationContext(SpringRedisConfig.class);
- // 得到 spring 容器 中 的类
- StringRedisTemplate stringRedisTemplate =
- (StringRedisTemplate) bean.getBean("redisTemplate");
- //使用 SpringRedisTemplate
- stringRedisTemplate.boundValueOps("test").set("zhe shi yi ge ce shi !");
- System.out.println(stringRedisTemplate.boundValueOps("test").get());
- }

运行效果:
- zhe shi yi ge ce shi !
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"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
- <!--配置连接池-->
- <bean id="poolConfig" class="redis.clients.jedis.JedisPoolConfig">
- <!--最大等待时间-->
- <property name="maxWaitMillis" value="20000"/>
- <!--最大空闲数-->
- <property name="maxIdle" value="50"/>
- <!--最大连接数-->
- <property name="maxTotal" value="100"/>
- </bean>
- <!--Spring 提供的redis连接工厂-->
- <bean id="connectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
- <property name="poolConfig" ref="poolConfig"/>
- </bean>
- <!--Spring Template-->
- <bean id="stringRedisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate">
- <property name="connectionFactory" ref="connectionFactory"/>
- </bean>
- </beans>

测试类

- public static void main(String[] args) {
- //加载 配置文件
- ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("redisConfig.xml");
- //从容器中 获取 一个 bean
- StringRedisTemplate bean = (StringRedisTemplate) context.getBean("stringRedisTemplate");
- bean.boundValueOps("test").set("zhe shi yi ge jian dan de ce shi ");
- System.out.println(bean.boundValueOps("test").get());
- }

运行效果:
- zhe shi yi ge jian dan de ce shi
Spring + Redis ( 简单使用)的更多相关文章
- redis之(二十一)redis之深入理解Spring Redis的使用
关于spring redis框架的使用,网上的例子很多很多.但是在自己最近一段时间的使用中,发现这些教程都是入门教程,包括很多的使用方法,与spring redis丰富的api大相径庭,真是浪费了这么 ...
- spring redis入门
小二,上菜!!! 1. 虚拟机上安装redis服务 下载tar包,wget http://download.redis.io/releases/redis-2.8.19.tar.gz. 解压缩,tar ...
- 分布式缓存技术redis学习—— 深入理解Spring Redis的使用
关于spring redis框架的使用,网上的例子很多很多.但是在自己最近一段时间的使用中,发现这些教程都是入门教程,包括很多的使用方法,与spring redis丰富的api大相径庭,真是浪费了这么 ...
- 深入理解Spring Redis的使用 (七)、Spring Redis 使用 jackson序列化 以及 BaseDao代码
之前在介绍Spring Redis进行存储的时候,都是通过RedisTemplate中的defaultSerializer,即JdkSerializationRedisSerializer.通过Jdk ...
- spring redis @Cacheable注解使用部分错误及无效原因
spring redis @Cacheable注解使用部分错误及无效原因 说明: spring项目用到redis注解无效,解决问题中遇到一堆BUG,各种搜索,看了许多错误解决方案一一测试,对于 ...
- 一篇文章带你了解NoSql数据库——Redis简单入门
一篇文章带你了解NoSql数据库--Redis简单入门 Redis是一个基于内存的key-value结构数据库 我们会利用其内存存储速度快,读写性能高的特点去完成企业中的一些热门数据的储存信息 在本篇 ...
- Spring cache简单使用guava cache
Spring cache简单使用 前言 spring有一套和各种缓存的集成方式.类似于sl4j,你可以选择log框架实现,也一样可以实现缓存实现,比如ehcache,guava cache. [TOC ...
- Spring的简单demo
---------------------------------------- 开发一个Spring的简单Demo,具体的步骤如下: 1.构造一个maven项目 2.在maven项目的pom.xml ...
- spring+redis 集群下的操作
文章就是记录一下工作当中的用到的点,与测试方法以备用,会不断更新. 配置文件spring-redis.xml: <?xml version="1.0" encoding=&q ...
随机推荐
- How To:配置Openfiler磁盘
目录 1.系统登陆 2.启用iSCSI Target服务 3.初始化卷组 4.映射LUN 5.查看状态 1.系统登陆 Openfiler系统安装完毕之后,使用提示的地址登陆:https://172.1 ...
- 网际协议IP简述
最近花了些时间重新回顾了谢希仁教授主编的<计算机网络>关于网络层的章节,这是一本高校教材,里面关于计算机网络的内容比较基础,并且讲的很细致,笔者针对网际协议IP地址部分觉得有必要进行阅读后 ...
- [luogu4054 JSOI2009] 计数问题(2D BIT)
传送门 Solution 2D BIT模板 Code //By Menteur_Hxy #include <cmath> #include <cstdio> #include ...
- LVM(Logical Volume Manager)逻辑卷管理
本文实验部分,完全由本人亲自动手实践得来 文章中有部分的内容是我个人通过实验测试出来的,虽以目前本人的能力还没发现不通之处,但错误难免,所以若各位朋友发现什么错误,或有疑惑.更好的建议等,盼请各位能在 ...
- codeforeces近日题目小结
题目源自codeforeces的三场contest contest/1043+1055+1076 目前都是solved 6/7,都差了最后一题 简单题: contest/1043/E: 先不考虑m个限 ...
- LINUX 查看硬件配置命令
系统 # uname -a # 查看内核/操作系统/CPU信息 # head -n 1 /etc/issue # 查看操作系统版本 # cat /proc/cpuinfo # 查看CPU信息 # ...
- 2.1.5、SparkEnv中创建MapOutputTracker
SparkEnv中创建MapOutputTracker def registerOrLookupEndpoint( name: String, endpointCreator: => RpcEn ...
- 09springMVC对ajax的支持
u 最直接的Ajax处理 u 数据绑定@RequestBody/@ResponseBody u 使用@RequestBody/@ResponseBody来支持Ajax u 使用HttpEnti ...
- nyoj_114_某种序列_201403161700
某种序列 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 数列A满足An = An-1 + An-2 + An-3, n >= 3 编写程序,给定A0, A1 ...
- JCE, Java Cryptography Extension
JCE, Java Cryptography Extension Java 8 JCE下载地址: http://www.oracle.com/technetwork/java/javase/downl ...