| This version is still in development and is not considered stable yet. For the latest stable version, please use Spring Modulith 1.4.4! | 
Appendix
Appendix A: Spring Boot Compatibility
| Spring Modulith Version | Spring Boot Version (compiled against) | Spring Boot Version (examples tested against) | jMolecules (compiled) | jMolecules (tested) | 
|---|---|---|---|---|
| 1.4 (snapshot) | 3.4 | 3.1, 3.2, 3.3, 3.4 | 2023.2 | 2023.2, 2025.0 RC2 | 
| 1.3 | 3.4 | 3.1, 3.2, 3.3, 3.4 | 2023.1 | 2023.1, 2023.2, 2025.0 RC2 | 
| 1.2 | 3.3 | 3.1, 3.2, 3.3, 3.4 | 2023.1 | 2023.1, 2023.2, 2025.0 RC2 | 
| 1.1 | 3.2 | 3.1, 3.2, 3.3, 3.4 | 2023.1 | 2023.1, 2023.2, 2025.0 RC2 | 
Appendix B: Spring Modulith Configuration Properties
| Property | Default value | Description | 
|---|---|---|
| 
 | 
 | Whether to configure defaults for the async processing termination, namely to wait for task completion for 2 seconds. See  | 
| 
 | 
 | Whether to enable event externalization. | 
| 
 | 
 | Whether to initialize the JDBC event publication schema. | 
| 
 | 
 | Whether to enable JSON support for  | 
| 
 | 
 | Whether to automatically enable transactions for MongoDB. Requires the database to be run with a replica set. | 
| 
 | 
 | Whether to create indexes on the . | 
| 
 | 
 | Whether to enable JSON support for  | 
| 
 | 
 | Whether to enable the  | 
| 
 | 
 | The granularity of events to publish. ( | 
| 
 | 
 | The  | 
| 
 | 
 | The timezone of the dates for the events being published. | 
| 
 | 
 | Whether to republish outstanding event publications on restarts of the application. Usually not recommended in multi-instance deployments as other instances might still be processing events. | 
Appendix C: Spring Modulith modules
| Starter | Typical scope | Includes | 
|---|---|---|
| 
 | 
 | 
 | 
| 
 | 
 | 
 | 
| 
 | 
 | 
 | 
| 
 | 
 | 
 | 
| 
 | 
 | 
 | 
| 
 | 
 | 
 | 
| 
 | 
 | 
 | 
| Module | Typical scope | Description | 
|---|---|---|
| 
 | 
 | A Spring Boot actuator to expose the application module structure via an actuator. | 
| 
 | 
 | The abstractions to be used in your production code to customize Spring Modulith’s default behavior. | 
| 
 | 
 | The core application module model and API. | 
| 
 | 
 | The  | 
| 
 | 
 | Event externalization support for AMQP. | 
| 
 | 
 | API to customize the event features of Spring Modulith. | 
| 
 | 
 | The core implementation of the event publication registry as well as the integration abstractions  | 
| 
 | 
 | A Jackson-based implementation of the  | 
| 
 | 
 | A JDBC-based implementation of the  | 
| 
 | 
 | Event externalization support for JMS. | 
| 
 | 
 | A JPA-based implementation of the  | 
| 
 | 
 | Event externalization support for Kafka. | 
| 
 | 
 | A MongoDB-based implementation of the  | 
| 
 | 
 | A Neo4j-based implementation of the  | 
| 
 | 
 | Test execution optimizations based on the application module structure. Find more details here. | 
| 
 | 
 | The Passage of Time events implementation described here. | 
| 
 | 
 | Observability infrastructure described here. | 
| 
 | 
 | Support to bootstrap an  | 
| 
 | 
 | Integration testing support. Find more details here. | 
Appendix D: Event publication registry schemas
The JDBC-based event publication registry support expects the following database schemas to be present in the database.
If you would like Spring Modulith to create the schema for you, set the application property spring.modulith.events.jdbc-schema-initialization.enabled to true.
H2
CREATE TABLE IF NOT EXISTS EVENT_PUBLICATION
(
  ID               UUID NOT NULL,
  COMPLETION_DATE  TIMESTAMP(9) WITH TIME ZONE,
  EVENT_TYPE       VARCHAR(512) NOT NULL,
  LISTENER_ID      VARCHAR(512) NOT NULL,
  PUBLICATION_DATE TIMESTAMP(9) WITH TIME ZONE NOT NULL,
  SERIALIZED_EVENT VARCHAR(4000) NOT NULL,
  PRIMARY KEY (ID)
)HSQLDB
CREATE TABLE IF NOT EXISTS EVENT_PUBLICATION
(
  ID               UUID NOT NULL,
  COMPLETION_DATE  TIMESTAMP(9),
  EVENT_TYPE       VARCHAR(512) NOT NULL,
  LISTENER_ID      VARCHAR(512) NOT NULL,
  PUBLICATION_DATE TIMESTAMP(9) NOT NULL,
  SERIALIZED_EVENT VARCHAR(4000) NOT NULL,
  PRIMARY KEY (ID)
)Appendix E: Migrating from Moduliths
- 
o.m.model.Moduleshas been renamed too.s.m.model.ApplicationModules
- 
o.m.model.ModuleDetectionStrategyhas been renamed too.s.m.model.ApplicationModuleDetectionStrategy
- 
@o.m.test.ModuleTesthas been renamed to@o.s.m.test.ApplicationModuleTest
- 
o.m.docs.Documenter.Optionshas been renamed too.s.m.docs.Documenter.DiagramOptions
- 
The diagram style of component diagrams now defaults to DiagramStyle.C4(override by callingDiagramOptions.withStyle(DiagramStyle.UML))
- 
The module canvas hides non exposed types by default. To include application-module-internal types in the canvas, configure CanvasOptionsto….revealInternals().
- 
The output folder for component diagrams and application module canvases has moved from moduliths-docstospring-modulith-docslocated in your build’s target folder (such astargetfor Maven).