服务器 A、服务器 B 均为 FreeBSD-12.2-RELEASE-amd64
服务器 A(发起端):192.168.100.10/24
服务器 B(同步源):192.168.100.20/24
设计需求 :实现服务器 B 的数据同步到服务器 A 上
# pkg install rsync
或
# cd /usr/ports/net/rsync/
# make install clean
# pkg info | grep rsync
rsync-3.2.3
# mkdir test
# chown root /home/test/
# cd /home/test/
# touch txt001
# ee /usr/local/etc/rsync/rsyncd.conf
uid = root
#服务端操作系统的用户
gid = wheel
#服务端操作系统的用户的组
use chroot = yes
#禁锢在源目录
address = 192.168.100.20
#监听地址
port 873
#用于通信的 TCP 端口,缺省是 873
log file = /var/log/rsyncd.log
#日志文件位置
pid file = /var/run/rsyncd.pid
#存档进程 ID 的文件位置
hosts allow = 192.168.100.0/24
#允许访问的客户机地址
[testcom]
#共享模块名称,自定义的名称,不一定要与同步目录相同
path = /home/test
#同步的目录名,必须是 uid 参数指定的用户和 gid 参数指定的组
comment = testcombackup
#模块说明文字
read only = yes
#是否为只读
dont compress = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2
#同步时不再压缩的文件类型
auth users = root
#授权账户
secrets file = /etc/rsyncd_users.db
#定义rsync客户端用户认证的密码文件
# ee /etc/rsyncd_users.db
root:12345678 #格式为 授权账户用户名:密码。支持多个用户,一行一个即可。
# chmod 600 /etc/rsyncd_users.db
rsync 的服务名是 rsyncd,启动 rsync 服务程序
# rsync --daemon #启动服务
# sysrc rsyncd_enable="YES" #设置开机自启动
# /usr/local/etc/rc.d/rsyncd start #启动服务
# sockstat | grep rsync
root rsync 1185 4 dgram -> /var/run/logpriv
root rsync 1185 5 tcp4 192.168.100.20:873 *:*
# ee /etc/ipfw.rules
IPF="ipfw -q add"
ipfw -q -f flush
#loopback
$IPF 10 allow all from any to any via lo0
$IPF 20 deny all from any to 127.0.0.0/8
$IPF 30 deny all from 127.0.0.0/8 to any
$IPF 40 deny tcp from any to any frag
# statefull
$IPF 50 check-state
$IPF 60 allow tcp from any to any established
$IPF 70 allow all from any to any out keep-state
$IPF 80 allow icmp from any to any
# open port for ssh
$IPF 110 allow tcp from any to any 22 out
$IPF 120 allow tcp from any to any 22 in
# open port for rsync
$IPF 130 allow tcp from any to any 873 in
# deny and log everything
$IPF 500 deny log all from any to any
# mkdir testBackUp
# chown root:root testBackUp
# rsync -avz [email protected]::testcom /home/testBackUp
testcom
是要从服务器同步的目录,由上方 /usr/local/etc/rsync/rsyncd.conf
自定义。
指定密码文件方式
创建授权备份账户认证的密码文件(客户端)
# ee /etc/rsyncd_users.db 12345678 #格式:密码进行同步:
# rsync -auvz --progress --password-file=/etc/rsyncd_users.db [email protected]::testcom /home/testBackUp
# ls -l /home/testBackUp/
total 0
-rw-r--r-- 1 root root 0 Feb 2 22:27 txt001