rsync备份企业方案

企业有Linux服务器又有windows服务器,备份用rsync(服务端),Linux(客户端),Windows(客户端,cwrsync,旧版本有免费版)打包压缩数据往服务器上推!

rsync服务器,yum安装rsync,通过rsync--daemon方式运行

步骤:1,Yum安装后打开/etc/rsyncd.conf,写入以下配置参数

 1 ###resyncd.conf  start 
 2 uid = rsync
 3 gid = rsync
 4 use chroot = no
 5 max connections = 200
 6 timeout = 300
 7 pid file = /var/run/rsyncd.pid
 8 lock file = /var/run/rsyncd.lock
 9 log file = /var/log/rsyncd.log
10 ignore errors
11 read only = false
12 list = false
13 hosts allow = 0.0.0.0/24
14 secrets file = /etc/rsync.backup.password
15 auth users = rsync.backup
16 incoming chmod = D755,F755  #这个是windows客户端上传文件时会改动备份目录权限,故加此选项可以让推送到服务器的文件跟目录都是755权限
17 fake super = yes #这个是新版本rsync要加入的选项,详细看下面故障现象
18 [ruser] #rsync模块
19 path = /backup
20 #####rsync_config-------------------------------------end---------------------
View Code

           2,新建用户:useradd rsync,新建模块目录:目录的所有者更改为rsync用户,chown -R rsync.rsync 

           3,新建认证密码文件:echo 'rsync.backup:123456' > /etc/rsync.backup.password,并把密码文件的权限更改:chmod 600   注意:这个密码文件的所有者是开启rsync服务的用户

           4,检查防火墙跟selinux,让873端口能被其他服务器访问

           5,见rsync客户端(Linux)第五项,shell命令如下

 1 for dir in `ls /backup/` #循环备份目录,dir就是每台服务器的IP地址
 2 do
 3  if [ -f /backup/$dir/bak_$(date +%F)_${dir}.tar.gz ] #判断目录下有无当天的打包数据,有就证明客户端推送成功,没有即是失败
 4  then
 5    echo "$dir backup is success">>/tmp/log/$(date +%F)_backup_result.log
 6  else
 7    echo "$dir backup is faild">>/tmp/log/$(date +%F)_backup_result.log
 8  fi
 9 done
10 #以上会把当天推送成功与失败的信息写入到日志里面
View Code

rsync客户端(Linux)

步骤:1,Yum安装rsync

           2,新建认证密码文件:echo '123456' > /etc/rsync.backup.password,并把密码文件的权限更改:chmod 600

           3,测试:rsync -avz /backup/ rsync.backup@0.0.0.0::ruser --password-file=/etc/rsync.backup.password

           4,打包备份目录与文件,然后推送到服务器上,用定时任务每天执行一次,shell命令如下

#!/bin/bash
ip=$(ifconfig ens192 | awk -F "[ :]+" 'NR==2{print $3}') #获取本机IP地址
[ ! -d /backup/$ip ] && mkdir -p /backup/$ip #判断备份目录有无以本机IP地址命令的目录,没有就创建 
 cd /backup/$ip &&
 tar -zcf  bak_$(date +%F)_${ip}.tar.gz /etc /var/log/yum.log >/dev/null 2>&1 #打包
 rsync -az /backup/ rsync.backup@172.17.2.110::ruser --password-file=/etc/rsync.backup.password #推送  
 find /backup -type f -name '*.tar.gz' -mtime +7|xargs rm -rf #查找目录下打包文件超过7天的就删除掉
View Code

           5,由于有多台服务器需要备份,所以我们要在rsync服务端新建脚本,目的就是当客户端每日推送成功后把信息写入到文档里面,再把文档发送给管理员

rsync客户端(windows)

步骤:1,安装cwrsync客户端软件,记住rsync安装路径

           2, 进入安装路径的bin下面,新建密码文件,把认证密码写入

           3,cmd到rsync安装路径/bin下,执行rsync -avz /cygdrive/c/backup/ rsync.backup@0.0.0.0::ruser < rsync.backup.password

           4,新建.bat批处理文件,把rsync的相关命令写入

           5,在计划任务页面新建计划,每天备份一次,选定时间,程序选择上面新建的.bat批处理文件

内容来源于网络如有侵权请私信删除
你还没有登录,请先登录注册
  • 还没有人评论,欢迎说说您的想法!