Jedis

官方文档

jedis官方文档:jedis 5.2.0-beta1 javadoc (redis.clients)

如何安全访问云服务器6379端口:

jedis是redis提供的依赖,让我们可以在Java程序中使用redis。redis是一个服务器/客户端程序,当我们在终端执行redis命令的时候,实际上是想redis服务器端发送包含命令信息的http请求,理论上只要了解RESP(redis应用层协议),我们也可以写出向jedis这样的依赖。废话不多说,举个例子认识一下jedis:

public class pingtest {
    public static void main(String[] args) {
        //为什么这里要访问127.0.0.1:8888呢?
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888"); 
        try (Jedis jedis = jedisPool.getResource()) {
            String ping = jedis.ping();
            System.out.println(ping);
        }

    }
}

Redis一般安装在云服务器上,之前我们都是使用xshell连接云服务器,在xshell上学习使用redis命令,相当于客户端和服务器端在同一台主机上:

 

我们Java代码基本是在本地的windows环境上开发的,所以想要访问redis服务器就需要通过访问云服务器的外网IP来访问redis,端口位6379。也就需要修改防火墙开放6379端口允许外界访问,这就有可能遇到黑客的攻击,那把是修改redis服务的端口了没有用。

为什么呢?为什么开放8080端口、22端口就没有问题呢?

那么如何解决这个问题呢?我们可以配置ssh端口(22端口)转发,把云服务器的redis端口,映射到本地主机的端口。这样一来,访问本地端口就相当于访问了服务器的6379端口。

操作方法如下:

打开xshell,右键会话点击属性:

 点击添加,配置转移规则:

win + R 打开cmd输入以下命令查看8888端口是否被监听:

 

 Jedis使用:

只是简单介绍了相关语法,知道对命令足够熟悉,即使这些Jedis语法不熟悉用到的时候查一查看看官方文档。

maven依赖:

首先要添加maven依赖:

<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency>
	<groupId>redis.clients</groupId>
	<artifactId>jedis</artifactId>
	<version>4.3.2</version>
</dependency>

通用命令:

public class RedisDemoGeneric {
    public static void test1(Jedis jedis) {
        System.out.println("get 和 set 的使用");
        // 先清空数据库. 要避免上一组测试的残留数据影响到下一组测试的结果.
        jedis.flushAll();

        jedis.set("key", "111");
        jedis.set("key2", "222");
        SetParams params = new SetParams();
        params.ex(10);
        params.nx();
        jedis.set("key", "333", params);

        String value = jedis.get("key");
        System.out.println("value=" + value);
    }

    public static void test2(Jedis jedis) {
        System.out.println("exists 和 del");
        jedis.flushAll();

        jedis.set("key", "111");
        jedis.set("key2", "222");
        jedis.set("key3", "333");

        boolean result = jedis.exists("key");
        System.out.println("result: " + result);

        long result2 = jedis.del("key");
        System.out.println("result2: " + result2);

        result = jedis.exists("key");
        System.out.println("result: " + result);

        result2 = jedis.del("key", "key2", "key3");
        System.out.println("result2: " + result2);
    }

    public static void test3(Jedis jedis) {
        System.out.println("keys");
        jedis.flushAll();

        jedis.set("key", "111");
        jedis.set("key2", "111");
        jedis.set("key3", "111");
        jedis.set("key4", "111");

        // redis 中的 key 不能重复~ 而且也是不在意顺序的.
        Set<String> keys = jedis.keys("*");
        System.out.println(keys);
    }

    public static void test4(Jedis jedis) {
        System.out.println("expire 和 ttl");
        jedis.flushAll();

        jedis.set("key", "111");
        jedis.expire("key", 10);

        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        long time = jedis.ttl("key");
        System.out.println("time: " + time);
    }

    public static void test5(Jedis jedis) {
        System.out.println("type");
        jedis.flushAll();

        jedis.set("key", "111");
        String type = jedis.type("key");
        System.out.println("type: " + type);

        jedis.lpush("key2", "111", "222", "333");
        type = jedis.type("key2");
        System.out.println("type: " + type);

        jedis.hset("key3", "f1", "111");
        type = jedis.type("key3");
        System.out.println("type: " + type);

        jedis.sadd("key4", "111", "222", "333");
        type = jedis.type("key4");
        System.out.println("type: " + type);

        jedis.zadd("key5", 10, "zhangsan");
        type = jedis.type("key5");
        System.out.println("type: " + type);
    }

    public static void main(String[] args) {
        // 连接到 Redis 服务器上.
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");

        try (Jedis jedis = jedisPool.getResource()) {
            // redis 的各种命令, 就都对应到 jedis 对象的各种方法.
//            String pong = jedis.ping();
//            System.out.println(pong);

            // test1(jedis);
            // test2(jedis);
            // test3(jedis);
            // test4(jedis);
            test5(jedis);
        }
    }
}

String:

public class RedisDemoString {

    public static void test1(Jedis jedis) {
        System.out.println("mget 和 mset");
        jedis.flushAll();

        jedis.mset("key1", "111", "key2", "222", "key3", "333");

        List<String> values = jedis.mget("key1", "key2", "key100", "key3");
        System.out.println("values: " + values);
    }

    public static void test2(Jedis jedis) {
        System.out.println("getrange 和 setrange");
        jedis.flushAll();

        jedis.set("key", "abcdefghijk");
        String result = jedis.getrange("key", 2, 5);
        System.out.println("result: " + result);

        jedis.setrange("key", 2, "xyz");
        String value = jedis.get("key");
        System.out.println("value: " + value);
    }

    public static void test3(Jedis jedis) {
        System.out.println("append");
        jedis.flushAll();

        jedis.set("key", "abcdef");
        jedis.append("key", "ghij");

        String value = jedis.get("key");
        System.out.println("value: " + value);
    }

    public static void test4(Jedis jedis) {
        System.out.println("incr 和 decr");
        jedis.flushAll();

        jedis.set("key", "100");

        long result = jedis.incr("key");
        System.out.println("result: " + result);

        String value = jedis.get("key");
        System.out.println("value: " + value);

        result = jedis.decr("key");
        System.out.println("result: " + result);

        value = jedis.get("key");
        System.out.println("value: " + value);
    }

    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()) {
            // test1(jedis);
            // test2(jedis);
            // test3(jedis);
            test4(jedis);
        }
    }
}

List:

public class RedisDemoList {
    public static void test1(Jedis jedis) {
        System.out.println("lpush 和 lrange");
        jedis.flushAll();

        jedis.lpush("key", "111", "222", "333");

        List<String> result = jedis.lrange("key", 0, -1);
        System.out.println(result);
    }

    public static void test2(Jedis jedis) {
        System.out.println("rpush");
        jedis.flushAll();

        jedis.rpush("key", "111", "222", "333");

        List<String> result = jedis.lrange("key", 0, -1);
        System.out.println("result: " + result);
    }

    public static void test3(Jedis jedis) {
        System.out.println("lpop");
        jedis.flushAll();

        jedis.rpush("key", "111", "222", "333");
        String result = jedis.lpop("key");
        System.out.println("result: " + result);

        result = jedis.lpop("key");
        System.out.println("result: " + result);

        result = jedis.lpop("key");
        System.out.println("result: " + result);

        result = jedis.lpop("key");
        System.out.println("result: " + result);
    }

    public static void test4(Jedis jedis) {
        System.out.println("rpop");
        jedis.flushAll();

        jedis.rpush("key", "111", "222", "333");
        String result = jedis.rpop("key");
        System.out.println("result: " + result);
        result = jedis.rpop("key");
        System.out.println("result: " + result);
        result = jedis.rpop("key");
        System.out.println("result: " + result);
        result = jedis.rpop("key");
        System.out.println("result: " + result);
    }

    public static void test5(Jedis jedis) {
        System.out.println("blpop");
        jedis.flushAll();

        // 返回结果是一个 "二元组", 一个是从哪个 key 对应的list中删除的, 一个是删除的元素是什么.
        List<String> results = jedis.blpop(100, "key");
        System.out.println("results[0]: " + results.get(0));
        System.out.println("results[1]: " + results.get(1));
    }

    public static void test6(Jedis jedis) {
        System.out.println("llen");
        jedis.flushAll();

        jedis.rpush("key", "111", "222", "333");
        long len = jedis.llen("key");
        System.out.println("len: " + len);
    }

    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()) {
            // test1(jedis);
            // test2(jedis);
            // test3(jedis);
            // test4(jedis);
            // test5(jedis);
            test6(jedis);
        }
    }
}

hash:

public class RedisDemoHash {
    public static void test1(Jedis jedis) {
        System.out.println("hset 和 hget");
        jedis.flushAll();

        jedis.hset("key", "f1", "111");
        Map<String, String> fields = new HashMap<>();
        fields.put("f2", "222");
        fields.put("f3", "333");
        jedis.hset("key", fields);

        String result = jedis.hget("key", "f1");
        System.out.println("result: " + result);

        result = jedis.hget("key", "f2");
        System.out.println("result: " + result);

        result = jedis.hget("key", "f100");
        System.out.println("result: " + result);
    }

    public static void test2(Jedis jedis) {
        System.out.println("hexists");
        jedis.flushAll();

        jedis.hset("key", "f1", "111");
        jedis.hset("key", "f2", "111");
        jedis.hset("key", "f3", "111");

        boolean result = jedis.hexists("key", "f1");
        System.out.println("result: " + result);

        result = jedis.hexists("key", "f100");
        System.out.println("result: " + result);
    }

    public static void test3(Jedis jedis) {
        System.out.println("hdel");
        jedis.flushAll();

        jedis.hset("key", "f1", "111");
        jedis.hset("key", "f2", "111");
        jedis.hset("key", "f3", "111");

        long result = jedis.hdel("key", "f1", "f2");
        System.out.println("result: " + result);

        boolean exists = jedis.hexists("key", "f1");
        System.out.println("exists: " + exists);
        exists = jedis.hexists("key", "f2");
        System.out.println("exists: " + exists);
    }

    public static void test4(Jedis jedis) {
        System.out.println("hkeys 和 hvals");
        jedis.flushAll();

        jedis.hset("key", "f1", "111");
        jedis.hset("key", "f2", "111");
        jedis.hset("key", "f3", "111");

        Set<String> fields = jedis.hkeys("key");
        List<String> vals = jedis.hvals("key");
        System.out.println("fields: " + fields);
        System.out.println("vals: " + vals);
    }

    public static void test5(Jedis jedis) {
        System.out.println("hmget 和 hmset");
        jedis.flushAll();

        Map<String, String> map = new HashMap<>();
        map.put("f1", "111");
        map.put("f2", "222");
        map.put("f3", "333");
        jedis.hmset("key", map);

        List<String> values = jedis.hmget("key", "f2", "f1", "f3");
        System.out.println("values: " + values);
    }

    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()) {
            // test1(jedis);
            // test2(jedis);
            // test3(jedis);
            // test4(jedis);
            test5(jedis);
        }
    }
}

set:

public class RedisDemoSet {

    public static void test1(Jedis jedis) {
        System.out.println("sadd 和 smembers");
        jedis.flushAll();

        jedis.sadd("key", "111", "222", "333");
        Set<String> result = jedis.smembers("key");
        System.out.println("result: " + result);
    }

    public static void test2(Jedis jedis) {
        System.out.println("sismember");
        jedis.flushAll();

        jedis.sadd("key", "111", "222", "333");
        boolean result = jedis.sismember("key", "100");
        System.out.println("result: " + result);
    }

    public static void test3(Jedis jedis) {
        System.out.println("scard");
        jedis.flushAll();

        jedis.sadd("key", "111", "222", "333");
        long result = jedis.scard("key");
        System.out.println("result: " + result);
    }

    public static void test4(Jedis jedis) {
        System.out.println("spop");
        jedis.flushAll();

        jedis.sadd("key", "111", "222", "333", "444", "555");
        String result = jedis.spop("key");
        System.out.println("result: " + result);
    }

    public static void test5(Jedis jedis) {
        System.out.println("sinter");
        jedis.flushAll();

        jedis.sadd("key", "111", "222", "333");
        jedis.sadd("key2", "111", "222", "444");

        Set<String> result = jedis.sinter("key", "key2");
        System.out.println("result: " + result);
    }

    public static void test6(Jedis jedis) {
        System.out.println("sinterstore");
        jedis.flushAll();

        jedis.sadd("key", "111", "222", "333");
        jedis.sadd("key2", "111", "222", "444");

        long len = jedis.sinterstore("key3", "key", "key2");
        System.out.println("len: " + len);

        Set<String> result = jedis.smembers("key3");
        System.out.println("result: " + result);
    }

    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()) {
            // test1(jedis);
            // test2(jedis);
            // test3(jedis);
            // test4(jedis);
            // test5(jedis);
            test6(jedis);
        }
    }
}

zset:

em.out.println("zrank");
        jedis.flushAll();

        jedis.zadd("key", 10, "zhangsan");
        jedis.zadd("key", 20, "lisi");
        jedis.zadd("key", 30, "wangwu");

        Long rank = jedis.zrank("key", "zhangsan2");
        System.out.println("rank: " + rank);
    }

    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()) {
            // test1(jedis);
            // test2(jedis);
            // test3(jedis);
            // test4(jedis);
            test5(jedis);
        }
    }
}

  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值