解决Springboot2.1.x配置Activiti7单独数据源问题

 更新时间:2019年09月30日 11:31:26   作者:Purgeyao  
这篇文章主要介绍了Springboot2.1.x配置Activiti7单独数据源问题,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

1|1简介

最近基于最新的Activiti7配置了SpringBoot2。

简单上手使用了一番。发现市面上解决Activiti7的教程很少,采坑也比较多,在Activiti6配置数据源和Activiti7有所区别,基于Activiti6在Activiti7里是无法正常使用的。接下来让我们看下区别。

1|2问题

Activiti6多数据源配置

6的配置比较简单点。

先加入配置:

# activiti 数据源
spring.datasource.activiti.driver=com.mysql.jdbc.Driver
spring.datasource.activiti.url=jdbc:mysql://10.1.1.97:3311/test-activiti7-db?useUnicode=true&characterEncoding=utf8&useSSL=false&allowMultiQueries=true
spring.datasource.activiti.username=root
spring.datasource.activiti.password=Rtqw123OpnmER
spring.datasource.activiti.driverClassName=com.mysql.jdbc.Driver
  • 用@ConfigurationProperties加载以spring.datasource.activiti开头的DataSource。
  • 创建ActivitiConfig继承AbstractProcessEngineAutoConfiguration方法注入SpringProcessEngineConfigurationbean,调用AbstractProcessEngineAutoConfiguration#baseSpringProcessEngineConfiguration方法把创建的数据源注入。
@Configuration
public class ActivitiConfig extends AbstractProcessEngineAutoConfiguration {

 @Bean
 @ConfigurationProperties(prefix = "spring.datasource.activiti")
 public DataSource activitiDataSource() {
  return DataSourceBuilder.create().build();
 }

 @Bean
 public SpringProcessEngineConfiguration springProcessEngineConfiguration(
   PlatformTransactionManager transactionManager,
   SpringAsyncExecutor springAsyncExecutor) throws IOException {

  return baseSpringProcessEngineConfiguration(
    activitiDataSource(),
    transactionManager,
    springAsyncExecutor);
 }
}

Activiti6的数据源已经配置完成,如果是7的话会发现

AbstractProcessEngineAutoConfiguration#baseSpringProcessEngineConfiguration方法已经不存在了,我们需要产考源码构建方式改造一番。

1|3修复

Activiti7多数据源配置

配置还是要上面的。

  • 创建ActivitiConfig继承AbstractProcessEngineAutoConfiguration方法注入SpringProcessEngineConfigurationbean。
  • 用@ConfigurationProperties加载以spring.datasource.activiti开头的DataSource
@Configuration
public class ActivitiConfig extends AbstractProcessEngineAutoConfiguration {
 
 @Bean
 @ConfigurationProperties(prefix = "spring.datasource.activiti")
 public DataSource activitiDataSource() {
  return DataSourceBuilder.create().build();
 }
 
 ...略
}
SpringProcessEngineConfiguration注入方式改为下面:
 @Bean
 @Primary
 public SpringProcessEngineConfiguration springProcessEngineConfiguration(
   PlatformTransactionManager transactionManager,
   SpringAsyncExecutor springAsyncExecutor,
   ActivitiProperties activitiProperties,
   ProcessDefinitionResourceFinder processDefinitionResourceFinder,
   @Autowired(required = false) DefaultActivityBehaviorFactoryMappingConfigurer processEngineConfigurationConfigurer,
   @Autowired(required = false) List<ProcessEngineConfigurator> processEngineConfigurators,
   UserGroupManager userGroupManager,
   DataSource dataSource) throws IOException {

  SpringProcessEngineConfiguration conf = new SpringProcessEngineConfiguration();
  conf.setConfigurators(processEngineConfigurators);
  configureProcessDefinitionResources(processDefinitionResourceFinder,
    conf);
  conf.setDataSource(dataSource);
  conf.setTransactionManager(transactionManager);

  if (springAsyncExecutor != null) {
   conf.setAsyncExecutor(springAsyncExecutor);
  }
  conf.setDeploymentName(activitiProperties.getDeploymentName());
  conf.setDatabaseSchema(activitiProperties.getDatabaseSchema());
  conf.setDatabaseSchemaUpdate(activitiProperties.getDatabaseSchemaUpdate());
  conf.setDbHistoryUsed(activitiProperties.isDbHistoryUsed());
  conf.setAsyncExecutorActivate(activitiProperties.isAsyncExecutorActivate());
  if (!activitiProperties.isAsyncExecutorActivate()) {
   ValidatorSet springBootStarterValidatorSet = new ValidatorSet("activiti-spring-boot-starter");
   springBootStarterValidatorSet.addValidator(new AsyncPropertyValidator());
   if (conf.getProcessValidator() == null) {
    ProcessValidatorImpl processValidator = new ProcessValidatorImpl();
    processValidator.addValidatorSet(springBootStarterValidatorSet);
    conf.setProcessValidator(processValidator);
   } else {
    conf.getProcessValidator().getValidatorSets().add(springBootStarterValidatorSet);
   }
  }
  conf.setMailServerHost(activitiProperties.getMailServerHost());
  conf.setMailServerPort(activitiProperties.getMailServerPort());
  conf.setMailServerUsername(activitiProperties.getMailServerUserName());
  conf.setMailServerPassword(activitiProperties.getMailServerPassword());
  conf.setMailServerDefaultFrom(activitiProperties.getMailServerDefaultFrom());
  conf.setMailServerUseSSL(activitiProperties.isMailServerUseSsl());
  conf.setMailServerUseTLS(activitiProperties.isMailServerUseTls());

  if (userGroupManager != null) {
   conf.setUserGroupManager(userGroupManager);
  }

  conf.setHistoryLevel(activitiProperties.getHistoryLevel());
  conf.setCopyVariablesToLocalForTasks(activitiProperties.isCopyVariablesToLocalForTasks());
  conf.setSerializePOJOsInVariablesToJson(activitiProperties.isSerializePOJOsInVariablesToJson());
  conf.setJavaClassFieldForJackson(activitiProperties.getJavaClassFieldForJackson());

  if (activitiProperties.getCustomMybatisMappers() != null) {
   conf.setCustomMybatisMappers(
     getCustomMybatisMapperClasses(activitiProperties.getCustomMybatisMappers()));
  }

  if (activitiProperties.getCustomMybatisXMLMappers() != null) {
   conf.setCustomMybatisXMLMappers(
     new HashSet<>(activitiProperties.getCustomMybatisXMLMappers()));
  }

  if (activitiProperties.getCustomMybatisXMLMappers() != null) {
   conf.setCustomMybatisXMLMappers(
     new HashSet<>(activitiProperties.getCustomMybatisXMLMappers()));
  }

  if (activitiProperties.isUseStrongUuids()) {
   conf.setIdGenerator(new StrongUuidGenerator());
  }

  if (activitiProperties.getDeploymentMode() != null) {
   conf.setDeploymentMode(activitiProperties.getDeploymentMode());
  }

  conf.setActivityBehaviorFactory(new DefaultActivityBehaviorFactory());

  if (processEngineConfigurationConfigurer != null) {
   processEngineConfigurationConfigurer.configure(conf);
  }

  return conf;
 }

 private void configureProcessDefinitionResources(
   ProcessDefinitionResourceFinder processDefinitionResourceFinder,
   SpringProcessEngineConfiguration conf) throws IOException {
  List<Resource> procDefResources = processDefinitionResourceFinder
    .discoverProcessDefinitionResources();
  if (!procDefResources.isEmpty()) {
   conf.setDeploymentResources(procDefResources.toArray(new Resource[0]));
  }
 }

1|4常见错误

在以上配置中可能会有jdbcUrl is required with driverClassName错误

解决办法如下:

# activiti 数据源
spring.datasource.activiti.driver=com.mysql.jdbc.Driver
spring.datasource.activiti.url=jdbc:mysql://10.1.1.97:3311/test-activiti7-db?useUnicode=true&characterEncoding=utf8&useSSL=false&allowMultiQueries=true
# url换为jdbc-url 解决jdbcUrl is required with driverClassName错误
# 官方文档的解释是:
# 因为连接池的实际类型没有被公开,所以在您的自定义数据源的元数据中没有生成密钥,而且在IDE中没有完成(因为DataSource接口没有暴露属性)。
# 另外,如果您碰巧在类路径上有Hikari,那么这个基本设置就不起作用了,因为Hikari没有url属性(但是确实有一个jdbcUrl属性)。在这种情况下,您必须重写您的配置如下:
spring.datasource.activiti.jdbc-url=${spring.datasource.activiti.url}
spring.datasource.activiti.username=root
spring.datasource.activiti.password=Rtqw123OpnmER
spring.datasource.activiti.driverClassName=com.mysql.jdbc.Driver

1|5总结

Activiti7国内的教程不是很多,需要自己在社区里或者官方文档,源码去看了解,细心学习。

示例代码地址:activiti-starter

总结

以上所述是小编给大家介绍的解决Springboot2.1.x配置Activiti7单独数据源问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

相关文章

  • Spring的@Autowired加到接口上但获取的是实现类的问题

    Spring的@Autowired加到接口上但获取的是实现类的问题

    这篇文章主要介绍了Spring的@Autowired加到接口上但获取的是实现类的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • Springboot主程序类注解配置过程图解

    Springboot主程序类注解配置过程图解

    这篇文章主要介绍了Springboot主程序类注解配置过程图解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • Java实现“年-月-日 上午/下午时:分:秒”的简单代码

    Java实现“年-月-日 上午/下午时:分:秒”的简单代码

    当前的日期输出的方法有很多,本文为大家介绍下在java中是如何实现“年-月-日 上午/下午时:分:秒”,感兴趣的朋友不妨参考下
    2015-08-08
  • Spring中存储Bean的常见注解方式

    Spring中存储Bean的常见注解方式

    Spring框架中的控制反转(IoC)和依赖注入(DI)是核心概念,实现了对象的解耦和动态依赖,IoC容器负责对象的生命周期和对象间的依赖关系,通过DI方式注入依赖,本文介绍Spring中存储Bean的常见注解方式,感兴趣的朋友一起看看吧
    2024-09-09
  • Java接口和抽象类实例分析

    Java接口和抽象类实例分析

    这篇文章主要介绍了Java接口和抽象类,实例分析了java接口与抽象类的概念与相关使用技巧,需要的朋友可以参考下
    2015-05-05
  • 一文搞清楚Spring事务

    一文搞清楚Spring事务

    Spring事务是指在Spring框架中对于数据库操作的一种支持,它通过对一组数据库操作进行整体控制来保证数据的一致性和完整性。本文介绍Spring事务介绍的非常详细,有需要的朋友可以参考本文
    2023-04-04
  • 代码生成器MyBatisX:自动生成代码方式

    代码生成器MyBatisX:自动生成代码方式

    MyBatisX是一款提高开发效率的插件,可以自动生成Mapper、XML和Java实体类代码,并支持数据库表的重置和JAP提示,安装步骤简单,只需在IDEA的Plugin市场搜索并安装MyBatisX,然后打开数据库窗口选择表进行生成即可
    2024-11-11
  • SpringBoot整合Solr实现文档检索

    SpringBoot整合Solr实现文档检索

    Solr高度可靠、可扩展和容错,提供分布式索引、复制和负载平衡查询、自动故障转移和恢复、集中配置等,Solr 为世界上许多最大的 Internet 站点的搜索和导航功能提供支持,本文将给大家介绍SpringBoot整合Solr实现文档检索,需要的朋友可以参考下
    2023-08-08
  • springboot之SpringApplication生命周期和事件机制解读

    springboot之SpringApplication生命周期和事件机制解读

    这篇文章主要介绍了springboot之SpringApplication生命周期和事件机制,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • java调用opencv身份证号识别详解

    java调用opencv身份证号识别详解

    这篇文章主要为大家详细介绍了java如何调用opencv实现身份证号的识别,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-03-03

最新评论