Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ineat/ineat-spring-boot-starter
Provides a set of utilities configurations for spring-boot
https://github.com/ineat/ineat-spring-boot-starter
Last synced: 6 days ago
JSON representation
Provides a set of utilities configurations for spring-boot
- Host: GitHub
- URL: https://github.com/ineat/ineat-spring-boot-starter
- Owner: ineat
- Created: 2018-01-26T09:05:38.000Z (almost 7 years ago)
- Default Branch: develop
- Last Pushed: 2018-02-23T16:08:08.000Z (almost 7 years ago)
- Last Synced: 2024-11-07T11:44:25.669Z (about 2 months ago)
- Language: Java
- Size: 246 KB
- Stars: 3
- Watchers: 9
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Ineat Lab Spring Boot Starter
Set of AutoConfigurations for spring-boot[![Maven Central](https://maven-badges.herokuapp.com/maven-central/com.ineat-group.lab/ineat-spring-boot-starter/badge.svg)](https://maven-badges.herokuapp.com/maven-central/com.google.guava/guava)
![quality](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=alert_status
)> ![coverage](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=coverage)
![bugs](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=bugs)
![code_smells](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=code_smells)
![duplicated_lines_density](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=duplicated_lines_density)
![ncloc](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=ncloc)
![vulnerabilities](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=vulnerabilities)
![reliability_rating](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=reliability_rating)
![security_rating](https://sonarcloud.io/api/project_badges/measure?project=com.ineat-group.lab%3Aineat-spring-boot-starter&metric=security_rating)
## Why ?The main idea of this library is to provide a set of Spring Boot AutoConfigurations for commons needs in business
applications developments.
## How to use this starterThe Maven group ID is `com.ineat-group.lab`, and the artifact ID is `ineat-spring-boot-starter`.
To add a dependency using Maven, use the following:
```xml
com.ineat-group.lab
ineat-spring-boot-starter
LATEST```
To add a dependency using Gradle:
```
dependencies {
compile 'com.ineat-group.lab:ineat-spring-boot-starter:+'
}
```## List of available auto-configurations
> You can see all our available configurations in your favorite IDE by taping `ineat.` and using the auto-completion (ctrl + space)
> into your application.yaml/properties :
> ![configurations](src/docs/assets/monitoring_properties.png)### Monitoring
Inspired by [Baeldung spring-performance-logging article](http://www.baeldung.com/spring-performance-logging), this
starter provides a fast way to register* a [Simple Trace Interceptor](https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/aop/interceptor/SimpleTraceInterceptor.html)
to log in `TRACE` level each method invocation
* a [Performance Interceptor](https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/aop/interceptor/PerformanceMonitorInterceptor.html)
to log **method execution delay** (usefull for example to monitoring your method execution time !)**IMPORTANT** : Because of these interceptors logs at `TRACE` level, you need to set your spring `logging.level` property to
`TRACE` :```yaml
logging:
level:
com.ineat.lab.sample: TRACE```
```yaml
logging:
level:
com.ineat.lab.sample: TRACE
ineat:
monitoring:
trace:
enabled: true # easily use, or not the interceptor
pointcut-expression: execution(* com.ineat.lab.sample.**(..)) # set the pointcut expression according to AspectJ pointcut pattern```
Result on logs :
```
2018-02-01 15:37:46.882 TRACE 3480 --- [nio-8080-exec-1] c.i.l.s.DemoApplication$SampleController : Entering method 'test' of class [com.ineat.lab.sample.DemoApplication$SampleController]
2018-02-01 15:37:46.884 TRACE 3480 --- [nio-8080-exec-1] c.i.l.s.DemoApplication$SampleController : Exiting method 'test' of class [com.ineat.lab.sample.DemoApplication$SampleController]```
#### PerformanceMonitorInterceptor```yaml
ineat:
monitoring:
performance:
enabled: true # easily use, or not the interceptor
pointcut-expression: execution(* com.ineat.lab.sample.*.*(..)) # set the pointcut expression according to AspectJ pointcut pattern
```Result on logs :
```
2018-02-01 15:39:29.975 TRACE 3480 --- [nio-8080-exec-1] c.i.l.s.DemoApplication$SampleController : StopWatch 'com.ineat.lab.sample.DemoApplication$SampleController.test': running time (millis) = 3```
## Want to contribute ?
If you uses our starter-kit and you want to contribute by adding others commons use-cases/needs auto-configuration for
spring-boot, send us a pull request with an explanation of your feature.