Spring Boot 1.4.1和Cassandra 3.x

时间:2016-10-25 15:55:49

标签: java spring spring-boot cassandra cassandra-3.0

我想在Spring Boot项目中使用Cassandra 3.x.我发现当前发布的Spring Data Cassandra项目版本仅支持Cassandra 2.x.所以我想使用DataStax驱动程序而不是Spring Data Cassandra项目。我添加了

compile 'com.datastax.cassandra:cassandra-driver-core:3.1.1'

作为依赖。现在我可以将值插入到Cassandra集群的键空间中。但是当运行REST控制器的测试时,我得到一个错误

java.lang.NoClassDefFoundError: io/netty/handler/codec/http/FullHttpRequest

所以我添加了

compile 'io.netty:netty-all:4.1.6.Final'

作为依赖,错误消失了。但现在所有测试都使用

TestRestTemplate.postForObject(...)

TestRestTemplate.put(...)

失败。但是使用

TestRestTemplate.getForObject(...)

按预期工作。我假设Spring Boot的依赖项和我作为依赖项添加的Netty版本存在一些冲突。

我发现最新版本的DataStax Cassandra驱动程序在没有额外的Netty依赖性的情况下工作是2.1.5,其日期为2015年3月,并且不支持Cassandra 3.使用此驱动程序一切正常但我不想要使用旧的驱动程序。

更新: 我删除了DataStax驱动程序依赖项,并尝试使用Spring Data Cassandra的1.5.0.M1版本,并在buildcript中覆盖Spring,Spring Data Cassandra和Cassandra驱动程序版本。

ext['spring.version'] = '5.0.0.M2'
ext['spring-data-releasetrain.version'] = 'Ingalls-M1'
ext['cassandra-driver.version'] = '3.1.1'

这导致以下错误:

java.lang.NoClassDefFoundError: io/netty/util/Timer

使用Cassandra功能时。当我再次包含Netty时,Cassandra功能正常,但我使用TestRestTemplate.put.post的测试不再运行。 我再次尝试升级到Spring Boot Version 2.0.0.BUILD-SNAPSHOT,其中还包括Spring Data Cassandra 1.5.0.M1。现在,当我启动应用程序并使用DataStax驱动程序功能时,我得到与以前相同的NoClassDefFoundError。将Netty添加为依赖项会再次导致基于TestRestTemplate的单元测试......

更新:TestRestTemplate无法正常工作,因为Spring Boot在类路径上找到Netty且Netty4ClientHttpRequestFactory似乎不起作用时将其配置为使用Netty4ClientHttpRequestFactory

参见https://github.com/spring-projects/spring-boot/issues/7240https://jira.spring.io/browse/SPR-14860

如需修复,请参阅我对此问题的回答。

1 个答案:

答案 0 :(得分:5)

我坚持使用Spring Data Cassandra 1.5.0.M1和Cassandra驱动程序3.1.1使用以下版本覆盖:

ext['spring.version'] = '5.0.0.M2'
ext['spring-data-releasetrain.version'] = 'Ingalls-M1'
ext['cassandra-driver.version'] = '3.1.1'

为了使Cassandra驱动程序功能正常工作,我不得不将Netty添加为依赖项。

compile 'io.netty:netty-all:4.1.6.Final'

要制作TestRestTemplate.postForObject(...)TestRestTemplate.put(...),我必须提供RestTemplateBuilder @Bean并将其配置为使用SimpleClientHttpRequestFactory

@TestConfiguration
static class TestConfig {
    @Bean
    public RestTemplateBuilder restTemplateBuilder() {
        return new RestTemplateBuilder().detectRequestFactory(false).requestFactory(SimpleClientHttpRequestFactory.class);
    }
}