本人博客开始迁移,博客整个架构本身搭建及编码 http://www.cookqq.com/listBlog.action html
activiti自带了不少表,如图: java
ACT_HI_*:HI表示历史数据(History)表,包括过时的流程实例,过时的变量和过时的任务等。 数据库
历史表中没有建立外键,能够很好的控制历史表。架构
在项目中,有可能不须要保存历史记录,也就是这些ACT_HI_*表能够删除了。ide
删除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.javaui
if (dbSqlSessionFactory.isDbHistoryUsed() && !isHistoryTablePresent()) { errorMessage = addMissingComponent(errorMessage, "history"); }
这里主要的工做是检查数据库中是否有历史表,由于上面删除了数据库中的历史表因此报错了。编码
这里面有一个很重要的变量dbSqlSessionFactory.isDbHistoryUsed() ,从代码上面的意思也就是能够关闭使用历史表,好吧,就在建立配置文件的时候把它设置成false。 spa
ProcessEngineConfiguration configuration = ProcessEngineConfiguration .createProcessEngineConfigurationFromResourceDefault(); if(configuration instanceof ProcessEngineConfigurationImpl){ //这里的主要做用是为了,删除历史数据,在启动的时候不去检测历史数据库是否存在 ((ProcessEngineConfigurationImpl) configuration).setDbHistoryUsed(false); } ProcessEngine processEngine = configuration.buildProcessEngine();
从新启动后仍是有问题,后来debug跟进去发如今使用: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" />
启动后项目,成功了,不在报错了。