一、Java连接Redis

在官方网站列一些Java客户端访问,有:Jedis/Redisson/Jredis/JDBC-Redis等,其中官方推荐使用JedisRedisson。常用Jedis

开始在Java 中使用 Redis 前, 我们需要确保已经安装了 redis服务及Java redis驱动,且你的机器上能正常使用JavaJava的安装配置可以参考我们的 Java开发环境配置 接下来让我们安装Java redis 驱动。

安装相应JAR:

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

java redis sc_java redis sc

1、开启端口防火墙

开放端口(如下命令只针对Centos7以上)

查看已经开放的端口:firewall-cmd --list-ports

开启端口:

firewall-cmd --zone=public --add-port=6379/tcp --permanent

重启防火墙:

firewall-cmd --reload #重启

2、java操作redis设置密码

java redis sc_java redis sc_02


这个问题是由于Redis没有配置密码的原因导致的,只需要为redis设置密码即可config get requirepass: 这是查询redis是否配置密码,如果返回为空,则表明未配置密码

java redis sc_中间件_03


config set requirepass “hx”这是将redis的密码设置为“hx”

客户端登录:用redis-cli密码登陆(redis-cli -a password

3、Java Jedis连接池优化

java redis sc_java redis sc_04

java redis sc_java_05

4、案例(Jedis操作Stringhash

  • Jedis操作String
  • java redis sc_java_06

  • Jedis操作hash

java redis sc_java redis sc_07

二、Redis Template

1、简介

Spring data 提供了RedisTemplate模版

它封装了redis连接池管理的逻辑,业务代码无须关心获取,释放连接逻辑;spring redis同时支持了JedisJredis,rjc 客户端操作;

RedisTemplate中提供了几个常用的接口方法的使用,分别是:

java redis sc_java_08

java redis sc_中间件_09

2、Spring data 使用Redis Template模板

  • jar包:
//Redis和Spring整合
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>2.4.2</version>
</dependency>

<dependency>
   <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-redis</artifactId>
    <version>1.4.2.RELEASE</version>
</dependency>
  • 对应实体Bean进行序列化操作 :

java redis sc_redis_10

  • 编写相应配置文件

利用RedisTemplate操作Redis:

java redis sc_中间件_11

3、JedisPoolConfig常见的配置信息

java redis sc_redis_12

• #最大空闲数

• redis.maxIdle=300

• #连接池的最大数据库连接数。设为0表示无限制,如果是jedis 2.4以后用redis.maxTotal

• #redis.maxActive=600

• #控制一个pool可分配多少个jedis实例,用来替换上面的redis.maxActive,如果是jedis 2.4以后用该属性

• redis.maxTotal=1000

• #最大建立连接等待时间。如果超过此时间将接到异常。设为-1表示无限制。

• redis.maxWaitMillis=1000

• #连接的最小空闲时间 默认1800000毫秒(30分钟)

• redis.minEvictableIdleTimeMillis=300000

• #每次释放连接的最大数目,默认3

• redis.numTestsPerEvictionRun=1024

• #逐出扫描的时间间隔(毫秒) 如果为负数,则不运行逐出线程, 默认-1

• redis.timeBetweenEvictionRunsMillis=30000

• #是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个

• redis.testOnBorrow=true

• #在空闲时检查有效性, 默认false

redis.testWhileIdle=true

4、Redis客户端工具介绍

工具链接

java redis sc_redis_13

查看Redis客户端:

java redis sc_中间件_14


原因 :把任何数据保存到redis中时,都需要进行序列化,默认使用JdkSerializationRedisSerializer进行数据序列化。

所有的keyvalue还有hashkeyhashvalue的原始字符前,都加了一串字符。

java redis sc_缓存_15