Comments (5)
I basically want this function to be executed by one server only. So, I'm trying that whenever first server executes this cron, puts a lock on this function, so that 2nd server cannot execute this. Am I doing it right way?
from node-redlock.
Hi @ajay2611, it looks like you are returning too soon here, and your lock
variable isn't in the scope of the second function; I'd definitely suggest reading up on how promises work, but here's what your function should look like:
var resource = 'redisKey';
function getData(){
return redlock.lock(resource, ttl)
.then(function(lock) {
return Promise.resolve(logicToRun())
.then(
function(result) {
// we can fire this off in the background here,
// because we don't really care if it succeeds
lock.unlock()
.catch(function(errofFromUnlocking) {
console.log(errofFromUnlocking);
});
// let's make sure to return the result
return result;
},
function(errorFromLogic) {
// we can fire this off in the background here,
// because we don't really care if it succeeds
lock.unlock()
.catch(function(errofFromUnlocking) {
console.log(errofFromUnlocking);
});
// let's make sure to propagate the error
throw errorFromLogic;
}
);
});
});
function logicToRun() {
// logic of function; it can return a promise OR a
// resolved value, because it's called from inside
// Promise.resolve()
}
// using your function:
getData()
// if you want something to run AFTER it's finished, chain with `then`:
.then(function(result) {
// do something...
});
from node-redlock.
Thanks for a prompt reply. Implementing and testing it this way.
By the way, is this a correct usage case of redlock algo as I've only one redis client?
from node-redlock.
Yep! It can use multiple redis instances (which provides high availability since one of 3 could go down, etc) but it's perfectly normal to have just one.
from node-redlock.
Thanks for help @mike-marcacci . Closing this issue.
from node-redlock.
Related Issues (20)
- Migration guide from 4.2.0 to 5.x?
- Redlock 4.x Compatible with Redit 7.x? HOT 1
- Unable to achieve a quorum during its retry window
- Cannot extend an already-expired lock crashes consumer pods. HOT 1
- Throw specific errors when there's an issue either acquiring or releasing the lock HOT 1
- "ioredis": "^5.3.2" incompatible with "redlock": "^5.0.0-beta.2" and "@types/redlock": "^4.0.5", HOT 2
- TypeError: client.evalsha is not a function HOT 3
- No support for redis functions
- Lock in use should throw a specific error HOT 1
- Do not wait for lock (NOWAIT)
- Release with fixed type resolution HOT 2
- Do not execute RELEASE_SCRIPT lock failed with one client
- Return resource name of lock that was not acquired in vote against error
- MOVED Error Handling in Redis Cluster Environment
- Issue with Redlock Stuck in Redis Cluster Setup
- Expiration time is in the past HOT 2
- a few issues after trying beta 5.0.0
- Configure Redis DB # explicitly? HOT 1
- Wrong acquire() lock duration
- Typescript support for v5
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from node-redlock.