Redis——Java中使用Jedis操作Redis

目录

1、Java中使用Jedis操作Redis-项目中常采用

1.1 项目结构

1.2 RedisUtils.java 类

1.3 JRedisTest.java 类

1.4 操作结果

(1)控制台输出:

(2)Redis服务器输出

2、Java中使用Jedis操作Redis-项目实战

2.0 项目中加入 jar包

2.1 字符串(string) 做测试

2.2 哈希(hash) 做测试

2.2.1 使用Jedis连接实例池:RedisUtil.java

2.2.2 使用Jedis连接池操作 hash 数据类型1

2.2.2 使用Jedis连接池操作 hash 数据类型2

2.3 列表 (list) 做测试

2.4 集合(Set)  做测试

2.5 有序集合(ZSet)  做测试

2.6 事务(Transaction)  做测试

3、参考文档

1、Java中使用Jedis操作Redis-项目中常采用

1.1 项目结构

Redis——Java中使用Jedis操作Redis_第1张图片

1.2 RedisUtils.java 类

package com.wind.ssm.javaRedis.test;

import org.springframework.stereotype.Component;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import java.io.Serializable;

@Component
public class RedisUtils implements Serializable {

    private static final long serialVersionUID = 7223626844967286296L;
    private static JedisPool pool; //整个项目中只有这一个JedisPool

    /**
     * 池化思想:创建JedisPool对象(Jedis实例池)
     */
    public static JedisPool openPool(String host, int port) {
        if (pool == null) {
            //(1)创建JedisPoolConfig,给config设置连接池的参数,使用config对象创建JedisPool
            JedisPoolConfig poolConfig = new JedisPoolConfig();

            //(2)给config对象设置连接池的参数
            //(2.1)设置最大的线程数,一个线程就是一个Jedis实例
            poolConfig.setMaxIdle(20);
            //(2.2)设置最大空闲数,总有两个Jedis实例存活以便瞬时可以拿来使用
            poolConfig.setMaxIdle(2);
            //(2.3)设置检查项为true,表示从线程池中获取的Jedis实例都是经过检查的,都是可用的实例
            poolConfig.setTestOnBorrow(true);

            //(3)创建JedisPool对象
            /**
             * poolConfig:JedisPoolConfig对象
             * host:Redis服务器IP地址
             * port:Redis服务器进程的端口号
             * timeout:连接Redis的超时时间,毫秒值
             * password:Redis的访问密码
             */
            pool = new JedisPool(poolConfig, host, port, 6000);
        }
        return pool;
    }

    /**
     * 关闭pool池对象
     */
    public static void closePool() {
        if (pool != null) {
            pool.close();
        }
    }
}

1.3 JRedisTest.java 类

package com.wind.ssm.javaRedis.test;

import org.springframework.stereotype.Component;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;

import java.io.Serializable;
import java.util.List;
import java.util.Objects;

@Component
public class JRedisTest implements Serializable {

    private static final long serialVersionUID = -5396106851277887769L;

    public static void main(String[] args) {

        /**
         * 通过网络访问Redis服务器:
         *(1)修改redis.conf文件,启动Redis需要指定redis.conf的位置。
         *(2)关闭linux防火墙,或者让Redis的端口号通过防火墙。
         * (3)设置密码了吗
         */
        JedisPool pool = null;
        Jedis jedis = null;
        try {
            //使用工具类获取Jedis对象池
            //String host:Redis服务器的IP。int port:Redis服务器进程运行的端口号。
            String host = "127.0.0.1";
            int port = 6382;
            pool = RedisUtils.openPool(host, port);

            //从pool中获取Jedis对象
            jedis = pool.getResource();

            //调用Jedis对象的方法,操作Redis数据
            jedis.set("breakfast", "breakfastDouJiangAndYouTiao2");
            //获取key的值
            String breakfastValue = jedis.get("breakfast");
            System.out.println("breakfastKey=breakfast,breakfastValue=" + breakfastValue);

            //mset一次创建多个key-value
            jedis.mset("lunch", "lunchMilk2", "dinner", "dinnerNoodle2");
            //mget获取每个key对应的值
            List values = jedis.mget("breakfast", "lunch", "dinner");
            values.stream().filter(Objects::nonNull).forEach(System.out::println);

        } finally {
            //关闭Jedis对象,把从pool中获取的Jedis对象放回到Pool池子中,以便其他请求使用
            if (jedis != null) {
                jedis.close();
            }
            //在这里关闭了Jedis对象的池子
            if (pool != null) {
                pool.close();
            }
        }
    }

}

1.4 操作结果

(1)控制台输出:

Redis——Java中使用Jedis操作Redis_第2张图片

(2)Redis服务器输出

Redis——Java中使用Jedis操作Redis_第3张图片

2、Java中使用Jedis操作Redis-项目实战

2.0 项目中加入 jar包

● jedis-2.9.0.jar

● commons-pool2-2.4.2.jar

加入项目后如图:

Redis——Java中使用Jedis操作Redis_第4张图片

2.1 字符串(string) 做测试

Redis——Java中使用Jedis操作Redis_第5张图片

2.2 哈希(hash) 做测试

2.2.1 使用Jedis连接实例池:RedisUtil.java

Redis——Java中使用Jedis操作Redis_第6张图片

2.2.2 使用Jedis连接池操作 hash 数据类型1

Redis——Java中使用Jedis操作Redis_第7张图片

2.2.2 使用Jedis连接池操作 hash 数据类型2

Redis——Java中使用Jedis操作Redis_第8张图片

2.3 列表 (list) 做测试

Redis——Java中使用Jedis操作Redis_第9张图片

2.4 集合(Set)  做测试

Redis——Java中使用Jedis操作Redis_第10张图片

2.5 有序集合(ZSet)  做测试

Redis——Java中使用Jedis操作Redis_第11张图片

2.6 事务(Transaction)  做测试

Redis——Java中使用Jedis操作Redis_第12张图片

3、参考文档

(1)动力节点Redis文档:http://www.bjpowernode.com/tutorial_redis/343.html

 

 

 

 

你可能感兴趣的:(MySQL+Redis基础知识,redis,java,jedis,Redis工具类,Jedis连接池)