9

I have a requirement, where i have to run a one minute background process after returning the response for an api. That background process will do some operation on mongodb.

My approach is, i am emitting an event for background process after returning the response.

Is there any best approach to this operation? Please help me.

Thanks,

aaqib90
  • 510
  • 1
  • 5
  • 16

3 Answers3

7

You could use an EventEmitter to trigger the background task.

Or you can trigger an asynchronous task before you return the response.

I would implement some kind of simple in-memory queue. Before returning the response I would add a task to the queue, emit an event telling listeners there is task in the queue.

Edit:

I'm not sure if I understand your use case exactly. But this might be one approach.

If you do not have reference to do the mongo you might have to do some fast lookup or creation, then return the response, then run the task

const myqueue = []

const eventHandler = new EventEmitter();

eventHandler.on('performBackgroundTask', () => {

  myqueue.forEach(task => {
    // perform task
  })

})

app.get('/api', function (req, res) {

    const identificationForItemInMongo = 123

    myqueue.push(identificationForItemInMongo)

    eventHandler.emit('performBackgroundTask',     identificationForItemInMongo)

   res.send('Send the response')
})
Khlbrg
  • 199
  • 1
  • 6
  • i have to return the response , i don't want to increase the response time. can you tell me how to implement in-memory queue here? – aaqib90 Mar 07 '18 at 03:29
0

when you want to make asynchronous calls to db and wait for the result you need to use callback or using promises or async/await in ES6.

read this for more info

Siamak S
  • 31
  • 1
  • 3
0

You can use Promise chaining for your approach. Call first Api, once response is received display the value in the UI then second call will haven automatically and it will not interfere any UI process. You can refer more details about promise chaining here.

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then

var promise1 = new Promise(function(resolve, reject) {
  resolve('Success!');
});

//Run the background process.
var promise2 = new Promise(function(resolve, reject) {
  resolve('Success!');
});

promise1.then(function(value) {
  console.log(value);
  // expected output: "Success!"
  return promise2;
}).then(function(value){
  // Response for the second process completion.
}).catch(function(){
  // Failure for first api call/ second api call
});
Mani Vel
  • 1
  • 1