依赖引入
对于redis数据库spring提供了基于jedis的数据访问框架Spring Data Redis,可以直接使用以下方式引入:
compile("org.springframework.session:spring-session-data-redis")
对于mongo数据库spring同样提供了访问框架,依然是Spring Data下,引入方式:
compile("org.springframework.session:spring-session-data-mongo")
参数配置
redis参数配置
#Redis配置
#数据库索引(默认为0)可以理解为DB2中等schema
spring.redis.database=0
#服务器地址
spring.redis.host=172.16.1.230
#服务器连接端口
spring.redis.port=6379
#服务器连接密码(默认为空)
spring.redis.password=
#连接池最大连接数(使用负值表示没有限制)
spring.redis.pool.max-active=8
#拦截池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.pool.max-wait=-1
#连接池中最大空闲连接
spring.redis.pool.max-idle=8
#连接池中最小空闲连接
spring.redis.pool.min-idle=0
#连接超时时间(毫秒)
spring.redis.timeout=0
spring.session.store-type=none
mongo参数配置
spring.data.mongodb.uri=mongodb://test:test@172.16.1.230:27017/test
创建要操作的实体
public class Customer{
private long id;
private String name;
private int age;
...省略构造方法、set、get、toString方法
}
其中redis操作由于需要序列化,实现Serializable接口。
redis数据库访问实现
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<String, Customer> redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String, Customer> template = new RedisTemplate<String, Customer>();
template.setConnectionFactory(factory);
template.setKeySerializer(new StringRedisSerializer());
template.setValueSerializer(new RedisObjectSerializer());
return template;
}
}
需要注意的是,这里不需要在注入RedisConnectionFactory,spring会为我自动读取配置文件中的配置,生成bean。
mongo数据库访问实现
相较于redis需要自己实现序列化和序列化,mongodb的访问要简单的多。只需要继承MongoRepository并添加自己需要的方法即可。
public interface CustomerRepository extends MongoRepository<Customer, Long> {
Customer findByName(String name);
}
其中CustomerRepository提供了新增,查询,删除等基本操作。
测试
redis测试
@Test
public void test() {
Customer customer = new Customer(1, "siva", 18);
redisTemplate.opsForValue().set(String.valueOf(customer.getId()), customer);
customer = new Customer(2, "zhourui", 24);
redisTemplate.opsForValue().set(String.valueOf(customer.getId()), customer);
Assert.assertEquals("siva", redisTemplate.opsForValue().get("1").getName());
}
mongo测试
@Before
public void setUp() {
customerRepository.deleteAll();
}
@Test
public void test() throws Exception {
customerRepository.save(new Customer(1L, "siva", 18));
customerRepository.save(new Customer(2L, "zhour", 24));
customerRepository.save(new Customer(4L, "xingm", 40));
Assert.assertEquals(3, customerRepository.findAll().size());
}
最后吐槽下mongo2.x和mongo3.x差距太大了,连创建用户等函数都不一样了,简直是丧心病狂。