概述

数据库的备份非常非常非常重要!!!否则出问题连哭的机会有没有(欲哭无泪)今天主要是做一个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备份策略的更多相关文章

  1. MongoDB 备份与还原 mongodump、mongorestore

    目录 MongoDB 备份与还原 一. MongoDB 备份 1.mongodump 2 .cp 或者rsync 3.单节点意外关闭后,如何恢复数据 4.查看备份数据 二.MongoDB 还原 1.m ...

  2. mongodb 备份

    本篇文章来自于阿里云技术专家郑涔(明俨)在2018年<Redis.MongoDB.HBase大咖直播大讲堂>技术直播峰会中的分享,该分享整体由四个部分构成: 1.MongoDB备份恢复 2 ...

  3. DG环境数据库RMAN备份策略制定

    DG环境数据库RMAN备份策略制定: 主库(Primary) 全库备份 归档备份 删除历史文件夹 备库(Standby) 删除归档 引用说明 主库(Primary) $ crontab -l 0 1 ...

  4. 记录一则RMAN备份策略修正案例

    背景:在给某客户处理问题时,发现客户数据库的备份空间即将用尽,进一步查看发现是用户数据库的当前RMAN备份策略存在潜在问题,需要修改备份策略. 环境:SunOS 5.10 + Oracle 11.2. ...

  5. mongodb 备份 还原 导出 导入

    张映 发表于 2013-12-03 分类目录: nosql 标签:mongodb, 备份, 导入, 导出, 还原 mongodb数据备份和还原主要分为二种,一种是针对于库的mongodump和mong ...

  6. Oracle备份及备份策略

    第二章. 了解备份的重要性 可以说,从计算机系统出世的那天起,就有了备份这个概念,计算机以其强大的速度处理能力,取代了很多人为的工作,但是,往往很多时候,它又是那么弱不禁风,主板上的芯片.主板电路.内 ...

  7. Oracle RMAN备份策略

    建立增量备份:如果数据库运行于不归档模式下,只能在数据库干净关闭的情况下 ( 以 normal .immediate . transactional 方式关闭 ) 才能进行一致性的增量备份,如果数据库 ...

  8. MongoDB 备份(mongodump)恢复(mongorerstore) 导出 (Mongoexport) 导入( Mongoimport)

    MongoDB 备份(mongodump) 在Mongodb中我们使用mongodump命令来备份MongoDB数据.该命令可以导出所有数据到指定目录中. mongodump命令可以通过参数指定导出的 ...

  9. SVN服务器几种备份策略---重点svnsync备份---OK

    配置管理的一个重要使命是保证数据的安全性,防止服务器应硬盘损坏.误操作造成数据无法恢复的灾难性后果.因此制定一个完整的备份策略非常重要. 一般来说,备份策略应规定如下几部分内容:备份频度.备份方式.备 ...

随机推荐

  1. POJ1468 Sorting Slides

    Sorting Slides Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 4442   Accepted: 1757 De ...

  2. FastReport报表设计(仔细看)

    FastReport报表设计 2011-06-16 16:56:19|  分类: 系统开发|举报|字号 订阅     下载LOFTER我的照片书  |     目录 5.1 前言 5.2 基本概念及操 ...

  3. jsp中文乱码解决办法

    一.JSP页面显示乱码 二.表单提交中文时出现乱码 三.数据库连接 大家在JSP的开发过程中,经常出现中文乱码的问题,可能一至困扰着您,我现在把我在JSP开发中遇到 的中文乱码的问题及解决办法写出来供 ...

  4. .net framework 4.5 +steeltoe+ springcloud(三)实现Hystrix断路器

    在基于.net framework的服务客户端实现断路器功能,基本项目创建步骤可以参照我的另一篇发现和调用服务的笔记,地址:http://www.cnblogs.com/troytian/p/8621 ...

  5. ovs stp

    环路拓扑 组成拓扑结构的脚本 构成连通脚本 ip netns add ns1 ovs-vsctl add-br br1 ovs-vsctl add-port br1 tap1 -- set Inter ...

  6. Akka(42): Http:身份验证 - authentication, authorization and use of raw headers

    当我们把Akka-http作为数据库数据交换工具时,数据是以Source[ROW,_]形式存放在Entity里的.很多时候除数据之外我们可能需要进行一些附加的信息传递如对数据的具体处理方式等.我们可以 ...

  7. Spark踩坑——java.lang.AbstractMethodError

    今天新开发的Structured streaming部署到集群时,总是报这个错: SLF4J: Class path contains multiple SLF4J bindings. SLF4J: ...

  8. gulp 打包错误 TypeError: Path must be string. Received undefined

    Running gulp gives “path.js:7 throw new TypeError('Path must be a string. Received ' + inspect(path) ...

  9. Windows 网卡超过序列

    以前连接过别的网络,现在重新装网已经排到"网络连接9"了,连以前起过的wifi名称(ssid)都变成"*** 3"了,怎么把以前的清空呢? 这是解决办法: wi ...

  10. [Leetcode]303.区域和检索&&304.二维区域和检索

    题目 1.区域和检索: 简单题,前缀和方法 乍一看就觉得应该用前缀和来做,一个数组多次查询. 实现方法: 新建一个private数组prefix_sum[i],用来存储nums前i个数组的和, 需要找 ...