[英]Spring Boot and Infinspan cache on JBoss
我已經在集群中安裝並運行了JBoss 7。 我正在開發一個Spring Boot 1.3.2應用程序。 我在domain.xml中定義了以下Infinispan緩存:
<cache-container name="my-cache" default-cache="auth">
<transport stack="tcp" lock-timeout="10000"/>
<replicated-cache name="auth" mode="SYNC" batching="true">
<locking isolation="REPEATABLE_READ"/>
<transaction mode="NONE"/>
<eviction strategy="LRU" max-entries="100"/>
<expiration max-idle="300000"/>
</replicated-cache>
</cache-container>
在application.properties文件中,我定義了以下內容:
spring.cache.type=infinispan
然后在我的緩存類中定義:
@CacheConfig(cacheNames="java:jboss/infinispan/cache/my-cache/auth")
當我嘗試在JBoss上部署應用程序時,出現以下錯誤:
Caused by: java.lang.IllegalArgumentException: No cache manager could be auto-configured, check your configuration (caching type is 'INFINISPAN'
如何配置它才能正常工作?
好的,我按照本教程解決了該問題。
這就是我所做的。
我創建了緩存配置類,它將定義在JBoss中配置的CacheManager:
@Configuration
@EnableCaching
public class CachingConfig {
@Bean
public CacheManager cacheManager() {
JndiTemplate jndiTemplate = new JndiTemplate();
try {
EmbeddedCacheManager embededCacheManager = (EmbeddedCacheManager) jndiTemplate.lookup("java:jboss/infinispan/container/my-cache");
SpringEmbeddedCacheManager cacheManager = new SpringEmbeddedCacheManager(embededCacheManager);
return cacheManager;
} catch (NamingException e) {
e.printStackTrace();
return null;
}
}
}
我添加了以下依賴項:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
</dependency>
<dependency>
<groupId>org.infinispan</groupId>
<artifactId>infinispan-spring</artifactId>
<version>5.1.2.FINAL</version>
</dependency>
並明確聲明Infinispan依賴項:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<configuration>
<archive>
<manifestEntries>
<Dependencies>org.infinispan</Dependencies>
</manifestEntries>
</archive>
</configuration>
</plugin>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.