more info about caching (Caffeine) and logging

This commit is contained in:
Gavin 2023-05-20 18:27:26 +02:00 committed by Christian Beikov
parent 8518854524
commit e34e08b918
2 changed files with 65 additions and 25 deletions

View File

@ -57,7 +57,7 @@ You'll also need to add a dependency for the JDBC
driver for your database. driver for your database.
.JDBC driver dependencies .JDBC driver dependencies
[cols="40,~"] [cols="50,~"]
|=== |===
| Database | Driver dependency | Database | Driver dependency
@ -85,22 +85,34 @@ Where `{version}` is the latest version of the JDBC driver for your databse.
:ehcache: https://www.ehcache.org :ehcache: https://www.ehcache.org
:infinispan: https://infinispan.org :infinispan: https://infinispan.org
:generator: https://hibernate.org/orm/tooling/ :generator: https://hibernate.org/orm/tooling/
:caffeine: https://github.com/ben-manes/caffeine/
Optionally, you might also add any of the following additional features: Optionally, you might also add any of the following additional features:
.Optional dependencies .Optional dependencies
[cols="40,~"] [cols="50,~"]
|=== |===
| Optional feature | Dependencies | Optional feature | Dependencies
| An {slf4j}[SLF4J] logging implementation | `org.apache.logging.log4j:log4j-core` or `org.slf4j:slf4j-jdk14` | An {slf4j}[SLF4J] logging implementation |
| A JDBC connection pool, for example, {agroal}[Agroal] | `org.hibernate.orm:hibernate-agroal` and `io.agroal:agroal-pool` `org.apache.logging.log4j:log4j-core` +
or `org.slf4j:slf4j-jdk14`
| A JDBC connection pool, for example, {agroal}[Agroal] |
`org.hibernate.orm:hibernate-agroal` +
and `io.agroal:agroal-pool`
| The {generator}[Hibernate Metamodel Generator], especially if you're using the JPA criteria query API | `org.hibernate.orm:hibernate-jpamodelgen` | The {generator}[Hibernate Metamodel Generator], especially if you're using the JPA criteria query API | `org.hibernate.orm:hibernate-jpamodelgen`
| {validator}[Hibernate Validator] | `org.hibernate.validator:hibernate-validator` and `org.glassfish:jakarta.el` | {validator}[Hibernate Validator] |
| Local second-level cache support via JCache and {ehcache}[EHCache] | `org.hibernate.orm:hibernate-jcache` along with `org.ehcache:ehcache` `org.hibernate.validator:hibernate-validator` +
and `org.glassfish:jakarta.el`
| Local second-level cache support via JCache and {ehcache}[EHCache] | `org.hibernate.orm:hibernate-jcache` +
and `org.ehcache:ehcache`
| Local second-level cache support via JCache and {caffeine}[Caffeine]| `org.hibernate.orm:hibernate-jcache` +
and `com.github.ben-manes.caffeine:jcache`
| Distributed second-level cache support via {infinispan}[Infinispan] | `org.infinispan:infinispan-hibernate-cache-v60` | Distributed second-level cache support via {infinispan}[Infinispan] | `org.infinispan:infinispan-hibernate-cache-v60`
// | SCRAM authentication support for PostgreSQL | `com.ongres.scram:client:2.1` // | SCRAM authentication support for PostgreSQL | `com.ongres.scram:client:2.1`
| A JSON serialization library for working with JSON datatypes, for example, {jackson}[Jackson] or {yasson}[Yasson] | `com.fasterxml.jackson.core:jackson-databind` or `org.eclipse:yasson` | A JSON serialization library for working with JSON datatypes, for example, {jackson}[Jackson] or {yasson}[Yasson] |
`com.fasterxml.jackson.core:jackson-databind` +
or `org.eclipse:yasson`
| <<spatial,Hibernate Spatial>> | `org.hibernate.orm:hibernate-spatial` | <<spatial,Hibernate Spatial>> | `org.hibernate.orm:hibernate-spatial`
|=== |===
@ -368,20 +380,11 @@ sessionFactory.getSchemaManager().exportMappedObjects(true);
:log4j: https://github.com/hibernate/hibernate-reactive/blob/main/examples/session-example/src/main/resources/log4j2.properties :log4j: https://github.com/hibernate/hibernate-reactive/blob/main/examples/session-example/src/main/resources/log4j2.properties
To see the generated SQL as it's sent to the database, either: To see the generated SQL as it's sent to the database, you have two options.
- set the property `hibernate.show_sql` to `true`, or One way is to set the property `hibernate.show_sql` to `true`, and Hibernate will log SQL direct to the console.
- enable debug-level logging for the category `org.hibernate.SQL` using your preferred SLF4J logging implementation. You can make the output much more readable by enabling formatting or highlighting.
These settings really help when troubleshooting the generated SQL statements.
For example, if you're using Log4J 2 (as above in <<optional-dependencies>>), add these lines to your `log4j2.properties` file:
[source,properties]
----
logger.hibernate.name = org.hibernate.SQL
logger.hibernate.level = debug
----
You can make the SQL logged to the console more readable by enabling formatting or highlighting.
.Settings for SQL logging to the console .Settings for SQL logging to the console
[cols="35,~"] [cols="35,~"]
@ -393,7 +396,26 @@ You can make the SQL logged to the console more readable by enabling formatting
| `hibernate.highlight_sql` | If `true`, log SQL with syntax highlighting via ANSI escape codes | `hibernate.highlight_sql` | If `true`, log SQL with syntax highlighting via ANSI escape codes
|=== |===
These settings can really help when troubleshooting SQL. Alternatively, you can enable debug-level logging for the category `org.hibernate.SQL` using your preferred SLF4J logging implementation.
For example, if you're using Log4J 2 (as above in <<optional-dependencies>>), add these lines to your `log4j2.properties` file:
[source,properties]
----
# SQL execution
logger.hibernate.name = org.hibernate.SQL
logger.hibernate.level = debug
# JDBC parameter binding
logger.jdbc-bind.name=org.hibernate.orm.jdbc.bind
logger.jdbc-bind.level=trace
# JDBC result set extraction
logger.jdbc-extract.name=org.hibernate.orm.jdbc.extract
logger.jdbc-extract.level=trace
----
But with this approach we miss out on the pretty highlighting.
[[minimizing]] [[minimizing]]
=== Minimizing repetitive mapping information === Minimizing repetitive mapping information

View File

@ -329,13 +329,12 @@ But in case it helps, we often test Hibernate with the following configuration,
:ehcache-config: https://www.ehcache.org/documentation/ :ehcache-config: https://www.ehcache.org/documentation/
.EHCache provider configuration .EHCache configuration
[cols="35,~"] [cols="35,~"]
|=== |===
| Configuration property name | Property value | Configuration property name | Property value
| `hibernate.cache.region.factory_class` | `jcache` | `hibernate.cache.region.factory_class` | `jcache`
| `hibernate.javax.cache.provider` | `org.ehcache.jsr107.EhcacheCachingProvider`
| `hibernate.javax.cache.uri` | `/ehcache.xml` | `hibernate.javax.cache.uri` | `/ehcache.xml`
|=== |===
@ -344,6 +343,25 @@ that explicitly configures the behavior of each cache region belonging to
your entities and collections. your entities and collections.
You'll find more information about configuring EHCache {ehcache-config}[here]. You'll find more information about configuring EHCache {ehcache-config}[here].
:caffeine: https://github.com/ben-manes/caffeine/
We may use any other implementation of JCache, such as {caffeine}[Caffeine].
JCache automatically selects whichever implementation it finds on the classpath.
If there are multiple implementations on the classpath, we must disambiguate using:
.Disambiguating the JCache implementation
[cols="35,~"]
|===
| Configuration property name | Property value
| `hibernate.javax.cache.provider` a| The implementation of `javax.cache.spiCachingProvider`, for example:
[cols="~,20"]
!===
! `org.ehcache.jsr107.EhcacheCachingProvider` ! for EHCache
! `com.github.benmanes.caffeine.jcache.spi.CaffeineCachingProvider` ! for Caffeine
!===
|===
Alternatively, to use Infinispan as the cache implementation, the following settings are required: Alternatively, to use Infinispan as the cache implementation, the following settings are required:
:infinispan-hibernate: https://infinispan.org/docs/stable/titles/hibernate/hibernate.html :infinispan-hibernate: https://infinispan.org/docs/stable/titles/hibernate/hibernate.html
@ -365,7 +383,7 @@ Alternatively, to use Infinispan as the cache implementation, the following sett
|=== |===
Infinispan is usually used when distributed caching is required. Infinispan is usually used when distributed caching is required.
You'll find more information about using Infinispan with Hibernate {infinispan-hibernate}[here] . There's more about using Infinispan with Hibernate {infinispan-hibernate}[here].
Finally, there's a way to globally disable the second-level cache: Finally, there's a way to globally disable the second-level cache: