Skip to content

Library for common logging approach for java application

License

Notifications You must be signed in to change notification settings

hmcts/java-logging

Repository files navigation

GitHub version JitPack Badge Known Vulnerabilities

Java logging

A Java module which standardises the logging for the reform projects.

Prerequisites

User guide

The module provides a logback.xml configuration file which configures Logback to use a default reform format. It allows a number of configuration options to customize the logging to your needs.

Basic usage

Simply add base component as your project's dependency and then one or more of three components discussed below to use it.

Base component dependency, gradle:

implementation group: 'com.github.hmcts.java-logging', name: 'logging', version: '6.1.2'

java-logging-insights

Use for automatic configuration of Azure Application Insights for a Spring Boot project. Read more

Configuration defaults

By default the module will use a simple, human-friendly logging format which can be used out-of-the-box for development:

2017-02-02 12:22:23,647 INFO [main] io.dropwizard.assets.AssetsBundle: Registering AssetBundle with name: swagger-assets for path /swagger-static/*
2017-02-02 12:22:23,806 INFO [main] org.reflections.Reflections: Reflections took 96 ms to scan 1 urls, producing 79 keys and 87 values
2017-02-02 12:22:24,835 INFO [main] io.dropwizard.server.DefaultServerFactory: Registering jersey handler with root path prefix: /

Root logging level will be set to INFO. It can be adjusted by setting a ROOT_LOGGING_LEVEL environment variable.

Additional Logback configuration:

Additional Logback configuration can be provided by adding a logback-includes.xml file to the classpath root (just drop it in the main/resources folder). This allows to define any configuration allowed by Logback XML config, where a typical usage could be defining more specific loggers, e.g.:

<?xml version="1.0" encoding="UTF-8"?>
<included>
  <logger name="uk.goc.hmcts.reform" level="DEBUG"/>
  <logger name="uk.goc.hmcts.reform.resources" level="WARN"/>
</included>

Path to this file can adjusted by setting a LOGBACK_INCLUDES_FILE environment variable.

Logback can print additional information while processing its configuration files. This can be enabled by setting LOGBACK_CONFIGURATION_DEBUG variable to true.

Log pattern related configurations:

variable default
LOGBACK_DATE_FORMAT yyyy-MM-dd'T'HH:mm:ss.SSSZZ
EXCEPTION_LENGTH 50
LOGGER_LENGTH 50
CONSOLE_LOG_PATTERN %d{${LOGBACK_DATE_FORMAT}} %-5level [%thread] %logger{${LOGGER_LENGTH}}%ex{${EXCEPTION_LENGTH}} %msg%n}

where

  • LOGBACK_DATE_FORMAT: Date format is default logstash encoder date format. REQUIRE fields are flags representing show/hide feature.
  • EXCEPTION_LENGTH: how many lines to show in an exception stack trace ( per exception not including causes)
  • LOGGER_LENGTH: how long the logger name can be before logback starts abbreviating the package names

Development guide

Gradle wrapper will automatically download a project-local Gradle distribution the first time you run any of the gradlew commands below.

Tests and verification

To run all unit tests:

./gradlew test

To execute Checkstyle and PMD checks:

./gradlew check

You can also execute both via:

./gradlew build

Installing

To install the artifact to a local Maven repository:

./gradlew install

Releasing

Before releasing a new version create a PR and run the following script to update the README to use the new version number.

./prepare-for-release.sh

To publish a new release create a new release via the GitHub UI. The tag selected will be used as the version number.