Java 如何在我的WEB应用程序中启用infinispan缓存?

Java 如何在我的WEB应用程序中启用infinispan缓存?,java,caching,infinispan,Java,Caching,Infinispan,问题是: 我有一个动态Web应用程序,在那里我有一个会话列表作为一个静态字段,我现在正在研究将来可能出现的集群问题 我想将我的静态HashMap移动到一个可以独立于服务器访问的位置,换句话说,一旦我有2台服务器,并且一台具有静态HashMap的服务器死亡,另一台服务器应该能够使用infinispan缓存恢复HashMap,而不会因为服务器故障而丢失 因此,我尝试实现一些EmbeddedCacheManager和一些CashContainers,但在大多数情况下,我遇到了一个问题,就是我无法将in

问题是:

我有一个动态Web应用程序,在那里我有一个会话列表作为一个静态字段,我现在正在研究将来可能出现的集群问题

我想将我的静态HashMap移动到一个可以独立于服务器访问的位置,换句话说,一旦我有2台服务器,并且一台具有静态HashMap的服务器死亡,另一台服务器应该能够使用infinispan缓存恢复HashMap,而不会因为服务器故障而丢失

因此,我尝试实现一些EmbeddedCacheManager和一些CashContainers,但在大多数情况下,我遇到了一个问题,就是我无法将infinispan jar添加到我的项目中,并使用奇怪的缓存

我四处搜索,但找不到将依赖项添加到WEB项目的方法。网络上的所有教程,比如这个:,都在使用Maven,但我没有。我需要一个没有专家的解决方案

还有,我的代码:

static List<Session> sessions = new ArrayList<Session>(); 
但我就是不能把它做好。 我在网上四处搜索,发现我需要在MANIFEST.MF文件中将infinispan依赖项添加到我的项目中,一旦我这样做了:

Manifest-Version: 1.0
Dependencies: org.infinispan export
我将清单文件夹添加到我创建的src\META-INF文件夹中,因为它不在那里,现在我可以导入infinispan.cache

但是,我无法构建我的整个项目,在我添加的部分,它总是在我的standalone.xml文件中显示一些错误

代码如下:

<subsystem xmlns="urn:jboss:domain:infinispan:4.0">
        <cache-container name="myCache" default-cache="default" module="org.wildfly.clustering.server">
            <transport lock-timeout="60000"/>
            <replicated-cache name="sessions" mode="SYNC">
            </replicated-cache>
        </cache-container>
        ...
<\subsystem>
在控制台中,WildFly 10 btw写了一行,显示出现问题的行和列,问题在第2行,第4列我不知道第4列在哪里,因为在standalone.xml中,前几个字符是制表符

希望你明白我的问题,因为我不知道下一步该怎么办。
谢谢。

好的,我遵循了您的步骤,做了一些更改,使其正常工作

爪哇:

Standalone.xml

<replicated-cache name="sessions" mode="SYNC">
      <transaction mode="BATCH"/>   //added this line
</replicated-cache>
对于这个问题的解决方案,我在standalone-full-ha.xml中找到了您需要的关于jgroup的所有依赖项,并简单地将它们复制到standalone.xml中。我建议Total Commander执行此任务,他有内置的工具来比较两个文件

您的MANIFEST.MF文件是正确的,他在src/META-INF文件夹中的位置也是正确的

我曾经在infinispan上遇到过类似的问题,所有这些都是与Maven和他的依赖项一起工作的,但是有一项工作可以解决这个问题

您需要的是转到wildfly文件夹,在那里可以找到文件夹module\system\layers\base\org\infinispan\main 在那里你会发现这个文件:infinispan-core-8.2.4.Final可能是另一个版本 然后你必须去: Wildfly\module\system\layers\base\org\infinispan\commons\main 在那里你可以找到这个文件:infinispan-commons-8.2.4.Final,可能是另一个版本

这些文件显然是您的wildfly使用的:,它们具有您需要的infinispan函数的正确版本

将这两个文件复制到WEB/WebContent/WEB-INF/lib,我相信您还有其他JAR 如果还有其他infinispan jar,请删除它们,因为使用与服务器相同的版本很重要

完成后,您可以执行以下操作:

Manifest-Version: 1.0
Dependencies: org.infinispan export
爪哇:

这将允许您使用直接从缓存中获取的会话列表


希望我能帮助你。否则,祝你好运,你会需要它:

你在使用什么构建系统?我在eclipse中工作。新手,谢谢你给我指明了正确的方向,我有一个用于web应用程序的lib文件夹,但它是外部的,我现在移动到了项目中,你是对的,我在那里有一些infinispan罐子,这是一个更高的版本比我的罐子从野蝇,我删除他们,并放置正确的罐子从野蝇和它的工作!Thxalso,thx对于java代码和hashmap的建议,对于jgroups问题,但是它不是upnp,你很幸运,不久前我遇到了一个类似的问题,这花费了我很多时间来解决…:
<replicated-cache name="sessions" mode="SYNC">
      <transaction mode="BATCH"/>   //added this line
</replicated-cache>
<subsystem xmlns="urn:jboss:domain:jgroups:4.0">
private List<Session> sessions() {
    Cache<Integer, List<Session>> c = myCache.getCache("sessions");
    // since you List is not a HashMap, you will need to make sure that
    // you get this right
    List<Session> l = c.get(1); // this returns the List, but with the key 1, read all the code, you will understand
    if (l != null) { // if its ok, then return the list
        return l;
    } else { // you need to make sure the list exist in the cache, just for the first time, all the other times, l will be different then null
        l = new ArrayList<Session>(); // make an empty list
        c.put(1, l); //add it to the cache
        return l; // use the list as you wish
    }
}