第三章:jedis的使用

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Jedis是什么?那jedis就是集成了redis的一些命令操作,封装了redis的java客户端。提供了连接池管理。一般不直接使用jedis,而是在其上在封装一层,作为业务的使用。

Jedis是什么?

那jedis就是集成了redis的一些命令操作,封装了redis的java客户端。提供了连接池管理。一般不直接使用jedis,而是在其上在封装一层,作为业务的使用。如果用spring的话,可以看看spring 封装的 redis Spring Data Redis
·###Jedis基本使用

//生成一个Jedis对象,这个对象负责和指定Redis节点进行通信
Jedis jedis = new Jedis("127.0.0.1",6379);
//jedis执行set操作
jedis.set("hello","world");
//jedis执行get操作
String value = jedis.get("hello");
//incr key 自增1,如果key不存在,自增后get(key)=1
jedis.incr("counter");
//2.hash
jedis.hset("myhash","f1","v1");
jedis.hset("myhash","f2","v2");
//hash输出结果
jedis.hgetAll("myhash");
//3.list
jedis.rpush("mylist","1");
jedis.rpush("mylist","2");
jedis.rpush("mylist","3");
//输出结果[1,2,3]
jedis.lrange("mylist",0,-1);
//4.set
jedis.sadd("myset","a");
jedis.sadd("myset","b");
jedis.sadd("myset","c");
//输出结果
jedis.smembers("myset");
//5.zset
jedis.zadd("myzset",1,"jiao");
jedis.zadd("myzset",2,"fant");
jedis.zadd("myzset",3,"j");
//输出结果
jedis.zrangeWithScores("myzset",0,-1);

Jedis 连接池

  1. 直接连接
  • 优点:简单方便,适用于少量长期连接
  • 缺点:存在每次新建/关闭TCP开销;资源无法控制,存在连接泄露可能;线程不安全
  1. Jedis连接池
  • 优点:Jedis预先生成,降低开销使用;连接池的形式保护和控制资源的使用
  • 缺点:相对于直连,使用相对麻烦,尤其在资源的管理上需要很多参数来保证,一旦规划不合理也会出现问题。

Redis连接池工具类 RedisPool.java

package com.answer.admin.util.redis;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

/**
 * Redis连接池工具
 * Created by Fant.J.
 * 2017/10/24 20:55
 */
public class RedisPool {

    private static JedisPool jedisPool = null;
    private static Jedis jedis;
    static {
        jedis = getJedisPool().getResource();
    }
    /**
     * 构建redis连接池
     */
    public static JedisPool getJedisPool(){
        if (jedisPool == null){
            JedisPoolConfig config = new JedisPoolConfig();
            config.setMaxTotal(1024);//可用连接实例的最大数目,如果赋值为-1,表示不限制
            config.setMaxIdle(5);// 控制一个Pool最多有多少个状态为idle(空闲的)jedis实例,默认值也是8
            config.setMaxWaitMillis(1000*100);// 等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时/如果超过等待时间,则直接抛出异常
            config.setTestOnBorrow(true);// 在borrow一个jedis实例时,是否提前进行validate操作,如果为true,则得到的jedis实例均是可用的
            jedisPool = new JedisPool(config, "192.168.218.129", 6379);
        }
        return jedisPool;
    }
    /**
     * 释放redis资源
     */
    public static void returnResource(Jedis jedis){
        if(jedis != null){
            jedis.close();
        }
    }
}

使用

package com.answer.admin.util.redis;

import org.junit.Test;
import org.springframework.dao.DataAccessException;
import org.springframework.data.redis.connection.RedisConnection;
import org.springframework.data.redis.core.RedisCallback;
import org.springframework.data.redis.core.RedisTemplate;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;

/**
 * Created by Fant.J.
 * 2017/10/24 20:48
 */

public class RedisTest {
    /** 普通用法 */
    @Test
    public void redisLearn(){
        Jedis jedis = new Jedis("192.168.218.129",6379);
        String result = jedis.get("hello");
        System.out.println(result);
    }
    /** 连接池用法,切记操作结束要施放资源 */
    @Test
    public void redisPoolLearn(){
        String value = "hello";
        String result = null;
        Jedis jedis = null;
        try {
            JedisPool jedisPool = RedisPool.getJedisPool();
            jedis = jedisPool.getResource();
            result = jedis.get(value);
        }catch (Exception e){
            RedisPool.returnResource(jedis);//施放资源
            e.printStackTrace();
        }finally {
            RedisPool.returnResource(jedis);
        }
        System.out.println(result);
    }
}

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
12月前
|
NoSQL 算法 Redis
【Redis 系列】redis 学习十四,sorted_set 初步探究梳理
【Redis 系列】redis 学习十四,sorted_set 初步探究梳理
|
5月前
|
存储 NoSQL Java
Redis系列学习文章分享---第二篇(Redis快速入门之Java客户端--Jedis+连接池+SpringDataRedis+RedisTemplate+RedisSerializer+Hash)
Redis系列学习文章分享---第二篇(Redis快速入门之Java客户端--Jedis+连接池+SpringDataRedis+RedisTemplate+RedisSerializer+Hash)
232 0
|
消息中间件 NoSQL 数据可视化
【Redis基础知识 十三】Jedis的使用
【Redis基础知识 十三】Jedis的使用
188 0
|
存储 NoSQL Java
Redis学习9:Jedis学习
编程语言中的数据如任何和redis联动,如果是java语言,那么就可以使用Jedis工具,同时springdata redis也可以使用,lettuce也可以使用。
Redis学习9:Jedis学习
|
NoSQL Java 中间件
Jedis基础详解
Jedis基础详解
105 0
|
NoSQL JavaScript Java
【Redis高手修炼之路】Jedis——Jedis的基本使用
【Redis高手修炼之路】Jedis——Jedis的基本使用
429 0
【Redis高手修炼之路】Jedis——Jedis的基本使用
|
NoSQL 数据可视化 Java
jedis-jedis 简介 | 学习笔记
快速学习 jedis-jedis 简介
108 0
|
NoSQL Java Redis
jedis-jedis 常规操作演示 | 学习笔记
快速学习jedis-jedis 常规操作演示
100 0
|
NoSQL Redis 开发者
jedis-程序结构搭建 | 学习笔记
快速学习 jedis-程序结构搭建
|
监控 NoSQL Java
jedis-程序代码实现| 学习笔记
快速学习 jedis-程序代码实现
111 0