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 に答える