7

パスワードなしで Node アプリを Redis に問題なく接続できますが、パスワードを追加すると、何をしてもうまくいきません。

これが今の私のコードで、例からそのまま引用しました:

var redis = require('redis')
  , sio = require('socket.io')
  , RedisStore = sio.RedisStore
  , io = sio.listen();

var port = 6379
  , hostname = 'localhost'
  , password = 'password';

var redisClient = redis.createClient(port, hostname);
redisClient.auth(password, function (err) { if (err) throw err; });

var redisSubscriber = redis.createClient(port, hostname);
redisSubscriber.auth(password, function (err) { if (err) throw err; });

io.set('store', new RedisStore({ redisPub: redisClient, redisSub: redisSubscriber, redisClient: redisClient }));

アプリを実行すると、次のスタック トレースが表示されます。

/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/index.js:506
                throw callback_err;
                      ^
Error: Ready check failed: ERR operation not permitted
    at RedisClient.on_info_cmd (/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/index.js:319:35)
    at Command.RedisClient.ready_check.send_anyway [as callback] (/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/index.js:367:14)
    at RedisClient.return_error (/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/index.js:502:25)
    at RedisReplyParser.RedisClient.init_parser (/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/index.js:262:14)
    at RedisReplyParser.EventEmitter.emit (events.js:93:17)
    at RedisReplyParser.send_error (/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/lib/parser/javascript.js:266:14)
    at RedisReplyParser.execute (/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/lib/parser/javascript.js:125:22)
    at RedisClient.on_data (/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/index.js:478:27)
    at Socket.<anonymous> (/home/eric/christmas/sockets/node_modules/socket.io/node_modules/redis/index.js:79:14)
    at Socket.EventEmitter.emit (events.js:93:17)

これを生成する行が最後の行です。RedisStore を設定する試みをコメント アウトすると、エラーは発生しません。

パスワードが正しいと確信しています (redis-cli で確認できます。パスワードを間違ったものに変更すると、認証コールバックが起動しないことを確認できます)。このコードは、パスワードを削除して 2 つの認証行をコメントアウトした場合にも機能します。

ブログの投稿やドキュメントなどの実際の例はすべて、これが機能することを示していますが、なぜ私のものは機能しないのかわかりません。スタックのどの部分を見ればよいかわかりません。

上記のコードを実行すると、redis-cli モニターは次のようになります。

1353227107.912512 [0 127.0.0.1:56759] "auth" "password"
1353227107.912719 [0 127.0.0.1:56758] "auth" "password"
1353227107.913470 [0 127.0.0.1:56759] "info"
1353227107.913639 [0 127.0.0.1:56758] "info"

そして、パスワードをオフにし、上記の認証行をコメントアウトして、アプリを正常に実行した場合の redis-cli モニターの表示は次のとおりです。

1353227252.401667 [0 127.0.0.1:56771] "info"
1353227252.402020 [0 127.0.0.1:56770] "info"
1353227252.402131 [0 127.0.0.1:56769] "info"
1353227252.402423 [0 127.0.0.1:56768] "info"
1353227252.402611 [0 127.0.0.1:56767] "info"
1353227252.406254 [0 127.0.0.1:56770] "subscribe" "handshake"
1353227252.406287 [0 127.0.0.1:56770] "subscribe" "connect"
1353227252.406314 [0 127.0.0.1:56770] "subscribe" "open"
1353227252.406321 [0 127.0.0.1:56770] "subscribe" "join"
1353227252.406326 [0 127.0.0.1:56770] "subscribe" "leave"
1353227252.406337 [0 127.0.0.1:56770] "subscribe" "close"
1353227252.406354 [0 127.0.0.1:56770] "subscribe" "dispatch"
1353227252.406372 [0 127.0.0.1:56770] "subscribe" "disconnect"

成功した (パスワードなしの) 接続は 5 つの「情報」コマンドを作成し、失敗した (パスワード付き) コマンドは 2 つを作成し、「on_info_cmd」メソッドの呼び出しで終了します。

誰でもこれを理解できますか?ご協力いただきありがとうございます。

4

2 に答える 2

9

Redis モジュール自体をオプションとして RedisStore コンストラクターに渡すことで、これを解決しました。

io.set('store', new RedisStore({redis: redis, redisPub: redisClient, redisSub: redisSubscriber, redisClient: redisClient }));

これは、クライアント オブジェクトがinstanceof RedisClientテストに合格し、パスワードなしで再初期化されないようにするために必要でした。どうやら、RedisStoreredisモジュールを再要求すると、createClientメソッドで作成されたredisクライアントは、新しいクラスか何かのメンバーになります。

socket.ioの問題 #808で誰かが抱えていた関連する問題を見て、これを理解しました。

于 2012-11-20T04:38:39.237 に答える
1

一度だけ呼び出してみてくださいredisClient.auth(password, function (err) { if (err) throw err; });。redis は呼び出しごとに認証情報を保存します。2 回呼び出すとエラーが発生する可能性があります。

于 2012-11-18T17:25:25.313 に答える