Get your application events and errors to Trakerr via the Trakerr API.
You can send both errors and non-errors (plain log statements, for example) to Trakerr with this API.
The 3-minute guide is primarily oriented around sending errors or warnings and do not permit additional parameters to be set. When using log4j in the 3-minute guide you can however set the level individually to DEBUG for the trakerr logger. Option-3 in the detailed integration guide shows how you could send a non-error (or any log statement) with additional parameters.
The SDK takes performance impact seriously and all communication between the SDK <=> Trakerr avoids blocking the calling function. The SDK also applies asynchronous patterns where applicable.
A Trakerr Event can consist of various parameters as described here in AppEvent. Some of these parameters are populated by default and others will need to be supplied by you.
Since some of these parameters are common across all event's, the API has the option of setting these on the TrakerrClient instance (described towards the bottom) and offers a factory API for creating AppEvent's.
- Log Level This enum specifies the logging level to be used for this event ('debug','info','warning','error' or 'fatal')
- Event Type This defines the type of event or logger name. This is automatically set for errors.
- Classification This is a user settable property that controls how the events are grouped. Defaults to 'Issue'. Set this to a different value to group this event in a different group.
- Event User This is the user that is associated with this event. This can be any user data or could be encrypted if privacy is required.
- Event Session This is any session specific information associated with this event.
- Cross App Correlation ID This is an additional ID that can be used for cross-application correlation of the same event.
- Operation Time This property in milliseconds measures the operation time for this specific event.
In addition to the above, you can use custom properties and segments to send custom event, performance data. These can then be visualized in Trakerr's dashboards.
- Java 1.7+
- log4j 1.2 (if you want to use our log4j functionality)
This is a combination of using maven and log4j. This guide assumes you have log4j set up. If this is your first time setting up log4j check out the log4j docs. Note: our plugin is for log4j 1.2, although you may or may not be able to get it to work with log4j 2. A plugin for log4j 2 is planned for a future release.
Add us as a dependancy to your project's maven pom:
<dependency>
<groupId>io.trakerr</groupId>
<artifactId>trakerr-java-client</artifactId>
<version>1.1.0</version>
<scope>compile</scope>
</dependency>
Add a log4j appender as shown below to your log4j.properties
log4j.rootLogger=WARN, trakerr
log4j.appender.trakerr=io.trakerr.client.TrakerrAppender
#log4j.appender.trakerr.url=https://trakerr.io/api/v1
log4j.appender.trakerr.apiKey=<api-key>
log4j.appender.trakerr.appVersion=1.0
log4j.appender.trakerr.stage=development
#log4j.appender.trakerr.stage=production
#log4j.appender.trakerr.stage=test
log4j.appender.trakerr.enabled=true
log4j.appender.trakerr.useAsync=true
You can instead append it to a specific derivative logger, rather than root:
log4j.logger.mylogger=DEBUG, trakerr
log4j.appender.trakerr=io.trakerr.client.TrakerrAppender
...
And you can use the following to change the logging threshold of the logger:
log4j.appender.stdout.Threshold=WARN
Once installed any logging that is WARN or above gets logged. You are free to modify the logging levels or or other attributes as per your requirements.
There are a few options to send exceptions and other events to Trakerr manually. This offers you a greater degree of control than using log4j.
Install the Maven client dependency as above.
Use the guide above for configuring log4j.
Sending an exception programmatically requires a TrakerrClient to send the error to Trakerr. The example below illustrates how to do this. Import:
import io.trakerr.client.*;
Then you can simply catch an exception like so:
TrakerrClient client = new TrakerrClient("<api-key>", "1.0", "development");
try {
throw new Exception("This is a test exception.");
} catch (Exception e) {
// First argument is the classification ("Error", "Warn" etc.), you can also pass a custom classification if required
//client.sendException("Error", e); For a syncronous call
client.sendExceptionAsync(AppEvent.LogLevelEnum.WARNING, null, e, null);
}
For any asyncronous call the threadpool and connection pool limits are set to 5.
Sending an exception programmatically requires a TrakerrClient to send the error to Trakerr. The example below illustrates how to do this.
You'll need to import AppEvent to modify the app event, and all the properties inside of it. The other two imprts are for capturing the exception and response, if you wish:
import io.trakerr.client.*;
import io.trakerr.ApiException;
import io.trakerr.ApiResponse;
import io.trakerr.model.AppEvent;
If you would like to add custom parameters, you'll also need to import this. Afterwards, you can create your own app event:
TrakerrClient client = new TrakerrClient("<api-key>", "1.0", "development");
try {
throw new Exception("This is a test exception.");
} catch (Exception e) {
// First argument is the classification ("Error", "Warn" etc.), you can also pass a custom classification if required
AppEvent exceptionEvent = client.createAppEventFromException("Error", e);
CustomData customProperties = new CustomData();
CustomStringData stringData = new CustomStringData();
stringData.customData1("Some custom data");
customProperties.setStringData(stringData);
exceptionEvent.setCustomProperties(customProperties);
// send the event
try {
client.sendEventAsync(errevnt,null);
} catch (ApiException senderr) {
senderr.printStackTrace();
}
}
createAppEvent's signature is as follows:
public AppEvent createAppEvent(AppEvent.LogLevelEnum logLevel, String classification, String eventType, String eventMessage)
public AppEvent createAppEvent(AppEvent.LogLevelEnum logLevel, String classification, Throwable t)
logLevel enum is the level of the event defaulting to error, classification is string specification of the level and defaults to issue. Throwable t is interface that exceptions classes need to implement and what we can extract the type and message of the exception out of. Otherwise, you may pass in the event and message.
You can send non-errors or user events to Trakerr. If you do, we suggest that you provide an event name and message, along with populating the user and session fields at the very least. Use these imports:
import io.trakerr.client.*;
import io.trakerr.ApiException;
import io.trakerr.ApiResponse;
And then simply send the error. You may omit imports and the exception handling if you don't wish it.
TrakerrClient client = new TrakerrClient("<api-key>", "1.0", "development");
AppEvent event = client.createAppEvent("debug", "foo", "bar");
try {
client.sendEventAsync(event, null);
} catch (ApiException e) {
e.printStackTrace();
}
The TrakerrClient
class above can be constructed to take aditional data, rather than using the configured defaults. The constructor signature is:
public TrakerrClient(String apiKey, String contextAppVersion, String contextDeployementStage)
and
public TrakerrClient(String apiKey, String contextAppVersion, String contextDevelopmentStage, String contextAppSKU, List<String> contextTags)
The TrakerrClient module has a lot of exposed properties. The benefit to setting these immediately after after you create the TrakerrClient is that AppEvent will default it's values against the TrakerClient that created it. This way if there is a value that all your AppEvents uses, and the constructor default value currently doesn't suit you; it may be easier to change it in TrakerrClient as it will become the default value for all AppEvents created after. A lot of these are populated by default value by the constructor, but you can populate them with whatever string data you want. The following table provides an in depth look at each of those.
If you're populating an app event directly, you'll want to take a look at the AppEvent properties as they contain properties unique to each AppEvent which do not have defaults you may set in the client.
Name | Type | Description | Notes |
---|---|---|---|
apiKey | string | API Key for your application. | Defaults to reading "trakerr.apiKey" property under log4j.properties for log4j errors only. |
contextAppVersion | string | Provide the application version. | Defaults to reading "trakerr.contextAppVersion" property under log4j.properties for log4j errors only. |
contextDevelopmentStage | string | One of development, staging, production; or a custom string. | Default Value: trakerr.stage under log4j.properties log4j errors or "development" if not provided. |
contextEnvLanguage | string | Constant string representing the language the application is in. | Default value: "java" . |
contextEnvName | string | Name of the CLR the program is running on | Defaults to System.getProperty("java.vendor") . |
contextEnvVersion | string | Provide an environment version. | Defaults to System.getProperty("java.version") . |
contextEnvHostname | string | Provide the current hostname. | Defaults to InetAddress.getLocalHost().getHostName() . |
contextAppOS | string | Provide an operating system name. | Defaults to System.getProperty("os.name") . |
contextAppOSVersion | string | Provide an operating system version. | Defaults to System.getProperty("os.version") . |
contextAppOSBrowser | string | An optional string browser name the application is running on. | Defaults to null |
contextAppOSBrowserVersion | string | An optional string browser version the application is running on. | Defaults to null |
contextDataCenter | string | Data center the application is running on or connected to. | Defaults to null |
contextDataCenterRegion | string | Data center region. | Defaults to null |
contextTags | List | Array of string tags you can use to tag your components for searching., | Defaults to null |
contextAppSKU | string | Application SKU. | Defaults to null |