I'm using ioRedis node package for connecting my node js application to redis server which is secured by TLS. Redis version I'm using is Redis 6.0. My server is running fine with the certificates but while connecting from node application I get Error.
Redis({
host: "localhost",
port: 6379,
tls: {
key: fs.readFileSync('./redis.key'),
cert: fs.readFileSync('./redis.crt'),
maxVersion: 'TLSv1.3',
minVersion: 'TLSv1.3',
ca: [fs.readFileSync('./redis.pem')]
}
})
Error on the nodejs application side is
This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason:
Error: read ECONNRESET
at TCP.onStreamRead (internal/stream_base_commons.js:205:27)
Error on server while trying to connect from nodejs application
17:29:44.295 # Error accepting a client connection: error:1408F10B:SSL routines:ssl3_get_record:wrong version number
Objective is just to have a redis connection with TLS security.
I was also doing the same thing and I try this approach (node-redis v2.8.0):
const redis = require('redis');
const fs = require('fs');
const client = redis.createClient({
host: '<hostname>',
port: <port>,
tls: {}
});
Instead of passing the certificate key and everything try to pass the tls as an empty object. The guide for this approach is as follow. https://docs.upstash.com/docs/howto/connectwithtls
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With