npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@emartech/aggregate-metric-logger

v5.2.1

Published

aggregate metrics in memory for logging

Downloads

389

Maintainers

mruellmruellakapaakapamklsmklskaajkaajknagyknagyjfillmorejfillmorerehrethrehrethpeccpeccmhegedusmhegedusnorbert-levajsics-emarsysnorbert-levajsics-emarsysmmartinmmartinbsoosbsoosemarsys-deployeremarsys-deployerdravendravendrahos.istvandrahos.istvanjudgejudgeerikpetroemarerikpetroemaremarsys-securityemarsys-securitydaniel.bankydaniel.bankyszeistszeistrgargyargargyamarton.papp.emarsysmarton.papp.emarsysdgyenesdgyeness.viktors.viktorm4w4q7m4w4q7david.barkoczidavid.barkocziadroszleradroszlerdaniels1404daniels1404xin.hexin.heqw3rqw3rtamas.tothtamas.tothgergaczdgergaczdviauviaumuddammuddamgerikegerikealkraalkraepgrubmairepgrubmairbence.utobence.utocseby92cseby92morbanmorbanettancosettancosepmartiniepmartinigabor.balla.emarsysgabor.balla.emarsysmzsombormzsomborejperssonejperssonejwalkerejwalkerllosonczyllosonczyiben12iben12kartonfarkaskartonfarkasadamoaadamoambarnambarnapevapevabforgacsbforgacszsomborhzsomborhkozmakozmangabor84ngabor84zerosuxxzerosuxxandrasp3aandrasp3aedosreckiedosreckieadanieleadanielselatorselatorfhasefhasekkimakkkimakgaborbgaborbglendvaiglendvailverasztolverasztobozsadambozsadamrdoczirdoczifentosifentosiboristomicboristomicmbazsombazsodmihalekdmihaleklhalaszlhalaszevspasevskievspasevskijason-nelson-01jason-nelson-01bence.tothbence.tothdsztankodsztankotbugartbugarfqqdkfqqdkmenyhertfatyolmenyhertfatyolzoltanrideg-emarsyszoltanrideg-emarsyssarakollsarakollmmolnar-emarmmolnar-emarattila.galattila.galbenjamingehlbenjamingehlrkumari03rkumari03tdorkaatdorkaalkonyalkonyadudaaslacidudaaslacigpap_emagpap_emavimtaaivimtaailloki-emarsyslloki-emarsysmrmeszarosmrmeszarosborziborzivarszegikvarszegikpmaksa_emarsyspmaksa_emarsysi850773i850773dfaragodfaragoestefanlesnjakovicestefanlesnjakovicattilamuller01attilamuller01mhunyadymhunyadyatittelatittelmarton.matusekmarton.matuseksapfssapfsfenyopetifenyopetisixstepsixstepsap-jjfsap-jjfsaphendricksjoergsaphendricksjoergpjohnson02pjohnson02retfalvibenceretfalvibencebrandon-sapbrandon-sapmmothersillmmothersilljerryrichardsonjerryrichardsonarnaud.buchholzarnaud.buchholzjamescockerjamescockermanasbommakantimanasbommakantiadamszabolcsadamszabolcsushnpmushnpmmengjiao.zhaomengjiao.zhaoianhelmrichianhelmrichbtalosbtalosmmartin2mmartin2dkorposdkorposjbleclercjbleclercnvkaur2nvkaur2tbucsanszkitbucsanszkipendicg24pendicg24pinterapinteraasciortino1asciortino1dmorvaidmorvainicolaeciumacnicolaeciumacdimitrovndimitrovnmaurogrecomaurogrecooliverweisenburgeroliverweisenburgerbercziandbercziandnish343nish343scotthetrickscotthetrickkonradschewekonradscheweivanfroehlichivanfroehlichzbalazszbalazsmattfeldhake_emarsysmattfeldhake_emarsysttoth2ttoth2bborsibborsiziyadgziyadggresztergresztersovagossovagosapoonapoonburciburcimark.adorjanmark.adorjanxueboliangxueboliangskrivooskrivooazorahai3904azorahai3904koloshkoloshjviesersapjviesersapdrewhodsonsapdrewhodsonsapcrileycrileyiulianmihaiiulianmihaimariannagmariannagbobby_russelbobby_russeldkocsis-emarsysdkocsis-emarsysagruczaagruczamarko.fritzschemarko.fritzschedemajo_emsdemajo_emstothmarci25tothmarci25tsiraitnpmtsiraitnpmplsapplsapsseidmedsseidmedroxanamsroxanamsbencekadaremarbencekadaremarviktor.szellviktor.szelldunaicapadunaicapaccarrollemccarrollemgeczirobertgeczirobertsap-nssap-nsbalintkemenyemarsysbalintkemenyemarsysdhruv-sapdhruv-sapirvansapirvansapmarkjarvismarkjarvisrollandghrollandghlaralangnaularalangnautillmannrtillmannreggarciaeggarciarimo86rimo86sevket-atasevensevket-atasevenzhollerzhollerrobertoraczemarsysrobertoraczemarsyssamthomas02samthomas02mkrikoormkrikoormfel0123mfel0123luca.fasolino.seluca.fasolino.sendomkendomkefranziskajungfranziskajungandras.sarroandras.sarrodschuppadschuppadszunomardszunomaremarsys-stephen-ivesemarsys-stephen-ivesbencsobencsorcsullagrcsullagdputtadputtadwolter_emarsysdwolter_emarsysjisaacsonjisaacsontothbence8tothbence8d056437d056437ekkovatsekkovatsalanshialanshiearlpittsearlpittsprobalazsprobalazsrmafteiuscairmafteiuscailhammerllhammerliabrahamiabrahamandras-marton-emarsysandras-marton-emarsysnathan-matthews-sapnathan-matthews-sapsfarielsfarielschroedersteffenschroedersteffenbotondjavorkabotondjavorkadanielisapdanielisapgillyesgillyesbronikabronikatade82tade82dpkemarsysdpkemarsyskarlabrandlkarlabrandlmlesh-sapmlesh-saptonyhsaptonyhsapaidanlesh-sapaidanlesh-sapnikolett.tarnikolett.tarsridevirsridevircenglersapcenglersapbirokhunbirokhunabieler-sapabieler-sapi534456i534456daniel.balazsdaniel.balazslaszlo.orilaszlo.oritroywiegandtroywiegandbcsizmadiabcsizmadiaariceemariceemcsjakaboscsjakabosborcsaborcsannieman-sapnnieman-sapsap-amsap-amvszegedivszegedironnykrosseronnykrossetaylor-sethtaylor-sethmrclsumrclsufcolombo-sapfcolombo-sapmfawalmfawalszbszbahorvath1991ahorvath1991torokhelentorokhelenmatusekmamatusekma

Readme

aggregate-metric-logger

Aggregate metrics in memory and log them every minute

Setup

Set METRIC_LOGGER_ENABLED env variable to true for aggregate-metric-logger to start collecting and logging measurements.

To change the default aggregate-metric-logger namespace used for logs, set METRIC_LOGGER_NAMESPACE to a custom value.

Setup to send metrics to GCP monitoring

(currently only the metricLogger.count and metricLogger.measureGcp methods send metrics to GCP)

Set METRIC_LOGGER_ENABLED just us for LaaS based metrics.

Set MONITORING_PROJECT_ID and GCP_CREDENTIALS env variables. HOSTNAME env variable also has to be set, but for a pod running on kubernetes this should already be set.

Add Monitoring Metrics Writer Role to the service account in the GCP project.

Usage

The package exposes similar logging methods as the @emartech/json-logger package: trace, debug, info, warn, error and fatal.

When these are called, it will aggregate logs with the same parameters withing a minute, add an extra count property to the logs and log them at the end of the minute with @emartech/json-logger.

const metricLogger = require('@emartech/aggregate-metric-logger')

metricLogger.warn('etwas-went-wrong', { customer_id: 11 });
metricLogger.warn('etwas-went-wrong', { customer_id: 11 });

// will aggregate these to a single warning log

Measure values

If you want aggregate measurements about something you need to simply call the measure method for each value:

const metricLogger = require('@emartech/aggregate-metric-logger')

metricLogger.measure('thing-to-measure', 14)
metricLogger.measure('thing-to-measure', 20)

Every minute metric logger will log min, max, sum, count and average aggregated metrics for each measured tags. (Uses @emartech/json-logger behind the scenes for logging).

Measuring durations

For duration measurements, there are two convenient methods: start, and stop;

You start the measurement with start, the counted value for aggregation will be the duration between this start and the matching stop call;

function exampleIOHeavyFunction() {
  const measurement = metricLogger.start('tag-for-the-measuement');
  const result = db.findItems();
  metricLogger.stop(measurement);
  return result;
}

Group by extra parameters

If you want to group by additional parameters inside a tag, you can pass down these extra params in an object to measure and start as the last optional argument:

metricLogger.measure('thing-to-count', 14, { customer_id: 12 });

const measurement = metricLogger.start(
  'tag-for-the-measuement',
  { event_type: 'nyul', account: 3 }
);

A separate log entry will be created for each seen value combinations seen in the extra params and these extra params will be appended to the log entry.

Be very careful when using extra params, and only include information you really need. If you include too many parameters, you could lose the advantage you gain by aggregating your logs with this package.