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 ( 简单使用)的更多相关文章

  1. redis之(二十一)redis之深入理解Spring Redis的使用

    关于spring redis框架的使用,网上的例子很多很多.但是在自己最近一段时间的使用中,发现这些教程都是入门教程,包括很多的使用方法,与spring redis丰富的api大相径庭,真是浪费了这么 ...

  2. spring redis入门

    小二,上菜!!! 1. 虚拟机上安装redis服务 下载tar包,wget http://download.redis.io/releases/redis-2.8.19.tar.gz. 解压缩,tar ...

  3. 分布式缓存技术redis学习—— 深入理解Spring Redis的使用

    关于spring redis框架的使用,网上的例子很多很多.但是在自己最近一段时间的使用中,发现这些教程都是入门教程,包括很多的使用方法,与spring redis丰富的api大相径庭,真是浪费了这么 ...

  4. 深入理解Spring Redis的使用 (七)、Spring Redis 使用 jackson序列化 以及 BaseDao代码

    之前在介绍Spring Redis进行存储的时候,都是通过RedisTemplate中的defaultSerializer,即JdkSerializationRedisSerializer.通过Jdk ...

  5. spring redis @Cacheable注解使用部分错误及无效原因

    spring redis @Cacheable注解使用部分错误及无效原因 说明:     spring项目用到redis注解无效,解决问题中遇到一堆BUG,各种搜索,看了许多错误解决方案一一测试,对于 ...

  6. 一篇文章带你了解NoSql数据库——Redis简单入门

    一篇文章带你了解NoSql数据库--Redis简单入门 Redis是一个基于内存的key-value结构数据库 我们会利用其内存存储速度快,读写性能高的特点去完成企业中的一些热门数据的储存信息 在本篇 ...

  7. Spring cache简单使用guava cache

    Spring cache简单使用 前言 spring有一套和各种缓存的集成方式.类似于sl4j,你可以选择log框架实现,也一样可以实现缓存实现,比如ehcache,guava cache. [TOC ...

  8. Spring的简单demo

    ---------------------------------------- 开发一个Spring的简单Demo,具体的步骤如下: 1.构造一个maven项目 2.在maven项目的pom.xml ...

  9. spring+redis 集群下的操作

    文章就是记录一下工作当中的用到的点,与测试方法以备用,会不断更新. 配置文件spring-redis.xml: <?xml version="1.0" encoding=&q ...

随机推荐

  1. 最基础的rpm命令

    rpm -ivh package.rpm 安装一个rpm包 rpm -ivh --nodeeps package.rpm 安装一个rpm包而忽略依赖关系警告 rpm -U package.rpm 更新 ...

  2. sysbench_fileio.sh

    当我--file-total-size=30G 并且指定3个文件的时候,结果是产生3个10G的文件,然而--max-time=20被忽视了,虽然指定了20s的限制,实际上是在prepare阶段,--m ...

  3. Qt Creator 中文乱码问题

    一. Qt 4 乱码问题 解决方案 1. 在Qt 中 快捷菜单选项功能中 Edit(编辑)  --> Select Encoding...(选择编码) 选择载入(显示)编码和储存编码,要解决中文 ...

  4. play snake on linux

    在写完超Low的windows上的贪吃蛇后 被人吐槽了几个方面: 1.界面真的Low,开始,结束,游戏中,都太简陋了... 2.每次都清屏在输出字符矩阵的解决方案...太晃眼了 3.一个BUG,为了解 ...

  5. Restful传递数组参数的两种方式

    第一种,直接传递数组 js直接传递数组 var data = ["123","456"];that.loadDictionarys(data).subscrib ...

  6. [TYVJ1730]二逼平衡树

    [TYVJ1730]二逼平衡树 题目 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:1.查询k在区间内的排名2.查询区间内排名为k的值3.修改某一位值上的数值4.查 ...

  7. sgu 194 无源汇有上下界的最大流(最大流模板dinic加优化)

    模板类型的题具体参考国家集训队论文:http://wenku.baidu.com/view/0f3b691c59eef8c75fbfb35c.html 参考博客:http://blog.csdn.ne ...

  8. 为什么视频流一般都用UDP

    我们知道TCP 和 UDP的一个区别之一就是TCP要保证丢失的package会被再次重发,确保对方能够收到. 而在视频播放中,如果有一秒钟的信号确实,导致画面出现了一点瑕疵,那么最合适的办法是把这点瑕 ...

  9. swift2.0学习之拓展

    拓展:和oc的拓展方法功能差点儿相同.就是给已经存在的类,结构体.枚举,协议类型添加新的方法 拓展语法: 用extensionkeyword声明: extension SomeType { // ne ...

  10. Android Studio第一次启动的Fetching android sdk component information的问题

    1)进入刚安装的Android Studio文件夹下的bin文件夹.找到idea.properties文件,用文本编辑器打开. 2)在idea.properties文件末尾加入一行: disable. ...