使用NoSQL数据库
Spring Data还提供了对多种NoSQL数据库的支持,包括MongoDB、Neo4j和Redis。它不仅支持自动化的Repository,还支持基于模板的数据访问和映射注解。
此博客的主要内容是针对这些数据库在Spring中的配置以支持其使用。
一. 启用MongoDB
1.1Java配置方法1
为了有效使用Spring Data MongoDB,我们需要在Spring配置中添加几个必要的bean。首先,我们需要配置MongoClient,以便于访问MongoDB数据库。同时,我们还需要一个MongoTemplate bean,实现基于模板的数据库访问。此外,不是必须,但是强烈推荐启用Spring Data MongoDB的自动化Repository生成功能。
配置代码示例:
@Configuration
@EnableMongoRepositories(basePackages = "orders.db") //启用MongoDB的Repository功能
public class MongoConfig{
@Bean
public MongoFactoryBean mongo(){
MongoFactoryBean mongo = new MongoFactoryBean();
mongo.setHost("localhost");
return mongo;
}
@Bean
public MongoOperations mongoTemplate(Mongo mongo){
return new MongoTemplate(mongo, "OrderDB");
}
}
1.2 Java配置方法2
除了直接声明这些bean,我们还可以让配置类拓展AbstractMongoConfiguration并重载getDatabaseName()和mongo()方法。
配置代码示例(JavaConfig):
package orders.config;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.mongodb.config.AbstractMongoConfiguration;
import org.springframework.data.mongodb.repository.config.EnableMongoRepositories;
import com.mongodb.Mongo;
import com.mongodb.MongoClient;
@Configuration
@EnableMongoRepositories(basePackages = "orders.db") //启用MongoDB的Repository功能
public class MongoConfig extends AbstractMongoConfiguration {
//只当数据库名称
@Override
protected String getDatabaseName() {
return "OrdersDB";
}
//创建MongoDB客户端
@Override
public Mongo mongo() throws Exception {
return new MongoClient();
}
}
如果MongoDB服务器运行在其它的机器上,那么可以在创建MongoClient的时候进行指定:
public Mongo mongo() throws Exception {
return new MongoClient("mongodbserver");
}
如果MongoDB服务器监听的端口不是默认的27017,在创建MongoClient的时候,还需要制定端口:
public Mongo mongo() throws Exception {
return new MongoClient("mongodbserver", 37017);
}
如果MongoDB服务器运行在生产配置上,我认为你可能还启用了认证功能。在这种情况下,为了访问数据库,我们还需要提供应用的凭证。
@Autowired
private Environment dev;
public Mongo mongo() throws Exception {
MongoCredential credential = MongoCredential .createMongoCRCredential(
env.getProperty("mongo.username"), "OrdersDB", env.getProperty("mongo.password").toCharArray());
return new MongoClient(new ServerAddress("localhost", 37017), Arrays.asList(credential));
}
1.3 xml配置
核心代码:
<mongo:repositories base-package="order.db" />
<mongo:mongo />
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg ref="mongo" />
<constructor-arg value="OrdersDB" />
</bean>
二. Neo4j的配置
配置Spring Data Neo4j的关键在于声明GraphDatabaseService bean和启用Neo4j Repository自动生成功能。
2.1 Java配置示例
package orders.config;
import org.neo4j.graphdb.GraphDatabaseService;
import org.neo4j.graphdb.factory.GraphDatabaseFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.neo4j.config.EnableNeo4jRepositories;
import org.springframework.data.neo4j.config.Neo4jConfiguration;
@Configuration
@EnableNeo4jRepositories(basePackages = "orders.db") //启用Repository自动生成功能
public class Neo4jConfig extends Neo4jConfiguration {
//设置模型的基础包
public Neo4jConfig() {
setBasePackage("orders");
}
//配置嵌入式数据库
@Bean(destroyMethod="shutdown")
public GraphDatabaseService graphDatabaseService() {
return new GraphDatabaseFactory()
.newEmbeddedDatabase("/tmp/graphdb");
}
}
配置远程需要认证的数据库
@Bean(destroyMethod="shutdown")
public GraphDatabaseService graphDatabaseService(Enviroment env) {
return new SpringRestGraphDatabase("http://graphdbserver:7474/db/data/", env.getProperty("db.username"), env.getProperty("db.password"));
}
2.2 xml配置
xml配置文件核心代码:
<neo4j:config storeDirectory="tmp/graphdb" base-package="orders" />
<neo4j:repositories base-package="orders.db" />
如果要配置远程Spring Data Neo4j访问远程的Neo4j服务器:
<neo4j:config base-backage="orders" graphDatabaseService="graphDatabaseService" />
<bean id="graphDatabaseService" class="org.springframework.data.neo4j.rest.SpringRestGraphDatabase">
<constructor-arg value="http://graphdbserver:7474/db/data/" />
<constructor-arg value="db.username" />
<constructor-arg value="db.password" />
</bean>
三. 连接到Redis
配置代码:
package cart;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
@Configuration
public class RedisConfig {
@Bean
public RedisConnectionFactory redisCF() {
return new JedisConnectionFactory();
}
@Bean
public RedisTemplate<String, Product> redisTemplate(RedisConnectionFactory cf) {
RedisTemplate<String, Product> redis = new RedisTemplate<String, Product>();
redis.setConnectionFactory(cf);
return redis;
}
}