数据文件增量备份

问题描述

数据文件更新(修改或者新增)之后,需要拷贝一份到备份机器。
由于文件数量较多,更新的只是一小部分,不能全部scp过去,通过paramiko提供的sftp功能,比较本地与备份机器的文件记录,主要是比较修改时间(modify time,st_mtime)。,传输其中不同的文件。
此外,为了方便对数据库的情况按不同日期进行整理,传输过去的文件保持与本地相同的读写时间(读:acess time,st_atime;写:modify time,st_mtime)。

解决方案

paramiko.SSHClient().open_sftp() 提供了sftp功能,包括:

  1. 传输文件,put(local_file, remote_file)
  2. 统计远端文件信息,stat(remote_file),注意这里需要处理远端文件不存在的情况(即本地文件为新增的情况)
  3. 修改远端文件时间,utime(remote_file, (st_atime, st_mtime))
# use this node as a client, write to a file server to backup a copy

import paramiko
import tqdm
import errno
import os

client = paramiko.SSHClient()
client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
hostname = "xx.xx.xx.xx"
port = "8008"
username = "fake"
password = "123456"

client.connect(hostname, port, username, password, compress=True)
sftp_client = client.open_sftp()

def remote_finfo(sftp, filename, remote_path):
    try:
        info = sftp.stat(remote_path + filename)
    except IOError as e:
        if e.errno == errno.ENOENT:
            return None
        raise
    else:
        return info

DIR = 'YOUR_LOCAL_DIR_PATH/'
RPATH = 'YOUR_REMOTE_DIR_PATH/'
for filename in tqdm.tqdm(os.listdir(DIR)):
    local_file = DIR + filename
    remote_file = RPATH + filename
    info1 = os.stat(local_file)
    info2 = remote_finfo(sftp_client, filename, RPATH)
    if info2 is not None:
        if info1.st_mtime > info2.st_mtime:
            sftp_client.put(local_file, remote_file)
            sftp_client.utime(remote_file, (info1.st_atime, info1.st_mtime))
    else:
        sftp_client.put(local_file, remote_file)
        sftp_client.utime(remote_file, (info1.st_atime, info1.st_mtime))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张似衡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值