Provides annotations to avoid writing a ton of boilerplate code.
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
// class level annotations
@Data // generate getter setters for all fields
@Builder // Builder pattern
@AllArgsConstructor // constructor with all args
@NoArgsConstructor // constructor with no args
@Slf4j // logs (slf4j log)
@CommonsLog // same as above (but for Apache commons log)
@Log // same as above (but for java.util log)
@Generated // to mark the component as generated; excepted from coverage checks
@ToString // generates toString() for the class
@EqualsAndHashCode // generates hashcode() and equals() for fields of class
@Value // make immutable class (diff from Spring's @Value used to read properties)
// all fields are made private and final by default, and setters are not generated
@SneakyThrows // throw any checked exception without declaring it! (no compiler-error)
// field level annotations
@Getter // generate getter for the field
@Setter // generate setter for the field
// specify access modifier
@Getter(AccessLevel.PRIVATE) // PUBLIC, PROTECTED, PACKAGE, or NONE (disable)
String empName;
Reference: https://projectlombok.org/features/all
In the order of popularity:
Database migration (schema change management) tool. In simple words - a version control for DB schema changes. Vendor-agnostic (since we can write in XML, JSON, YAML) unlike Flyway (which only allows .sql
files).
liquibase.properties
)application.properties
)When we deploy our changes, Liquibase creates two tables in the database: DATABASECHANGELOG
and DATABASECHANGELOGLOCK
. The former stores detailed logs (id, author, desc, MD5 hash, changeset file name etc) and the latter ensures that only one instance of Liquibase is updating the database.
Each changelog file can contain multiple changesets (SQL queries or equivalent). We can have multiple changelog files as well in a hierarchy that makes sense to our use case.
/example/
changelog-foo.xml
changelog-bar.xml
Write changesets in changelog files in SQL, XML, JSON, or YAML. Example below shows changelog-foo.xml
:
<include file="com/example/changelog-bar.xml"/>
<changeSet author="your.name" id="4">
<addColumn tableName="person">
<column name="nickname" type="varchar(30)"/>
</addColumn>
</changeSet>
The optional <include>
tag will make sure that Liquibase runs changelog-bar.xml
first. Used to break down a big file into multiple smaller ones.
Must specify the root changelog file to run using Spring application.properties
(shown below) or in liquibase.properties
file (if using CLI client):
spring.liquibase.change-log=classpath:changelog-foo.xml
Liquibase will not run any changeset found to be exactly matching the schema in the database. Uses checksum of current changeset and data stored in DATABASECHANGELOG
table to detect redundancies. Any error or ambiguity causes error in the console.
References:
Library that:
It is like the opposite of ORMs like Hibernate, where we write code first and then represent DB schema with entity classes, after that database is created or modified. With Jooq, database is existing and we generate Java code using its schema.
When querying, Jooq DSL checks types at compile-time unlike JPQL in JPA.
Jooq works much “closely” to SQL and the DB vendor’s dialect, so the reason to use Jooq is to leverage the full power of the database underneath, unlike JPA where the goal is to abstract as much database specific details as possible.
Besides building and fetching simple SQL queries, we can also fetch associations i.e. data from One-to-One, One-to-Many, and Many-to-Many relations using a single query.
References:
A web framework that allows to write UI code in pure Java! Based on Web Component standard like React, Angular, etc.
Vaadin offers many other tools too such as Hilla.
Hilla API: Integrates Spring Boot Java backends with reactive frontends implemented in TypeScript. Call Java service code directly from UI code in the browser!
References:
We usually don’t change the version in the pom.xml
in local project but install Maven plugin on the CI system (e.g Jenkins) to inject a version number before final build mvn install
. We can then make code changes and commit (send to CI for build) without worrying about versioning.
jgitver is one such plugin that performs automatic semantic versioning using git tags, commits, and branches.
Upon mvn install
, jgitver calculates the new version and writes it to the version info POM inside the generated JAR, and all other relevant spots. The pom.xml
version tag is a dummy in this case and isn’t edited at all!
Add to CI pipeline Maven as an extension plugin, or in Gradle as a dependency. Use mvn validate
to check version calculation.
Maven provides maven:release
goals for this purpose which edits pom.xml
and make a commit afterwards leading to git history pollution.
Link: https://jgitver.github.io
Demo: https://youtu.be/v5Kj0oZO-HM
Maven CI Friendly Versions: https://maven.apache.org/maven-ci-friendly.html
Sonarqube - code best practices, test coverage, etc
Veracode - OWASP security vulnerability
Twistlock - Docker container vulnerability
Snyk - OWASP security vulnerability
AppDynamics - performance monitoring