一、數(shù)據(jù)備份以及還原
1. 數(shù)據(jù)備份
mongodb使用mongodump命令對(duì)數(shù)據(jù)庫(kù)進(jìn)行備份。
mongodump -h host:port -d dbname -o dbdumptargetfilepath
說(shuō)明:
- -h:指定mongodb所在服務(wù)器地址(需要備份)。比如:127.0.0.1或者127.0.0.1:27017
- -d:需要備份的數(shù)據(jù)庫(kù)實(shí)例
- -o:備份數(shù)據(jù)存放的文件路徑
2.數(shù)據(jù)還原
mongodb使用mongorestore命令進(jìn)行數(shù)據(jù)庫(kù)還原。
mongorestore -h host:port -d dbname path
說(shuō)明:
- -h:指定mongodb所在服務(wù)器地址(需要還原)。比如:127.0.0.1或者127.0.0.1:27017
- -d:需要備份的數(shù)據(jù)庫(kù)實(shí)例
- path:備份數(shù)據(jù)庫(kù)文件存放的路徑。比如:d://dbdump/mytest
以上部分就是mongodb數(shù)據(jù)庫(kù)備份和還原具體命令。
二、mongodb集群搭建(docker)
為什么要搭建mongodb集群?首先:正式庫(kù)肯定是要搭建集群的,來(lái)保證數(shù)據(jù)完整性和整個(gè)數(shù)據(jù)庫(kù)的安全性以及整個(gè)數(shù)據(jù)庫(kù)的性能;其次:mongodb事務(wù)控制不能在單點(diǎn)模式下進(jìn)行,需要在副本集環(huán)境下進(jìn)行事務(wù)處理。所以,搭建mongodb集群還是很有必要的。
1. 下載鏡像(關(guān)于docker怎么下載,可以自行百度一下)
docker pull mongo
2. 啟動(dòng)三個(gè)節(jié)點(diǎn)
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. 配置副本集
進(jìn)入容器,連接mongo
docker exec -it m0 mongo admin
進(jìn)行配置
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事務(wù)
1. 首先新增一個(gè)配置類(lèi)代碼如下:
@Configuration
public class MongoTransactionConfig {
// MongoDbFactory網(wǎng)上好多都是用這個(gè),但是會(huì)報(bào)錯(cuò),自己嘗試了下面這個(gè)(不用謝我)
@Bean
public MongoTransactionManager transactionManager(MongoDatabaseFactory dbFactory) {
return new MongoTransactionManager(dbFactory);
}
}
2. 然后就跟平常使用事務(wù)注解一樣使用就行了
@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("測(cè)試事務(wù)回滾"); //事務(wù)測(cè)試代碼
return true;
}
}
自說(shuō)自話。最近發(fā)現(xiàn)了一件事就是,那種能讓你不管能給多少錢(qián)、不管能花多少時(shí)間、不管投入多少精力都愿意去做的事情好像越來(lái)越少了,好像都沒(méi)有了,好害怕這種感覺(jué)。