Trong bài viết trước, mình đã hướng dẫn các bạn cấu hình Flyway với ứng dụng Spring Boot sử dụng Spring Data JDBC. Nếu ứng dụng Spring Boot của các bạn đang sử dụng Spring Data R2DBC thì Flyway sẽ không work.
Ví dụ mình có một Spring Boot project với Flyway, Spring Data R2DBC Starter, R2DBC PostgreSQL dependencies như sau:
Mình sẽ khai báo lại cấu hình như mình đã làm trong bài viết Sử dụng Flyway trong Spring Boot, bao gồm:
- Tập tin SQL V2023.07.09.00000__Init.sql nằm trong thư mục src/main/resources/db/migration với nội dung như sau:
1 2 3 4 |
CREATE TABLE student ( ID INT PRIMARY KEY, name VARCHAR(250) NOT NULL ); |
- Cấu hình datasource trong tập tin application.properties:
1 2 3 |
spring.datasource.url=jdbc:postgresql://localhost:5432/flyway_example spring.datasource.username=khanh spring.datasource.password=1 |
- Và cấu hình database cho Spring Data R2DBC nữa:
1 2 3 |
spring.r2dbc.url=r2dbc:postgresql://localhost:5432/flyway_example spring.r2dbc.username=khanh spring.r2dbc.password=1 |
Lúc này, nếu các bạn chạy ứng dụng, các bạn sẽ thấy Flyway không hoạt động.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
/Library/Java/JavaVirtualMachines/jdk-17.jdk/Contents/Home/bin/java -javaagent:/Applications/IntelliJ IDEA CE.app/Contents/lib/idea_rt.jar=53801:/Applications/IntelliJ IDEA CE.app/Contents/bin -Dfile.encoding=UTF-8 -classpath /Users/khanh/Documents/code/huongdanjava.com/spring-boot-flyway-spring-data-r2dbc-example/target/classes:/Users/khanh/.m2/repository/org/springframework/boot/spring-boot-starter-data-r2dbc/3.1.1/spring-boot-starter-data-r2dbc-3.1.1.jar:/Users/khanh/.m2/repository/org/springframework/boot/spring-boot-starter/3.1.1/spring-boot-starter-3.1.1.jar:/Users/khanh/.m2/repository/org/springframework/boot/spring-boot/3.1.1/spring-boot-3.1.1.jar:/Users/khanh/.m2/repository/org/springframework/boot/spring-boot-autoconfigure/3.1.1/spring-boot-autoconfigure-3.1.1.jar:/Users/khanh/.m2/repository/org/springframework/boot/spring-boot-starter-logging/3.1.1/spring-boot-starter-logging-3.1.1.jar:/Users/khanh/.m2/repository/ch/qos/logback/logback-classic/1.4.8/logback-classic-1.4.8.jar:/Users/khanh/.m2/repository/ch/qos/logback/logback-core/1.4.8/logback-core-1.4.8.jar:/Users/khanh/.m2/repository/org/apache/logging/log4j/log4j-to-slf4j/2.20.0/log4j-to-slf4j-2.20.0.jar:/Users/khanh/.m2/repository/org/apache/logging/log4j/log4j-api/2.20.0/log4j-api-2.20.0.jar:/Users/khanh/.m2/repository/org/slf4j/jul-to-slf4j/2.0.7/jul-to-slf4j-2.0.7.jar:/Users/khanh/.m2/repository/jakarta/annotation/jakarta.annotation-api/2.1.1/jakarta.annotation-api-2.1.1.jar:/Users/khanh/.m2/repository/org/yaml/snakeyaml/1.33/snakeyaml-1.33.jar:/Users/khanh/.m2/repository/org/springframework/data/spring-data-r2dbc/3.1.1/spring-data-r2dbc-3.1.1.jar:/Users/khanh/.m2/repository/org/springframework/data/spring-data-relational/3.1.1/spring-data-relational-3.1.1.jar:/Users/khanh/.m2/repository/org/springframework/data/spring-data-commons/3.1.1/spring-data-commons-3.1.1.jar:/Users/khanh/.m2/repository/org/springframework/spring-context/6.0.10/spring-context-6.0.10.jar:/Users/khanh/.m2/repository/org/springframework/spring-aop/6.0.10/spring-aop-6.0.10.jar:/Users/khanh/.m2/repository/org/springframework/spring-expression/6.0.10/spring-expression-6.0.10.jar:/Users/khanh/.m2/repository/org/springframework/spring-r2dbc/6.0.10/spring-r2dbc-6.0.10.jar:/Users/khanh/.m2/repository/org/slf4j/slf4j-api/2.0.7/slf4j-api-2.0.7.jar:/Users/khanh/.m2/repository/io/r2dbc/r2dbc-spi/1.0.0.RELEASE/r2dbc-spi-1.0.0.RELEASE.jar:/Users/khanh/.m2/repository/org/reactivestreams/reactive-streams/1.0.4/reactive-streams-1.0.4.jar:/Users/khanh/.m2/repository/io/r2dbc/r2dbc-pool/1.0.0.RELEASE/r2dbc-pool-1.0.0.RELEASE.jar:/Users/khanh/.m2/repository/io/projectreactor/addons/reactor-pool/1.0.0/reactor-pool-1.0.0.jar:/Users/khanh/.m2/repository/org/flywaydb/flyway-core/9.16.3/flyway-core-9.16.3.jar:/Users/khanh/.m2/repository/com/fasterxml/jackson/dataformat/jackson-dataformat-toml/2.15.2/jackson-dataformat-toml-2.15.2.jar:/Users/khanh/.m2/repository/com/fasterxml/jackson/core/jackson-databind/2.15.2/jackson-databind-2.15.2.jar:/Users/khanh/.m2/repository/com/fasterxml/jackson/core/jackson-annotations/2.15.2/jackson-annotations-2.15.2.jar:/Users/khanh/.m2/repository/com/fasterxml/jackson/core/jackson-core/2.15.2/jackson-core-2.15.2.jar:/Users/khanh/.m2/repository/org/apache/commons/commons-text/1.10.0/commons-text-1.10.0.jar:/Users/khanh/.m2/repository/org/apache/commons/commons-lang3/3.12.0/commons-lang3-3.12.0.jar:/Users/khanh/.m2/repository/org/springframework/spring-jdbc/6.0.10/spring-jdbc-6.0.10.jar:/Users/khanh/.m2/repository/org/springframework/spring-beans/6.0.10/spring-beans-6.0.10.jar:/Users/khanh/.m2/repository/org/springframework/spring-core/6.0.10/spring-core-6.0.10.jar:/Users/khanh/.m2/repository/org/springframework/spring-jcl/6.0.10/spring-jcl-6.0.10.jar:/Users/khanh/.m2/repository/org/springframework/spring-tx/6.0.10/spring-tx-6.0.10.jar:/Users/khanh/.m2/repository/org/postgresql/postgresql/42.6.0/postgresql-42.6.0.jar:/Users/khanh/.m2/repository/org/checkerframework/checker-qual/3.31.0/checker-qual-3.31.0.jar:/Users/khanh/.m2/repository/org/postgresql/r2dbc-postgresql/1.0.1.RELEASE/r2dbc-postgresql-1.0.1.RELEASE.jar:/Users/khanh/.m2/repository/com/ongres/scram/client/2.1/client-2.1.jar:/Users/khanh/.m2/repository/com/ongres/scram/common/2.1/common-2.1.jar:/Users/khanh/.m2/repository/com/ongres/stringprep/saslprep/1.1/saslprep-1.1.jar:/Users/khanh/.m2/repository/com/ongres/stringprep/stringprep/1.1/stringprep-1.1.jar:/Users/khanh/.m2/repository/io/projectreactor/reactor-core/3.5.7/reactor-core-3.5.7.jar:/Users/khanh/.m2/repository/io/projectreactor/netty/reactor-netty-core/1.1.8/reactor-netty-core-1.1.8.jar:/Users/khanh/.m2/repository/io/netty/netty-handler/4.1.94.Final/netty-handler-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-common/4.1.94.Final/netty-common-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-resolver/4.1.94.Final/netty-resolver-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-buffer/4.1.94.Final/netty-buffer-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-transport/4.1.94.Final/netty-transport-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-transport-native-unix-common/4.1.94.Final/netty-transport-native-unix-common-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-codec/4.1.94.Final/netty-codec-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-handler-proxy/4.1.94.Final/netty-handler-proxy-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-codec-socks/4.1.94.Final/netty-codec-socks-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-codec-http/4.1.94.Final/netty-codec-http-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-resolver-dns/4.1.94.Final/netty-resolver-dns-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-codec-dns/4.1.94.Final/netty-codec-dns-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-resolver-dns-native-macos/4.1.94.Final/netty-resolver-dns-native-macos-4.1.94.Final-osx-x86_64.jar:/Users/khanh/.m2/repository/io/netty/netty-resolver-dns-classes-macos/4.1.94.Final/netty-resolver-dns-classes-macos-4.1.94.Final.jar:/Users/khanh/.m2/repository/io/netty/netty-transport-native-epoll/4.1.94.Final/netty-transport-native-epoll-4.1.94.Final-linux-x86_64.jar:/Users/khanh/.m2/repository/io/netty/netty-transport-classes-epoll/4.1.94.Final/netty-transport-classes-epoll-4.1.94.Final.jar com.huongdanjava.springboot.SpringBootFlywaySpringDataR2dbcExampleApplication . ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v3.1.1) 2023-07-09T22:17:55.684-04:00 INFO 5852 --- [ main] tFlywaySpringDataR2dbcExampleApplication : Starting SpringBootFlywaySpringDataR2dbcExampleApplication using Java 17 with PID 5852 (/Users/khanh/Documents/code/huongdanjava.com/spring-boot-flyway-spring-data-r2dbc-example/target/classes started by khanh in /Users/khanh/Documents/code/huongdanjava.com/spring-boot-flyway-spring-data-r2dbc-example) 2023-07-09T22:17:55.689-04:00 INFO 5852 --- [ main] tFlywaySpringDataR2dbcExampleApplication : No active profile set, falling back to 1 default profile: "default" 2023-07-09T22:17:56.272-04:00 INFO 5852 --- [ main] .s.d.r.c.RepositoryConfigurationDelegate : Bootstrapping Spring Data R2DBC repositories in DEFAULT mode. 2023-07-09T22:17:56.290-04:00 INFO 5852 --- [ main] .s.d.r.c.RepositoryConfigurationDelegate : Finished Spring Data repository scanning in 12 ms. Found 0 R2DBC repository interfaces. 2023-07-09T22:17:57.196-04:00 INFO 5852 --- [ main] tFlywaySpringDataR2dbcExampleApplication : Started SpringBootFlywaySpringDataR2dbcExampleApplication in 2.159 seconds (process running for 3.052) Process finished with exit code 0 |
Nó không tự động khởi tạo và pick up tập tin SQL mà mình đã định nghĩa trong thư mục src/main/resources/db/migration như chúng ta mong muốn.
Để Flyway có thể làm việc bình thường trong ứng dụng Spring Boot có sử dụng Spring Data R2DBC, các bạn có thể sử dụng một số properties bắt đầu với “spring.flyway”. Cụ thể như sau:
1 2 3 |
spring.flyway.url=jdbc:postgresql://localhost:5432/flyway_example spring.flyway.user=khanh spring.flyway.password=1 |
Chỉ đơn giản vậy thôi các bạn.
Các bạn cũng có thể sử dụng những properties trên cho ứng dụng ví dụ trong bài viết Sử dụng Flyway trong Spring Boot nhưng vì Flyway có thể sử dụng lại datasource mà chúng ta đã khai báo cho Spring Data JDBC nên chúng ta không cần khai thêm những properties này.
Chạy lại ứng dụng, các bạn sẽ thấy Flyway work như đã từng:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
/Users/khanhnguyenj/.sdkman/candidates/java/21.0.4-tem/bin/java -XX:TieredStopAtLevel=1 -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true -Dmanagement.endpoints.jmx.exposure.include=* -javaagent:/Applications/IntelliJ IDEA.app/Contents/lib/idea_rt.jar=53130:/Applications/IntelliJ IDEA.app/Contents/bin -Dfile.encoding=UTF-8 -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8 -classpath /Users/khanhnguyenj/Documents/code/huongdanjava.com/spring-boot-flyway-spring-data-r2dbc-example/target/classes:/Users/khanhnguyenj/.m2/repository/org/springframework/boot/spring-boot-starter-data-r2dbc/3.3.4/spring-boot-starter-data-r2dbc-3.3.4.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/boot/spring-boot-starter/3.3.4/spring-boot-starter-3.3.4.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/boot/spring-boot/3.3.4/spring-boot-3.3.4.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/boot/spring-boot-autoconfigure/3.3.4/spring-boot-autoconfigure-3.3.4.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/boot/spring-boot-starter-logging/3.3.4/spring-boot-starter-logging-3.3.4.jar:/Users/khanhnguyenj/.m2/repository/ch/qos/logback/logback-classic/1.5.8/logback-classic-1.5.8.jar:/Users/khanhnguyenj/.m2/repository/ch/qos/logback/logback-core/1.5.8/logback-core-1.5.8.jar:/Users/khanhnguyenj/.m2/repository/org/apache/logging/log4j/log4j-to-slf4j/2.23.1/log4j-to-slf4j-2.23.1.jar:/Users/khanhnguyenj/.m2/repository/org/apache/logging/log4j/log4j-api/2.23.1/log4j-api-2.23.1.jar:/Users/khanhnguyenj/.m2/repository/org/slf4j/jul-to-slf4j/2.0.16/jul-to-slf4j-2.0.16.jar:/Users/khanhnguyenj/.m2/repository/jakarta/annotation/jakarta.annotation-api/2.1.1/jakarta.annotation-api-2.1.1.jar:/Users/khanhnguyenj/.m2/repository/org/yaml/snakeyaml/2.2/snakeyaml-2.2.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/data/spring-data-r2dbc/3.3.4/spring-data-r2dbc-3.3.4.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/data/spring-data-relational/3.3.4/spring-data-relational-3.3.4.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/data/spring-data-commons/3.3.4/spring-data-commons-3.3.4.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-context/6.1.13/spring-context-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-aop/6.1.13/spring-aop-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-expression/6.1.13/spring-expression-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/io/micrometer/micrometer-observation/1.13.4/micrometer-observation-1.13.4.jar:/Users/khanhnguyenj/.m2/repository/io/micrometer/micrometer-commons/1.13.4/micrometer-commons-1.13.4.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-r2dbc/6.1.13/spring-r2dbc-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/org/slf4j/slf4j-api/2.0.16/slf4j-api-2.0.16.jar:/Users/khanhnguyenj/.m2/repository/io/r2dbc/r2dbc-spi/1.0.0.RELEASE/r2dbc-spi-1.0.0.RELEASE.jar:/Users/khanhnguyenj/.m2/repository/org/reactivestreams/reactive-streams/1.0.4/reactive-streams-1.0.4.jar:/Users/khanhnguyenj/.m2/repository/io/r2dbc/r2dbc-pool/1.0.1.RELEASE/r2dbc-pool-1.0.1.RELEASE.jar:/Users/khanhnguyenj/.m2/repository/io/projectreactor/addons/reactor-pool/1.0.8/reactor-pool-1.0.8.jar:/Users/khanhnguyenj/.m2/repository/org/flywaydb/flyway-core/10.10.0/flyway-core-10.10.0.jar:/Users/khanhnguyenj/.m2/repository/com/fasterxml/jackson/dataformat/jackson-dataformat-toml/2.17.2/jackson-dataformat-toml-2.17.2.jar:/Users/khanhnguyenj/.m2/repository/com/fasterxml/jackson/core/jackson-databind/2.17.2/jackson-databind-2.17.2.jar:/Users/khanhnguyenj/.m2/repository/com/fasterxml/jackson/core/jackson-annotations/2.17.2/jackson-annotations-2.17.2.jar:/Users/khanhnguyenj/.m2/repository/com/fasterxml/jackson/core/jackson-core/2.17.2/jackson-core-2.17.2.jar:/Users/khanhnguyenj/.m2/repository/com/google/code/gson/gson/2.10.1/gson-2.10.1.jar:/Users/khanhnguyenj/.m2/repository/org/flywaydb/flyway-database-postgresql/10.10.0/flyway-database-postgresql-10.10.0.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-jdbc/6.1.13/spring-jdbc-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-beans/6.1.13/spring-beans-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-core/6.1.13/spring-core-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-jcl/6.1.13/spring-jcl-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/org/springframework/spring-tx/6.1.13/spring-tx-6.1.13.jar:/Users/khanhnguyenj/.m2/repository/org/postgresql/postgresql/42.7.4/postgresql-42.7.4.jar:/Users/khanhnguyenj/.m2/repository/org/checkerframework/checker-qual/3.42.0/checker-qual-3.42.0.jar:/Users/khanhnguyenj/.m2/repository/org/postgresql/r2dbc-postgresql/1.0.5.RELEASE/r2dbc-postgresql-1.0.5.RELEASE.jar:/Users/khanhnguyenj/.m2/repository/com/ongres/scram/client/2.1/client-2.1.jar:/Users/khanhnguyenj/.m2/repository/com/ongres/scram/common/2.1/common-2.1.jar:/Users/khanhnguyenj/.m2/repository/com/ongres/stringprep/saslprep/1.1/saslprep-1.1.jar:/Users/khanhnguyenj/.m2/repository/com/ongres/stringprep/stringprep/1.1/stringprep-1.1.jar:/Users/khanhnguyenj/.m2/repository/io/projectreactor/reactor-core/3.6.10/reactor-core-3.6.10.jar:/Users/khanhnguyenj/.m2/repository/io/projectreactor/netty/reactor-netty-core/1.1.22/reactor-netty-core-1.1.22.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-handler/4.1.113.Final/netty-handler-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-common/4.1.113.Final/netty-common-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-resolver/4.1.113.Final/netty-resolver-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-buffer/4.1.113.Final/netty-buffer-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-transport/4.1.113.Final/netty-transport-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-transport-native-unix-common/4.1.113.Final/netty-transport-native-unix-common-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-codec/4.1.113.Final/netty-codec-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-handler-proxy/4.1.113.Final/netty-handler-proxy-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-codec-socks/4.1.113.Final/netty-codec-socks-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-codec-http/4.1.113.Final/netty-codec-http-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-resolver-dns/4.1.113.Final/netty-resolver-dns-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-codec-dns/4.1.113.Final/netty-codec-dns-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-resolver-dns-native-macos/4.1.113.Final/netty-resolver-dns-native-macos-4.1.113.Final-osx-x86_64.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-resolver-dns-classes-macos/4.1.113.Final/netty-resolver-dns-classes-macos-4.1.113.Final.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-transport-native-epoll/4.1.113.Final/netty-transport-native-epoll-4.1.113.Final-linux-x86_64.jar:/Users/khanhnguyenj/.m2/repository/io/netty/netty-transport-classes-epoll/4.1.113.Final/netty-transport-classes-epoll-4.1.113.Final.jar com.huongdanjava.springboot.SpringBootFlywaySpringDataR2dbcExampleApplication . ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v3.3.4) 2024-10-15T07:40:58.713+08:00 INFO 6912 --- [ main] tFlywaySpringDataR2dbcExampleApplication : Starting SpringBootFlywaySpringDataR2dbcExampleApplication using Java 21.0.4 with PID 6912 (/Users/khanhnguyenj/Documents/code/huongdanjava.com/spring-boot-flyway-spring-data-r2dbc-example/target/classes started by khanhnguyenj in /Users/khanhnguyenj/Documents/code/huongdanjava.com/spring-boot-flyway-spring-data-r2dbc-example) 2024-10-15T07:40:58.714+08:00 INFO 6912 --- [ main] tFlywaySpringDataR2dbcExampleApplication : No active profile set, falling back to 1 default profile: "default" 2024-10-15T07:40:58.844+08:00 INFO 6912 --- [ main] .s.d.r.c.RepositoryConfigurationDelegate : Bootstrapping Spring Data R2DBC repositories in DEFAULT mode. 2024-10-15T07:40:58.849+08:00 INFO 6912 --- [ main] .s.d.r.c.RepositoryConfigurationDelegate : Finished Spring Data repository scanning in 3 ms. Found 0 R2DBC repository interfaces. 2024-10-15T07:40:59.257+08:00 INFO 6912 --- [ main] org.flywaydb.core.FlywayExecutor : Database: jdbc:postgresql://localhost:5432/flyway_example (PostgreSQL 16.3) 2024-10-15T07:40:59.281+08:00 INFO 6912 --- [ main] o.f.core.internal.command.DbValidate : Successfully validated 1 migration (execution time 00:00.014s) 2024-10-15T07:40:59.302+08:00 INFO 6912 --- [ main] o.f.core.internal.command.DbMigrate : Current version of schema "public": 2023.07.09.00000 2024-10-15T07:40:59.303+08:00 INFO 6912 --- [ main] o.f.core.internal.command.DbMigrate : Schema "public" is up to date. No migration necessary. 2024-10-15T07:40:59.333+08:00 INFO 6912 --- [ main] tFlywaySpringDataR2dbcExampleApplication : Started SpringBootFlywaySpringDataR2dbcExampleApplication in 0.739 seconds (process running for 1.0) Process finished with exit code 0 |