Boot的约定大于配置。默认情况下,如果中只有H2,就会创建内存数据库,并传递给流程引擎配置。
可以简单地通过提供 bean来覆盖默认配置,来更换数据源。我们在这里使用类,这是 Boot的辅助类。如果中有, 或者 DBCP,就会(按照这个顺序,先是)选择一个(作为连接池)。例如,要切换到MySQL数据库:
@Bean
public DataSource database() {
return DataSourceBuilder.create()
.url("jdbc:mysql://127.0.0.1:3306/flowable-spring-boot?characterEncoding=UTF-8")
.username("flowable")
.password("flowable")
.driverClassName("com.mysql.jdbc.Driver")
.build();
}
从Maven依赖中移除H2,并为添加MySQL驱动与连接池:
mysql
mysql-connector-java
5.1.34
org.apache.tomcat
tomcat-jdbc
8.0.15
应用这次启动后,可以看到使用了MySQL作为数据库(也使用了连接池框架):
org.flowable.engine.impl.db.DbSqlSession : performing create on engine with resource org/flowable/db/create/flowable.mysql.create.engine.sql
org.flowable.engine.impl.db.DbSqlSession : performing create on history with resource org/flowable/db/create/flowable.mysql.create.history.sql
org.flowable.engine.impl.db.DbSqlSession : performing create on identity with resource org/flowable/db/create/flowable.mysql.create.identity.sql
多次重启应用,会发现任务的数量增加了(H2内存数据库在关闭后会丢失,而MySQL不会)。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
相关文章
暂无评论...