我有这个简单的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
});
}
为什么会发生这种情况? 附:我从PHP中挖掘数据没有问题。
答案 0 :(得分:1)
它失败的原因与此question中的原因相同。将libcouchbase降级到2.0.7应解决问题。
UPD:在新的couchbase nodejs库发行版1.0.0-beta中“已修复”。