drools6 基本使用 -- 2
来源:互联网 发布:网络暴力微电影 编辑:程序博客网 时间:2024/06/01 09:17
续drools6 基本使用1
http://blog.csdn.net/cloud_ll/article/details/26979355
8. 创建src/main/test folder,把droolsTest.java移动到test folder,把droolsTest.java改装成junit test case,执行mvn test,确保rules运行没有问题
9. 执行mvn install 把rules打包成jar文件上传到本地库
Note: 如果rule文件里面有中文,记得要把文件保存成utf-8格式,然后测试的时候保证maven的surefire plugin加上了使用utf-8的运行参数,否则会乱码出错
10. 在另外一个项目中使用drools,主要是借助kie-ci框架,实现启动load rules,动态修改rules和执行规则
maven文件改动,加入如下依赖:
<dependency>
<groupId>org.kie</groupId>
<artifactId>kie-ci</artifactId>
</dependency
java代码:创建一个ruleservice接口和实现类,实现以下方法:启动load rules(initService),动态修改(refreshService), 执行规则(fireService)
public void initService(String groupId, String artifactId, String version) throws NotExistsException {ks = KieServices.Factory.get();try{kContainer = ks.newKieContainer(ks.newReleaseId(groupId, artifactId, version));} catch (Exception e){StringBuilder sb = new StringBuilder("fail to get maven rules kmodule from groupId: [");sb.append(groupId).append("] artifactId: [").append(artifactId).append("] version: [").append(version).append("]");throw new NotExistsException(sb.toString());}if(null != kContainer)kSession = kContainer.newStatelessKieSession("ksession-rules");}@Overridepublic void refreshService(String groupId, String artifactId, String version) throws NotExistsException {try{kContainer.updateToVersion(ks.newReleaseId(groupId, artifactId, version));} catch (Exception e){StringBuilder sb = new StringBuilder("fail to get maven rules kmodule from groupId: [");sb.append(groupId).append("] artifactId: [").append(artifactId).append("] version: [").append(version).append("]");throw new NotExistsException(sb.toString());}if(null != kContainer)kSession = kContainer.newStatelessKieSession("ksession-rules");}@Overridepublic void fireService(Message info) {kSession.execute(info);}
11. 基本测试,对于使用drools和直接写java代码,显然使用drools可以实现动态部署,更具优势,不过有人担心性能受到影响,这里我做了一下测试,
我这里的测试是基于一个自己写的rule规则,对对象的某些字段做业务逻辑处理,选择使用java代码和使用drools,看耗时差别,当然这个测试很简陋,也没有对drools使用做优化,也没有看CPU和内存使用情况
业务逻辑代码:
public void setMatchThresholdsInfo(CustomerInfo info) {String temp = info.getProfessionCode();// boolean flag = false;if (null == temp || 0 == (temp.trim()).length() || "其他".equals(temp) || "其它".equals(temp) || "无业".equals(temp) || "未知".equals(temp)) {info.setRiskValue(info.getRiskValue() + 20); info.setRiskType(info.getRiskType() + " Invalid professionCode value: " + info.getProfessionCode());}if (info.getCertificateEndDate() == null|| info.getCertificateEndDate().before(new Date())) { info.setRiskValue(info.getRiskValue() + 80); info.setRiskType(info.getRiskType() + " Invalid Certification End date value: " + info.getCertificateEndDate());}if (info.getCustomerName() == null || info.getCustomerName().trim().length() == 0) {info.setRiskValue(info.getRiskValue() + 80);info.setRiskType(info.getRiskType() + " Customer Name is null");}if (info.getCertificateId() == null || 0 == (info.getCertificateId().trim()).length()) {info.setRiskValue(info.getRiskValue() + 80); info.setRiskType(info.getRiskType() + " Invalid Certification ID: " + info.getCertificateId());}if (null == info.isForeignFlag() ||info.isForeignFlag()) {info.setRiskValue(info.getRiskValue() + 20);info.setRiskType(info.getRiskType() + " 境外标志: " + info.getForeignFlag());}info.setRiskType(info.getRiskType().trim());}rule规则:
//created on: May 19, 2014package com.elulian.CustomerSecurityManagementSystem.service.impl//list any import classes here.import com.elulian.CustomerSecurityManagementSystem.vo.CustomerInfoimport java.util.Date//declare any global variables hererule "Profession Rule" //include attributes such as "salience" here... when //conditions info : CustomerInfo (null == professionCode || 0 == (info.getProfessionCode().trim()).length() || "其他".equals(professionCode) || "其它".equals(professionCode) || "无业".equals(professionCode) || "未知".equals(professionCode)) then //actions info.setRiskValue(info.getRiskValue() + 20); info.setRiskType(info.getRiskType() + " Invalid professionCode value: " + info.getProfessionCode());endrule "Certification End date Rule" when //conditions info : CustomerInfo (null == certificateEndDate || certificateEndDate.before(new Date())) then //actions info.setRiskValue(info.getRiskValue() + 80); info.setRiskType(info.getRiskType() + " Invalid Certification End date value: " + info.getCertificateEndDate());endrule "Customer Name Rule" when //conditions info : CustomerInfo (null == customerName || 0 == (info.getCustomerName().trim()).length()) then //actions info.setRiskValue(info.getRiskValue() + 80); info.setRiskType(info.getRiskType() + " Customer Name is null");endrule "Certification ID Rule" when //conditions info : CustomerInfo (null == certificateId || 0 == (info.getCertificateId().trim()).length()) then //actions info.setRiskValue(info.getRiskValue() + 80); info.setRiskType(info.getRiskType() + " Invalid Certification ID: " + info.getCertificateId());end/*rule "Certification ID Rule 2" when //use regx here to check digital and length later info : CustomerInfo ("身份证" == certificateType && (15 != (info.getCertificateId().trim()) || 18 != (info.getCertificateId().trim()))) then info.setRiskValue(info.getRiskValue() + 80); info.setRiskType(info.getRiskType() + " Invalid Certification ID: " + info.getCertificateId());end*/ rule "Foregin Flag Rule" when info : CustomerInfo (null == foreignFlag || true == foreignFlag) then //actions info.setRiskValue(info.getRiskValue() + 20); info.setRiskType(info.getRiskType() + " 境外标志: " + info.getForeignFlag());end//execute after all other rules are firedrule "Trim Risk Type Rule" salience -9999 when info : CustomerInfo (true) then info.setRiskType(info.getRiskType().trim());end
测试代码:
@Testpublic void testExeuctionTime(){long recordsNumber = 100000;long start = System.currentTimeMillis();long used = 0;for(int i = 0; i < recordsNumber ; i++){CustomerInfo info = new CustomerInfo();info.setRiskType("");info.setRiskValue(0);thresholdService.setCustomerThresholdsInfo(info);}used = System.currentTimeMillis() - start;System.out.println(used);start = System.currentTimeMillis();used = 0;for(int i = 0; i < recordsNumber; i++){CustomerInfo info = new CustomerInfo();info.setRiskType("");info.setRiskValue(0);thresholdService.setMatchThresholdsInfo(info);}used = System.currentTimeMillis() - start;System.out.println(used);}
测试结果:
recordsNumber = 10
54
424
recordsNumber = 100
23
713
[Thread-3] WARN org.drools.core.rule.constraint.MvelConstraint - Exception jitting: null == certificateEndDate || certificateEndDate.before(
new Date()) This is NOT an error and NOT prevent the correct execution since the constraint will be evaluated in intrepreted mode
[Thread-4] WARN org.drools.core.rule.constraint.MvelConstraint - Exception jitting: null == customerName || 0 == (info.getCustomerName().t
rim()).length() This is NOT an error and NOT prevent the correct execution since the constraint will be evaluated in intrepreted mode
[Thread-2] WARN org.drools.core.rule.constraint.MvelConstraint - Exception jitting: null == professionCode || 0 == (info.getProfessionCode()
.trim()).length() || "鍏朵粬".equals(professionCode) || "鍏跺畠".equals(professionCode) || "鏃犱笟".equals(professionCode) || "鏈煡".equal
s(professionCode) This is NOT an error and NOT prevent the correct execution since the constraint will be evaluated in intrepreted mode
[Thread-5] WARN org.drools.core.rule.constraint.MvelConstraint - Exception jitting: null == certificateId || 0 == (info.getCertificateId()
.trim()).length() This is NOT an error and NOT prevent the correct execution since the constraint will be evaluated in intrepreted mode
recordsNumber = 10000
406
70937
更多rules warning。。。。。。。。有机会和时间要研究下如何调优
加几句,一不小心用了spring tx adv,慢的更离谱了
INFO - init threshold service before test
83813
[Thread-4] WARN org.drools.core.rule.constraint.MvelConstraint - Exception jitting: null == certificateEndDate || certificateEndDate.before(new Date()) This is NOT an error and NOT prevent the cor
[Thread-3] WARN org.drools.core.rule.constraint.MvelConstraint - Exception jitting: null == professionCode || 0 == (info.getProfessionCode().trim()).length() || "鍏朵粬".equals(professionCode) ||
[Thread-5] WARN org.drools.core.rule.constraint.MvelConstraint - Exception jitting: null == customerName || 0 == (info.getCustomerName().trim()).length() This is NOT an error and NOT prevent the
[Thread-6] WARN org.drools.core.rule.constraint.MvelConstraint - Exception jitting: null == certificateId || 0 == (info.getCertificateId().trim()).length() This is NOT an error and NOT prevent t
146309
Tests run: 3, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 343.06 sec - in com.elulian.CustomerSecurityManagementSystem.service.ThresholdServiceTest
Running com.elulian.CustomerSecurityManagementSystem.service.UserInfoServiceTest
- drools6 基本使用 -- 2
- Drools6 基本使用 -- 1
- Drools6.5使用Drools6.5 Workbench 上的规则
- [翻译]Drools6.2帮助文档-目录
- [翻译]Drools6.2帮助文档-10. CDI
- Drools6.2 Eclipse环境搭建及HelloWord
- Drools6.2官方文档,尝试翻译
- Drools6.2 Eclipse环境搭建及HelloWord
- [翻译]Drools6.2帮助文档-4.KIE-上
- [翻译]Drools6.2帮助文档-9. Drools命令
- [翻译]Drools6.2帮助文档-11.与Spring集成
- drools6入门例子
- drools6入门例子(二)
- Drools6 术语介绍
- Spring与Drools6集成
- mongodb基本使用2
- Drools6 入门学习(一)——Drools6新特性
- Groovy基本使用(2):基本语法
- [Bzoj1601][Usaco2008 Oct]灌水
- 第二学期第112周项目3--摩托车继承自行车和机动车
- 404页面设置
- Hibernate主键生成策略
- 使用Myeclipse10.0自动生成搭建SSH框架(数据库表自动反向转换成Hibernate实体)实现用户登陆
- drools6 基本使用 -- 2
- MFC快速入门
- Linux文件共享(五)——线程共享文件
- c++ 中的多重继承和其权限问题
- 点圆的关系
- linux 创建快捷方式
- android SDK 22.6.2 开发解决方法 activity_main.xml fragment_main.xml
- Linux文件共享(四)——父进程与子进程之间的文件共享
- 《C和指针》第十三章 高级指针话题