Je suis confronté à un problème tout en obtenant la valeur du cache.spring-boot-devtools provoquant l'exception ClassCastException à partir du cache.
java.lang.RuntimeException: java.lang.ClassCastException: com.mycom.admin.domain.User cannot be cast to com.mycom.admin.domain.User
Configuration du cache
@Configuration
@EnableCaching
@AutoConfigureAfter(value = { MetricsConfiguration.class, DatabaseConfiguration.class })
@Profile("!" + Constants.SPRING_PROFILE_FAST)
public class MemcachedCacheConfiguration extends CachingConfigurerSupport {
private final Logger log = LoggerFactory.getLogger(MemcachedCacheConfiguration.class);
@Override
@Bean
public CacheManager cacheManager() {
ExtendedSSMCacheManager cacheManager = new ExtendedSSMCacheManager();
try {
List<SSMCache> list = new ArrayList<>();
list.add(new SSMCache(defaultCache("apiCache"), 86400, false));
cacheManager.setCaches(list);
} catch (Exception e) {
e.printStackTrace();
}
return cacheManager;
}
@Override
public CacheResolver cacheResolver() {
return null;
}
@Override
public CacheErrorHandler errorHandler() {
return null;
}
private Cache defaultCache(String cacheName) throws Exception {
CacheFactory cacheFactory = new CacheFactory();
cacheFactory.setCacheName(cacheName);
cacheFactory.setCacheClientFactory(new MemcacheClientFactoryImpl());
String serverHost = "127.0.0.1:11211";
cacheFactory.setAddressProvider(new DefaultAddressProvider(serverHost));
cacheFactory.setConfiguration(cacheConfiguration());
return cacheFactory.getObject();
}
@Bean
public CacheConfiguration cacheConfiguration() {
CacheConfiguration cacheConfiguration = new CacheConfiguration();
cacheConfiguration.setConsistentHashing(true);
return cacheConfiguration;
}
}
et annotés avec
@Cacheable(value = "apiCache#86400", key = "'User-'.concat(#login)")
J'utilise com.google.code.simple-printemps-memcached 3.5.0
Valeur devient mis en cache mais lors de l'obtention de l'application renvoie erreur de distribution de classe. Quels seraient les problèmes possibles?
Avez-vous le même 'class' sur votre classpath deux fois? Ou l'avez-vous chargé à partir de plusieurs chargeurs de classe (ou exemple dans un environnement WebApp). La cause habituelle d'une classe ne peut pas être convertie en elle-même. Les problèmes sont que les classes sont chargées à partir d'endroits différents ... –
A première vue, cela ressemble à un problème de ClassLoader. On dirait que vous avez deux classloaders différents qui ont chargé la même classe. – sisyphus
@sisyphus j'utilise spring boot + devtools. J'ai lu certains où devtools maintient un chargeur de classe pour les pots statiques et un pour le code de l'application. Cela causerait-il problème? – titogeo