源代码下载: http://download.csdn.net/detail/jiangtao_st/7623113

1、Maven配置

  1. <dependency>
  2. <groupId>redis.clients</groupId>
  3. <artifactId>jedis</artifactId>
  4. <version>2.5.0</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>com.alibaba</groupId>
  8. <artifactId>fastjson</artifactId>
  9. <version>1.1.41</version>
  10. </dependency></span>

2、Properties 配置文件

redis.pool.maxActive=100

redis.pool.maxIdle=20

redis.pool.maxWait=3000

redis.ip=localhost

redis.port=6379

3、代码具体实现的Client

  1. /**
  2. *
  3. * <p>
  4. *  Redis客户端访问
  5. * </p>
  6. *
  7. * @author 卓轩
  8. * @创建时间:2014年7月11日
  9. * @version: V1.0
  10. */
  11. public class RedisClient {
  12. public  static  JedisPool jedisPool; // 池化管理jedis链接池
  13. static {
  14. //读取相关的配置
  15. ResourceBundle resourceBundle = ResourceBundle.getBundle("redis");
  16. int maxActive = Integer.parseInt(resourceBundle.getString("redis.pool.maxActive"));
  17. int maxIdle = Integer.parseInt(resourceBundle.getString("redis.pool.maxIdle"));
  18. int maxWait = Integer.parseInt(resourceBundle.getString("redis.pool.maxWait"));
  19. String ip = resourceBundle.getString("redis.ip");
  20. int port = Integer.parseInt(resourceBundle.getString("redis.port"));
  21. JedisPoolConfig config = new JedisPoolConfig();
  22. //设置最大连接数
  23. config.setMaxTotal(maxActive);
  24. //设置最大空闲数
  25. config.setMaxIdle(maxIdle);
  26. //设置超时时间
  27. config.setMaxWaitMillis(maxWait);
  28. //初始化连接池
  29. jedisPool = new JedisPool(config, ip, port);
  30. }
  31. /**
  32. * 向缓存中设置字符串内容
  33. * @param key key
  34. * @param value value
  35. * @return
  36. * @throws Exception
  37. */
  38. public static boolean  set(String key,String value) throws Exception{
  39. Jedis jedis = null;
  40. try {
  41. jedis = jedisPool.getResource();
  42. jedis.set(key, value);
  43. return true;
  44. } catch (Exception e) {
  45. e.printStackTrace();
  46. return false;
  47. }finally{
  48. jedisPool.returnResource(jedis);
  49. }
  50. }
  51. /**
  52. * 向缓存中设置对象
  53. * @param key
  54. * @param value
  55. * @return
  56. */
  57. public static boolean  set(String key,Object value){
  58. Jedis jedis = null;
  59. try {
  60. String objectJson = JSON.toJSONString(value);
  61. jedis = jedisPool.getResource();
  62. jedis.set(key, objectJson);
  63. return true;
  64. } catch (Exception e) {
  65. e.printStackTrace();
  66. return false;
  67. }finally{
  68. jedisPool.returnResource(jedis);
  69. }
  70. }
  71. /**
  72. * 删除缓存中得对象,根据key
  73. * @param key
  74. * @return
  75. */
  76. public static boolean del(String key){
  77. Jedis jedis = null;
  78. try {
  79. jedis = jedisPool.getResource();
  80. jedis.del(key);
  81. return true;
  82. } catch (Exception e) {
  83. e.printStackTrace();
  84. return false;
  85. }finally{
  86. jedisPool.returnResource(jedis);
  87. }
  88. }
  89. /**
  90. * 根据key 获取内容
  91. * @param key
  92. * @return
  93. */
  94. public static Object get(String key){
  95. Jedis jedis = null;
  96. try {
  97. jedis = jedisPool.getResource();
  98. Object value = jedis.get(key);
  99. return value;
  100. } catch (Exception e) {
  101. e.printStackTrace();
  102. return false;
  103. }finally{
  104. jedisPool.returnResource(jedis);
  105. }
  106. }
  107. /**
  108. * 根据key 获取对象
  109. * @param key
  110. * @return
  111. */
  112. public static <T> T get(String key,Class<T> clazz){
  113. Jedis jedis = null;
  114. try {
  115. jedis = jedisPool.getResource();
  116. String value = jedis.get(key);
  117. return JSON.parseObject(value, clazz);
  118. } catch (Exception e) {
  119. e.printStackTrace();
  120. return null;
  121. }finally{
  122. jedisPool.returnResource(jedis);
  123. }
  124. }
  125. }

4、Sharding 分片管理

  1. /**
  2. *
  3. * <p>
  4. * Sharding Redis Client 工具类
  5. * </p>
  6. *
  7. * @author 卓轩
  8. * @创建时间:2014年7月11日
  9. * @version: V1.0
  10. */
  11. public class ShardingRedisClient {
  12. private static ShardedJedisPool shardedJedisPool;
  13. static {
  14. // 读取相关的配置
  15. ResourceBundle resourceBundle = ResourceBundle.getBundle("redis");
  16. int maxActive = Integer.parseInt(resourceBundle.getString("redis.pool.maxActive"));
  17. int maxIdle = Integer.parseInt(resourceBundle.getString("redis.pool.maxIdle"));
  18. int maxWait = Integer.parseInt(resourceBundle.getString("redis.pool.maxWait"));
  19. String ip = resourceBundle.getString("redis.ip");
  20. int port = Integer.parseInt(resourceBundle.getString("redis.port"));
  21. //设置配置
  22. JedisPoolConfig config = new JedisPoolConfig();
  23. config.setMaxTotal(maxActive);
  24. config.setMaxIdle(maxIdle);
  25. config.setMaxWaitMillis(maxWait);
  26. //设置分片元素信息
  27. JedisShardInfo shardInfo1 = new JedisShardInfo(ip,port);
  28. JedisShardInfo shardInfo2 = new JedisShardInfo(ip,port);
  29. List<JedisShardInfo> list = new ArrayList<JedisShardInfo>();
  30. list.add(shardInfo1);
  31. list.add(shardInfo2);
  32. shardedJedisPool = new ShardedJedisPool(config, list);
  33. }
  34. /**
  35. * 向缓存中设置字符串内容
  36. * @param key key
  37. * @param value value
  38. * @return
  39. * @throws Exception
  40. */
  41. public static boolean  set(String key,String value) throws Exception{
  42. ShardedJedis jedis = null;
  43. try {
  44. jedis = shardedJedisPool.getResource();
  45. jedis.set(key, value);
  46. return true;
  47. } catch (Exception e) {
  48. e.printStackTrace();
  49. return false;
  50. }finally{
  51. shardedJedisPool.returnResource(jedis);
  52. }
  53. }
  54. /**
  55. * 向缓存中设置对象
  56. * @param key
  57. * @param value
  58. * @return
  59. */
  60. public static boolean  set(String key,Object value){
  61. ShardedJedis jedis = null;
  62. try {
  63. String objectJson = JSON.toJSONString(value);
  64. jedis = shardedJedisPool.getResource();
  65. jedis.set(key, objectJson);
  66. return true;
  67. } catch (Exception e) {
  68. e.printStackTrace();
  69. return false;
  70. }finally{
  71. shardedJedisPool.returnResource(jedis);
  72. }
  73. }
  74. /**
  75. * 删除缓存中得对象,根据key
  76. * @param key
  77. * @return
  78. */
  79. public static boolean del(String key){
  80. ShardedJedis jedis = null;
  81. try {
  82. jedis = shardedJedisPool.getResource();
  83. jedis.del(key);
  84. return true;
  85. } catch (Exception e) {
  86. e.printStackTrace();
  87. return false;
  88. }finally{
  89. shardedJedisPool.returnResource(jedis);
  90. }
  91. }
  92. /**
  93. * 根据key 获取内容
  94. * @param key
  95. * @return
  96. */
  97. public static Object get(String key){
  98. ShardedJedis jedis = null;
  99. try {
  100. jedis = shardedJedisPool.getResource();
  101. Object value = jedis.get(key);
  102. return value;
  103. } catch (Exception e) {
  104. e.printStackTrace();
  105. return false;
  106. }finally{
  107. shardedJedisPool.returnResource(jedis);
  108. }
  109. }
  110. /**
  111. * 根据key 获取对象
  112. * @param key
  113. * @return
  114. */
  115. public static <T> T get(String key,Class<T> clazz){
  116. ShardedJedis jedis = null;
  117. try {
  118. jedis = shardedJedisPool.getResource();
  119. String value = jedis.get(key);
  120. return JSON.parseObject(value, clazz);
  121. } catch (Exception e) {
  122. e.printStackTrace();
  123. return null;
  124. }finally{
  125. shardedJedisPool.returnResource(jedis);
  126. }
  127. }
  128. }

5、 单元测试、保存对象、写入对象

    1. /**
    2. *
    3. * <p>
    4. *  测试独立redis 客户端
    5. * </p>
    6. *
    7. * @author 卓轩
    8. * @创建时间:2014年7月11日
    9. * @version: V1.0
    10. */
    11. public class SimpleClient {
    12. @Test
    13. public void userCache(){
    14. //向缓存中保存对象
    15. UserDO zhuoxuan = new UserDO();
    16. zhuoxuan.setUserId(113445);
    17. zhuoxuan.setSex(1);
    18. zhuoxuan.setUname("卓轩");
    19. zhuoxuan.setUnick("zhuoxuan");
    20. zhuoxuan.setEmail("zhuoxuan@mogujie.com");
    21. //调用方法处理
    22. boolean reusltCache = RedisClient.set("zhuoxuan", zhuoxuan);
    23. if (reusltCache) {
    24. System.out.println("向缓存中保存对象成功。");
    25. }else{
    26. System.out.println("向缓存中保存对象失败。");
    27. }
    28. }
    29. @Test
    30. public void getUserInfo(){
    31. UserDO zhuoxuan = RedisClient.get("zhuoxuan",UserDO.class);
    32. if(zhuoxuan != null){
    33. System.out.println("从缓存中获取的对象," + zhuoxuan.getUname() + "@" + zhuoxuan.getEmail());
    34. }
    35. }
    36. }

Redis缓存 ava-Jedis操作Redis,基本操作以及 实现对象保存的更多相关文章

  1. 【Redis】使用Jedis操作Redis

    Jedis介绍 jedis就是集成了redis的一些命令操作,封装了redis的java客户端. Jedis使用 使用jedis需要引入jedis的jar包,下面提供了maven依赖 jedis.ja ...

  2. <Redis> 入门四 Jedis操作Redis

    pom依赖 <dependencies> <!-- https://mvnrepository.com/artifact/redis.clients/jedis --> < ...

  3. Jedis操作Redis

    Jedis操作Redis的常用封装方法 @Resource(name="jedispool") private JedisPool pool=null; /** * 设置缓存对象过 ...

  4. jedis操作redis的几种常见方式总结

    Redis是一个著名的key-value存储系统,也是nosql中的最常见的一种,这篇文章主要给大家总结了关于在java中jedis操作redis的几种常见方式,文中给出了详细的示例代码供大家参考学习 ...

  5. Java中Jedis操作Redis与Spring的整合

    Redis是一个key-value存储系统.它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有序集合).这些数据类型都支持push/pop. ...

  6. Redis入门和Java利用jedis操作redis

    Redis入门和Java利用jedis操作redis Redis介绍 Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库. Redis 与其他 key - val ...

  7. Jedis操作Redis数据库

    添加Maven依赖: <dependencies> <!-- 单元测试 --> <dependency> <groupId>junit</grou ...

  8. 四、Jedis操作Redis

    前言:  原来我们操作mysql需要用的jdbc,现在操作redis则需要jedis,jedis是客户端,而redis是服务器,使用jedis客户端来操作redis. 在这里要使用jedis操作red ...

  9. JAVA中通过Jedis操作Redis连接与插入简单库

    一.简述 JAVA中通过Jedis操作Redis连接与插入简单库 二.依赖 <!-- https://mvnrepository.com/artifact/redis.clients/jedis ...

  10. 第三百节,python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型

    python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型 delete(*names)根据删除redis中的任意数据类型 #!/usr/bin/env pyt ...

随机推荐

  1. Nhibernate与Dapper对比,及Nhibernate增删改和9种查询语法

    1,Sql语法. NH:HQL Dapper:原生Sql. 点评:原生Sql可以直接放在数据库里执行,Hql不行,且Hql增加学习负担.(Hn也可以原生Sql,但好像用的不多呀) 2,开发速度. NH ...

  2. 手动启动angular

    关于手动启动 angular 的问题 angular核心原理解析1:angular自启动过程 angular.element(document).ready(function() { angular. ...

  3. 白话spring依赖注入

    Spring能有效地组织J2EE应用各层的对象.Action?Service?DAO?,都可在Spring的管理下有机地协调.运行.Spring将各层的对象以松耦合的方式组织在一起,对象与对象之间没有 ...

  4. [JS前端开发] js/jquery控制页面动态加载数据 滑动滚动条自动加载事件

    页面滚动动态加载数据,页面下拉自动加载内容 相信很多人都见过瀑布流图片布局,那些图片是动态加载出来的,效果很好,对服务器的压力相对来说也小了很多 有手机的相信都见过这样的效果:进入qq空间,向下拉动空 ...

  5. jQuery.Validate验证库

    一.用前必备官方网站:http://bassistance.de/jquery-plugins/jquery-plugin-validation/ API: http://jquery.bassist ...

  6. 使用Spring Profile和Mybatis进行多个数据源(H2和Mysql)的切换

    最近在做WebMagic的后台,遇到一个问题:后台用到了数据库,本来理想情况下是用Mysql,但是为了做到开箱即用,也整合了一个嵌入式 数据库H2.这里面就有个问题了,如何用一套代码,提供对Mysql ...

  7. Tasks on 2013

    1.改进并补充实验 2.样本选取和文档分布调查 3. Diversity Metrics 4. PPT for Project starting 1. Chrome & webkit 2. O ...

  8. MATLAB将批量的图片保存为mat文件

    clc; clear all; num = 10; for i = 1 : num IM = imread(sprintf('E:\\TEST\\PtzTEST2015-8-9\\image1280x ...

  9. POJ3666-Making the Grade(左偏树 or DP)

    左偏树 炒鸡棒的论文<左偏树的特点及其应用> 虽然题目要求比论文多了一个条件,但是……只需要求非递减就可以AC……数据好弱…… 虽然还没想明白为什么,但是应该觉得应该是这样——求非递减用大 ...

  10. Java管道流PipedStream

    管道读取流和管道写入流可以像管道一样对接上,管道读取流就可以读取管道写入流写入的数据.需要注意的是需要加入多线程技术,因为单线程,先执行read,会发生死锁,因为read方法是阻塞式的,没有数据的re ...