本文主要是介绍在nodejs项目报错:CROSSSLOT Keys in request don't hash to the same slot解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
由于后台用的是redis集群,我前端刚好碰巧用的是nodejs express框架。express存储session有自己的机制。本来单独的redis主模式是很好用redis保存session的,但奈何用了集群分片模式~~。
下面是当后台使用redis分片模式时候,前端存储session连接redis的写法。主要的部分代码:
var session = require(‘express-session’);
var connectRedis = require(‘connect-redis’);
var Redis = require(‘ioredis’); //ioredis支持cluster模式,哨兵模式等,可以去看官方api
var RedisStore = connectRedis(session);
var cluster = new Redis.Cluster(
[{
port: 7001,
host: ‘132.21.1.31’,
password:’hha-redis’,
ttl: 60 * 60 * 24 * 7
}, {
port: 7001,
host: ‘132.22.1.31’,
password:’hha-redis’,
ttl: 60 * 60 * 24 * 7
}, {
port: 7002,
host: ‘132.21.1.34’,
password:’hha-redis’,
ttl: 60 * 60 * 24 * 7
},
{
port: 7002,
host: ‘132.21.1.34’,
password:’hha-redis’,
ttl: 60 * 60 * 24 * 7
}, {
这篇关于在nodejs项目报错:CROSSSLOT Keys in request don't hash to the same slot解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!