2017-06-21 79 views
0

問題:規則(的InterestRate .drl)在獨立的Java代碼被解僱,並給我準確的結果口水集成彈簧引導工作不正常

package com.test.drool.config; 

import org.kie.api.KieServices; 
import org.kie.api.runtime.KieContainer; 
import org.kie.api.runtime.KieSession; 

import com.test.drool.facts.InterestRate; 

public class RunSampleInterestRate { 

    public static void main(String[] args) { 
    // TODO Auto-generated method stub 


    KieContainer container= KieServices.Factory.get().getKieClasspathContainer(); 
InterestRate interestRate=new InterestRate(); 
interestRate.setLender("RBL"); 
System.out.println("printing session object before inserting"+interestRate.toString()); 

    KieSession kieSession=container.newKieSession("ksession-rules"); 
    kieSession.insert(interestRate); 

    kieSession.fireAllRules(); 


     System.out.println(interestRate.getRate()); 


    } 

} 

給了我預期的12.5爲利率。

問題:我必須在休息服務中集成這個,並且我一直試圖在休息環境下測試相同的邏輯,並且它沒有給我預期的結果。在激發規則後,服務 總是返回默認值0.0。我的環境是春季開機和口水是6.5.0最後。

POJO:

package com.test.drool.facts; 

import com.fasterxml.jackson.annotation.JsonIgnoreProperties; 

@JsonIgnoreProperties(ignoreUnknown=true) 
public class InterestRate { 

    @Override 
    public String toString() { 
    return "InterestRate [lender=" + lender + ", principal=" + principal + ", store=" + store 
     + ", dealer=" + dealer + ", rate=" + rate + "]"; 
    } 
    private String lender; 
    private String principal; 
    private String store; 
    private String dealer; 
    private double rate; 
    public double getRate() { 
    return rate; 
    } 
    public void setRate(double rate) { 
    this.rate = rate; 
    } 
    public String getLender() { 
    return lender; 
    } 
    public void setLender(String lender) { 
    this.lender = lender; 
    } 
    public String getPrincipal() { 
    return principal; 
    } 
    public void setPrincipal(String principal) { 
    this.principal = principal; 
    } 
    public String getStore() { 
    return store; 
    } 
    public void setStore(String store) { 
    this.store = store; 
    } 
    public String getDealer() { 
    return dealer; 
    } 
    public void setDealer(String dealer) { 
    this.dealer = dealer; 
    } 
} 

豆配置

package com.test.drool.config; 

import org.kie.api.KieServices; 
import org.kie.api.runtime.KieContainer; 
import org.springframework.context.annotation.Bean; 
import org.springframework.context.annotation.Configuration; 
@Configuration 
public class DroolDependencyConfig { 
@Bean(name="kieContainer") 
    public KieContainer kieContainer() { 
    return KieServices.Factory.get().getKieClasspathContainer(); 
    } 
} 

控制器:

package com.test.drool.controllers; 

import org.slf4j.Logger; 
import org.slf4j.LoggerFactory; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.http.HttpStatus; 
import org.springframework.http.MediaType; 
import org.springframework.http.ResponseEntity; 
import org.springframework.web.bind.annotation.PostMapping; 
import org.springframework.web.bind.annotation.RequestBody; 
import org.springframework.web.bind.annotation.RequestMapping; 
import org.springframework.web.bind.annotation.RestController; 

import com.test.drool.facts.InterestRate; 
import com.test.drool.service.RuleExecuteService; 

@RestController 
@RequestMapping(value="/rule") 
public class RuleExecuteController { 
@Autowired 
    private RuleExecuteService executeService; 
private static Logger logger=LoggerFactory.getLogger(RuleExecuteController.class); 


@PostMapping(value = "/execute", consumes = MediaType.APPLICATION_JSON_VALUE,produces = MediaType.APPLICATION_JSON_VALUE) 
public ResponseEntity<Double> getInterestRate(@RequestBody InterestRate interestRate){ 
    logger.info(String.format("logging Request Object %s",interestRate.toString())); 
    return new ResponseEntity<Double>(executeService.executeRule(interestRate),HttpStatus.OK); 
    } 
} 

個RuleServiceImpl:

package com.test.drool.service.impl; 

import org.kie.api.runtime.KieContainer; 
import org.kie.api.runtime.KieSession; 
import org.slf4j.LoggerFactory; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.stereotype.Service; 

import com.test.drool.facts.InterestRate; 
import com.test.drool.service.RuleExecuteService; 
@Service 
public class RuleExecutorServiceImpl implements RuleExecuteService { 
private KieContainer kieContainer; 
private static org.slf4j.Logger logger=LoggerFactory.getLogger(RuleExecutorServiceImpl.class); 
@Autowired 
public RuleExecutorServiceImpl(KieContainer kieContainer) { 
this.kieContainer=kieContainer; 
    } 
    @Override 
    public double executeRule(InterestRate interestRate) { 
     logger.info("firing up session and executing rules"); 

     KieSession kieSession= kieContainer.newKieSession("ksession-rules"); 
      logger.info("Printing object before inserting in session"+interestRate.toString()); 
     kieSession.insert(interestRate); 
     kieSession.fireAllRules(); 
     System.out.println("returning values from rule execution"+">>>"+interestRate.getRate()); 
     return interestRate.getRate(); 
    } 

} 

DRL文件:

包com.test.drool.facts

rule "Interest Rate" 
when 
    $interestrate := InterestRate(lender.equals("RBL")) 
then 
$interestrate.setRate(12.30); 

end 

搖籃依賴性:

dependencies { 
compile "org.kie:kie-spring:${droolsVersion}" 
compile "org.kie:kie-api:${droolsVersion}" 
compile "org.drools:drools-core:${droolsVersion}" 
compile "org.drools:drools-compiler:${droolsVersion}" 
//compile('org.springframework.cloud:spring-cloud-starter-eureka') 
    compile('org.springframework.boot:spring-boot-starter-actuator') 
    compile ('org.springframework.boot:spring-boot-starter-web') 
     compile ('org.springframework.boot:spring-boot-starter-data-rest') 
    compile ('org.springframework.boot:spring-boot-devtools') 
    testCompile('org.springframework.boot:spring-boot-starter-test') 
    compile group: 'org.apache.httpcomponents', name: 'httpclient', version: '4.5.2' 
    compile group: 'org.apache.commons', name: 'commons-lang3', version: '3.0' 
} 
+0

您是否通過RBL貸款?你可以添加日誌記錄 – pandaadb

+0

是的,我已經添加了記錄器,並確認RBL作爲一個值正從我的其餘控制器傳遞迴我的服務,在這裏被注入到rulesession中。 – MrWayne

+0

我的意思是在你的問題中添加日誌記錄的輸出。請改變你的規則,並刪除'lender.equals(「RBL」)'部分,看看你的規則是否觸發。我期望這個問題會在那裏出現 – pandaadb

回答

0

我不知道它的工作原因,但我們保持在我們的gradle文件中最小的彈簧流口水。所有我和我的同事所做的只是在gradle中只有kie-spring和drool編譯器,它的工作方式就像一個魅力。我們還需要排除一些spring的模塊,因爲spring boot 1.5不起作用以及彈簧3.2,在這個彈簧上依賴於kie。對於未來的春季開機流口水開發,這裏是gradle。只需將其粘貼並構建並編寫代碼,就可以編寫任何其他彈簧引導項目。

repositories { 
    mavenCentral() 
    maven { 
     name 'jboss' 
     url 'http://repository.jboss.org/nexus/content/groups/public-jboss' 
    } 
} 
buildscript { 
    ext { 
     springBootVersion = '1.5.3.RELEASE' 
    } 
    repositories { 
     mavenCentral() 
    } 
    dependencies { 
     classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}") 
    } 
} 

apply plugin: 'java' 
apply plugin: 'eclipse' 
apply plugin: 'org.springframework.boot' 

version = '0.0.1' 
sourceCompatibility = 1.8 
targetCompatibility = 1.8 

repositories { 
    mavenCentral() 
} 

dependencyManagement { 
    imports { 
     mavenBom 'org.springframework.cloud:spring-cloud-dependencies:Camden.SR6' 
    } 
} 
dependencies { 
    compile ('org.kie:kie-spring:6.5.0.Final'){ 
     exclude group:'org.springframework', module: 'spring-core' 
     exclude group:'org.springframework', module: 'spring-tx' 
     exclude group:'org.springframework', module: 'spring-beans' 
     exclude group:'org.springframework', module: 'spring-context' 
    } 
    compile "org.drools:drools-compiler:6.5.0.Final" 
    compile ('org.springframework.boot:spring-boot-starter-web') 
    compile group: 'org.apache.commons', name: 'commons-lang3', version: '3.0' 

} 
task createFolder{ 
    def configDir = new File(project.buildDir.path+"/libs", "config") 
    def keystoreDir = new File(project.buildDir.path+"/libs", "keystore") 
    def logDir = new File(project.buildDir.path+"/libs", "log") 
    def libDir = new File(project.buildDir.path+"/libs", "lib") 

    if(!logDir.exists()){ 
    logDir.mkdirs() 
    } 
    delete configDir 
    delete libDir 
    delete keystoreDir 

    libDir.mkdirs() 
    configDir.mkdirs() 
    keystoreDir.mkdirs() 
} 

//copy config 
task copyConfig(type: Copy) { 
    into project.buildDir.path+"/libs/config" 
    from "config" 

} 
//copy keystore 
task copyKeystore(type: Copy) { 
    into project.buildDir.path+"/libs/keystore" 
    from "keystore" 
} 

//copy dependencies 
task copyRuntimeLibs(type: Copy) { 
    into project.buildDir.path+"/libs/lib" 
    from configurations.compile 

} 

task bundleAll(type: Jar){ 
    dependsOn 'createFolder', 'copyRuntimeLibs', 'copyConfig', 'copyKeystore' 

    manifest { 
     def manifestClasspath = configurations.compile.collect { "lib/" + it.getName() }.join(' ') 
     attributes 'Implementation-Title': 'rule-service', 
        'Implementation-Version': version, 
        'Main-Class': 'com.test.drool.starte.RuleStarter', 
        'Class-Path': manifestClasspath 
    } 
    baseName=project.name 
    from { (configurations.compile - configurations.compile).collect { it.isDirectory() ? it : zipTree(it) } } 
    with jar 
    exclude 'META-INF/*.RSA', 'META-INF/*.SF','META-INF/*.DSA' 
} 

task zip(type: Zip){ 
    dependsOn 'bundleAll' 
    from 'build/libs' 
}