Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/claudioaltamura/spring-boot-structured-logging
Structured Logging example with Spring Boot 3.4!
https://github.com/claudioaltamura/spring-boot-structured-logging
github-actions gradle spring-boot structured-logging
Last synced: about 1 month ago
JSON representation
Structured Logging example with Spring Boot 3.4!
- Host: GitHub
- URL: https://github.com/claudioaltamura/spring-boot-structured-logging
- Owner: claudioaltamura
- License: mit
- Created: 2024-08-29T12:57:31.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-09-06T15:22:34.000Z (5 months ago)
- Last Synced: 2024-11-02T03:23:53.682Z (3 months ago)
- Topics: github-actions, gradle, spring-boot, structured-logging
- Language: Java
- Homepage:
- Size: 53.7 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![GitHub Workflow Status (with branch)](https://img.shields.io/github/actions/workflow/status/claudioaltamura/spring-boot-structured-logging/ci.yml?branch=main)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
# π Structured Logging with Spring Boot 3.4
Welcome to the **Structured Logging** example with Spring Boot 3.4! π
This project demonstrates how to enable and configure structured logging in a Spring Boot application, making your logs more readable, searchable, and usable in modern observability tools.
## π Getting Started
With the release of Spring Boot 3.4, enabling structured logging is easier than ever. This repository provides examples and configurations inspired by the official [Spring Blog](https://spring.io/blog/2024/08/23/structured-logging-in-spring-boot-3-4) and the [Baeldung article on Java Structured Logging](https://www.baeldung.com/java-structured-logging).
## β¨ Spring Boot Structured Logging Key Features
- Enable structured logging with simple application properties.
- Choose between different structured logging formats such as ECS (Elastic Common Schema) or Logstash.
- Implement your own formatters for custom log output.## π οΈ How to Run
Clone this repository and run the application using:```bash
./gradlew bootRun
```## π Viewing Logs
Depending on your configuration:```
Console Logs: View in your terminal or IDE console.
File Logs: Check the output file log.json in your project directory.
```## βοΈ Configuration Options
Here are some of the configuration options you can try in your `application.properties` file:
```properties
//logging.structured.format.console=logstash
//logging.structured.format.file=logstash
//logging.file.name=log.json
//logging.structured.format.console=de.claudioaltamura.spring_boot_structured_logging.MyStructuredLoggingFormatter
//logging.structured.format.console=de.claudioaltamura.spring_boot_structured_logging.MyStructuredLoggingFormatterJson
```
1. This configuration will format console logs in the Logstash format, suitable for ingestion by Logstash or other tools that support the Logstash format.
2. This configuration will format file logs in the Logstash format.
3. These settings will format logs in the Logstash format and write them to a file named log.json.
4. Use a custom formatter class for console logging. Replace MyStructuredLoggingFormatter with your own implementation.
5. This configuration uses a custom JSON formatter for console logs, offering full control over the structure and content of your log messages.## π‘Examples
logstash
```
{"@timestamp":"2024-09-06T10:45:47.566949+02:00","@version":"1","message":"Hello structured logging!","logger_name":"de.claudioaltamura.spring_boot_structured_logging.MyLogger","thread_name":"main","level":"INFO","level_value":20000,"userId":"1"}
```
ecs
```
{"@timestamp":"2024-09-06T10:46:37.390982Z","log.level":"INFO","process.pid":9954,"process.thread.name":"main","service.name":"spring-boot-structured-logging","log.logger":"de.claudioaltamura.spring_boot_structured_logging.MyLogger","message":"Hello structured logging!","userId":"1","ecs.version":"8.11"}
```## π Resources
[Spring Blog: Structured Logging in Spring Boot 3.4](https://spring.io/blog/2024/08/23/structured-logging-in-spring-boot-3-4)[Baeldung: Java Structured Logging](https://www.baeldung.com/java-structured-logging)
## π€ Contributing
Feel free to submit pull requests or raise issues to improve this example project. Contributions are always welcome!