Redis在java(Maven)中使用,常用基本命令大全,最全Termius怎么进行端口映射(MAC系统最简单教学)

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis在java(Maven)中使用,常用基本命令大全,最全Termius怎么进行端口映射(MAC系统最简单教学)

端口映射的操作

Redis服务器在官网上公开了RESP,任何一个三方都可以通过上述协议,来实现一个和redis

那么直接放开防火墙可以不呢?不行-一旦Redis端口公布到公网上,特别容易被入侵

tomcat开门了,也不好被黑,redis6379端口门锁-特别好被黑

换个端口名7379可以不呢?(掩耳盗铃,该黑还是被黑)

1.不能开发redis端口

2.我们又想要通过外网访问。

一、直接让java程序,也在linux运行,手动打jar包,然后拷贝到linux服务器上执行~,手工完成麻烦,第三方插件,简化上述步骤

二、配置SSH端口转发,把云服务器redis端口映射本地

通过ssh,把服务器的6379映射到本地的8888

当ssh连接上之后,端口转发才生效(把ssh连接断开,端口转发自然就消息。)

Termius如何进行端口转发

1.点击图中这里

2.第一个是他自己生成的不用管,第二个Local port 本地端口设置为8888,然后地址就写主机地址即可

3.这块依次你的服务器公网ip,服务器的主机,还有他的端口(我要转发redis,所以是6379)

4.点击这三个点

一定要点Connection,这个相当于保存设置

然后我们去终端查看,输入这个指令,查找对应的端口,我的是8888,你们随意啦

sudo lsof -i :8888

后续代码中,通过127.0.0.1:8888即可操作我们云服务器的redis了,同时外面的客户端是无法直接访问云服务器6379的。有人可能好奇redis,Mac又不是没有,直接在本地下一个就好啦-学的是方法(格局要大)

一个简单的demo,发现一个问题,这里对端口地址十分敏感,你写的localhost,就不能127.0.0.1,你要是127.0.0.1就不可以localhost。

当然还有一个要点,开始安装redis的时候,要配置绑定的ip,以及关闭保护模式,

默认的绑定127.0.0.1,此时只能本机和本机访问,不能跨主机访问

protected-mode no :这里默认是yes,开启保护模式,跨主机也是不能访问的。

jedis进行redis中的一些通用命令

1.get/set

2.exists

3.del

4.keys

5.expire/ttl

6.type

接下来介绍redis的命令在代码中的操作,不会覆盖到所有的命令,会挑选一些比较代表的命令去演示。

字符串基本命令使用

get,set-获取,设置

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
 
import java.util.List;
 
public class RedisDemoString {
    public static void main(String[] args) {
        JedisPool jedisPool=new JedisPool("tcp://localhost:8888");
        try (Jedis jedis=jedisPool.getResource()){
            test1(jedis);
        }
    }
 
    private static void test1(Jedis jedis) {
        System.out.println("mget和mset");
        jedis.flushAll();
        jedis.mset("key1","111","key2","222","key3","333");
        //此处多个key得到的value顺序都是和key匹配的,如果某个key在redis上不存在,对应的value使用null表示
        List<String>values=jedis.mget("key1","key100","key3");
        System.out.println("values"+values);
 
 
 
    }
}

getrange,获取区间长度,从offset开始,到endOffset结束

setrange,修改指定区间的值,从下标给出的2开始,往后三位

append-字符串添加操作

incr-对应的值,自增一个,decr-对应值,自减一个

以下是上面完整代码

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.params.SetParams;
 
import java.util.Set;
 
public class RedisDemoGeneric {
    public  static void test1(Jedis jedis){
        System.out.println("get和set的使用");
        //先去清空数据库,避免上一组残留数据影响下一组测试的结果
        jedis.flushAll();
        jedis.set("key","111");
        jedis.set("key2","222");
        //通过这个参数,给set 设置条件
        SetParams params=new SetParams();//相当于一个条件的包装类(包装我们需要的条件)
        //设置超时时间
        params.ex(10);
        //已经存在,才能进行修改
       // params.xx();
        //不存在,才能够修改
        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");
        Boolean result=jedis.exists("key");
        System.out.println("result:"+result);
        long result2=jedis.del("key","key2","key3");
        System.out.println("result2:"+result2);
        result=jedis.exists("key");
        System.out.println("result:"+result);
        result=jedis.exists("key2");
        System.out.println("result:"+result);
    }
    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不能重复!而且也是不在意顺序的,keys *
        //按照java的写法,分别针对N个服务器,调用N此keys,但是这N此keys的结果,可以使用同一个插入迭代器,往同一个容器中插入。
        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);
    }
    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");
        //获取value的type
        type=jedis.type("key5");
        System.out.println("type:"+type);
    }
 
 
    public static void main(String[] args) {
        //连接到Redis服务器上
        JedisPool jedisPool=new JedisPool("tcp://localhost:8888");//基于tcp协议
        //从Redis连接池中取一个连接出来,连接用完记得释放。
        try(Jedis jedis=jedisPool.getResource()){
            //redis各种命令,对应到jedis对象的各种方法。
//            String pong=jedis.ping();
//            System.out.println(pong);
            //test1(jedis);
            test5(jedis);
        }
    }
}

List基本命令使用

lpush和lrange-左侧插入,给定区间查询

rpush-右侧插入

Lpop-头删

rpop-右侧删除

Blpop-阻塞版本的lpop,返回的我们可以看到0是键 1是值

llen-返回列表长度(注意返回类型是long)

以下是上面完整代码
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
 
import java.util.List;
 
public class RedisDemoList {
 
//列表的操作
    /*
    1.lpush和lrange
    2.rpush,rpop,lpop
    3.blpop,brpop
    4.llen
     */
    public static void main(String[] args) {
        JedisPool jedisPool=new JedisPool("tcp://localhost:8888");
        try(Jedis jedis=jedisPool.getResource()){
            test6(jedis);
        }
    }
 
    private static void test6(Jedis jedis) {
        System.out.println("llen");
        jedis.flushAll();
        jedis.rpush("key","111","222","333");
        //注意llen返回值是long
        long len= jedis.llen("key");
        System.out.println(len);
    }
 
    public  static  void  test5(Jedis jedis){
        System.out.println("blpop");
        jedis.flushAll();
        //blpop支持删除多个,所以返回的结果也是多个
        List<String> result=jedis.blpop(100,"key");
        System.out.println(result.get(0));
        System.out.println(result.get(1));
    }
    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);
        String result1=jedis.rpop("key");
        System.out.println("result1"+result1);
        String result2=jedis.rpop("key");
        System.out.println("result2"+result2);
    }
 
    private static void test3(Jedis jedis) {
        System.out.println("lpop");
        jedis.flushAll();
        jedis.rpush("key","111","222","333");
       String resultold=jedis.lpop("key");
        System.out.println(resultold);
        String result=jedis.lpop("key");
        System.out.println("result:"+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);
}
    private 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);
    }
 
 
}

Set基本命令使用

sadd-往集合中添加元素(返回set)

sismember-判断元素在集合中是否存在。

scard:获取当前元素个数(返回long)

spop-头删,弹出头元素。

sinter-求两个key 交集,返回类型是一个set

sinterstore-把两个集合做交集放到一个集合里面

我们可以用Set来接收smembers("key3")

以下是上面完整代码
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
 
import java.util.Set;
 
public class RedisDemoSet {
 
    public static void main(String[] args) {
        JedisPool jedisPool=new JedisPool("tcp://localhost:8888");
        try(Jedis jedis=jedisPool.getResource()){
            test6(jedis);
        }
    }
    private static void test6(Jedis jedis) {
        System.out.println("sinterscore");
        jedis.flushAll();
        jedis.sadd("key","111","222","333");
        jedis.sadd("key2","111","222","444");
        //把两个数的交集,存储到一个key中
       long len= jedis.sinterstore("key3","key","key2");
        System.out.println("len:"+len);
        Set<String>result=jedis.smembers("key3");
        System.out.println("result:"+result);
    }
 
    private 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 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);
    }
 
    private 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);
    }
 
    private static void test2(Jedis jedis) {
        System.out.println("sismeber");
        jedis.flushAll();
        jedis.sadd("key","111","222","333");
        boolean result=jedis.sismember("key","111");
        System.out.println("result:"+result);
 
    }
 
    private 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);
    }
}

Hash基本命令使用

hget和hset获取哈希表值,设置哈希表值

hexist-根据你的key和field,看是否存在

hdel-删除key对应的field

hkey 和hvals-获取对应的key,获取对应的val,当然他返回的顺序不一定是一一对应的,我们也需要注意。

hmset,hmget-设置多个,获取多个(会按照你给的field的顺序,返回value)

以下是上面完整代码
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
 
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
 
public class RedisDemoHash {
 
    //1.hset和hget
    //2.hexists
    //3.hdel
    //4.hkeys和hvals
    //5.hmget和hmset
    public static void main(String[] args) {
        JedisPool jedisPool=new JedisPool("tcp://localhost:8888");
        try(Jedis jedis=jedisPool.getResource()){
            test5(jedis);
        }
    }
 
    private 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","f1","f2","f3");
        System.out.println("values:"+values);
    }
 
    private static void test4(Jedis jedis) {
        System.out.println("hkeys和hvals");
        jedis.flushAll();
        jedis.hset("key","f1","111");
        jedis.hset("key","f2","222");
        jedis.hset("key","f3","333");
        Set<String>field=jedis.hkeys("key");
        List<String>vals=jedis.hvals("key");
        System.out.println("field:"+field);
        System.out.println("vals:"+vals);
    }
 
    private static void test3(Jedis jedis) {
        System.out.println("hdel");
        jedis.flushAll();
        jedis.hset("key","f1","111");
        jedis.hset("key","f2","222");
        jedis.hset("key","f3","333");
        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);
        exists=jedis.hexists("key","f3");
        System.out.println("exists:"+exists);
    }
 
    private static void test2(Jedis jedis) {
        System.out.println("hexists");
        jedis.flushAll();
        jedis.hset("key","f1","111");
        jedis.hset("key","f2","222");
        jedis.hset("key","f3","333");
        boolean result=jedis.hexists("key","f1");
        System.out.println(result);
        result=jedis.hexists("key","f4");
        System.out.println(result);
    }
 
 
    private 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","f3");
        System.out.println("result"+result);
    }
}

zset基本命令使用

zrange和zrangewiehscore查找指定范围。

zcard获取元素个数

zrem-删除指定元素

zscore-获取元素分数

Zrank-获取member的排名(根据分数)。

以下是上述所有代码
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.resps.Tuple;
 
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
public class RedisDemoZSet {
    public static void main(String[] args) {
        JedisPool jedisPool=new JedisPool("tcp://localhost:8888");
        try(Jedis jedis=jedisPool.getResource()){
            test5(jedis);
        }
    }
 
    private static void test5(Jedis jedis) {
        System.out.println("zrank");
        jedis.zadd("key",10,"zhangsan");
        jedis.zadd("key",20,"lisi");
        jedis.zadd("key",30,"wangwu");
 
        Long rank=jedis.zrank("key","zhangsan");
        System.out.println("rank:"+rank);
        rank=jedis.zrank("key","zhangsan2");
        System.out.println(rank);
    }
 
    private static void test4(Jedis jedis) {
        System.out.println("zscore");
        jedis.flushAll();
        jedis.zadd("key",10,"zhangsan");
        jedis.zadd("key",20,"lisi");
        jedis.zadd("key",30,"wangwu");
        //包装类,假如是小写,不存在会不方便表示为空(会抛异常)
        Double score=jedis.zscore("key","zhangsan");
        System.out.println("score:"+score);
    }
 
    private static void test3(Jedis jedis) {
        System.out.println("zrem");
        jedis.flushAll();
        jedis.zadd("key",10,"zhangsan");
        jedis.zadd("key",20,"lisi");
        jedis.zadd("key",30,"wnagwu");
        long len=jedis.zrem("key","zhangsan");
        System.out.println("成功删除的个数:"+len);
        List<Tuple>result=jedis.zrangeWithScores("key",0,-1);
        System.out.println("result"+result);
    }
 
    private static void test2(Jedis jedis) {
        System.out.println("zcard");
        jedis.flushAll();
        jedis.zadd("key",10,"zhangsan");
        jedis.zadd("key",20,"lisi");
        jedis.zadd("key",30,"wangwu");
        long len=jedis.zcard("key");
        System.out.println("len:"+len);
    }
 
    private static void test1(Jedis jedis) {
        System.out.println("zadd和zrange");
        jedis.flushAll();
        jedis.zadd("key",10,"zhangsan");
        Map<String,Double> map=new HashMap<>();
        map.put("lisi",20.0);
        map.put("wangwu",30.0);
        jedis.zadd("key",map);
        //没有分数
        List<String> members=jedis.zrange("key",0,-1);
        System.out.println("member:"+members);
        //Tuple:一个数据结构,redis提供的,他是一个元祖
        List<Tuple>memberWithSocore=jedis.zrangeWithScores("key",0,-1);
        System.out.println("membersWithScore:"+memberWithSocore);
        String member=memberWithSocore.get(0).getElement();
        System.out.println(member);
        double score=memberWithSocore.get(0).getScore();
        System.out.println(score);
    }
}


相关文章
|
16天前
|
存储 SQL NoSQL
Redis-常用语法以及java互联实践案例
本文详细介绍了Redis的数据结构、常用命令及其Java客户端的使用,涵盖String、Hash、List、Set、SortedSet等数据类型及操作,同时提供了Jedis和Spring Boot Data Redis的实战示例,帮助开发者快速掌握Redis在实际项目中的应用。
170 1
Redis-常用语法以及java互联实践案例
|
5月前
|
存储 缓存 监控
Redis设计与实现——Redis命令参考与高级特性
Redis 是一个高性能的键值存储系统,支持丰富的数据类型(字符串、列表、哈希、集合等)和多种高级功能。本文档涵盖 Redis 的核心命令分类,包括数据类型操作、事务与脚本、持久化、集群管理、系统监控等。特别介绍了事务的原子性特性、Lua 脚本的执行方式及优势、排序机制、发布订阅模型以及慢查询日志和监视器工具的使用方法。适用于开发者快速掌握 Redis 常用命令及其应用场景,优化系统性能与可靠性。
|
24天前
|
存储 缓存 NoSQL
Redis基础命令与数据结构概览
Redis是一个功能强大的键值存储系统,提供了丰富的数据结构以及相应的操作命令来满足现代应用程序对于高速读写和灵活数据处理的需求。通过掌握这些基础命令,开发者能够高效地对Redis进行操作,实现数据存储和管理的高性能方案。
61 12
|
22天前
|
存储 消息中间件 NoSQL
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
本文将系统探讨 Redis List 的核心特性、完整命令体系、底层存储实现以及典型实践场景,为读者构建从理论到应用的完整认知框架,助力开发者在实际业务中高效运用这一数据结构解决问题。
|
2月前
|
存储 缓存 人工智能
Redis六大常见命令详解:从set/get到过期策略的全方位解析
本文将通过结构化学习路径,帮助读者实现从命令语法掌握到工程化实践落地的能力跃迁,系统性提升 Redis 技术栈的应用水平。
|
4月前
|
缓存 监控 NoSQL
Redis 实操要点:Java 最新技术栈的实战解析
本文介绍了基于Spring Boot 3、Redis 7和Lettuce客户端的Redis高级应用实践。内容包括:1)现代Java项目集成Redis的配置方法;2)使用Redisson实现分布式可重入锁与公平锁;3)缓存模式解决方案,包括布隆过滤器防穿透和随机过期时间防雪崩;4)Redis数据结构的高级应用,如HyperLogLog统计UV和GeoHash处理地理位置。文章提供了详细的代码示例,涵盖Redis在分布式系统中的核心应用场景,特别适合需要处理高并发、分布式锁等问题的开发场景。
280 40
|
3月前
|
NoSQL Redis
Lua脚本协助Redis分布式锁实现命令的原子性
利用Lua脚本确保Redis操作的原子性是分布式锁安全性的关键所在,可以大幅减少由于网络分区、客户端故障等导致的锁无法正确释放的情况,从而在分布式系统中保证数据操作的安全性和一致性。在将这些概念应用于生产环境前,建议深入理解Redis事务与Lua脚本的工作原理以及分布式锁的可能问题和解决方案。
132 8
|
4月前
|
缓存 NoSQL Java
Java Redis 面试题集锦 常见高频面试题目及解析
本文总结了Redis在Java中的核心面试题,包括数据类型操作、单线程高性能原理、键过期策略及分布式锁实现等关键内容。通过Jedis代码示例展示了String、List等数据类型的操作方法,讲解了惰性删除和定期删除相结合的过期策略,并提供了Spring Boot配置Redis过期时间的方案。文章还探讨了缓存穿透、雪崩等问题解决方案,以及基于Redis的分布式锁实现,帮助开发者全面掌握Redis在Java应用中的实践要点。
196 6
|
5月前
|
存储 缓存 NoSQL
Redis中的常用命令-get&set&keys&exists&expire&ttl&type的详细解析
总的来说,这些Redis命令提供了处理存储在内存中的键值对的便捷方式。通过理解和运用它们,你可以更有效地在Redis中操作数据,使其更好地服务于你的应用。
357 17
|
5月前
|
消息中间件 NoSQL Linux
Redis的基本介绍和安装方式(包括Linux和Windows版本),以及常用命令的演示
Redis(Remote Dictionary Server)是一个高性能的开源键值存储数据库。它支持字符串、列表、散列、集合等多种数据类型,具有持久化、发布/订阅等高级功能。由于其出色的性能和广泛的使用场景,Redis在应用程序中常作为高速缓存、消息队列等用途。
844 16