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

标签 java caching infinispan

问题是这样的:

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

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

所以,我尝试的是实现一些 EmbededCacheManager 和一些 CashContainers,但在大多数情况下,我遇到的问题是我根本无法添加 infinispan jar 到我的项目中,并使用该死的缓存。

我四处寻找,但找不到将依赖项添加到我的 WEB 项目中的方法。网上所有的教程,比如这个:http://infinispan.org/docs/stable/getting_started/getting_started.html ,正在使用 Maven,但我没有。我需要一个 Maven 免费的解决方案。

另外,我的代码:

static List<Session> sessions = new ArrayList<Session>(); 

我想做什么:

@Resource(lookup = "java:jboss/infinispan/container/myCache")
public CacheContainer myCache;

但我就是无法纠正。 我在网上搜索了一下,发现我需要在 MANIFEST.MF 文件中将 infinispan 依赖项添加到我的项目中,一旦我这样做了:

Manifest-Version: 1.0
Dependencies: org.infinispan export

我将我的 manifest 文件夹添加到 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 顺便说一句,是一行文字,显示了出现问题的行和列,问题出在第二行和第四列(我不知道第四列在哪里,因为,在standalone.xml 中,前几个字符是制表符...?)

希望您能解决我的问题,因为我不知道下一步该怎么做。 谢谢。

最佳答案

好的,我按照您的步骤进行操作,并进行了一些更改,

Java:

@Resource(lookup = "java:jboss/infinispan/container/myCache")
public CacheContainer myCache;

独立.xml

<replicated-cache name="sessions" mode="SYNC">
      <transaction mode="BATCH"/>   //added this line
</replicated-cache>

此外,在同一个 standalone.xml 文件中,我遇到了缺少 jgroup 子系统依赖项的错误

<subsystem xmlns="urn:jboss:domain:jgroups:4.0">

针对此问题的解决方案,我在standalone-full-ha.xml 中找到了有关jgroups 所需的所有依赖项,然后将它们全部复制到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 (我确信你那里还有其他 jars) 如果还有其他 infinispan jar,请删除它们,因为使用与服务器相同的版本很重要。

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

Java:

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
    }
}

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

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

关于java - 如何在我的 WEB 应用程序中启用 infinispan 缓存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48749143/

相关文章:

Java HTTP 发布原始数据

java - Android - 强制关闭、PDF 不可用、iText

java - 解析 XML 文件 (java)

python - 为什么我的 LRU 缓存未命中相同的参数?

caching - IIS7 Web.Config 缓存 - 这里有什么区别,它们是如何结合在一起的?

java - Infinispan 并发 DefaultCacheManager

java - 执行错误 : org. infinispan.util.concurrent.TimeoutException:ISPN000299:10 秒后无法获取 key 的锁

java - 将onClickListener与ListView中的CheckBoxes一起使用

android - 为 exoplayer 启用缓存

java - Hibernate为不同的表提供不同的缓存?