mongodb备份策略
概述
数据库的备份非常非常非常重要!!!否则出问题连哭的机会有没有(欲哭无泪)今天主要是做一个mongodb的数据库备份。
1、关于备份
备份其实很简单,这里选择的是对mongodb中的某个库进行全备,例如saturn。关于备份策略,要根据实际情况来定,我们是一个小时备份一次。不废话直接上代码:
#!/usr/bin/env python
#-*- encoding: utf-8 -*-
import time
from subprocess import call
go_time = time.strftime("%Y-%m-%d_%H")
dir_path = "/data/backup"
def db_backup(user,pwd,host,db):
call("mongodump -u {} -p {} -h {} -d {} --gzip --archive={}/saturn-{}.gz".format(user,pwd,host,db,dir_path,go_time))
if __name__ == '__main__':
db_backup("hqms","hqms123","127.0.0.1:27017","saturn")
备份的文件saturn_2018-01-17_23.gz
我把备份和删除旧文件分开了,why?写在一个里面不是很好吗,主要是两个任务的执行频率不一样,删除的任务执行频率比较低,每天执行一次既可以,否则会浪费系统资源。
并且过多的耦合总会出问题。下面贴出删除代码:
#!/usr/bin/env python
# -*-encoding: utf-8 -*-
import os
import time
cur_time = time.time()
#当天零点的时间戳
st = cur_time - cur_time%86400 + time.timezone
dir_path = "/data/backup"
#删除
def drop_file(file_dir):
for filename in os.listdir(file_dir):
if os.path.isfile(file_dir + "/" +filename):
ft = os.stat(file_dir + "/" +filename)
lt = int(ft.st_mtime)
nt = cur_time - 3600*2 #距离现在2个小时之前的时间戳
dt = st - 86400*5 #距离现在5天之前的时间戳
#delete file by hour in today
if st < lt < nt:
try:
os.remove(file_dir + "/" + filename)
time.sleep(3)
print "Deleted success" + file_dir + "/" + filename
except (SyntaxError,IOError) as error:
print error
#delete file by day
elif lt < dt:
try:
os.remove(file_dir + "/" + filename)
time.sleep(3)
print "Deleted success" + file_dir + "/" + filename
except (SyntaxError,IOError) as error:
print error
if __name__ == '__main__':
drop_file(dir_path)
说明删除的代码是python2.7版本的。
附:
python3.6版本:
#!/usr/bin/env python
import os
import time
cur_time = time.time()
#获取当天零点的时间戳
st = cur_time - cur_time%86400 + time.timezone
dir_path = "/data/backup"
#删除
def drop_file(file_dir):
for filename in os.listdir(file_dir):
if os.path.isfile(file_dir + "/" +filename):
ft = os.stat(file_dir + "/" +filename)
lt = int(ft.st_mtime)
nt = cur_time - 3600*2 #获取当天保留截止的时间戳
dt = st - 86400*5 #获取保留天数的时间戳
#delete file by hour in today
if st < lt < nt:
try:
os.remove(file_dir + "/" + filename)
time.sleep(3)
print ("Deleted success" + file_dir + "/" + filename)
except (SyntaxError,IOError) as e:
print (e)
#delete file by day
elif lt < dt:
try:
os.remove(file_dir + "/" + filename)
time.sleep(3)
print ("Deleted success" + file_dir + "/" + filename)
except (SyntaxError,IOError) as e:
print (e)
if __name__ == '__main__':
drop_file(dir_path)
2、关于策略
备份脚本是一个小时执行一次,删除脚本是每天执行一次。使用jenkins的pipeline执行,给出删除策略的pipeline:
1)create a pipeline task in jenkins
pipeline{
agent{ label 'db1'}
stages{
stage('drop old file'){
steps{
dir('/data/scripts'){
sh 'python rm_backup.py'
}
}
}
}
}
2)you must create a schedule
Build periodically
50 23 * * *
mongodb备份策略的更多相关文章
- MongoDB 备份与还原 mongodump、mongorestore
目录 MongoDB 备份与还原 一. MongoDB 备份 1.mongodump 2 .cp 或者rsync 3.单节点意外关闭后,如何恢复数据 4.查看备份数据 二.MongoDB 还原 1.m ...
- mongodb 备份
本篇文章来自于阿里云技术专家郑涔(明俨)在2018年<Redis.MongoDB.HBase大咖直播大讲堂>技术直播峰会中的分享,该分享整体由四个部分构成: 1.MongoDB备份恢复 2 ...
- DG环境数据库RMAN备份策略制定
DG环境数据库RMAN备份策略制定: 主库(Primary) 全库备份 归档备份 删除历史文件夹 备库(Standby) 删除归档 引用说明 主库(Primary) $ crontab -l 0 1 ...
- 记录一则RMAN备份策略修正案例
背景:在给某客户处理问题时,发现客户数据库的备份空间即将用尽,进一步查看发现是用户数据库的当前RMAN备份策略存在潜在问题,需要修改备份策略. 环境:SunOS 5.10 + Oracle 11.2. ...
- mongodb 备份 还原 导出 导入
张映 发表于 2013-12-03 分类目录: nosql 标签:mongodb, 备份, 导入, 导出, 还原 mongodb数据备份和还原主要分为二种,一种是针对于库的mongodump和mong ...
- Oracle备份及备份策略
第二章. 了解备份的重要性 可以说,从计算机系统出世的那天起,就有了备份这个概念,计算机以其强大的速度处理能力,取代了很多人为的工作,但是,往往很多时候,它又是那么弱不禁风,主板上的芯片.主板电路.内 ...
- Oracle RMAN备份策略
建立增量备份:如果数据库运行于不归档模式下,只能在数据库干净关闭的情况下 ( 以 normal .immediate . transactional 方式关闭 ) 才能进行一致性的增量备份,如果数据库 ...
- MongoDB 备份(mongodump)恢复(mongorerstore) 导出 (Mongoexport) 导入( Mongoimport)
MongoDB 备份(mongodump) 在Mongodb中我们使用mongodump命令来备份MongoDB数据.该命令可以导出所有数据到指定目录中. mongodump命令可以通过参数指定导出的 ...
- SVN服务器几种备份策略---重点svnsync备份---OK
配置管理的一个重要使命是保证数据的安全性,防止服务器应硬盘损坏.误操作造成数据无法恢复的灾难性后果.因此制定一个完整的备份策略非常重要. 一般来说,备份策略应规定如下几部分内容:备份频度.备份方式.备 ...
随机推荐
- C++语言定义的标准转换
标准转换 C++ 语言定义其基础类型之间的转换. 它还定义指针.引用和指向成员的指针派生类型的转换. 这些转换称为“标准转换. 1. 整型提升 整数类型的对象可以转换为另一个更宽的整数类型(即,可表示 ...
- cpld fpga 区别
cpld fpga 区别 系统的比较,与大家共享: 尽管FPGA和CPLD都是可编程ASIC器件,有很多共同特点,但由于CPLD和FPGA结构上的差异,具有各自的特点: ①CPLD更适合完成各种算法和 ...
- Python自动化开发 - 面向对象(一)
本节内容 1.编程范式 面向过程编程 面向对象编程 2.面向对象编程介绍 类的语法 类与实例内存分配 构造方法 自定义方法 3.面向对象特性 一.编程范式 编程是程序员 用特定的语法+数据结构+算法组 ...
- Oracle包被锁定的原因分析及解决方案
http://blog.csdn.net/jojo52013145/article/details/7470812 在数据库的开发过程中,经常碰到包.存储过程.函数无法编译或编译时会导致PL/SQL ...
- 【DirectX】 AudioVideoPlayback 中的事件BUG
当访问 Video 中的 Audio 属性时,会造成 Video 的所有事件失效.经过反汇查看源码,原来在访问Audio属性时,Audio会通过当前Video对象创建一个新实例.而这个新实例会覆盖掉当 ...
- Python 关于 encode与decode 中文乱码问题
字符串在Python内部的表示是unicode编码,因此,在做编码转换时,通常需要以unicode作为中间编码,即先将其他编码的字符串解码(decode)成unicode,再从unicode编码(en ...
- LOJ#3048. 「十二省联考 2019」异或粽子(trie树+堆)
题面 传送门 题解 我们先把它给前缀异或和一下,然后就是要求前\(k\)大的\(a_i\oplus a_j\).把\(k\)乘上个\(2\),变成前\(2k\)大的\(a_i\oplus a_j\), ...
- [学习笔记]树形dp
最近几天学了一下树形\(dp\) 其实早就学过了 来提高一下打开树形\(dp\)的姿势. 1.没有上司的晚会 我的人生第一道树形\(dp\),其实就是两种情况: \(dp[i][1]\)表示第i个人来 ...
- jQuery基础(4)- 位置信息、事件流、事件对象、事件代理、jquery事件
一.jQuery的位置信息 jQuery的位置信是JS的client系列.offset系列.scroll系列封装好的一些简便api. 1.宽度和高度 a.获取宽度和高度,例如: .width() // ...
- Mac使用brew安装nginx,并解决端口访问权限问题
1.安装 brew install nginx 2.修改配置文件 sudo vi /usr/local/etc/nginx/nginx.conf 修改默认的8080端口为80 修改日志文件地方 err ...