问题是这样的:
我有一个动态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/