昨天已经在windows环境下安装使用了redis。

下面准备在java项目中测试使用redis。

redis官网推荐使用jedis来访问redis。所以首先准备了jedis的jar包,以及需要依赖的jar包。

commons-pool2-2.3

hamcrest-core-1.3

jedis-2.7.2.jar

因为redis也是属于一种数据库,也是对数据的访问,所以把他放置在dao层,与service分开

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool; import com.dyuproject.protostuff.LinkedBuffer;
import com.dyuproject.protostuff.ProtostuffIOUtil;
import com.dyuproject.protostuff.runtime.RuntimeSchema;
import com.xhxkj.ssm.entity.UserEntity; /**
* 访问redis数据层
* @author XX
*
*/
public class RedisDao { private final JedisPool jedisPool;//redis连接池 /**
* 构造方法
* @param ip 访问的ip
* @param port 访问的端口
*/
public RedisDao(String ip, int port)
{
jedisPool = new JedisPool(ip,port);
} //创建一个schema用来序列化
private RuntimeSchema<UserEntity> schema = RuntimeSchema.createFrom(UserEntity.class); /**
* 通过用户名获取redis中对应的用户信息
* @param username 输入的用户名
* @return 存在返回:这个对象,不存在返回:null
*/
public UserEntity getUser(String username)
{
//redis操作
try{
Jedis jedis = jedisPool.getResource();
try {
//在redis中存放时,key的书写规则,官方推荐,对象:对象属性
//也就是获取时利用“user:username”作为键来得到值
String key = "user:" + username; //自定义序列化
//在redis中获取的值一定是一个字节数组,需要通过反序列化转换成java对象
byte[] bytes = jedis.get(key.getBytes());
if(bytes != null)
{
//获取一个空对象
UserEntity user = schema.newMessage();
//反序列化后放置在user中
ProtostuffIOUtil.mergeFrom(bytes, user, schema);
return user;
}
}finally{
jedis.close();
}
}catch (Exception e){
e.printStackTrace();
}
return null;
} /**
* 在缓存中存放user对象
* @param user
* @return 成功返回“OK”;失败返回错误信息
*/
public String putUser(UserEntity user)
{
try {
Jedis jedis = jedisPool.getResource();
try {
//通过对应的键存放user对象
String key = "user:" + user.getUsername(); //自定义序列化操作,利用protostuff将对象序列化成字节数组
byte[] bytes = ProtostuffIOUtil.toByteArray(user, schema,
LinkedBuffer.allocate(LinkedBuffer.DEFAULT_BUFFER_SIZE)); //缓存时间1小时,缓存的时间是用秒来计的
int timeout = 60*60; //在redis中存放这个对象
return jedis.setex(key.getBytes(),timeout,bytes);
} finally{
jedis.close();
}
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
}

这里提供了两个方法,分别是put和get,其中需要用到序列化和反序列化的操作,用到的jar包有下面这几个

protostuff-core-1.0.8.jar

protostuff-runtime-1.0.8.jar

protostuff-collectionschema-1.0.8.jar

protostuff-api-1.0.8.jar

protostuff属于性能相当优秀的一种

在spring中配置

<!-- redisDao -->
    <bean id="redisDao" class="com.xxx.dao.redis.RedisDao">

<constructor-arg index="0" value="localhost"/>

<constructor-arg index="1" value="6379"/>

</bean>

之后就可以直接在服务层调用redisDao的方法了

//首先去redis中寻找是否存在缓存的用户信息

        UserEntity resultUser = redisDao.getUser("xx");

//如果不存在,那就在缓存中放置一个用户信息

if(resultUser == null)

{

String result = redisDao.putUser(user);

System.out.println(result);

return null;

}

else

{

return resultUser;

}

需要注意的是,如果存放成功,返回是一个字符串“OK”

在使用前一定要确定你的redis服务处于开启状态,cmd窗口是开着的

因为网络上面很多都是用maven配置的,所以jar包比较难找,jar包间的依赖确实比较麻烦,推荐一个网站http://maven.outofmemory.cn/

这个网站能很好的找到各种jar包,并且告诉你依赖的关系,非常方便

Redis(2)用jedis实现在java中使用redis的更多相关文章

  1. Redis入门教程(三)— Java中操作Redis

    在Redis的官网上,我们可以看到Redis的Java客户端众多 其中,Jedis是Redis官方推荐,也是使用用户最多的Java客户端. 开始前的准备 使用jedis使用到的jedis-2.1.0. ...

  2. Redis笔记(六):Java中使用Redis

    Java程序使用Redis 添加依赖包 Maven依赖方式 <dependency> <groupId>redis.clients</groupId> <ar ...

  3. 在java中使用redis

    在java中使用redis很简单,只需要添加jedist.jar,通过它的api就可以了.而且,api和redis的语法几乎完全相同.以下简单的测试: 参考:http://www.runoob.com ...

  4. JAVA中使用Redis

    上节讲解了如何在centos上安装redis,点击查看.本节我们学习在java中使用redis.需要将jedis-*.jar添加到classpath(点击下载),如果使用连接池还需要commons-p ...

  5. redis的介绍与操作及Django中使用redis缓存

    redis VS mysql的区别 """ redis: 内存数据库(读写快).非关系型(操作数据方便) mysql: 硬盘数据库(数据持久化).关系型(操作数据间关系) ...

  6. java中的redis工具类

    1.redis基础类 package com.qlchat.component.redis.template; import javax.annotation.PostConstruct; impor ...

  7. java中使用redis --- Hash的简单应用

    1.java代码 public class RedisTest01 { public static void main(String[] args) { // connect redis server ...

  8. java中使用redis --- List列表的简单应用

    1.Dos中启动server端 2.idea中启动client端 public class RedisTest01 { public static void main(String[] args){ ...

  9. Java中的Redis 哨兵高可用性

    让我们探索Redis Sentinel,看看如何在Java上运行它,一起来看看,最近get了很多新知识,分享给大家参考学习.需要详细的java架构思维导图路线也可以评论获取! 什么是Redis哨兵? ...

随机推荐

  1. js中两个感叹号的原理与用法分析(转载记录没找到原帖)

    var foo; alert(!foo);//undifined情况下,一个感叹号返回的是true; alert(!goo);//null情况下,一个感叹号返回的也是true; var o={flag ...

  2. Javascript兑现图片预加载【回调函数,多张图片】 (转载)

    Javascript实现图片预加载[回调函数,多张图片] 使用JS实现一组图片动画效果或者使用HTML5 Canvas渲染一系列图片等案例中,需要图片全部加载完成方可运行动画效果.此时程序中就会涉及多 ...

  3. treecnt

    treecnt  ﹡    LH (命题人)   基准时间限制:1 秒 空间限制:131072 KB 分值: 40 给定一棵n个节点的树,从1到n标号.选择k个点,你需要选择一些边使得这k个点通过选择 ...

  4. First blogs start

    这是我第一次写博客笔记,为了更好的成长,从现在开始我的博客记录. 我是从事linux运维的,到目前为止,已经有2年的工作经验了. 希望从此以后我能够坚持每天记录下点点滴滴.

  5. HDU1577-WisKey的眼神

    Problem Description WisKey的眼镜有500多度,所以眼神不大好,而且他有个习惯,就是走路喜欢看着地(不是为了拣钱哦^_^),所以大家下次碰见他的时候最好主动打下招呼,呵呵.但是 ...

  6. 浅析PageRank算法

    很早就对Google的PageRank算法很感兴趣,但一直没有深究,只有个轮廓性的概念.前几天趁团队outing的机会,在动车上看了一些相关的资料(PS:在动车上看看书真是一种享受),趁热打铁,将所看 ...

  7. Windows进程间通信(上)

    一.管道 管道(pipe)是用于进程间通信的共享内存区域.创建管道的进程称为管道服务器,而连接到这个管道的进程称为管道客户端.一个进程向管道写入信息,而另外一个进程从管道读取信息. 异步管道是基于字符 ...

  8. poi的各种单元格样式以及一些常用的配置

    之前我做过一个poi到处excel数据的博客,但是,后面使用起来发现,导出的数据单元格样式都不对. 很多没有居中对齐,很多单元格的格式不对,还有就是单元格的大小不对,导致数据显示异常,虽然功能可以使用 ...

  9. 按钮特效-Enter键自动提交表单

    —————————————————————— <script type="text/javascript">                        //当用户按 ...

  10. HAProxy与varnish

    Even if HAProxy can do TCP proxying, it is often used in front of web application, exactly where we ...