Rsync服务端
系统Ubuntu Server
IP地址
数据存放目录/home/mysql_data
cwRsync客户端
系统Windows Server
IP地址
同步的目录D:mysql_data
实现目的
cwRsync客户端每天凌晨:钟自动同步Rsync服务端/home/mysql_data目录中的数据到D:mysql_data目录
系统运维 温馨提醒qihang原创内容版权所有转载请注明出处及原文链接
一Rsync服务端配置
开启防火墙tcp 端口(Rsync默认端口)
说明Ubuntu默认安装是没有开启任何防火墙的为了服务器的安全建议大家安装启用防火墙设置这里推荐使用iptables防火墙
whereis iptables #查看系统是否安装防火墙
iptables: /sbin/iptables /usr/share/iptables /usr/share/man/man/iptablesgz #表示已经安装iptables防火墙
aptget install iptables #如果默认没有安装请运行此命令安装防火墙
iptables L #查看防火墙配置信息显示如下
Chain INPUT (policy ACCEPT)
target prot opt source destination
Chain FORWARD (policy ACCEPT)
target prot opt source destination
Chain OUTPUT (policy ACCEPT)
target prot opt source destination
nano /etc/iptablesdefaultrules #设置防火墙规则添加以下内容
##################################################################################################
*filter
# Allows all loopback (lo) traffic and drop all traffic to / that doesnt use lo
A INPUT i lo j ACCEPT
# Accepts all established inbound connections
A INPUT m state state ESTABLISHEDRELATED j ACCEPT
# Allows all outbound traffic
# You could modify this to only allow certain traffic
A OUTPUT j ACCEPT
# Allows HTTP and MySQLconnections from anywhere (the normal ports for websites)
A INPUT p tcp dport j ACCEPT
A INPUT p tcp dport j ACCEPT
A INPUT p tcp dport j ACCEPT
# Allows SSH connections for script kiddies
# THE dport NUMBER IS THE SAME ONE YOU SET UP IN THE SSHD_CONFIG FILE
A INPUT p tcp m state state NEW dport j ACCEPT
# Now you should read up on iptables rules and consider whether ssh access
# for everyone is really desired Most likely you will only allow access from certain IPs
# Allow ping
A INPUT p icmp m icmp icmptype j ACCEPT
# log iptables denied calls (access via dmesg command)
A INPUT m limit limit /min j LOG logprefix "iptables denied: " loglevel
# Reject all other inbound default deny unless explicitly allowed policy:
A INPUT j REJECT
A FORWARD j REJECT
COMMIT
##################################################################################################
ctrl+o #保存
ctrl+x #退出
备注是Rsync端口
iptablesrestore < /etc/iptablesdefaultrules #使防火墙规则生效
nano /etc/network/ifpreupd/iptables #创建文件添加以下内容使防火墙开机启动
##########################################################
#!/bin/bash
/sbin/iptablesrestore </etc/iptablesdefaultrules
##########################################################
chmod +x /etc/network/ifpreupd/iptables #添加执行权限
安装Rsync服务端软件
whereis rsync #查看系统是否已安装rsync出现下面的提示说明已经安装
rsync: /usr/bin/rsync /usr/share/man/man/rsyncgz
aptget install rsync #如果没有安装请执行这行命令来安装rsync
nano /etc/default/rsync #编辑配置文件
RSYNC_ENABLE=true #把false改为true设置开机启动rsync
ctrl+o #保存
ctrl+x #退出
创建rsyncdconf配置文件
nano /etc/rsyncdconf #创建配置文件添加以下代码
log file = /var/log/rsyncdlog #日志文件位置启动rsync后自动产生这个文件无需提前创建
[MySQL_Backup] #自定义名称
path = /home/mysql_data #Rsync服务端数据目录路径
comment = MySQL_Backup #模块名称与[MySQL_Backup]自定义名称相同
uid = root #设置rsync运行权限为root
gid = root #设置rsync运行权限为root
port= #默认端口
read only = no #设置为nocwRsync客户端可上传文件yes只读
write only = no #设置为nocwRsync客户端可下载文件yes不能下载
auth users = mysqlbakuser #执行数据同步的用户名可以设置多个用英文状态下逗号隔开
secrets file = /etc/rsyncpass #用户认证配置文件里面保存用户名称和密码后面会创建这个文件
hosts allow = #允许进行数据同步的客户端IP地址可以设置多个用英文状态下逗号隔开
hosts deny = #禁止数据同步的客户端IP地址可以设置多个用英文状态下逗号隔开
list = yes #显示Rsync服务端资源列表
ctrl+o #保存
ctrl+x #退出
创建用户认证文件
nano /etc/rsyncpass #配置文件添加以下内容
mysqlbakuser: #格式用户名:密码可以设置多个每行一个用户名:密码
ctrl+o #保存
ctrl+x #退出
设置文件权限
chmod /etc/rsyncdconf #设置文件所有者读取写入权限
chmod /etc/rsyncpass #设置文件所有者读取写入权限
启动rsync
/etc/initd/rsync start #启动
service rsync stop #停止
service rsync restart #重新启动
二cwRsync客户端设置
下载cwRsync客户端软件
下载地址
安装cwRsync客户端
解压cwRsync__Installerzip 双击打开cwRsync__Installerexe
Next 下一步
IAgree 同意安装
Next
默认安装路径 C:Program FilescwRsync
Install 安装
Close 安装完成关闭
测试是否与Rsync服务端通信成功
开始运行cmd
输入cd C:Program FilescwRsyncbin 回车
再输入telnet 回车
出现下面的界面说明与Rsync服务端通信成功
备注 C:Program FilescwRsyncbin 是指cwRsync程序安装路径
cwRsync客户端同步Rsync服务端的数据
开始运行cmd输入cd C:Program FilescwRsyncbin 回车
再输入rsync vzrtopg progress delete mysqlbakuser@::MySQL_Backup /cygdrive/d/mysql_data
输入密码 回车
出现下面的界面说明数据同步成功
可以打开D:mysql_data 与Rsync服务端/home/mysql_data目录中的数据对比一下查看是否相同
相关说明
d/mysql_data 代表D:mysql_data
MySQL_Backup 代表/etc/rsyncdconf文件中自定义的模块名称comment = MySQL_Backup
#Rsync服务端IP地址
mysqlbakuser #执行数据同步的用户
vzrtopg progress #显示同步过程详细信息
delete #从cwRsync客户端D:mysql_data目录中删除与Rsync服务端/home/mysql_data目录中不相同的数据即保证两边的数据完全一致
三在cwRsync客户端的任务计划中添加批处理脚本文件每天凌晨:钟自动同步Rsync服务端/home/mysql_data目录中的数据到D:mysql_data目录
打开C:Program FilescwRsyncbin目录新建passwdtxt
输入
保存
继续在C:Program FilescwRsyncbin目录新建MySQL_Backupbat
输入
@echo off
echo
echo 开始同步数据请稍等
echo
cd C:Program FilescwRsyncbin
rsync vzrtopg port= progress delete mysqlbakuser@::MySQL_Backup /cygdrive/d/mysql_data < passwdtxt
echo
echo 数据同步完成
echo
最后保存退出
添加批处理脚本到Windows任务计划
开始设置控制面板任务计划
打开添加任务计划下一步
浏览选择打开C:Program FilescwRsyncbin目录里面的MySQL_Backupbat
执行这个任务选择每天下一步
起始时间:
运行这个任务每天下一步
输入Windows系统管理员的登录密码下一步
完成
扩展说明如果要调整同步的时间打开任务计划里面的MySQL_Backup
切换到日程安排来选项设置还可以打开高级来设置每隔几分钟运行一次MySQL_Backupbat这个脚本
至此Ubuntu Server Rsync服务端与Windows cwRsync客户端实现数据同步完成