Drools集成CDI(二)

简介: Drools集成CDI(二)

上节课《Drools集成CDI(一)》中我们介绍了CDI的基本使用,这节课带大家学习一下Drools如何集成CDI。

添加依赖

首先使用drools7的话需要在正常使用CDI的基础上添加drools-cdi的依赖:

<dependency>
    <groupId>org.drools</groupId>
    <artifactId>drools-cdi</artifactId>
    <version>${drools.version}</version>
</dependency>

beans.xml和kmodule.xml配置与之前的使用方式一致;

使用方式一

public class Chapter4 {
  @KSession
  KieSession kieSession;
  @Inject
  Chapter4(KieSession kieSession){
    this.kieSession = kieSession;
  }
  public static void main(String[] args) {
    Weld weld = new Weld();
    Chapter4 chapter4 = weld.initialize().instance().select(Chapter4.class).get();
    chapter4.doFire();
  }
  private void doFire(){
    int nums = kieSession.fireAllRules();
    System.out.println("Fire " + nums + " rules!");
  }
}

方式二

将获取对象的方式由Weld替换为SeContainer:

SeContainer seContainer = null;
try {
  seContainer = SeContainerInitializer.newInstance().initialize();
  Chapter4 chapter4 = seContainer.select(Chapter4.class).get();
  chapter4.doFire();
} finally {
  if (seContainer != null && seContainer.isRunning()) {
    seContainer.close();
  }
}

更多详细内容请参考《Drools7规则引擎进阶教程》

目录
相关文章
|
安全 Java 数据库连接
工作流容器化的依赖注入!Activiti集成CDI实现工作流的可配置性和可扩展性
本篇文章介绍了工作流集成CDI实现工作流的可配置性和可扩展性。详细说明的CDI的基本设置来配置流程引擎并发布流程。通过基于CDI的流程的执行,实现与流程实例的交互,声明式流程控制,在流程中使用Bean,注入流程变量和接收流程事件的功能。通过这篇文章学习,可以学会Activiti的使用进阶。
475 0
工作流容器化的依赖注入!Activiti集成CDI实现工作流的可配置性和可扩展性
|
开发框架 Java Maven
Drools集成CDI(一)
Drools集成CDI(一)
241 0
|
Java Maven Docker
gitlab-ci 集成 k3s 部署spring boot 应用
gitlab-ci 集成 k3s 部署spring boot 应用
|
11月前
|
消息中间件 监控 Java
您是否已集成 Spring Boot 与 ActiveMQ?
您是否已集成 Spring Boot 与 ActiveMQ?
324 0
|
监控 druid Java
spring boot 集成配置阿里 Druid监控配置
spring boot 集成配置阿里 Druid监控配置
972 6
|
Java 关系型数据库 MySQL
如何实现Springboot+camunda+mysql的集成
【7月更文挑战第2天】集成Spring Boot、Camunda和MySQL的简要步骤: 1. 初始化Spring Boot项目,添加Camunda和MySQL驱动依赖。 2. 配置`application.properties`,包括数据库URL、用户名和密码。 3. 设置Camunda引擎属性,指定数据源。 4. 引入流程定义文件(如`.bpmn`)。 5. 创建服务处理流程操作,创建控制器接收请求。 6. Camunda自动在数据库创建表结构。 7. 启动应用,测试流程启动,如通过服务和控制器开始流程实例。 示例代码包括服务类启动流程实例及控制器接口。实际集成需按业务需求调整。
866 4
|
消息中间件 Java 测试技术
【RocketMQ系列八】SpringBoot集成RocketMQ-实现普通消息和事务消息
【RocketMQ系列八】SpringBoot集成RocketMQ-实现普通消息和事务消息
1039 1
|
消息中间件 Java Kafka
springboot集成kafka
springboot集成kafka
403 2
|
监控 前端开发 Java
五分钟后,你将学会在SpringBoot项目中如何集成CAT调用链
五分钟后,你将学会在SpringBoot项目中如何集成CAT调用链
|
消息中间件 Java Kafka
Spring Boot与Apache Kafka Streams的集成
Spring Boot与Apache Kafka Streams的集成