一、Java
连接Redis
在官方网站列一些Java客户端访问,有:Jedis/Redisson/Jredis/JDBC-Redis
等,其中官方推荐使用Jedis
和Redisson
。常用Jedis
。
开始在Java
中使用 Redis
前, 我们需要确保已经安装了 redis
服务及Java redis
驱动,且你的机器上能正常使用Java
。 Java
的安装配置可以参考我们的 Java
开发环境配置 接下来让我们安装Java redis
驱动。
安装相应JAR:
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.4.2</version>
</dependency>
1、开启端口防火墙
开放端口(如下命令只针对Centos7
以上)
查看已经开放的端口:firewall-cmd --list-ports
开启端口:
firewall-cmd --zone=public --add-port=6379/tcp --permanent
重启防火墙:
firewall-cmd --reload #重启
2、java
操作redis
设置密码
这个问题是由于Redis没有配置密码的原因导致的,只需要为redis设置密码即可config get requirepass
: 这是查询redis
是否配置密码,如果返回为空,则表明未配置密码
config set requirepass “hx”
这是将redis
的密码设置为“hx”
客户端登录:用redis-cli
密码登陆(redis-cli -a password
)
3、Java Jedis
连接池优化
4、案例(Jedis
操作String
和hash
)
Jedis
操作String
Jedis
操作hash
二、Redis Template
1、简介
Spring data
提供了RedisTemplate
模版
它封装了redis
连接池管理的逻辑,业务代码无须关心获取,释放连接逻辑;spring redis
同时支持了Jedis
,Jredis
,rjc
客户端操作;
在RedisTemplate
中提供了几个常用的接口方法的使用,分别是:
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
进行序列化操作 :
- 编写相应配置文件
利用RedisTemplate
操作Redis
:
3、JedisPoolConfig
常见的配置信息
• #最大空闲数
• 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
客户端工具介绍
查看Redis
客户端:
原因 :把任何数据保存到redis
中时,都需要进行序列化,默认使用JdkSerializationRedisSerializer
进行数据序列化。
所有的key
和value
还有hashkey
和hashvalue
的原始字符前,都加了一串字符。