美文网首页Java 杂谈redis学习
Redis学习之Jedis使用

Redis学习之Jedis使用

作者: 颜洛滨 | 来源:发表于2018-09-28 09:27 被阅读0次

    Redis学习是Jedis使用

    前言

    在前面的内容中,我们简单学习了Redis的基本操作,并且通过redis-cli客户端操作redis,在本小节中,我们将学习在代码中操作Redis的方式,本小节中,我们使用的是Jedis

    Redis提供了众多的客户端,支持众多的编程语言,如果你使用的不是Java的话,可以在官方网站找到合适的客户端 Redis客户端

    Jedis是官方推荐的Java连接Redis的客户端 Jedis项目

    Jedis使用

    Jedis依赖

    <dependency>
      <groupId>redis.clients</groupId>
      <artifactId>jedis</artifactId>
      <version>2.9.0</version>
    </dependency>
    

    由于Jedis实例并不是线程安全的,所以,不应该在多线程环境下使用同一个Jedis实例,同时,频繁创建Jedis实例也不是很推荐,最好的方式是使用Jedis连接池,当需要使用的时候,向Jedis连接池申请资源,使用完毕后,将资源还给Jedis连接池。

    Jedis连接池是线程安全的,基于Common Pool2,所以可以在多线程中共享同一个Jedis连接池。

    建立连接池

    Jedis中提供了多个构造方法,用于构造Jedis连接池实例,如

    JedisPool jedisPool = new JedisPool("localhost", 6379);
    

    上面的方式采用默认的配置方式,一般情况下,我们还需要根据实际情况进行配置,则可以采用如下的方式

    private static JedisPool jedisPool;
    static {
        JedisPoolConfig config = new JedisPoolConfig();
        config.setMaxWaitMillis(60 * 1000);
        config.setMaxIdle(50);
        config.setTestOnBorrow(true);
        config.setMinIdle(20);
        config.setMaxTotal(200);
        jedisPool = new JedisPool(config, "localhost");
    }
    

    注意事项

    由于目前的Redis是运行在本地的,所以可以直接通过Jedis进行连接,如果Redis是部署在其他服务器上,Redis默认是不允许连接的,所以需要将配置文件中的bind 127.0.0.1注释掉

    这种方式意味着可以从任意IP进行连接,其实是不太安全的,所以在连接的时候,我们会收到Redis的提示,要求我们要么关闭保护模式,要么指定IP,要么配置密码,这里我是采用配置密码的方式,在配置文件中,加入requirepass YOUR_PASSWORD,然后,在配置Jedis的时候,配置密码,就可以进行正常操作了。

    JedisPool jedisPool = new JedisPool(config, "localhost", 6379, 20000, "YOUR_PASSWORD");
    

    Jedis操作

    设置操作

    public void testJedisSet() {
        try(Jedis jedis = jedisPool.getResource()) {
            jedis.set("hello", "world");
    
            jedis.hset("stu", "name", "xavier");
            jedis.hset("stu", "age", "23");
    
            jedis.lpush("myList", "1", "2", "3");
    
            jedis.sadd("names", "xavier", "john", "tom");
    
            jedis.zadd("scoreboard", 99, "xavier");
            Map<String, Double> scoreboard = new HashMap<>();
            scoreboard.put("tom", 100.0);
            scoreboard.put("john", 101.0);
            jedis.zadd("scoreboard", scoreboard);
        }
    }
    

    获取操作

    public void testJedisGet() {
        try (Jedis jedis = jedisPool.getResource()) {
            String hello = jedis.get("hello");
            System.out.println(hello);
    
            Map<String, String> stu = jedis.hgetAll("stu");
            System.out.println(stu);
    
            List<String> list = jedis.lrange("myList", 0, -1);
            System.out.println(list);
    
            Set<String> names = jedis.smembers("names");
            System.out.println(names);
    
            Set<String> scoreboard = jedis.zrange("scoreboard", 0, -1);
            Set<String> score = jedis.zrangeByScore("scoreboard", 80, 100);
            System.out.println(scoreboard);
            System.out.println(score);
        }
    }
    

    从上面的演示代码可以看到,Jedis的操作跟使用原生的Redis命令来操作是基本一致的,或者说,Jedis其实就是原生命令的Java实现,好处是使用起来非常方便,不用再去记忆其他的API,缺点是偏底层了一些,有一些内容还是需要我们手动封装处理。

    总结

    本小节主要学习了Java中的Redis操作工具,Jedis,并且通过代码的形式,学习了通过Jedis来操作Redis,在使用Jedis的过程中,我们也可以看到,Jedis的使用跟直接使用Redis命令是类似的。

    相关文章

      网友评论

        本文标题:Redis学习之Jedis使用

        本文链接:https://www.haomeiwen.com/subject/hpeuoftx.html