5

I'm using nodejs (expressjs) hosted on heroku.

Sessions are stored in redis (Redistogo plugin for heroku):

RedisStore = require('connect-redis')(express)
app.use express.session
      secret: process.env.CLIENT_SECRET
      cookie: { maxAge: 604800000 }
      store: new RedisStore {client: redis}

After user logged in I store his info in req.session

after_user_logged_id = (req, user)->    
  req.session.current_user =
    id: user._id
    name: user.name

I need to restart server and clean all sessions: logout all users to force them login one more time. How should I do this ? Restarting redis plugin doesn't help.

4

2 に答える 2

6

redis.flushdb()は、他の何かをredisに保存することになった場合、少し極端になる可能性があります。すべての「sess:*」キーを削除する必要があります。残念ながら、del *はないので、次のようなものを使用できます。

redis.keys("sess:*", function(err, key) {
  redis.del(key, function(err) {
  });
});
于 2013-02-05T22:36:14.403 に答える
0

すべてのredisセッションをクリーンアップするコード:

RedisStore = require('connect-redis')(express)
rtg   = require('url').parse process.env.REDISTOGO_URL
redis = require('redis').createClient rtg.port, rtg.hostname  
redis.auth rtg.auth.split(':')[1] # auth 1st part is username and 2nd is password separated by ":"
  try
    console.log "clean sessions"
    redis.flushdb()
  catch err
    console.log "error:", err
于 2013-02-05T14:11:57.937 に答える