Comments (2)
You're creating three clients there, once per trip through the loop, which is probably not what you want. If you're looping through data that you want to do something asynchronous with, use a continuer function. I updated the emitjobs.js example to show this off, but here's a stripped down example:
var fivebeans = require('fivebeans');
var joblist = [ 'one', 'two', 'three', 'four', 'five' ];
var doneEmittingJobs = function()
{
console.log('We reached our completion callback. Now closing down.');
emitter.end();
process.exit(0);
};
var continuer = function(err, jobid)
{
console.log('emitted job id: ' + jobid);
if (joblist.length === 0)
return doneEmittingJobs();
emitter.put(0, 0, 60, JSON.stringify(['testtube', joblist.shift()]), continuer);
};
var emitter = new fivebeans.client('localhost', 11300);
emitter.connect(function(err)
{
emitter.use('testtube', function(err, tname)
{
console.log("using " + tname);
emitter.put(0, 0, 60, JSON.stringify(['testtube', joblist.shift()]), continuer);
});
});
First you define a continuer function that knows how to tell when you've looped through all your data and knows how to kick off processing on the next chunk of data. Then you invoke your processing on the first data item & pass the continuer as a callback. This is a general pattern you'll use often when looping through data in node. There's a pretty good explanation of this pattern in this article, with a more for-loop-y variation on it.
Or you could use a flow control module to help with loops. I often use async for this.
from fivebeans.
@ceejbot Thank you provide those information:)
from fivebeans.
Related Issues (20)
- bug: if .connect() called more than once, incorrect callbacks are used HOT 1
- Obsolete documentation for yaml configuration HOT 3
- Release/Destroy fails to fire when using multiple Reserve in parallel HOT 4
- Is there a way to clear / destroy a queue?
- Connections left open
- Limit number of worker nodes.
- Security vulnerability
- Race condition
- Confused: Is Watch not allowed while in Reserve? HOT 1
- Havent check if callback is avilable
- Delayed job executes now
- Possible to support multiple beanstalkd servers? HOT 3
- Reserve doesn't respond after use tube HOT 3
- Multiple worker HOT 3
- Not an issue don't flag it! Missed something in the great doc HOT 2
- Handlers issues HOT 2
- runner, why class?
- is connected method?
- eslint should only be in devDependencies HOT 2
- SyntaxError: Unexpected token HOT 1
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 fivebeans.