共计 2944 个字符,预计需要花费 8 分钟才能阅读完成。
今天丸趣 TV 小编给大家分享一下扩展 activiti 删除 ACT_HI_* 历史表报错怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
activiti 自带了很多表,如图:
ACT_HI_*:HI 表示历史数据 (History) 表,包括过期的流程实例,过期的变量和过期的任务等。
历史表中没有创建外键,可以很好的控制历史表。
在项目中,有可能不需要保存历史记录,也就是这些 ACT_HI_* 表可以删除了。
删除 ACT_HI_* 历史表,重新启动项目后报错:
严重: Error while closing command context
org.activiti.engine.ActivitiException: Activiti database problem: Tables missing for component(s) history
at org.activiti.engine.impl.db.DbSqlSession.dbSchemaCheckVersion(DbSqlSession.java:713)
at org.activiti.engine.impl.db.DbSqlSession.performSchemaOperationsProcessEngineBuild(DbSqlSession.java:1097)
at org.activiti.engine.impl.SchemaOperationsProcessEngineBuild.execute(SchemaOperationsProcessEngineBuild.java:27)
at org.activiti.engine.impl.interceptor.CommandExecutorImpl.execute(CommandExecutorImpl.java:24)
at org.activiti.engine.impl.interceptor.CommandContextInterceptor.execute(CommandContextInterceptor.java:60)
at org.activiti.engine.impl.interceptor.LogInterceptor.execute(LogInterceptor.java:32)
at org.activiti.engine.impl.ProcessEngineImpl. init (ProcessEngineImpl.java:75)
at org.activiti.engine.impl.cfg.ProcessEngineConfigurationImpl.buildProcessEngine(ProcessEngineConfigurationImpl.java:311)
at org.activiti.engine.ProcessEngines.buildProcessEngine(ProcessEngines.java:194)
at org.activiti.engine.ProcessEngines.initProcessEnginFromResource(ProcessEngines.java:167)
at org.activiti.engine.ProcessEngines.init(ProcessEngines.java:98)
定位到错误地方:DbSqlSession.java
if (dbSqlSessionFactory.isDbHistoryUsed() !isHistoryTablePresent()) {
errorMessage = addMissingComponent(errorMessage, history
}
这里主要的工作是检查数据库中是否有历史表,因为上面删除了数据库中的历史表所以报错了。
这里面有一个很重要的变量 dbSqlSessionFactory.isDbHistoryUsed(),从代码上面的意思也就是可以关闭使用历史表,好吧,就在创建配置文件的时候把它设置成 false。
ProcessEngineConfiguration configuration = ProcessEngineConfiguration
.createProcessEngineConfigurationFromResourceDefault();
if(configuration instanceof ProcessEngineConfigurationImpl){
// 这里的主要作用是为了,删除历史数据,在启动的时候不去检测历史数据库是否存在
((ProcessEngineConfigurationImpl) configuration).setDbHistoryUsed(false);
}
ProcessEngine processEngine = configuration.buildProcessEngine();
重新启动后还是有问题,后来 debug 跟进去发现在使用:
ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
使用上面代码获取引擎的时候又一次去加载配置文件了,搞了半天,才发现:
ProcessEngines.getDefaultProcessEngine()获取默认的 activiti 引擎,首先会根据字段 isInitialized 判断是否已经加载了 activiti 配置文件,如果没有加载就去加载 activiti.cfg.xml 和 activiti-context.xml,如果加载了,就在 processEngines 根据名称在获取相应的引擎。
使用 configuration.buildProcessEngine()创建 activiti 引擎的时候,加载了 activiti 配置文件,然后把创建的引擎添加到了工具类 ProcessEngines 的 processEngines 中。并没有设置字段 isInitialized。
所以在项目中使用 ProcessEngines.getDefaultProcessEngine()获取默认的 activiti 引擎时候,第一次还会去加载配置文件信息。
这个怎么解决呢?
后来想到 activiti.cfg.xml 中的配置信息需要加载到 ProcessEngineConfigurationImpl 中,应该是先解析,然后寻找相应属性的 set 方法进行赋值啊(我猜的)。那就通过配置文件设置吧:
property name= dbHistoryUsed value= false /
启动后项目,成功了,不在报错了。
以上就是“扩展 activiti 删除 ACT_HI_* 历史表报错怎么解决”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,丸趣 TV 小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注丸趣 TV 行业资讯频道。