Redis

Redis

1.开启Redis服务

  1. 下载redis压缩包:Releases · microsoftarchive/redis (github.com)

  1. 解压压缩文件夹

  2. 运行redis服务端

    • 第一种开启方法:编写.bat文件,然后直接点击.bat文件 【本质是使用redis-server.exe + redis.windows.conf】

      .bat文件内容

      cd Redis-x64-3.0.504
      redis-server redis.windows.conf
      

    • 第二种开启方法:就是双击redis-server.exe运行服务即可。

  3. 开启成功后会有一个弹窗。弹窗关闭则服务关闭

2.使用redis服务

  1. 使用redis客户端来连接redis

    • 双击redis-cli.exe即可

  2. 使用Jredis

    看 3.使用Jredis详细描述

  3. Redis可视化工具

    • RedisDesktopManager一款好用的Redis桌面管理工具

3.使用Jredis详细描述

Jedis使用教程详解-CSDN博客

3.1基本使用
<dependency>
	<groupId>redis.clients</groupId>
	<artifactId>jedis</artifactId>
	<version>4.4.1</version>
</dependency>
//引入Redis驱动程序
import redis.clients.jedis.Jedis;

public class RedisJava {
    public static void main(String[] args) {
        //连接本地的 Redis 服务
        Jedis jedis = new Jedis("localhost",6379);
        // 如果设置 Redis 服务的密码,需要进行验证,若没有则可以省去
        // jedis.auth("123456");
        System.out.println("连接成功");
        //查看服务是否运行
        System.out.println("服务正在运行: "+jedis.ping());
        //设置 redis 字符串数据
        jedis.set("webkey", "swawdwa");
        // 获取存储的数据并输出
        System.out.println("redis 存储的字符串为: "+ jedis.get("webkey"));
    }
}

事务:Jedis使用教程详解-CSDN博客

同时Jedis也支持发布订阅:Jedis使用教程详解-CSDN博客

3.2Jedis连接池

连接池参数

public class RedisPoolUtils {
    private static JedisPool jedisPool = null;

    /**
     * redis服务器地址
     */
    private static String addr = "127.0.0.1";

    /**
     * redis服务器端口
     */
    private static int port = 6379;

    /**
     * redis服务器密码
     */
    private static String auth = "111111";


    static {
        try {
            JedisPoolConfig config = new JedisPoolConfig();
            // 连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true
            config.setBlockWhenExhausted(true);
            // 设置的逐出策略类名, 默认DefaultEvictionPolicy(当连接超过最大空闲时间,或连接数超过最大空闲连接数)
            config.setEvictionPolicyClassName("org.apache.commons.pool2.impl.DefaultEvictionPolicy");
            // 是否启用pool的jmx管理功能, 默认true
            config.setJmxEnabled(true);
            // MBean ObjectName = new ObjectName("org.apache.commons.pool2:type=GenericObjectPool,name=" + "pool" + i); 默认为"pool", JMX不熟,具体不知道是干啥的...默认就好.
            config.setJmxNamePrefix("pool");
            // 是否启用后进先出, 默认true
            config.setLifo(true);
            // 最大空闲连接数, 默认8个
            config.setMaxIdle(8);
            // 最大连接数, 默认8个
            config.setMaxTotal(8);
            // 获取连接时的最大等待毫秒数(如果设置为阻塞时BlockWhenExhausted),如果超时就抛异常, 小于零:阻塞不确定的时间,  默认-1
            config.setMaxWaitMillis(-1);
            // 逐出连接的最小空闲时间 默认1800000毫秒(30分钟)
            config.setMinEvictableIdleTimeMillis(1800000);
            // 最小空闲连接数, 默认0
            config.setMinIdle(0);
            // 每次逐出检查时 逐出的最大数目 如果为负数就是 : 1/abs(n), 默认3
            config.setNumTestsPerEvictionRun(3);
            // 对象空闲多久后逐出, 当空闲时间>该值 且 空闲连接>最大空闲数 时直接逐出,不再根据MinEvictableIdleTimeMillis判断  (默认逐出策略)
            config.setSoftMinEvictableIdleTimeMillis(1800000);
            // 在获取连接的时候检查有效性, 默认false
            config.setTestOnBorrow(false);
            // 在空闲时检查有效性, 默认false
            config.setTestWhileIdle(false);
            // 逐出扫描的时间间隔(毫秒) 如果为负数,则不运行逐出线程, 默认-1
            config.setTimeBetweenEvictionRunsMillis(-1);
            jedisPool = new JedisPool(config, addr, port, 3000, auth);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * 获取 Jedis 资源
     *
     * @return
     */
    public static Jedis getJedis() {
        if (jedisPool != null) {
            return jedisPool.getResource();
        }
        return null;
    }

    /**
     * 释放Jedis资源
     */
    public static void close(final Jedis jedis) {
        if (jedis != null) {
            jedis.close();
        }
    }
}

连接池

JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
// 连接池最大连接数
jedisPoolConfig.setMaxTotal(20);
// 只要是连接池的相关配置都可以通过JedisPoolConfig来进行修改
// redisHost和redisPort是实例的IP和端口
// redisPassword是实例的密码
// timeout,这里既是连接超时又是读写超时,从Jedis 2.8开始有区分connectionTimeout和soTimeout的构造函数
JedisPool jedisPool =  new  JedisPool(jedisPoolConfig, redisHost, redisPort, timeout, redisPassword);
// 执行命令如下:
Jedis jedis =  null;
try  {
     jedis = jedisPool.getResource();
    //  具体的命令
    //	jedis.set()
} catch  (Exception e) {
    logger.error(e.getMessage(), e);
}  finally  {
    // 注意这里不是关闭连接,在JedisPool模式下,Jedis会被归还给资源池。
    if  (jedis !=  null){
    	jedis.close();
	}
}
3.3其他
  1. 哨兵模式
  2. 集群模式
  3. Springboot当中使用Jedis
  4. Springboot源码分析

Jedis使用教程详解-CSDN博客

posted @ 2024-12-01 15:12  deyang  阅读(21)  评论(0编辑  收藏  举报