- Add play framework preview instrumentation #1958.
- Add span kind to sampling overrides #1960.
- Fix status exception in a readonly file system #1967.
- Reduce noisy truncation logging #1968.
- Fix jackson initialization #1984.
- Add url, name and fix operation name to request document in live metrics sample telemetry #1993.
- Fix duration in live metrics sample telemetry feature. #1996.
- Fix instrumentation key is null when sending persisted files from disk #1948.
- Fix consumer span exporter mapping #1952.
- Handle weird folder name like 'test%20-test' #1946.
- Support read-only file system #1945.
- Reduce netty pool size #1944.
- Do not apply sampling to metrics #1902.
- Support for multiple instrumentation key #1938.
- Bridge session id from 2.x SDK #1930
- Fix NullPointerException when sending raw bytes from persisted files on disk #1931.
- Add non-essential Statsbeat #1925
- Update OpenTelemetry to 1.7 #1920
- Add Akka preview instrumentation #1911.
- Add internal-reflection instrumentation #1912.
- Reduce spammy logging #1915.
- Add Quartz and Apache Camel instrumentations to preview #1899.
- Database dependency names are now more concise, e.g.
SELECT mydatabase.mytable
instead ofSELECT x, y, z, ... from ... where ...........
(the full sanitized query is still captured in the dependency data field) - Database dependency target field slightly updated to enable better U/X integration
- HTTP dependency names are now more descriptive, e.g.
GET /the/path
instead ofHTTP GET
- Update default configuration:
- 'azuresdk' configuration moved out of preview configuration and is now enabled by default.
- 'openTelemetryApiSupport' moved out of preview configuration and is now enabled by default.
- 'httpMethodInOperationName' moved out of preview configuration and is now enabled by default.
- Fix quick pulse memory leak.
- Log all available jmx metrics at debug level.
- Misc logging improvements #1828.
- Add grizzly instrumentation as preview.
- Fix live metrics sampled counts.
- Fix stack traces not being captured for deadlocks #1263.
- Support Sample Telemetry feature for live metrics #1852.
- Add inherited attributes preview #1743.
- Fix Application Map to App service/function view support #1868.
- Fix service bus mapping #1848.
- Lots of internal clean up.
- Reduce binary size from 3.2.0-BETA
- Add Spring Integration instrumentation (preview).
- Add thread name to log capture #1699.
- Support W3C baggage propagation.
- Disable legacy Request-Id propagation by default.
- Handle partial content success due to Stamp specific redirects #1674.
- Log controlled warning when telemetry truncated #1021.
- Support system properties for connection string, role name and role instance #1684.
- Small fixes to 2.x interop.
- Updated to support OpenTelemetry API 1.4.1 (preview)
- Moves 3 instrumentations out of preview, and enables them by default
- Java 11 HTTP client
- JAX-WS
- RabbitMQ
- Pulls in new instrumentations (enabled by default)
- AsyncHttpClient
- Google HTTP client
- JAX-RS client
- Jetty client
- Spring RabbitMQ
- Servlet 5.0 #1800
- Support Azure Active Directory Authentication.
- Support Stamp Specific redirects.
- Use v2.1/track endpoint to send telemetry instead of v2/track.
- Fix 2.x interop of timestamps #1726.
- Add metric filtering to telemetry processor #1728.
- Add log processor to telemetry processor #1713.
- Fix app id retrieval 404 for Linux Consumption Plan #1730.
- Fix invalid instrumentation keys for Linux Consumption Plan #1737.
- Reduce agent jar file size back to normal #1716.
- Fix memory leak caused by not removing Netty listeners upstream #2705
- Improve Azure Service Bus support #1710.
- Updated to support OpenTelemetry API 1.2.0
- Support explicit operation id and parent id from 2.x SDK #1708.
- Fix exceptions with deep stack trace exceeding 64 KB rejected by Application Insights backend #1702.
- Use shorter telemetry names for all telemetry types to reduce payload #1700.
- Improve Azure SDK support #1698.
- Fix NullPointerExceptions for App Services #1681.
- Add Application Insights stats.
- Capture http method in the operation name #1679
- Enable users to override iKey, cloud role name and cloud role instance per telemetry #1630.
- Fix duplicate headers #1640.
- Add preview instrumentations for javaHttpClient, rabbitmq, and jaxws #1650.
- Add a new env var called APPLICATIONINSIGHTS_RP_CONFIGURATION_FILE.
- Add cloud role name and instance to applicationinsights-rp.json configuration.
- Improve agent start up time.
- Enable Azure Functions to update the instrumentation logging level at runtime.
- Enable Azure Functions to update the self-diagnostics logging level at runtime.
- Fix grails failure #1653.
- Remove class loader optimization opt out system property for Azure Functions #1627.
- Suppress redis.encode.start/end custom events #1586
- Add Azure SDK instrumentation preview #1585
- Fix WebFlux HTTP client hanging on nested calls #1563
- Fix instrumentation of reactor netty
HttpClient.from()
#1578
- Added env var
APPLICATIONINSIGHTS_PREVIEW_OTEL_API_SUPPORT
to enable preview OpenTelemetry API support #1548 - Added env var
APPLICATIONINSIGHTS_SELF_DIAGNOSTICS_FILE_PATH
(and use that to log json config parsing errors) #1550 - RP integration improvements #1551, #1558, #1559
- Add env var
APPLICATIONINSIGHTS_PREVIEW_LIVE_METRICS_ENABLED
to disable live metrics #1552 - Remove unwanted custom dimension that showed up in 3.0.3-BETA #1565
- Add sampling overrides that can be used to implement telemetry filtering #1564
- Switch native performance counter collection to use OSHI #1482
- Extra attributes in
applicationinsights.json
(e.g. typos) are logged as warnings at startup #1459 - Better 2.x SDK interop #1454
- Fix for ClassNotFoundException when deploying some JBoss ear files #1465
- Fix configuration for disabling spring boot actuator metrics #1478
- Add env vars for disabling instrumentation #1495
- Removed the undocumented micrometer reportingIntervalSeconds,
and instead, added preview configuration
metricIntervalSeconds
that controls all metrics: #1507 - Changed undocumented reload of connection string and sampling percentage to be preview and opt-in #1507
- Additional reactor-netty and kotlin coroutine instrumentation #1511
- Improved error messages for network connectivity issues #1483
- Support for roles in Live metrics #1510
- Fixed role name on Azure Functions #1526
- Populate client IP #1538
- Support for role name in Azure Functions consumption plan #1537
- Fix App Services logback parser exceptions.
- Log instead of throwing exception on unbridged API #1442
- Fix role name config #1450
- Support more interop with 2.x SDK ThreadContext (getId and getParentId)
- Suppress duplicate AI agents. Resolves #1345
- Fix role name precedence. Resolves #1425
- Fix APPLICATIONINSIGHTS_CONNECTION_STRING env var. Resolves #1428
- Add APPLICATIONINSIGHTS_SELF_DIAGNOSTICS_LEVEL env var. Resolves #1422
- New 'extract' attribute feature added to Telemetry processors.
- Fix code to use the correct logging configuration 'level' #1415)
- Capture log4j2 async logging. Addresses issue #1389
- Add configuration for disabling dependencies #1294
-
Friendly error messages thrown for the following scenarios
- Missing connection string
- Invalid SSL certificate issues when not able to connect to IngestionEndPoint Url, Live endpoint Url and CdsProfiler endpoint url.
- Invalid Telemetry Processor Configuration
-
Telemetry processor config throws null pointer exception when attribute value is not provided and matchType is regexp.
-
Map service.version to application_Version(Resolves #1392)
-
This release also brings more interoperability with the 2.x SDK:
- ThreadContext.getRequestTelemetryContext().getHttpRequestTelemetry().getProperties().put("key1", "val1")
- ThreadContext.getRequestTelemetryContext().getHttpRequestTelemetry().setName("new name")
- ThreadContext.getRequestTelemetryContext().getHttpRequestTelemetry().getContext().getUser().setId("uname")
-
Add thread details span processor
-
Add agent version number to startup message
- Config changes
- Change json config file name from ApplicationInsights.json to applicationinsights.json
- Redesign json config structure (Java Standalone Config)
- Send JMX metrics to CustomMetrics instead of PerformanceCounter (Default Mettrics Captured by Java 3.0 Agent)
- Telemetry processor for requests, dependencies, and traces
- Attach custom dimensions to all telemetries
- Fix QuickPulse bug (Live Metrics are showing incorrect results)
- Fix URL with spaces (microsoft#1290)
- Improve overall logging
- Dropped Java 7 support
- Supported boolean JMX metrics (#1235)
- Added support for JMX metrics environment variable APPLICATIONINSIGHTS_JMX_METRICS
- Added two default JMX metrics for thread count and class count
- Changed default logging capture from WARN to INFO
- Added support for logging capture environment variable APPLICATIONINSIGHTS_LOGGING_THRESHOLD
- Added support for sampling percentage environment variable APPLICATIONINSIGHTS_SAMPLING_PERCENTAGE
- Added auto-collection for 2.x SDK trackTrace, trackRequest and trackException
- Added capturing MDC logging properties
- Added support for Jetty Native Handler
- Fixed JMX metrics which aren't available initially are never recorded (#1233)
- Fixed capturing JMX metrics inside of CompositeData (#952)
- Fixed HTTP request header to use X-Forwarded-For as Client IP when present (#404)
- Fixed URLs with spaces (#1290)
- Fixed NullPointer when testing with MockMvc (#1281)
- Fixed client_Browser data populated incorrectly
- Fixed non-daemon thread pool so that it won't prevent app from shutting down
- Fixed retry transmission on client side exception (#1282).
- Fixed RequestTelemetryContext initialization (#1247). Thanks, librucha!
- Built in instrumentation for Jetty Native handlers
- Added additional error logging for troubleshooting issues loading JNI performance counter library (#1254)
- Fix backoff condition so that retries will continue indefinitely (#1253)
- Fix memory leak
- Fix shutdown issue due to non-daemon thread
- Fix backoff condition so that retries will continue indefinitely
- Fix shutdown issue due to non-daemon thread (#1245)
- Fix W3C BackCompat across multiple Application Insights instrumentation keys (#1228)
- Fix spring boot starter when used with
spring.main.lazy-initialization=true
(#1227)
- No changes since 2.6.0-BETA.3
- Use newer id format when reporting request and dependency telemetry (#1149)
- Fixed pom file dependency in applicationinsights-spring-boot-starter (#1149)
- Removed Local Forwarder Channel. Local Forwarder is now a deprecated solution. The classes and configuration elements which supported this solution have been removed.
- Removed unused dependencies from azure-application-ingishts-spring-boot-starter (xmlpull, xstream).
- Fixed
Unknown constant pool
issue with modeule-info.class when using older versions of ClassGraph. - Fixed potential issue with URI building in ConnectionString parsing.
- Updated to the latest version of the struts API library (used by
com.microsoft.applicationinsights.web.struts.RequestNameInterceptor
). - Fixed memory leak with ChannelFetcher when TelemetryClient is instantiated in large numbers.
- Various stability improvements (#1177)
- W3C tracing with back-compat is now enabled by default (#1141)
- Improved MongoDB instrumentation (#1132)
- Agent now supports Java 13 (#1149)
- Older Jersey versions failing when scanning classes due to inclusion of a few Java 8 class files (#1142)
- Fix remote dependency target field format (#1138)
- No changes since 2.5.1-BETA.2
- Fixed exception thrown by agent when using Apache HttpClient ResponseHandler methods (#1067)
- Connection String introduced for better government cloud support
- Agent now captures MongoDB queries
- No changes since 2.5.0-BETA.5
- Fixed
ClassCastException
that could happen when usingHttpURLConnection
(#1053)
- Fixed registration of custom JMX performance counters (#1042)
- Fixed
IllegalStateException
that could happen when usingHttpURLConnection
(#1037) - Fixed
NullPointerException
that could happen when using Java 11 (#1032)
- Fixed
HttpURLConnection
instrumentation was not capturing outgoing url (#1025) - Added agent logging capture threshold, configurable via
<Logging threshold="warn" />
in theAI-Agent.xml
, with default thresholdwarn
(#1026) - Fixed request telemetry displaying
200
response code for some failed requests (#810) - Fixed GC performance counters not working (#929)
- Added back support for
<Class>
custom instrumentation inAI-Agent.xml
- Fixed opting out of agent capturing logging via
<Logging enabled="false" />
- Misc fixes #969, #978
- Added support for Java 9-12
- Added new
applicationinsights-web-auto.jar
artifact that automatically registers the web filter by just being present in your dependencies (works for both servlet containers and spring boot standalone)- No need to modify
web.xml
, or add@WebFilter
- No need to modify
- Agent now captures application logging via
Log4j 1.2
,Log4j2
andLogback
- No need to add
applicationinsights-logging-*.jar
dependency and modify the application's logging configuration (e.g.log4j.properties
,log4j2.xml
,logback.xml
) - To opt out of this (e.g. if you prefer to capture logging via the Application Insights appenders),
add
<Logging enabled="false" />
to theAI-Agent.xml
file inside of theBuiltin
tag
- No need to add
- Agent now automatically captures dependencies for async requests by tracking the request across multiple threads
- Agent now captures JDBC queries for all JDBC drivers
- Added additional HTTP client support
java.net.HttpURLConnection
- Apache HttpClient 3.x (4.x was already previously supported)
- OkHttp3
- OkHttp2 (previously did not propagate distributed trace context)
- Agent now sets
Operation Name
(used for aggregating similar requests) automatically based on Spring@RequestMapping
and JAX-RS@Path
- No need for registering
RequestNameHandlerInterceptorAdapter
or writing own interceptor - (also supports Struts, based on action class / method name)
- No need for registering
- Agent now supports multiple applications deployed in the same application server
- (support was removed temporarily in the 2.4.0 release)
- Simplified JBoss and Wildfly deployment when using the agent
- No need for setting
jboss.modules.system.pkgs
,java.util.logging.manager
and-Xbootclasspath
- No need for setting
- Added
<RoleName>
tag inApplicationInsights.xml
to simplify role name configuration- No need to write a custom
ContextInitializer
- No need to write a custom
- Removed support for
<Class>
custom instrumentation inAI-Agent.xml
- Removed support for
<RuntimeException>
custom instrumentation inAI-Agent.xml
- Fix #910 Fixed correlation id serialization.
- Upgraded spring boot dependencies in spring-boot-starter from 1.5.9 to 1.5.21.
- Updated Spring Boot Starter version number to track with the SDK version.
- Upgrade gradle to 5.3.1
- Fix #907 - ensure string compare is case insensitive when running a SQL explain on a select statement.
- Fixed ThreadLocal leak #887
- Fixed QuickPulse schema version #904
- Added retries to CDSProfileFetcher #901
- Fix #919 - Fixed issue when adding duplicate Windows performance counter.
- Added caching of sdk version id, reducing number of file IO operations #896
- Fixed bug with live metrics (QuickPulse) where request/dependency durations were being truncated to the millisecond.
- Misc stability improvements #932 #941 #945 #946 #947 #948
- Removed support for multiple apps instrumented with single JVM Agent. Instrumentation will only work for single apps in application server.
- Fixed #749 introduce support for PostgreSQL jdbc4 prepared statements.
- Introduced support for Manual Async and Explicit Multithreading correlation.
IntroducedsetRequestTelemetryContext
API inWebTelemetryModule
Interface.- Introduced experimental API's
AIHttpServletListner
,HttpServerHandler
,ApplicationInsightsServletExtractor
andHttpExtractor
. - Deprecated
ApplicationInsightsHttpResponseWrapper
- Fixed #826 Remove duplicate provider.
- Fix incorrect sdk version being sent in Quick Pulse payload.
- Fix #882 Dependency metrics does not show up on Livemetrics UX.
- Fixed #799 Removed dependency on Guava vulnerable to CVE-2018-10237.
- Introducing Application Insights SpringBoot Starter 1.1.1 (GA VERSION).
- Fix #784 Shade guava dependency.
- #716 Introduced W3C Distributed tracing protocol.
- Fixed #767. Updated gRPC dependencies which inlcudes latest netty version.
- Fixed #751. Added support for absolute paths for log file output.
- Abstracted Internal Logger in Core into separate reusable module.
- Deprecated InternalAgentLogger in favor of InternalLogger for better consistency.
- Fixed #752. Agent now supports diagnostic writing logs to file.
- Added ability to configure FileLogger for SpringBootStarter.
- Fixed the
WebRequestTrackingFilter
order in FilterChain for SpringBoot Starter.
- Introduces SpringBoot Starter 1.1.0-BETA
- Starter now respects autoconfiguration for Micrometer metrics.
- Starter adds autoconfiguration for Local Forwarder Telemetry Channel. (Please look at readme for details on configuration.)
- Fix #712 the thread shutdown issue in SpringBoot Starter by registering
ApplicationInsightsServletContextListener
. - SpringBoot Starter now supports reading iKey using all the variable names as core sdk.
- Starter would no longer support relaxed binding of ikey property due to complex conditional need and backport problems with RelaxedBinder from Boot 2 to 1.5.x.
InterceptorRegistry
class no longer has@EnableWebMvc
annotation as it breaks springboot autoconfig.- Deprecated
getRoleName
/setRoleName
andgetRoleInstance
/setRoleInstance
inDeviceContext
. IntroducedCloudContext
to hold replacements,getRole
/setRole
andgetRoleInstance
/setRoleInstance
, respectively. - Introduced
CloudInfoContextInitializer
to set roleInstance inCloudContext
. This new initializer is included by default and therefore will not affect the current tags. - Adds
WebAppNameContextInitializer
for use with theWebRequestTrackingFilter
. - Adds
LocalForwarderChannel
for use with the LocalForwarder. - Removes Servlet 3.0 annotations from
WebRequestTrackingFilter
andApplicationInsightsServletContextListener
which were causing issues in certain cases. This will allow easier customization of the filter. To use the listener moving forward, it will need to be defined in web.xml. - Fix QuickPulse post interval bug from 5 seconds to 1 second.
- Fix #676. This fixes the HTTP dependency collection when using NetFlix Zuul Library.
- Remove the method
httpMethodFinishedWithPath
from the interfaceImplementationCoordinator.java
as the associated instrumentation explicitly depended onHttpUriRequest
class of ApacheHttpClient which is not always true. - Fix #662. Updated thread pool to properly shutdown all threads.
- Fix #661. We now properly shadow the com.google.thirdparty package.
- Fix #686. Added required attributes to @WebFilter annotation.
- Introducing support for SpringBoot via Application-Insights-SpringBoot-Starter #646. This is currently in beta.
- In order to add support for SpringBoot starter some fields in core SDK are made public.
- Introduced public constructor in
InProcessTelemetryChannel.java
class. - Introduced a public method
getActiveWithoutInitializingConfig()
inTelemetryConfiguration.java
class.
- Introduced Heartbeat feature which sends periodic heartbeats with basic information about application and runtime to Application Insights.
- Enable support for system properties in the instrumentation key resolving component.
- Performance improvements during initialization.
- Fix #647. If a performance counter cannot be computed, it will not report a placeholder value (
-1
). Instead, it does not report any value.
- Fix incorrect success flag set when capturing HTTP Dependency.
- Fix #577, removed HttpFactory class as it was not being used.
- Fixed issue with sessionId not being set in request telemetry due to date parsing issues.
- Fix #616, added a way to have real time SDK Logs when logging on File.
- Fix #609, fixes the inaccurate timestamp recorded with JMX Metrics.
- Added a way to configure MaxInstantRetries from XML.
- Added the ability to have cold SDK initialization (no logs except critical logAlways messages)
- Fix issue when dependency start time was not being recorded correctly.
- Fixed #533 HTTP Dependency Telemetry now matches with .NET SDK.
- Introduced public method
httpMethodFinishedWithPath(String identifier, String method, String path, String correlationId, String uri, String target, int result, long delta)
to support instrumentation of Path of URI in HTTP requests. httpMethodFinished(String identifier, String method, String correlationId, String uri, String target, int result, int delta)
is now marked as deprecated- Logger Messages now being pushed as custom dimension when reporting exceptions via Loggers. (#400)
- Enhanced Log4j2 appender to support basic parameters including Filters, Layouts and includeException. (#348)
- Fixed PageView telemetry data not being reported.
- Fixed Issue #526 (NPE in MapUtil.copy())
- Fixed Issue #513 (Memory leak in SDKShutdownActivity). This fix upgrades our Servlet version from 2.5 to 3.0. The SDK must now be run on an application server supporting Servlet 3.0.
- Fixed Issue #504 (SDK initialization happens twice) to improve startup performance.
- Fix Inconsistency in artifact names in POM files
- Upgraded logback dependency version to 1.2.3
- Improved FixedRateSampling so that it also supports Sampling Percentage set by users programmatically. Fixes issue #535
- Fault Tolerance improvements: introducing retries and exponential backoff capabilities with disk persistence.
- Issue #499: Fix handling of NaN and +/-Infinity in JSON serializer
- Issue #506: Null Reference Check causing Null Pointer Exception in
TelemetryCorrelationUtils.java
- Updating various dependencies to latest version
- Introducing public class CustomClassWriter in Agent to enable finding common super classes used for Agent instrumentation without loading it
- Introducing Parametrized constructor in WebRequestTrackingFilter to ensure name binding
- Fixed Issue #428 (Agent cannot capture oracle dependencies)
- Fixed Issue #418 (Java.lang.verify error caused while capturing sql dependencies in JDK 1.8)
- Fixed Issue #286, #277 (Issues in capturing preparedStatement calls)
- Fixed Issue #365 (Relocate all web jars)
- Fixed Issue #276 (Instrumentation issues with HTTP Client)
- Introducing public method 'getIncludedTypes' and 'getExcludedTypes' in TelemetryProcessorXmlElement.
- Introducing class 'com.microsoft.applicationinsights.internal.config.ParamIncludedTypeXmlElement'.
- Introducing class 'com.microsoft.applicationinsights.internal.config.ParamExcludedTypeXmlElement'
- Introducing class 'com.microsoft.applicationinsights.internal.channel.samplingV2.SamplingScoreGeneratorV2'
- Introducing Telemetry Processor 'com.microsoft.applicationinsights.internal.channel.samplingV2.FixedRateSamplingTelemetryProcessor'
- Introducing FixedRate Sampling v2 Using Telemetry Processors
- Fixed issue #436 (TraceTelemetry with Severity is not shown in UI). This fixes a regression issue with
TelemetryClient.trackTrace
andTelemetryClient.trackException
. - Introducing support for cross-component correlation. Addresses issue #457.
- Changed signature of com.microsoft.applicationinsights.internal.agent.CoreAgentNotificationHandler.httpMethodFinished. It now includes correlation information.
- Compilation now targets Java 1.7. Java 1.6 is no longer supported.
- Adding system property
applicationinsights.configurationDirectory
to allow to explicitly set directory containing the config file.
track()
method of 'com.microsoft.applicationinsights.TelemetryClient' is now modified. No longer performing pre-sanitization- All Sanitization will now occur in
com.microsoft.applicationinsights.telemetry.JsonTelemetryDataSerializer
class. - Method
sanitize
of interfacecom.microsoft.applicationinsights.telemetry.Telemetry
is now obsolete. - The auto generated schema classes now have writer method with limits according to endpoint.
- Fixed issue #403 (Exceeding property length invalidates custom event)
- Fixed issue #401 (Custom key and property sanitized)
- Fixed Request Telemetry Sending bug with new schema.
- Fixed reliability issue with Jedis client dependency collector
- Fixed Request Telemetry Sending bug with new schema
- Schema updated to the latest version. Changes in internal namespace
core/src/main/java/com/microsoft/applicationinsights/internal/schemav2
. - Class
SendableData
in internal namespace deleted. - Class
com.microsoft.applicationinsights.telemetry.BaseSampleSourceTelemetry
takes generic class qualifierDomain
instead ofSendableData
. - Class
com.microsoft.applicationinsights.telemetry.BaseTelemetry
takes generic class qualifierDomain
instead ofSendableData
. - Methods
getExceptionHandledAt
andsetExceptionHandledAt
ofExceptionTelemetry
marked obsolete and do not do anything. - Obsolete methods of
RemoteDependencyTelemetry
:getCount
,setCount
,getMin
,setMin
,getMax
,setMax
,getStdDev
,setStdDev
,getDependencyKind
,setDependencyKind
,getAsync
,setAsync
,getDependencySource
,setDependencySource
. - Obsolete methods of
RequestTelemetry
:getHttpMethod
,setHttpMethod
. - Add option to configure instrumentation key via
APPINSIGHTS_INSTRUMENTATIONKEY
environment variable for consistency with other SDKs. - Fix the issue where
track(...)
ofTelemetryClient
class was overwriting the provided telemetry timestamp. - Changed the policy on failed sent requests to delay retrying for 5 minutes instead of immediately retrying.
- Fix the issue of infinite retry and connection drain on certificate error by updating the version of http client packaged with the SDK.
- #367 Updated the agent project not to be transitive when resolved for core
- #374 Updated the core JAR to remove the transitive dependencies for guava, removed the transitive dependency from core and agent, & updated to the latest version of the httpclient
- #376 Delaying retry on send when no connection is found
- #377 Bug fixes for Live Metrics Stream integration
- #378 Added Live Metrics Stream URL filter and fixed duration
- #379 Updated Gradle to 3.5
- #380 Delaying retry on send when ConnectionException is thrown
- #381 Delaying retry on send when HostUnknownException is thrown
- Use Shadow plugin to create self contained JAR files in the SDK
- Allow marking a metric as custome performance counter. See here
- Better support for Visual Studio Code for edting the Application Insights Java SDK Code
- Added sampling support. See here
- Allow changing the performance counter collection frequency and added hooks before and after sending the PC see here and here
- Agent built-in types are now off by default. Support wildcard to monitor multiple classes in the agent.
- Add dependency type in the agent configuration see here
- Allow reporting runtime exceptions
- Collect JVM heap memory usage and automatic deadlock detection
- Make frequency of performance counter collection configurable
- Plugin to allow intervening before and after performance counters collection change docs
- Comply to server side throttling
- Upgrade to Gradle 3.0 build
- Allow running Java agent outside of webapp context
- Built in instrumentation for MuleESB client
- Built in instrumentation for current Apache Derby DB
- Added proxy support.
- Treat HTTP response codes below 400 (and 401) as success.
- Fix agent load problem on Linux.
- Improve cleanup and exception handling in WebRequestTrackingFilter.
- Propagate log context properties in custom properties.
- Ability to filter out certain telemetry from being sent.
- Some other miscellaneous fixes and improvements.
- Interim version replaced by 1.0.5 on August 2016
- Align to a new BOND schema used by the Application Insights data collection endpoints.
- Prevent from overriding the instrumentation key using the one specified in the config when it's provided explicitly in code.
- Handle all successfull HTTP status codes and report the relevant HTTP Requests as successful.
- Handle all exceptions thrown by the ConfigurationFileLocator .
- The Java agent collects dependency information about the following:
- HTTP calls made via HttpClient, OkHttp and RestTemplate (Spring).
- Calls to Redis made via the Jedis client. When a configurable threshold is passed, the SDK will also fetch the call arguments.
- JDBC calls made with Oracle DB and Apache Derby DB clients.
- Support the 'executeBatch' query type for prepared statements – The SDK will show the statement with the number of batches.
- Provide the query plan for JDBC clients that has support for that (MySql, PostgreSql) – The query plan is fetched only when a configurable threshold is crossed
- Adding support for the Application Insights writer plugin for CollectD.
- Adding support for the Application Insights Java agent.
- Fix for a compatibility issue with supporting HttpClient versions 4.2 and later.
- Make the Java SDK compatible with servlet v2.5 and HttpClient pre-v4.3.
- Adding support for Java EE interceptors.
- Removing redundant dependencies from the Logback appender.
- Fix for an issue where custom events are not correlated with Users/Sessions due to cookie parsing errors.
- Improved logic for resolving the location of the ApplicationInsights.xml configuration file.
- Anonymous User and Session cookies will not be generated on the server side. To implement user and session tracking for web apps, instrumentation with the JavaScript SDK is now required – cookies from the JavaScript SDK are still respected. Note that this change may cause a significant restatement of user and session counts as only user-originated sessions are being counted now.
- Support collecting performance counters from 32-bit Windows machines.
- Support manual tracking of dependencies using a new
trackDependency
method API. - Ability to tag a telemetry item as synthetic, by adding a
SyntheticSource
property to the reported item.