A very simple and small services to simplify process to connect a redis host or cluster and provide some sugars and environments flavors.
This services use some environment variables to pre-adjust some things, like:
This services use some environment variables to pre-adjust some things, like:
REDIS_${INSTANCENAME}_CLUSTER
: a redis cluster or host, example and default: [{ port: 6379, host: '127.0.0.1' }]
;REDIS_${INSTANCENAME}_PASSWORD
: a password for access redis, example and default: password
;REDIS_CONNECTION_POOLING
: timing between multiples connections to check for instance;getConnection
or disconnect
it will use as default main
.nodes
and password
.For debug purposes, we are using debug library. You can use:
DEBUG
: with a value like redis-connection:*
to see all logs.For use this library you will need to run a RabbitMQ. A sample docker-compose:
version: '2.0'
services:
redis:
image: redis:6
environment:
ALLOW_EMPTY_PASSWORD: 'no'
REDIS_EXTRA_FLAGS: '--maxmemory 250mb'
command: >
--requirepass password
ports:
- 6379:6379
If you would like to use a docker swarm (stack) version, you can see in your sample folder.
You will found other samples in: Samples Folder.
/* eslint-disable no-console */
import { getConnection, disconnect } from '@nsfilho/redis-connection';
const createSampleKey = async () => {
const redis = await getConnection();
redis.set(
'mysample',
JSON.stringify({
when: new Date().toISOString(),
status: true,
}),
);
};
const readSampleKey = async () => {
const redis = await getConnection();
const valueStr = await redis.get('mysample');
if (valueStr) {
const valueObj = JSON.parse(valueStr);
console.log('Recovered values:', valueObj);
}
};
const execute = async () => {
await createSampleKey();
await readSampleKey();
await disconnect();
};
execute();
Generated using TypeDoc