前言
看过上一篇接手老项目的痛——MongoDB学习及集群搭建知道,最近接手了一个后妈养的项目,项目的数据库没有人维护,DBA以各种理由推脱暂时不接,面对裸奔没有备份的数据库,我的内心很焦灼,于是花了点时间把生产环境的自动备份给搞起来。
下面话不多说了,来一起看看详细的介绍吧
一些准备
既然都备份了,为了保险起见,备份与库就不放在同一台服务器上了,于是向运维申请了一台服务器,同时安装好mongo,如果不知道怎么安装mongo的话可以看我的上一篇文章。
安装完之后,首先测试下是否可以远程访问目标mongodb,到安装好mongo的bin目录下
./mongo 10.100.1.101:27017 #目标mongo的ip及端口
然后创建些必要的目录,比如备份文件放在哪个目录之类的。
接下来测试下利用mongodump来备份数据库:
./bin/mongodump --host test/10.100.1.101:27017,10.100.1.102:27017 -d testdb --out /data/temp # test为副本集名称 # 10.100.1.101:27017,10.100.1.102:27017为副本集节点,有多个可以多个 # -d testdb是要备份的库名,不填默认副本集下全部 # --out 保存路径
到这里,mongo的备份已经实现,现在要完成的就是自动啦。
编写脚本
自动定时备份其实就是通过crontab命令来实现啦。但前提是我们需要编写个定时跑的脚本。首先我们新建个脚本:
vi /home/local/mongod_bak.sh
然后编写对应的脚本,脚本上有对应的注释,供大家参考,这里主要做了三个动作,首先是备份,然后将备份的文件压缩,然后只保留最近7天的文件。
#!/bin/bash sourcepath='/home/local/mongodb/bin' #mongodb文件路径 targetpath='/home/local/mongodb_bak' #备份的路径 nowtime=$(date +%Y-%m-%d-%H) replicationname='test' #副本集名 dbname='testdb' #库名 port='27017' #端口 ip1='10.100.1.101' #ip ip2='10.100.1.102' echo "============== start backup ${nowtime} ==============" start() { ${sourcepath}/mongodump --host ${replicationname}/${ip1}:${port},${ip2}:${port} -d ${dbname} --out ${targetpath}/${nowtime} } execute() { start if [ $"back successfully!" else echo "back failure!" fi } if [ ! -d "${targetpath}/${nowtime}/" ] then mkdir ${targetpath}/${nowtime} fi execute echo "============== back end ${nowtime} ==============" echo "============== start zip ${nowtime} ==============" zip -r ${targetpath}/${nowtime}.zip ${targetpath}/${nowtime} rm -rf ${targetpath}/${nowtime} echo "============== zip end ${nowtime} ==============" echo "============== start delete seven days ago back ${nowtime} ==============" find ${targetpath} -type f -mtime +7 -name "*" -exec rm -rf {} \; echo "============== delete end ${nowtime} =============="
编写完之后,给到文件可执行权限,并可以手动执行测试下:
chmod +x /home/local/mongod_bak.sh
定时任务
最后就是添加执行计划了,修改/etc/crontab
crontab -e
添加执行脚本,保存即可。
30 1 * * * /home/local/mongod_bak.sh #表示每天凌晨1点30执行备份
这里简单介绍下crontab。
crontab命令常见于Unix和类Unix的操作系统之中,用于设置周期性被执行的指令。该命令从标准输入设备读取指令,并将其存放于crontab文件中,以供之后读取和执行。
通常,crontab储存的指令被守护进程激活, crond常常在后台运行,每一分钟检查是否有预定的作业需要执行。这类作业一般称为cron jobs。
一些常用命令可以参考下:
#启动服务 /sbin/service crond start #关闭服务 /sbin/service crond stop #重启服务 /sbin/service crond restart #重新载入配置 /sbin/service crond reload #查看crontab服务状态 service crond status #手动启动crontab服务 service crond start #查看crontab服务是否已设置为开机启动,执行命令: ntsysv #加入开机自动启动: chkconfig --level 35 crond on #列出crontab文件 crontab -l #编辑crontab文件 crontab -e #删除crontab文件 $ crontab -r #恢复丢失的crontab文件 #假设你在自己的$HOME目录下还有一个备份,那么可以将其拷贝到/var/spool/cron/<username>,其中<username >是用户名 #或者使用如下命令其中,<filename>是你在$HOME目录中副本的文件名 crontab <filename>
总结
慢工出细活,有些东西一开始觉得很难很麻烦,但当你静下心来认真研究下,还是很容易理解的,毕竟你不是第一个踩坑的,所以还是好好学习吧。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]