quave:publish-performant-counts

v1.0.0Published last year

quave:publish-performant-counts

A package to help you publish the count of a cursor in near real time. Interval based counting suitable for very large collections and high user load.

Counter API

new Counter(name, cursor, [updateInterval])

name is a string used to fetch the count of the count

cursor is a collection query that will be counted

updateInterval defaults to 10000, which will update the count every 10 seconds.

Publish from Server

Publish scoped counts

Counts that are specific to a user or parameter must be declared within the publish function. This will create 1 counter for each user who subscribes.

Meteor.publish('countPublish', function(someValue) {
  return new Counter('countCollection', Collection.find({
  	userId:this.userId,
  	someField:someValue
  }));
});

Server scoped counts

Server scoped counts that are defined outside of publish functions are more efficient that specific counts as it only creates 1 counter per server.

var counter = new Counter('countCollection', Collection.find({}));

Meteor.publish('countPublish', function() {
  return counter;
});

Subscribe from client

Subscribe to the publication from client side code.

Meteor.subscribe('countPublish');

Blaze Usage

Define a global helper

UI.registerHelper("getCount", function(name) {
	if(name)
      return Counter.get(name);
});

Call from within a template

...
{{getCount 'countCollection'}}
...

Credits

Inspired by publish-counts which is great, but does run into performance issues with large collections

Performant solution derived directly from bullet-counter

License

MIT