我尝试连接到我的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)
});
我哪里做错了?请帮帮我!
发布于 2015-04-10 20:54:18
必须在sslOption属性中指定ssl实例才能在驱动程序上启用Object。
使用您的代码示例:
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模块中指定的默认值。
发布于 2015-04-10 05:11:15
您不应该指定tls.connect(options),而应该只为sslOptions提供options。驱动程序使用您提供的sslOptions调用tls.connect。
如果您进行了此更改,但仍然出现错误,您能与我分享它们是什么吗?有许多不同的因素会导致建立ssl连接失败。
https://stackoverflow.com/questions/29548694
复制相似问题