Forbindelsesfejl rapporteres som en error
hændelse på klienten Redis
objekt.
Ifølge afsnittet "Auto-genopret forbindelse" i dokumenterne, vil ioredis automatisk forsøge at genoprette forbindelsen, når forbindelsen til Redis mistes (eller formodentlig ikke kan etableres i første omgang). Kun efter maxRetriesPerRequest
forsøg vil de afventende kommandoer "blive tømt med en fejl", dvs. komme til catch
her:
try {
cachedItem = await redisClient.get(queryString); // This emit an error on the redis client, because it fails to connect (that's intended, to test the behaviour)
} catch (e) {
logger.error(e); // It never goes there, as the error isn't "thrown", but rather "emitted" and handled by redis its own way
epsagon.setError(e);
}
Siden du stopper dit program ved den første fejl:
client.on('error', function (e) {
// ...
if (e.message === 'ERR invalid password') {
logger.error(`Fatal error occurred "${e.message}". Stopping server.`);
throw e; // Fatal error, don't attempt to fix
...forsøgene igen og den efterfølgende "udskylning med en fejl" aldrig får chancen for at køre.
Ignorer fejlene i client.on('error'
, og du skulle få fejlen returneret fra await redisClient.get()
.