扩展activiti删除ACT_HI_*历史表
cookqq ›博客列表 ›activiti

扩展activiti删除ACT_HI_*历史表

2013-03-27 09:19:54.0|分类: activiti|浏览量: 2501

摘要: activiti自带了很多表,如图:

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引擎时候,第一次还会去加载配置文件信息。

这个怎么解决呢?

http://www.activiti.org/userguide/index.html 没有找到相应的信息。

后来想到activiti.cfg.xml中的配置信息需要加载到ProcessEngineConfigurationImpl中,应该是先解析,然后寻找相应属性的set方法进行赋值啊(我猜的)。那就通过配置文件设置吧:

<property name="dbHistoryUsed" value="false" />
启动后项目,成功了,不在报错了。







请问下楼主用的activiti版本是多少?

引用来自“thinkeee”的评论

请问下楼主用的activiti版本是多少?

5.12

一键分享文章

分类列表

  • • struts源码分析
  • • flink
  • • struts
  • • redis
  • • kafka
  • • ubuntu
  • • zookeeper
  • • hadoop
  • • activiti
  • • linux
  • • 成长
  • • NIO
  • • 关键词提取
  • • mysql
  • • android studio
  • • zabbix
  • • 云计算
  • • mahout
  • • jmeter
  • • hive
  • • ActiveMQ
  • • lucene
  • • MongoDB
  • • netty
  • • flume
  • • 我遇到的问题
  • • GRUB
  • • nginx
  • • 大家好的文章
  • • android
  • • tomcat
  • • Python
  • • luke
  • • android源码编译
  • • 安全
  • • MPAndroidChart
  • • swing
  • • POI
  • • powerdesigner
  • • jquery
  • • html
  • • java
  • • eclipse
  • • shell
  • • jvm
  • • highcharts
  • • 设计模式
  • • 列式数据库
  • • spring cloud
  • • docker+node.js+zookeeper构建微服务
版权所有 cookqq 感谢访问 支持开源 京ICP备15030920号
CopyRight 2015-2018 cookqq.com All Right Reserved.