1

我有这个简单的 js 脚本:

var cb = require('couchbase');
var bucket;
var connectionSettings = {
                            'user':'test-bucket',
                            'password':'test',
                            'hosts':['localhost:8091'],
                            'bucket':'test-bucket'
                         };

cb.connect(connectionSettings, function(e, bucket) {

    if (e) {

        errorHandler('connect', e);

    } else {

        console.log('Connection established!');

        bucket.get('testObject', function(e, doc) {
            if(e) {
                errorHandler('get', e);
            } else {
                console.log(doc);
            }       
        });

    }

});

function errorHandler(from, e) {

    console.log('Function: ' + from);
    console.log(e.message);
    console.log(e.stack);

}

执行它后,正在建立连接,但是当我尝试在此测试用例中获取 id 为“a”的文档时,出现以下错误:

syd@HP-Notebook:~/Desktop$ node test.js
Connection established!
Function: get
Network error
Error: Network error
    at makeError (/home/syd/node_modules/couchbase/lib/bucket.js:578:18)
    at getParsedHandler (/home/syd/node_modules/couchbase/lib/bucket.js:625:17)
node: ../src/ioplugin.cc:496: virtual int Couchnode::IoOps::updateEvent(lcb_socket_t, void*, short int, void*, void (*)(lcb_socket_t, short int, void*)): Assertion `socket != __null' failed.
Aborted (core dumped)

此外,这里是在 bucket.js 中发生这些错误的代码片段。

578:

function makeError(conn, errorCode) {
    // Early-out for success
    if (errorCode == 0) {
        return null;
    }

    // Build a standard NodeJS Error object with the passed errorCode
    var errObj = new Error(conn.strError(errorCode)); // <- 578 error here
    errObj.code = errorCode;
    return errObj;
}

625:

function getParsedHandler(data, errorCode, key, cas, flags, value) {
    // if it looks like it might be JSON, try to parse it
    if (/[\{\[]/.test(value)) {
        try {
            value = JSON.parse(value);
        } catch (e) {
        // console.log("JSON.parse error", e, value)
        }
    }
    var error = makeError(data[1], errorCode); // <- 625 error here
    data[0](error, value, {
        id : key,
        cas: cas,
        flags : flags
    });
}

任何想法为什么会发生这种情况?PS我从PHP挖掘数据没有问题。

4

1 回答 1

1

由于与此问题相同的原因,它失败了。将 libcouchbase 降级到 2.0.7 应该可以解决问题。

UPD:在新的 couchbase nodejs 库版本 1.0.0-beta 中“修复”。

于 2013-08-23T11:49:14.517 回答