spring-boot为cassandra配置hibernate-ogm [未找到dataSource]

时间:2016-10-24 14:30:20

标签: spring-boot cassandra spring-data spring-data-jpa hibernate-ogm

我正在尝试在spring boot上配置hibernate-ogm for Cassandra,但是没有dataSource是透明的,提供给entityManager,并且运行时出现以下错误:

***************************
APPLICATION FAILED TO START
***************************

Description:

Parameter 0 of constructor in org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaAutoConfiguration required a bean of type 'javax.sql.DataSource' that could not be found.
    - Bean method 'dataSource' not loaded because @ConditionalOnProperty (spring.datasource.jndi-name) did not find property 'jndi-name'
    - Bean method 'dataSource' not loaded because @ConditionalOnBean (types: org.springframework.boot.jta.XADataSourceWrapper; SearchStrategy: all) did not find any beans


Action:

Consider revisiting the conditions above or defining a bean of type 'javax.sql.DataSource' in your configuration.

为案例打击工作流程

首先在spring上禁用相关jpa的自动配置:

@Configuration
@ComponentScan
@EnableAutoConfiguration(exclude = {
        DataSourceAutoConfiguration.class,
        DataSourceTransactionManagerAutoConfiguration.class,
        HibernateJpaAutoConfiguration.class
})
public class GsDataApplication {
    public static void main(String[] args) {
        SpringApplication.run(GsDataApplication.class, args);
    }
}

和项目依赖项是:

dependencies {
    compile project(':shared')

    compile('joda-time:joda-time:2.9.4')
    //compile('org.hibernate:hibernate-core:5.2.2.Final')
    compile('org.hibernate.ogm:hibernate-ogm-cassandra:5.0.1.Final')
    compile('org.hibernate:hibernate-search-orm:5.5.4.Final')
    compile('javax.transaction:jta:1.1')
    compile('org.springframework.data:spring-data-jpa:1.10.4.RELEASE')
    compile('org.springframework.boot:spring-boot-starter-social-facebook')
    compile('org.springframework.boot:spring-boot-starter-social-twitter')
}

持久性配置:

@Configuration
@EnableJpaRepositories(basePackages = {
        "com.gs.gsData.identity"
})
@EnableTransactionManagement
class PersistenceContext {
    @Bean
    LocalContainerEntityManagerFactoryBean entityManagerFactory(Environment env) {
        LocalContainerEntityManagerFactoryBean entityManagerFactoryBean = new LocalContainerEntityManagerFactoryBean();
        entityManagerFactoryBean.setJpaVendorAdapter(new HibernateJpaVendorAdapter());
        entityManagerFactoryBean.setPackagesToScan("com.gs.gsData.domain");

        Properties jpaProperties = new Properties();
        jpaProperties.put("javax.persistence.transactionType", "resource_local");
        jpaProperties.put("hibernate.ogm.datastore.provider", "cassandra_experimental");
        jpaProperties.put("hibernate.ogm.datastore.host", "127.0.0.1");
        jpaProperties.put("hibernate.ogm.datastore.port", "9042");
        jpaProperties.put("hibernate.ogm.datastore.database", "db-name");
        jpaProperties.put("hibernate.ogm.datastore.username", "cassandra");
        jpaProperties.put("hibernate.ogm.datastore.password", "password");
        jpaProperties.put("hibernate.ogm.datastore.create_database", "true");

        entityManagerFactoryBean.setPersistenceProviderClass(HibernateOgmPersistence.class);
        entityManagerFactoryBean.setJpaProperties(jpaProperties);

        return entityManagerFactoryBean;
    }

    @Bean
    JpaTransactionManager transactionManager(EntityManagerFactory entityManagerFactory) {
        JpaTransactionManager transactionManager = new JpaTransactionManager();
        transactionManager.setEntityManagerFactory(entityManagerFactory);
        return transactionManager;
    }
}

实体样本

@Entity
@Data
@AllArgsConstructor
@Table(name = "`User`")
public class User extends AbstractTiming{
    @Id @GeneratedValue
    private Long id;
    private String firstName, lastName, description;

    public User(){}
}

ADO @Repository

public interface UserDAO extends JpaRepository<User, Long> {
    User findByFirstName(String firstName);
    List<User> findByLastName(String lastName);
}

那么最后,有没有办法创建DataSource来引用Hibernate OGM?

或避免直接dataSource提供程序的任何其他操作。非常感谢任何帮助!

1 个答案:

答案 0 :(得分:0)

Hibernate OGM将连接存储在自己的类中:org.hibernate.ogm.datastore.spi.DatastoreProvider

所以在启动时它不处理DataSource,不确定是否有办法从cassandra连接创建一个DataSource,并将它添加到JNDI中以供springboot查找。

原因是目前在定义连接细节的NoSQL数据存储中没有标准。