部署线上服务启动报错
redis.clients.jedis.exceptions.JedisDataException: ERR unknown command 'CONFIG'
Redis CONFIG GET命令是用来读取运行Redis服务器的配置参数。并非所有的配置参数在Redis2.4支持,而Redis2.6可以读取使用此命令的服务器的整体配置。
之前开发环境的redis都是自己部署的,权限都很大,所以程序也没报什么异常。现在生产环境是由运维管理,redis也是运维提供的一个2.8。
根据错误提示,直接redis-cli连上redis去执行Config命令
10.xx:6379> CONFIG GET parameter
(error) ERR unknown command 'CONFIG'
确定了没有放开权限,就只能看能否不用这个命令了。
发现是spring-session-redis需要使用Keyspace notifications
这个功能。
在 Redis 的 2.8.0 版本之后,其推出了一个新的特性——键空间消息(Redis Keyspace Notifications)……
键空间通知,允许Redis客户端从“发布/订阅”通道中建立订阅关系,以便客户端能够在Redis中的数据因某种方式受到影响时收到相应事件。……
在GitHub上看到有issues spring-session #124
具体解决方案:
-
开启redis的
Keyspace notifications
功能,重启notify-keyspace-events Ex
-
关闭Spring-session中对CONFIG的操作
在xml里加上:
<util:constant static-field="org.springframework.session.data.redis.config.ConfigureRedisAction.NO_OP"/>
或者
@Bean public static ConfigureRedisAction configureRedisAction() { return ConfigureRedisAction.NO_OP; }
注意:
如果采用XML配置的方式,很有可能需要引入 util标签
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:mvc="http://www.springframework.org/schema/mvc"<