我正在使用spring处理drool dtable xls文件。 我已经使用外部位置在xls文件中实现了业务规则,然后在kie服务的帮助下执行规则。 以下是我在加载引擎规则的代码片段。 在spring初始化时我调用了init()方法 见下面的弹簧配置。
<bean id="droolsService" class="com.example.drools.DroolsServiceImpl" init-method="init">
Java代码
public void init() {
LOG.info("inside init");
KieSession kieSession;
for (RequestType type : droolsMap.keySet()) {
try {
kieSession = getKieSession(this.getDroolsMap().get(type));
droolsRules.put(type, kieSession);
} catch (Exception e) {
LOG.error("Failed to load kiesession:", e);
throw new RuntimeException(e);
}
}
}
private KieSession getKieSession(final String file) throws DroolsParserException, IOException, BiffException {
KieServices kieServices = KieServices.Factory.get();
KieFileSystem kfs = kieServices.newKieFileSystem();
InputStream stream = null;
String drl = null;
String RULE_PATH = "src/main/resources/";
SpreadsheetCompiler converter = new SpreadsheetCompiler();
//Workbook workbook = Workbook.getWorkbook(DroolsServiceImpl.class.getResourceAsStream(file));
Workbook workbook = Workbook.getWorkbook(new FileInputStream(file));
LOG.info("Loading rule file " + file);
for (Sheet sheet : workbook.getSheets()) {
LOG.info("Loading Sheet " + sheet.getName());
stream = new FileInputStream(file);
drl = converter.compile(stream, sheet.getName());
//StringReader reader = new StringReader(drl);
String DRL_FILE = RULE_PATH + sheet.getName() + ".drl";
System.out.println("Drool file added ::: " + DRL_FILE);
kfs.write(DRL_FILE, ResourceFactory.newReaderResource(new StringReader(drl)));
stream.close();
}
KieBuilder kieBuilder = kieServices.newKieBuilder(kfs).buildAll();
KieContainer kieContainer = kieServices.newKieContainer(kieServices.getRepository().getDefaultReleaseId());
KieSessionConfiguration conf = SessionConfiguration.newInstance();
KieSession ksession = kieContainer.newKieSession(conf);
if (kieBuilder.getResults().hasMessages(Message.Level.ERROR)) {
List<Message> errors = kieBuilder.getResults().getMessages(Message.Level.ERROR);
StringBuilder sb = new StringBuilder("Errors:");
for (Message msg : errors) {
sb.append("\n " + msg);
}
try {
throw new Exception(sb.toString());
} catch (Exception e) {
e.printStackTrace();
} finally {
if (stream != null)
stream.close();
if (workbook != null)
workbook.close();
}
}
return ksession;
}
一切都很完美,但问题是我无法扫描文件更改。如果文件被修改,那么我必须重新启动服务器才能同步更改。
我已经尝试过侦听器在xls dtable有任何更改后加载特定的init()方法,但它不起作用,同样的旧结果即将到来。
我尝试过kiescanner,但我无法理解这个概念。 KieScanner正在加载maven kjar,所以我想如何创建kjar。
如果drool文件中有任何更改,我只想kie api扫描并尝试在没有服务器重启的情况下重新加载kiecontainer中的整个更改。
答案 0 :(得分:0)
自己找到答案,发帖是因为它会帮助需要的人。
我做了什么,我使用过apache VFS File Monitor-
rootEpic
当文件被修改,创建或删除时,它将调用CustomFileListener。
以下是CustomFileListener的实现。
DefaultFileMonitor fm = new DefaultFileMonitor(new CustomFileListener());
}
当文件发生变化时我做了什么,它将调用fileChanged方法。
因为我从 ContextLoader.getCurrentWebApplicationContext(); 获取了缓存bean(DroolServiceImpl)并调用了它的init()方法。
所以这将重新加载整个过程并重新初始化KieModule,KieRepository。