NoSQL数据库redis和mongo使用

本文介绍如何在Spring框架中集成Redis与MongoDB数据库,包括依赖引入、参数配置、实体类创建、数据库访问实现及测试方法。

依赖引入

对于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;
    ...省略构造方法、setget、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差距太大了,连创建用户等函数都不一样了,简直是丧心病狂。

以下是在 Ubuntu 18.04 系统中安装 HBase 2.5.8、Neo4j 3.5.28、Redis 4.0.9 MongoDB 3.6.3 的方法: ### 安装 HBase 2.5.8 1. **下载 HBase**:从 HBase 官方网站下载 HBase 2.5.8 的压缩包。 ```bash wget https://archive.apache.org/dist/hbase/2.5.8/hbase-2.5.8-bin.tar.gz ``` 2. **解压文件**: ```bash tar -zxvf hbase-2.5.8-bin.tar.gz ``` 3. **移动到指定目录**: ```bash sudo mv hbase-2.5.8 /usr/local/hbase ``` 4. **配置环境变量**:编辑 `~/.bashrc` 文件,添加以下内容: ```bash export HBASE_HOME=/usr/local/hbase export PATH=$PATH:$HBASE_HOME/bin ``` 使环境变量生效: ```bash source ~/.bashrc ``` ### 安装 Neo4j 3.5.28 参考安装 Neo4j 3.5+版本的步骤,添加 Neo4j version 4.0 apt-key 并且更新 apt 库: ```bash wget -O - https://debian.neo4j.com/neotechnology.gpg.key | sudo apt-key add - echo 'deb https://debian.neo4j.com stable 3.5' | sudo tee /etc/apt/sources.list.d/neo4j.list sudo apt update ``` 查看可安装的 Neo4j 版本: ```bash sudo apt list -a neo4j ``` 安装 Neo4j 3.5.28(如果有该版本): ```bash sudo apt install neo4j=3.5.28 ``` [^2] ### 安装 Redis 4.0.9 1. **下载 Redis 4.0.9**: ```bash wget http://download.redis.io/releases/redis-4.0.9.tar.gz ``` 2. **解压文件**: ```bash tar xzf redis-4.0.9.tar.gz ``` 3. **进入目录并编译**: ```bash cd redis-4.0.9 make MALLOC=libc ``` 4. **安装**: ```bash sudo make install ``` [^1] ### 安装 MongoDB 3.6.3 1. **导入公钥**: ```bash sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 ``` 2. **创建源列表文件**: ```bash echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu bionic/mongodb-org/3.6 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.6.list ``` 3. **更新 apt 库**: ```bash sudo apt update ``` 4. **安装 MongoDB 3.6.3**: ```bash sudo apt install -y mongodb-org=3.6.3 mongodb-org-server=3.6.3 mongodb-org-shell=3.6.3 mongodb-org-mongos=3.6.3 mongodb-org-tools=3.6.3 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值