【问题标题】:Getting "ERR syntax error" on set using node-redis使用 node-redis 在设置上获取“ERR 语法错误”
【发布时间】:2025-11-28 02:30:02
【问题描述】:

我无法使用 node-redis 在 redis 中设置和获取密钥。但是在使用 redis-cli 时 set 和 get 效果很好。 这是我的代码:

const redis = require('redis');
const util = require('util');

const GLOBAL_KEY = 'lambda-test';
const redisOptions = {
    host: process.env.REDIS_HOST,
    port: process.env.REDIS_PORT
}

try{
    test();
}
catch(err) {
    console.log('catch err ' + err);
}

async function test() {
    var client = redis.createClient(redisOptions);
    client.on("error", function(error) {
        console.error(error);
    });
    client.get = util.promisify(client.get);
    client.set = util.promisify(client.set);
    await client.set("ke", "test1", redis.print).catch(function(err){console.log('err: '+ err);});
    await client.get("ke", redis.print).catch(function(err){console.log('err: '+ err);});
}

输出:

err: ReplyError: ERR syntax error
err: ReplyError: ERR wrong number of arguments for 'get' command

不知道是什么原因,谁能帮我弄清楚我错过了什么?

更新: 我尝试使用绑定,但没有运气:

    client.get = util.promisify(client.get).bind(client);
    client.set = util.promisify(client.set).bind(client);

我还启用了 DEBUG 以获取额外的日志:

2021-04-20T07:48:36.279Z Queueing set for next server connection.
2021-04-20T07:48:36.303Z Stream connected XXXXX:6379 id 0
2021-04-20T07:48:36.303Z Checking server ready state...
2021-04-20T07:48:36.304Z Send XXXXXX:6379 id 0: *1
$4
info

2021-04-20T07:48:36.305Z Net read XXXXX:6379 id 0
2021-04-20T07:48:36.306Z Redis server ready.
2021-04-20T07:48:36.306Z on_ready called XXXXX:6379 id 0
2021-04-20T07:48:36.307Z Sending offline command: set
2021-04-20T07:48:36.307Z Send XXXXX:6379 id 0: *4
$3
set
$2
ke
$5
test1
$187
function print (err, reply) {
    if (err) {
        // A error always begins with Error:
        console.log(err.toString());
    } else {
        console.log('Reply: ' + reply);
    }
}

2021-04-20T07:48:36.307Z Net read XXXXX:6379 id 0
err: ReplyError: ERR syntax error
2021-04-20T07:48:36.309Z Send XXXXX:6379 id 0: *3
$3
get
$2
ke
$187
function print (err, reply) {
    if (err) {
        // A error always begins with Error:
        console.log(err.toString());
    } else {
        console.log('Reply: ' + reply);
    }
}

2021-04-20T07:48:36.310Z Net read XXXXX:6379 id 0
err: ReplyError: ERR wrong number of arguments for 'get' command

【问题讨论】:

  • 试试client.get = util.promisify(client.get).bind(client)
  • 谢谢,没有帮助,请检查更新
  • 使用const data = await client.get("ke"); console.log(data);
  • 它返回undefined
  • 我认为如果你想正确绑定 client.get 你应该做 util.promisify(client.get.bind(client)) - 即这是对 client.get 函数的引用应该是绑定,而不是 promisify 方法返回的函数。不确定这是否会解决您的问题。

标签: node.js redis


【解决方案1】:

感谢大家的建议。我将问题作为问题发布在 repo https://github.com/NodeRedis/node-redis/issues/1599 上,并从 leibale 得到了答案:

async function test() {
    const client = redis.createClient(redisOptions);
    client.on("error", function(error) {
        console.error(error);
    });
    client.get = util.promisify(client.get).bind(client);
    client.set = util.promisify(client.set).bind(client);

    try {
        console.log('SET reply:', await client.set("ke", "test1"));
    } catch (err) {
        console.error(err);
    }

    try {
        console.log('GET reply:', await client.get("ke"));
    } catch (err) {
        console.error(err);
    } 
}

问题是bind 并使用redis.print 作为回调

【讨论】:

    最近更新 更多