一、数据备份以及还原
1. 数据备份
mongodb使用mongodump命令对数据库进行备份。
mongodump -h host:port -d dbname -o dbdumptargetfilepath
说明:
- -h:指定mongodb所在服务器地址(需要备份)。比如:127.0.0.1或者127.0.0.1:27017
- -d:需要备份的数据库实例
- -o:备份数据存放的文件路径
2.数据还原
mongodb使用mongorestore命令进行数据库还原。
mongorestore -h host:port -d dbname path
说明:
- -h:指定mongodb所在服务器地址(需要还原)。比如:127.0.0.1或者127.0.0.1:27017
- -d:需要备份的数据库实例
- path:备份数据库文件存放的路径。比如:d://dbdump/mytest
以上部分就是mongodb数据库备份和还原具体命令。
二、mongodb集群搭建(docker)
为什么要搭建mongodb集群?首先:正式库肯定是要搭建集群的,来保证数据完整性和整个数据库的安全性以及整个数据库的性能;其次:mongodb事务控制不能在单点模式下进行,需要在副本集环境下进行事务处理。所以,搭建mongodb集群还是很有必要的。
1. 下载镜像(关于docker怎么下载,可以自行百度一下)
docker pull mongo
2. 启动三个节点
docker run --name m0 -p 27018:27017 -d mongo --replSet "rs"
docker run --name m1 -p 27019:27017 -d mongo --replSet "rs"
docker run --name m2 -p 27020:27017 -d mongo --replSet "rs"
3. 配置副本集
进入容器,连接mongo
docker exec -it m0 mongo admin
进行配置
var config = {
_id:"rs",
members: [
{_id: 0, host: "192.168.1.128:27018"},
{_id: 1, host: "192.168.1.128:27019"},
{_id: 2, host: "192.168.1.128:27020"}
]
};
rs.initiate(config);
按照以上配置就可完成mongodb的副本集配置。
三、springboot配置mongodb事务
1. 首先新增一个配置类代码如下:
@Configuration
public class MongoTransactionConfig {
// MongoDbFactory网上好多都是用这个,但是会报错,自己尝试了下面这个(不用谢我)
@Bean
public MongoTransactionManager transactionManager(MongoDatabaseFactory dbFactory) {
return new MongoTransactionManager(dbFactory);
}
}
2. 然后就跟平常使用事务注解一样使用就行了
@Service
public class UserService {
@Resource
MongoTemplate mongotemplate;
public List<User> getAllUser(){
return mongotemplate.findAll(User.class);
}
@Transactional
public boolean addUser(User user, UserInfo userInfo){
user.setUserInfo(userInfo);
mongotemplate.save(userInfo);
mongotemplate.save(user);
throw new RuntimeException("测试事务回滚"); //事务测试代码
return true;
}
}
自说自话。最近发现了一件事就是,那种能让你不管能给多少钱、不管能花多少时间、不管投入多少精力都愿意去做的事情好像越来越少了,好像都没有了,好害怕这种感觉。