Redis缓存 ava-Jedis操作Redis,基本操作以及 实现对象保存
源代码下载: http://download.csdn.net/detail/jiangtao_st/7623113
1、Maven配置
- <dependency>
- <groupId>redis.clients</groupId>
- <artifactId>jedis</artifactId>
- <version>2.5.0</version>
- </dependency>
- <dependency>
- <groupId>com.alibaba</groupId>
- <artifactId>fastjson</artifactId>
- <version>1.1.41</version>
- </dependency></span>
2、Properties 配置文件
redis.pool.maxActive=100
redis.pool.maxIdle=20
redis.pool.maxWait=3000
redis.ip=localhost
redis.port=6379
3、代码具体实现的Client
- /**
- *
- * <p>
- * Redis客户端访问
- * </p>
- *
- * @author 卓轩
- * @创建时间:2014年7月11日
- * @version: V1.0
- */
- public class RedisClient {
- public static JedisPool jedisPool; // 池化管理jedis链接池
- static {
- //读取相关的配置
- ResourceBundle resourceBundle = ResourceBundle.getBundle("redis");
- int maxActive = Integer.parseInt(resourceBundle.getString("redis.pool.maxActive"));
- int maxIdle = Integer.parseInt(resourceBundle.getString("redis.pool.maxIdle"));
- int maxWait = Integer.parseInt(resourceBundle.getString("redis.pool.maxWait"));
- String ip = resourceBundle.getString("redis.ip");
- int port = Integer.parseInt(resourceBundle.getString("redis.port"));
- JedisPoolConfig config = new JedisPoolConfig();
- //设置最大连接数
- config.setMaxTotal(maxActive);
- //设置最大空闲数
- config.setMaxIdle(maxIdle);
- //设置超时时间
- config.setMaxWaitMillis(maxWait);
- //初始化连接池
- jedisPool = new JedisPool(config, ip, port);
- }
- /**
- * 向缓存中设置字符串内容
- * @param key key
- * @param value value
- * @return
- * @throws Exception
- */
- public static boolean set(String key,String value) throws Exception{
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- jedis.set(key, value);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- /**
- * 向缓存中设置对象
- * @param key
- * @param value
- * @return
- */
- public static boolean set(String key,Object value){
- Jedis jedis = null;
- try {
- String objectJson = JSON.toJSONString(value);
- jedis = jedisPool.getResource();
- jedis.set(key, objectJson);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- /**
- * 删除缓存中得对象,根据key
- * @param key
- * @return
- */
- public static boolean del(String key){
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- jedis.del(key);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- /**
- * 根据key 获取内容
- * @param key
- * @return
- */
- public static Object get(String key){
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- Object value = jedis.get(key);
- return value;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- /**
- * 根据key 获取对象
- * @param key
- * @return
- */
- public static <T> T get(String key,Class<T> clazz){
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- String value = jedis.get(key);
- return JSON.parseObject(value, clazz);
- } catch (Exception e) {
- e.printStackTrace();
- return null;
- }finally{
- jedisPool.returnResource(jedis);
- }
- }
- }
4、Sharding 分片管理
- /**
- *
- * <p>
- * Sharding Redis Client 工具类
- * </p>
- *
- * @author 卓轩
- * @创建时间:2014年7月11日
- * @version: V1.0
- */
- public class ShardingRedisClient {
- private static ShardedJedisPool shardedJedisPool;
- static {
- // 读取相关的配置
- ResourceBundle resourceBundle = ResourceBundle.getBundle("redis");
- int maxActive = Integer.parseInt(resourceBundle.getString("redis.pool.maxActive"));
- int maxIdle = Integer.parseInt(resourceBundle.getString("redis.pool.maxIdle"));
- int maxWait = Integer.parseInt(resourceBundle.getString("redis.pool.maxWait"));
- String ip = resourceBundle.getString("redis.ip");
- int port = Integer.parseInt(resourceBundle.getString("redis.port"));
- //设置配置
- JedisPoolConfig config = new JedisPoolConfig();
- config.setMaxTotal(maxActive);
- config.setMaxIdle(maxIdle);
- config.setMaxWaitMillis(maxWait);
- //设置分片元素信息
- JedisShardInfo shardInfo1 = new JedisShardInfo(ip,port);
- JedisShardInfo shardInfo2 = new JedisShardInfo(ip,port);
- List<JedisShardInfo> list = new ArrayList<JedisShardInfo>();
- list.add(shardInfo1);
- list.add(shardInfo2);
- shardedJedisPool = new ShardedJedisPool(config, list);
- }
- /**
- * 向缓存中设置字符串内容
- * @param key key
- * @param value value
- * @return
- * @throws Exception
- */
- public static boolean set(String key,String value) throws Exception{
- ShardedJedis jedis = null;
- try {
- jedis = shardedJedisPool.getResource();
- jedis.set(key, value);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- /**
- * 向缓存中设置对象
- * @param key
- * @param value
- * @return
- */
- public static boolean set(String key,Object value){
- ShardedJedis jedis = null;
- try {
- String objectJson = JSON.toJSONString(value);
- jedis = shardedJedisPool.getResource();
- jedis.set(key, objectJson);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- /**
- * 删除缓存中得对象,根据key
- * @param key
- * @return
- */
- public static boolean del(String key){
- ShardedJedis jedis = null;
- try {
- jedis = shardedJedisPool.getResource();
- jedis.del(key);
- return true;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- /**
- * 根据key 获取内容
- * @param key
- * @return
- */
- public static Object get(String key){
- ShardedJedis jedis = null;
- try {
- jedis = shardedJedisPool.getResource();
- Object value = jedis.get(key);
- return value;
- } catch (Exception e) {
- e.printStackTrace();
- return false;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- /**
- * 根据key 获取对象
- * @param key
- * @return
- */
- public static <T> T get(String key,Class<T> clazz){
- ShardedJedis jedis = null;
- try {
- jedis = shardedJedisPool.getResource();
- String value = jedis.get(key);
- return JSON.parseObject(value, clazz);
- } catch (Exception e) {
- e.printStackTrace();
- return null;
- }finally{
- shardedJedisPool.returnResource(jedis);
- }
- }
- }
5、 单元测试、保存对象、写入对象
- /**
- *
- * <p>
- * 测试独立redis 客户端
- * </p>
- *
- * @author 卓轩
- * @创建时间:2014年7月11日
- * @version: V1.0
- */
- public class SimpleClient {
- @Test
- public void userCache(){
- //向缓存中保存对象
- UserDO zhuoxuan = new UserDO();
- zhuoxuan.setUserId(113445);
- zhuoxuan.setSex(1);
- zhuoxuan.setUname("卓轩");
- zhuoxuan.setUnick("zhuoxuan");
- zhuoxuan.setEmail("zhuoxuan@mogujie.com");
- //调用方法处理
- boolean reusltCache = RedisClient.set("zhuoxuan", zhuoxuan);
- if (reusltCache) {
- System.out.println("向缓存中保存对象成功。");
- }else{
- System.out.println("向缓存中保存对象失败。");
- }
- }
- @Test
- public void getUserInfo(){
- UserDO zhuoxuan = RedisClient.get("zhuoxuan",UserDO.class);
- if(zhuoxuan != null){
- System.out.println("从缓存中获取的对象," + zhuoxuan.getUname() + "@" + zhuoxuan.getEmail());
- }
- }
- }
Redis缓存 ava-Jedis操作Redis,基本操作以及 实现对象保存的更多相关文章
- 【Redis】使用Jedis操作Redis
Jedis介绍 jedis就是集成了redis的一些命令操作,封装了redis的java客户端. Jedis使用 使用jedis需要引入jedis的jar包,下面提供了maven依赖 jedis.ja ...
- <Redis> 入门四 Jedis操作Redis
pom依赖 <dependencies> <!-- https://mvnrepository.com/artifact/redis.clients/jedis --> < ...
- Jedis操作Redis
Jedis操作Redis的常用封装方法 @Resource(name="jedispool") private JedisPool pool=null; /** * 设置缓存对象过 ...
- jedis操作redis的几种常见方式总结
Redis是一个著名的key-value存储系统,也是nosql中的最常见的一种,这篇文章主要给大家总结了关于在java中jedis操作redis的几种常见方式,文中给出了详细的示例代码供大家参考学习 ...
- Java中Jedis操作Redis与Spring的整合
Redis是一个key-value存储系统.它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有序集合).这些数据类型都支持push/pop. ...
- Redis入门和Java利用jedis操作redis
Redis入门和Java利用jedis操作redis Redis介绍 Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库. Redis 与其他 key - val ...
- Jedis操作Redis数据库
添加Maven依赖: <dependencies> <!-- 单元测试 --> <dependency> <groupId>junit</grou ...
- 四、Jedis操作Redis
前言: 原来我们操作mysql需要用的jdbc,现在操作redis则需要jedis,jedis是客户端,而redis是服务器,使用jedis客户端来操作redis. 在这里要使用jedis操作red ...
- JAVA中通过Jedis操作Redis连接与插入简单库
一.简述 JAVA中通过Jedis操作Redis连接与插入简单库 二.依赖 <!-- https://mvnrepository.com/artifact/redis.clients/jedis ...
- 第三百节,python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型
python操作redis缓存-其他常用操作,用于操作redis里的数据name,不论什么数据类型 delete(*names)根据删除redis中的任意数据类型 #!/usr/bin/env pyt ...
随机推荐
- poj 2993 Emag eht htiw Em Pleh(模拟)
题目:http://poj.org/problem?id=2993 题意:和2996反着 #include <iostream> #include<cstdio> #inclu ...
- OS.ENVIRON()详解
OS.ENVIRON()详解
- Dataguard Content
1.Dataguard环境设计的三个重要概念 1.1 Primary数据库 在Data Guard的环境中与Standby数据库对应的数据库即是Primary数据库,也就是Primary数据库正在运行 ...
- NopCommerce源码架构详解--初识高性能的开源商城系统cms
很多人都说通过阅读.学习大神们高质量的代码是提高自己技术能力最快的方式之一.我觉得通过阅读NopCommerce的源码,可以从中学习很多企业系统.软件开发的规范和一些新的技术.技巧,可以快速地提高我们 ...
- Oracle ORA-00119和ORA-00132的解决方案
今天在启动服务器上的ORACLE时遇到如下错误: SQL> startup; ORA-00119: invalid specification for system parameter LOCA ...
- mkimage的-a 和 –c参数和内核引导
目录 一.mkimage工具简介二.-a参数与-e参数和内核引导的关系三.实例测试 3.1 -a参数与-e参数相同,可以将内核下载到SDRAM的任何地址,然后从这启动 3.2 -a参数与-e参数不同, ...
- Java8 Stream API
Stream是Java8中,操作集合的一个重要特性. 从iteration到Stream操作 当你操作一个集合的时候,你通常的做法是迭代每一个元素,然后处理你想要的事情.举个例子: String co ...
- 利用CryptoStream进行加密解密
public class DBSecurity { //sKey sIV这两个自己随意设定,不能外泄 private const string sKey = "11,22,33,43,34, ...
- VBScript: Windows脚本宿主介绍
Windows脚本宿主(Windows Script Host, WSH)是一个Windows管理工具.WSH创建了一个脚本运行的主环境,WSH使脚本能够使用对象和服务,并提供脚本执行的准则.WSH还 ...
- input子系统 KeyPad-Touch上报数据格式与机制
-----------------------------------------------------------------------本文系本站原创,欢迎转载!转载请注明出处:http://b ...