我尝试连接到我的 Cassandra,但我可能配置错误。我在本地主机上运行它。 Cassandra 已生成认证并添加。在 cqlsh 中,标志 --ssl 没有错误。我的片段代码是
var tls = require('tls');
var fs = require('fs');
var options = {
key : fs.readFileSync('client-key.pem'),
cert : fs.readFileSync('client-cert.pem'),
ca : [fs.readFileSync('server-cert.pem')]
};
var client = new cassandra.Client({
contactPoints : ['127.0.0.1'],
authProvider : new cassandra.auth.PlainTextAuthProvider('cassandra', 'cassandra'),
sslOptions : tls.connect(options)
});
我做错了什么? 请帮忙!
最佳答案
您必须在 sslOption
属性中指定一个 Object
实例以在驱动程序上启用 ssl。
使用您的代码示例:
var fs = require('fs');
var sslOptions = {
key : fs.readFileSync('client-key.pem'),
cert : fs.readFileSync('client-cert.pem'),
ca : [fs.readFileSync('server-cert.pem')]
};
var client = new cassandra.Client({
contactPoints : ['127.0.0.1'],
authProvider : new cassandra.auth.PlainTextAuthProvider('cassandra', 'cassandra'),
sslOptions : sslOptions
});
如果你不使用客户端证书,你可以只使用一个空的对象实例:
var client = new cassandra.Client({
contactPoints : ['127.0.0.1'],
authProvider : new cassandra.auth.PlainTextAuthProvider('cassandra', 'cassandra'),
sslOptions : {}
});
并且它将使用 Node.js tls
模块中指定的默认值。
关于node.js - 在 Node.js 中使用 cassandra-driver 通过 SSL 连接到 Cassandra Apache,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29548694/