java - 如何让 Infinispan 与 Camel 一起工作

标签 java caching intellij-idea apache-camel infinispan

import org.apache.camel.builder.RouteBuilder;
import org.apache.camel.component.infinispan.InfinispanConstants;
import org.apache.camel.component.jackson.JacksonDataFormat;
import org.apache.camel.model.dataformat.JsonLibrary;
import uk.co.sammy.model.Collection;

public class InfinispanRoute extends RouteBuilder {

    private JacksonDataFormat json = new JacksonDataFormat(Collection.class);

    @Override
    public void configure() throws Exception {
        from("file:src/data?noop=true&include=.*.json")
                .choice()
                .when()
                .jsonpath("$..CustInfo[?(@.firstName == 'Sammy')]").unmarshal(json)
                .log("Got customer data for ${body.custInfo.firstName}")
                .setHeader(InfinispanConstants.OPERATION, constant(InfinispanConstants.PUT_IF_ABSENT))
                .setHeader(InfinispanConstants.KEY, simple("${body.custInfo.firstName}"))
                .to("infinispan://localhost")
                .marshal().json(JsonLibrary.Jackson)
                .to("activemq:queue:incomingApplication", "activemq:queue:customerDetails");

        from("activemq:queue:incomingApplication")
                .setHeader(InfinispanConstants.OPERATION, constant(InfinispanConstants.GET))
                .setHeader(InfinispanConstants.KEY, constant("${body.custInfo.firstName}"))
                .to("infinispan://foo?cacheName=localCache")
                .setBody(simple("${header.CamelInfinispanOperationResult}"))
                .to("activemq:output");
    }
}

我的 pom.xml 如下所示

<properties>
        <activemq.version>5.14.1</activemq.version>
        <camel.version>2.18.0</camel.version>
        <infinispan.version>8.3.0.Final-redhat-1</infinispan.version>
        <camel-jbossdatagrid.version>6.6.1.Final-redhat-1</camel-jbossdatagrid.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.apache.camel</groupId>
            <artifactId>camel-core</artifactId>
            <version>${camel.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.camel</groupId>
            <artifactId>camel-jackson</artifactId>
            <version>${camel.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.camel</groupId>
            <artifactId>camel-jsonpath</artifactId>
            <version>${camel.version}</version>
        </dependency>
        <dependency>
            <groupId>org.infinispan</groupId>
            <artifactId>infinispan-embedded</artifactId>
            <version>${infinispan.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.camel</groupId>
            <artifactId>camel-jbossdatagrid</artifactId>
            <version>${camel-jbossdatagrid.version}</version>
        </dependency>

        <!--ActiveMQ -->
        <dependency>
            <groupId>org.apache.activemq</groupId>
            <artifactId>activemq-camel</artifactId>
            <version>${activemq.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.activemq</groupId>
            <artifactId>activemq-pool</artifactId>
            <version>${activemq.version}</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.10</version>
        </dependency>
        <dependency>
            <groupId>org.ow2.asm</groupId>
            <artifactId>asm-all</artifactId>
            <version>5.1</version>
        </dependency>
    </dependencies>

    <repositories>
        <repository>
            <id>fuse-release</id>
            <name>jboss Release Repository</name>
            <releases>
                <updatePolicy>never</updatePolicy>
            </releases>
            <snapshots>
                <enabled>false</enabled>
            </snapshots>
            <url>http://repo.fusesource.com/nexus/content/groups/public/</url>
        </repository>
    </repositories>
</project>

我已经尝试了三天,使用 REdhat 入门指南让这个简单的示例代码与 Infinispan 一起使用,并下载了快速入门 zip 来运行它,但仍然无法工作!我不断收到 Spring JMS 的错误“无法连接到 foo:11222”或“池未打开”,然后收到有关混合 Uber 和 Jars 版本的警告。我一开始使用 ehcache,它实现起来很痛苦,因为有限的简单示例展示了如何存储、检索和清除来自其余调用的缓存等。现在,我需要它工作,以便我可以轻松地将其迁移到 Openshift,但是,仍然行不通!每次重新启动项目时,我都会遇到不同的错误。请帮助您逐步设置 Infinispan 以使用我的上述代码进行工作,我们将非常感激。谢谢大家!

P.S:我已经通读了 Redhat 数据网格入门页面并按照他们的说明进行操作,然后才将此作为我的最后手段!!!

最佳答案

使用“infinispan://localhost”uri 格式将尝试连接到 Infinispan 服务器。要使用嵌入式缓存,您应该使用类似“infinispan://?cacheName=localCache”的内容

关于java - 如何让 Infinispan 与 Camel 一起工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40659202/

相关文章:

在 XML 中配置的 Spring Integration Kafka 端点的 Java DSL 等价物

java - 在 JBoss 7.x 中加载模块

java - java中哪些数据类型共享状态?

PHP Cache_Lite 替代方案

performance - 缓存高流量站点时处理并发问题

java - EhCache:简单程序不起作用

git - 每个git分支的IntelliJ运行配置

java - 我应该避免使用静态变量吗

java - 如何使用 IntelliJ IDEA 删除 javadoc

带有 IntelliJ IDEA 的 git : Could not read from remote repository