定时备份文件

将机房服务器文件定时备份到本地,以实现异地容灾! A:文件服务器 B:备份服务器(将A服务器文件备份到B服务器)
摸索完成写的本文,没有附上相关截图!

1.ssh免密登录

登录流程:
在这里插入图片描述
登录原理:
在这里插入图片描述

(1) 免密登录配置

在B服务器:
(1) 生成公私钥

ssh-keygen -t rsa        # 执行中会提示 ① 在/用户名/.ssh/目录下生成公私钥 ② 提示两次输入密码(无密码直接enter即可)

在A服务器:
(1) 生成公私钥
(2) 添加 authorized_keys文件

touch authorized_keys         # 将B服务器中/用户名/.ssh/目录下id_rsa.pub文件内容拷贝到新建的authorized_keys中

(3) 文件设置执行权限

chmod 600 authorized_keys

(4) 重启ssh服务

/etc/init.d/sshd restart

ssh免密登录原理

(2) 免密登录测试

在B服务器执行

ssh A-user@A-ip -p port         # A-user:A服务器用户名; A-ip:A服务器IP;port:A服务器端口号

正常情况,可以直接登录到A服务器!但是可能存在还需要输入A服务器密码情况
解决:参考博文
查看A服务器日志

cat /var/log/secure

可能存在:Authentication refused: bad ownership or modes for directory /root;提示我们 /root 目录的属主和权限配置不当。SSH不希望home目录和~/.ssh目录对组有写权限,于是执行以下命令进行更改:

chmod g-w /root

2. 简单备份脚本
#!/bin/bash
# 远程复制目录到指定目录  copy files from remote directory to local directory
# 声明一个变量用来表示要备份的目录(当然可以写成从控制台输入,这样脚本就更通用了)
remoteFileName=oa
backupFolder=/home/backup/
echo "开始远程文件备份......"
# 调用scp命令,其中port为服务器(服务器A)开放的ssh端口号 ipaddress为服务器的ip地址(可以使用公网或局域网)
scp -P22 -r root@10.0.192.19:/public/hart_file/file/$remoteFileName /home/backup/

# 睡眠1小时
# sleep 1h
# 当scp完成时,输出此信息
echo "文件备份已完成,开始压缩......"

# 声明一个变量用来获取当前系统时间并格式化为yyyyMMddhhmm
date=$(date "+%Y%m%d%H%M")

# 将备份的目录进行打包 打包名为:201903111021.zip
zip -r $backupFolder$date.zip $backupFolder$remoteFileName

# 删除未打包目录
rm -rf $backupFolder$remoteFileName
3.定时执行脚本

定时执行,点我!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值