redis - hapi js是否使用redis共享session?

标签 redis hapi.js

Redis 通常被 expressJS 用于跨多个节点 js 进程共享 session 。 hapiJs 是否使用类似的技术?

最佳答案

在回答您的问题之前,我想先介绍一下背景。是的,您可以使用 Redis 来共享 session ,但首先要确定它是您真正想要/需要的。在 session 方面,hapi 和 Express 有点不同。

如果您已经确定这是您想要的设置,请跳至第 2 部分。

1。背景

在 Express 中,唯一存储在您的 cookie 中的是您的 session ID。这意味着当您需要扩展到单个服务器之外时,您需要以某种方式查看它们之间的共享 session 。 Redis 是一种选择。

Note Session data is not saved in the cookie itself, just the session ID. Session data is stored server-side.

https://github.com/expressjs/session#sessionoptions

hapi 的官方 session 插件 Yar , 采用与 Express 略有不同的方法。 只要您尝试在 session 中存储的数据低于 maxCookieSize,整个 session 将被加密(通过 Iron)并存储在 cookie 中 .这意味着您不需要任何额外的服务器端机器来水平扩展,因为客户端会记住所有内容。

但是,如果这不符合您的要求或者您只是不喜欢它,您可以通过将 Yar 的 maxCookieSize 设置为 0 来强制服务器端存储。

maxCookieSize - maximum cookie size before using server-side storage. Defaults to 1K. Set to zero to always use server-side storage.

https://github.com/hapijs/yar/blob/master/API.md

2。将 Redis 与 Yar 和服务器端存储一起使用

将 Yar 与服务器端存储一起使用时,hapi 将使用其 cache存储数据的功能。例如,要使用 Redis,只需将 Redis cache 配置传递给 Yar:

const Hapi = require('hapi');
const Hoek = require('hoek');

const server = new Hapi.Server({
    cache: {
        engine: require('catbox-redis'),
        name: 'session',                  // cache name
        host: '127.0.0.1',                // redis host
        port: 6379,                       // redis port
        database: 'my-db'                 // redis-db
    }
});

server.register({
    register: require('yar'),
    options: {
        maxCookieSize: 0,                 // force server-side storage
        cache: {
            cache: 'session'
        },
        cookieOptions: {
            password: 'U32KuiKPnVguRKM',  // cookie password
            isSecure: false               // allow non HTTPS
        }
    }
}, (err) => {

    Hoek.assert(!err, err);
    server.start((err) => {

        Hoek.assert(!err, err);
        console.log('Started server');
    });
});

关于redis - hapi js是否使用redis共享session?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34454899/

相关文章:

node.js - Nodejs + Hapi + SSL/TLS + OATH2 + JWTs 作为承载

caching - 序列化和反序列化 POJO 的开销是否是使用 Infinispan 而不是 Memcached 或 Redis 来缓存 POJO 的一个很好的理由?

redis - 如何从redis中恢复所有数据?

django - 我在哪里放置代码以将数据从数据库推送到 django-redis 的 redis?

Redis SPOP 不是原子的?

javascript - 使用 Handlebars 在 hapijs 中显示来自辅助模块的 json 数据

node.js - joi 验证中的 .when(),根据另一个 key 验证一个 key

sinon - 如何在Hapi/Lab测试中使用Sinon来消除knex调用?

caching - 我的公司使用 memcache 作为对象就好了,看不到缓存中需要 redis

javascript - Object.and() 的自定义 Joi 验证消息