Skip to content

Latest commit

 

History

History
466 lines (317 loc) · 16.2 KB

CHANGELOG.md

File metadata and controls

466 lines (317 loc) · 16.2 KB

Changelog

v2.50.0

December 30, 2024

  • Create custom traces with Monti.traceJob
  • Add monitoring for job queues, cron jobs, and custom functions
  • Add disableInstrumentation option
  • Use websockets to start cpu profiling
  • Support for recording heap snapshots

v2.49.4

July 11, 2024

  • Handle traces with invalid errors

v2.49.3

June 20, 2024

  • Fix issues with instrumenting redis oplog for observers with limit (#124 and #125)

v2.49.2

June 18, 2024

  • Fix error in redis oplog monitoring (#123)

v2.49.1

May 9, 2024

  • Remove unnecessary log added in 2.49.0

v2.49.0

May 6, 2024

  • Support for redis-oplog
  • Improve accuracy of waited on metric

v2.48.2

March 27, 2024

  • Fix some edge cases with publication wait time tracking that could result in a crash

v2.48.1

March 22, 2024

  • Improve accuracy of system memory metrics

v2.48.0

March 6, 2024

  • Track waitedOn time for methods and publications - the amount of time it is blocking other methods and publications
  • Track system memory
  • Fix using outdated staticFilesByArch in development on some Meteor versions
  • Add Monti.event to match v3 of agent
  • Fix tracking wait time for publications
  • Run object filters on HTTP req body
  • Document Monti.tracer.redactField
  • Rounds event loop lag to nearest 500 microseconds
  • Remove unused pctEvloopBlock metric

2.47.4

Nov 24, 2023

  • Fix handling uncaught exceptions when null or undefined are thrown
  • Fix event type for Email.sendAsync

2.47.3

August 10, 2023

  • Fix logging payload size only when enabled
  • Fix crash when promise rejected with undefined

2.47.2

January 9, 2023

  • Add type definitions for apps that use zodern:types
  • Add stalled method or publication detection. If a method is still running or a publication is not ready after 30 minutes, the agent will record an error to inform you.
  • Add stalledTimeout option to configure how long it waits before deciding a method or publication is stalled.
  • If called while there is an active trace, Monti.trackError will send the trace events with the error
  • Improve checks for why a query is not using the oplog. Many of the checks were out of date with new Meteor versions. We've also added some new checks, including for the reactive publish package.
  • Add disableClientErrorTracking option to only disable error tracking on the client
  • Fix possible error when running app tests, and global.window is set using jsdom
  • Fix ending async events in traces when an async function throws an error
  • Improve stack trace generated in safari for errors that are missing one
  • Sends the Meteor release in every request to the engine, instead of only when the app starts

2.46.1

November 8, 2022

  • Publish again without dev npm dependencies

2.46.0

November 8, 2022

  • Instrument fetch package (@afrokick)
  • Remove Monti APM: completed instrumenting the app logged every time the app starts
  • When already connected, calling Monti.connect again does nothing
  • Change to only auto-connect after instrumentation is finished
  • Handle RangeError: Invalid string length error
  • Add disableNtp option

2.45.1

February 13, 2022

  • Fix compatibility with Meteor 2.6

2.45.0

December 29, 2021

  • Add simplified Monti.trackError api: Monti.trackError(error)
  • Track collection.createIndex in traces
  • Fix some cases where details for unhandled rejections were not collected
  • The dependencies email and http are now weak
  • Removed dependency on localstorage, and replaced deprecated livedata and mongo-livedata packages with mongo and ddp

2.44.2

August 30, 2021

  • Fix Kadira._getInfo is not a function error
  • Update monti-apm-core to fix sending large traces and cpu profiles

2.44.1

July 20, 2021

  • Fix memory leak with Node 8 from monitoring garbage collection
  • Fix memory leak when agent is not connected
  • Remove support for beta versions of Meteor 2.3

2.44.0

July 14, 2021

  • Add createdFibers, activeFibers, fiberPoolSize, activeRequests, and activeHandles metrics
  • Add garbage collection metrics, enabled when using Node 8.5 or newer
  • Record histogram of event loop delay
  • Add metrics for mongo node driver's connection pool, enabled when using Meteor 2.2 or newer
  • Record system and user cpu usage in cpu history

2.43.1

June 9, 2021

  • Store current cpu usage percent for profiler

2.43.0

June 7, 2021

  • Fix compatibility with Meteor 2.3
  • Remove HTTP package from client dependencies

2.42.0

May 25, 2021

  • Add memoryArrayBuffers, memoryExternal, memoryHeapUsed, and memoryHeapTotal metrics
  • Fix pcpuUser and pcpuSystem metrics
  • Fix error when DocSize is given a map
  • Fix error when MeteorX.Multiplexer is undefined, which fixes using the agent in Rocket Chat
  • Fix how stripSensitiveThorough filter handles waitend event
  • Continuous profiles are only sent if the agent is connected
  • Remove pidusage npm dependency

2.41.2

March 24, 2021

  • Update monti-apm-core

2.41.1

March 23, 2021

  • Fix error when filtering arrays with null values

2.41.0

March 22, 2021

  • Add Monti.tracer.redactField(fieldName). Removes the value of these fields from objects before storing them in a trace. By default it filters the password field. Is used for headers from incoming HTTP requests, and parameters passed to methods and pub/sub.
  • Reduce time spent loading the package in the server by up to 80% (from up to ~1,000ms to 200ms)
  • Reduce disk usage of package from 25mb to 3mb
  • Warns when an app uses multiple APM agent packages since they can conflict with each other
  • Remove internal use of Meteor's HTTP package. Monti APM still instruments it to track outgoing HTTP calls in traces.
  • Store detail property of Method and pub/sub errors (Thanks @ulion).
  • Fix sending errors from Internet Explorer 9
  • Documented Meteor and browser compatibility in readme. We support Meteor 1.4 and newer, and Internet Explorer 9 and newer web browsers.
  • Add Tracer.stripSensitiveThorough filter. This filter internally uses a list of which fields to not strip instead of which fields to strip, which reduces the consequences of forgetting to update the filter after adding new fields
  • Update Tracer.stripSensitive to support headers and request bodies for HTTP traces
  • Increase minimum version for monitoring incoming HTTP requests from Meteor 1.6.1 to Meteor 1.7. As before, HTTP monitoring is automatically disabled when using an older version of Meteor.
  • Drop compatibility for old beta versions of Meteor's email package. You can still force the beta version by modifying your app's .meteor/packages file to have a ! after the email package's version.
  • Fix filter examples in readme

v2.40.1

January 8, 2021

  • Fix issues publishing v2.40.0

v2.40.0

January 8, 2021

  • Store histogram of response times for Methods and Publications
  • Store CPU usage every 2 seconds instead of 20
  • Improve performance when there are a large number of different methods, publications, or HTTP routes
  • Add Monti.startContinuousProfiling(). Requires a version of montiapm:profiler that supports continuous profiling.

v2.39.1

Nov 11, 2020

  • Fix return value of connect app .use
  • Log a message if trying to add a nested event to an invalid trace

v2.39.0

August 21, 2020

  • Add monitoring for incoming HTTP requests, supported for Meteor 1.6.1 and newer
    • Instruments WebApp.rawConnectHandlers, WebAppInternals.meteorInternalHandlers, WebApp.connectHandlers, WebApp.connectApp, fast-render, connect-route, and simple:json-routes (which is used by most Meteor REST packages)
  • Create histograms of HTTP response time
  • Instrument fs.stat and fs.createReadStream
  • Fix unhandled promise rejections not being logged to the console
  • Fix calculating compute time between the second to last event and complete event
  • Sends agent version to the engine

v2.38.1

January 23, 2020

  • Improve detection of errors that should be ignored in Meteor._debug. This will fix some errors not being reported
  • Fix some stack traces missing when logged by Meteor._debug

v2.38

November 6, 2019

  • Fix many instances of unhelpful errors reported by Meteor._debug
    • Fix tracker errors being reported as 3 different errors. Now one error has all the relevant details
      • One error had the tracker function that caught the error
      • One had the error message without the stack
      • Another had the error stack without the message
    • Fix internal server errors with no name or stack
    • Fix empty stack from Meteor._debug on Firefox
    • Add stack if missing to Meteor._debug server errors
  • Fixed duplicate : appearing in some error names
  • Limit method and subscription start params to 2,000 characters
  • Limit traces to 1,000 events. This will not affect the method or subscription metrics.

v2.37

August 14, 2019

  • Fix many errors in IE not being recorded due to having the wrong time from ntp requests being cached
  • Fix crash when event added to trace after it was processed
  • Replace meteorhacks:kadira-profiler with montiapm:profiler in console message (@Brouilles)

v2.36.1

June 14, 2018

  • Fix the stack trace for some client errors showing as [object Object]

v2.36.0

May 22, 2019

  • Tracer records one level of nested events
  • Custom events can be added to a trace with Monti.startEvent and Monti.endEvent. These methods are only available on the server
  • Optionally record a stack trace of where event started
  • Added db _nextObject event, recorded during cursor.forEach and cursor.map
  • Events that were ended due to the trace ending have a forceEnd property
  • Some events uploaded to the engine have a fourth item in their array with the data needed for the above features. This is backwards compatible with the open source Kadira, but Kadira would have to be modified to use the additional data.

v2.35.0

March 25, 2019

  • Fix pubsub and system metrics that were broken in Meteor 1.8.1
  • Add recordIPAddress option which can be used to tell Monti APM to anonymize IP addresses or to not record them. This option has no effect on the open sourced Kadira.
  • Add section to readme to document options

v2.34.3

December 26, 2018

  • Fix session count in Meteor 1.8.1

v2.34.2

December 5, 2018

  • Replace meteorhacks:meteorx with lamhieu:meteorx to add support for Meteor 1.8.1

v2.34.1

November 16, 2018

  • Fix error when initializing client
  • Fix errors in zone utils

v2.34.0

November 15, 2018

  • Remove underscore from client (@sebakerckhof)
  • Remove endevent forced complete warning

v2.33.0

September 29, 2018

  • Add uploadSourceMaps option. It is enabled by default in production when using a minifier that creates source maps. When enabled, source maps that Monti APM does not cached are uploaded when needed by a new client error
  • Track unhandled promise rejections in the server and in browsers that support it
  • Client architecture and version is sent with client errors

v2.32.2

July 13, 2018

  • Fix error stack trace from method and subscription errors showing as an object when error tracking is disabled
  • Fix using environment variables that were not prefixed with MONTI_ or KADIRA_. See #5
  • Fix crashing app when unable to get cpu or memory usage on Windows. Instead, a message will be shown in the logs, and the memory and cpu usage will show as 0 in the Monti APM UI. See #4

v2.32.1

June 18, 2018

  • Fix error stack trace from method and subscription errors showing as an object

v2.32.0

May 27, 2018

  • Remove jquery dependency
  • Export a Monti object as an alias to the Kadira object
  • A monti object can be used in the settings.json instead of the kadira object
  • Environment variables can be prefixed with MONTI_ instead of KADIRA_
  • Kadira has been replaced with Monti APM in all console.log messages
  • Fix tracking subscription message sizes on Meteor 1.5 and newer

v2.31.1

  • Show better error message when unable to connect

v2.31.0

  • Rename to montiapm:agent

v2.30.4

  • Use Object.create(null) rather than object initializer notation when initializing objects to store metric data.

v2.30.3

  • Ensure error strings are encapsulated in an Error-like object for transmission to the APM server.

v2.30.2

v2.30.0

  • Stop sending hostname to the client side. See #245.

v2.29.1

  • Remove MongoDB labeling. See: PR239

v2.29.0

  • DocSzCache size is now configurable. See PR238

v2.28.7

20-05-2016

  • Use kadira-core@1.3.2

v2.28.6

12-05-2016

  • Fix an issue of potentially, killing the due to CPU labeling of the MongoDB module.

v2.28.5

09-03-2016

  • Fix coding style issues
  • Track polledDocSize on polling observers as well

v2.28.4

04-03-2016

  • Fix regression of not tracking size data correctly. See: #219

v2.28.3

04-03-2016

  • Fix re-opened bug #83 which tries to use update options when it's undefined or null. This came with the recent addition of size tracking.

v2.28.2

01-03-2016

  • Fix issue of not tracking null publications properly in data size tracking.

v2.28.1

  • Remove cache handlers tracking from observers. This leads to better CPU usage.

v2.28.0

  • Tracking different data size meterics (all in and out data sizes from the app). This is done is very efficient manner. So, this doesn't impact to the app's CPU usage.

v2.27.3

  • Update pidusage to v1.0.1

v2.27.2

  • Fix potential issue of not sending data to engine. Earlier we stopped sending when we see an error. Actually, we need to reschedule to send data to engine even if there is an error.

v2.27.1

  • Fix an issue on server crashing due to a bug on kadira-core. Fixed by adding kadira-core v1.3.1, which has a fix for that.

v2.27.0

  • Now, transport layer is handled by the kadira-core NPM module.

v2.26.3

  • Add potential fix for #200

v2.26.2

  • Add initiallyAddedDocuments to track initial adds

v2.26.1

  • Change the metrics we track for LiveQuery tracking.

v2.26.0

  • Add more metrics which tracks the Live Query usage. This will be helpful for our upcoming LiveQuery tracking feature.

v2.25.0

  • Allow to filter by method/sub name when striping trace data. See this PR.

v2.24.1

  • Add better error reporting. Actually fixed this issue: meteorhacks/kadira#193
  • How we fix is little unconventional but it worked.

v2.24.0

  • Start instrumenting Kadira rightway. So, we can get the CPU profile labeling.

v2.23.6

  • Using MeteorX for the server only.

v2.23.5

  • Using the latest MeteorX version, which has some fixes for startup related issues

v2.23.4

  • Fix for a weird bug we found from the customer support. Without this fix, his app won't bind to the port.

v2.23.3

  • Fix a potential issue where the possiblity to mutate authHeaders.

v2.23.2

  • Change console.error in connect code to console.log.

v2.23.1

  • Add support for Meteor 1.2. Fixes: #181. It was an issue with how we are tracking Fiber.yield.

v2.23.0

v2.22.1

  • Prevnt string errors crashing the app. Potential fix for: #175

v2.22.0

  • We've seen some users getting older version when installed via meteor add meteorhacks:kadira. We've no idea when it's happening. May be because we still support Meteor 0.9.
  • So, this version drops Meteor 0.9 support and only support Meteor 1.0 or higher.

v2.21.0

  • Fix an issue with the time-sync logic
  • Do not retry if kadira engine return a status code of range 400-500 (except 401. It throws an error.)
  • Add the protocol version as 1.0.0