rsync单向同步
系统版本:Centos X64 6.4(最小化安装)
先安装依赖包
[root@localhost ~]# yum install vim wget lsof gcc make cmake makeconf autoconf automake openssh -y
开始下载安装
[root@localhost ~]# wget http://down1.chinaunix.net/distfiles/rsync-3.0.4.tar.gz
[root@localhost ~]# tar zxf rsync-3.0..tar.gz
[root@localhost ~]# cd rsync-3.0.
[root@localhost rsync-3.0.]# ./configure && make && make install
安装完毕后命令的绝对路径:/usr/local/bin/rsync
参数:
-a:表示归档模式,用递归方式传输文件
-v:详细输出
-z:传输时对文件进行压缩处理
-r:对子目录进行递归
-t:保持文件的时间信息
-p:保持文件的权限
-o:保持文件的属主信息
-g:保持文件的属组信息
--delete:表示以服务端为基准进行同步,保持服务端的目录文件和客户端的完全一致
--progress:用于显示数据同步的过程
--exclude:排除不需要同步的目录或者文件
同步本地目录到远程主机
命令格式:rsync -av --delete 本地目录绝对路径(不能带斜杠) 远程主机用户名@远程主机地址:远程绝对路径
如果没做ssh信任关系的话会需要输入远程主机的登录密码
[root@localhost ~]# rsync -a --delete /etc root@192.168.1.100:/tmp
同步本地目录下的文件到远程主机
命令格式:rsync -av --delete 本地目录绝对路径/ 远程主机用户名@远程主机地址:远程绝对路径
[root@localhost ~]# rsync -a --delete /etc/ root@192.168.1.100:/tmp
把rsync作为服务启动让远程客户端来同步
rsync服务端:192.168.1.101
rsync客户端:192.168.1.100
在rsync服务端创建一个默认的配置文件/etc/rsyncd.conf,
内容如下:
#指定传输文件时守护进程具有的用户ID,这里表示默认为nobady
uid=nobady
#指定传输文件时守护进程具有的用户组ID,这里表示默认为nobady
gid=nobody
#禁止切换目录
use chroot=no
#客户端的最大连接数
max connection=
#检查口令文件的权限,口令文件的权限用户属组必须是root,权限必须是600
strict modes=yes
#pid文件的位置
pid file=/var/run/rsyncd.pid
#lock文件的位置
lock file=/var/run/rsyncd.lock
#日志文件的位置
log file=/var/log/rsyncd.log #定义模块名
[gamelog]
#指定这个模块需要同步的路径
path=/usr/local/
#这个是注释 可以自己定义
comment=gamelog file
#忽略一些无关的IO错误
ignore errors
#no代表客户端可以上传文件,yes表示只读取
read only=no
#no表示客户端可以下载文件,yes表示不能下载
write only=no
#表示允许连接的主机地址
hosts allow=192.168.1.100
#表示不允许连接的主机地址
hosts deny=*
#不允许该模块被客户端列出
list=false
#指定传输文件时守护进程具有的用户ID,
uid=root
#指定传输文件时守护进程具有的用户组ID,
gid=root
#用来指定连接该模块的用户名,用户名可以自定义
auth users=back
#指定密码文件,文件里面记录的是用户名:密码
secrets file=/etc/srs.pass
帐号密码文件/etc/srs.pass
[root@localhost ~]# ll /etc/srs.pass
-rw-------. root root Jul : /etc/srs.pass
[root@localhost ~]# cat srs.pass
back:
启动服务端程序
[root@localhost ~]# /usr/local/bin/rsync --daemon
也可以指定配置文件启动:/usr/local/bin/rsync --daemon --config=配置文件绝对路径
客户端192.168.1.100
创建密码文件:
[root@localhost etc]# echo "" > rsyncd.pass
[root@localhost etc]# chmod rsyncd.pass
客户端同步命令格式:/usr/local/bin/rsync -vzrtopg --delete --progress --exclude "需要排除的目录和文件" 服务端用户名@服务端地址::模块名字 本地目录 --password-file=密码文件路径
[root@localhost etc]# rsync -vzrtopg --delete --password-file=/etc/rsyncd.pass back@192.168.1.101::gamelog /tmp/
receiving incremental file list
./
xx sent bytes received bytes 512.00 bytes/sec
total size is speedup is 4745.42
出错的排查方法
1.查看防火墙是否关闭,或者对873端口添加了白名单,可以在客户端telnet 服务端的873端口
2.查看帐号密码文件的权限和所属用户是否正确
shell安装脚本:
rsync_install.sh
#!/bin/bash function Install_Rsync()
{
yum install wget gcc make automake makeconf openssh*-y
wget http://down1.chinaunix.net/distfiles/rsync-3.0.4.tar.gz
tar zxf rsync-3.0..tar.gz && cd rsync-3.0.
./configure && make && make install
} function Create_Rsync_Conf()
{
cat <<EOF > /etc/rsyncd.conf
uid=nobody
gid=nobody
use chroot=no
max connections=
strict modes=yes
pid file=/var/run/rsyncd.pid
lock file=/var/run/rsyncd.pid
log file=/var/log/rsyncd.log
[WEBSERVER]
path=/webserver
comment=SHENG file
ignore errors
read only=no
write only=no
hosts allow=xxx.xxx.xxx.xxx
hosts deny=*
auth users=test
secrets file=/etc/rsyncd.pass
EOF
} which rsync
if [ $? -eq ]
then
echo -e "\033[1;32m \033[05m The rsync is Exist! \033[0m"
Create_Rsync_Conf
echo -e "\033[1;32m The configure file is /etc/rsyncd.conf \033[0m"
else
echo -e "\033[1;32m Setup rsync \033[0m"
Install_Rsync
echo -e "\033[1;32m Create config file \033[0m"
Create_Rsync_Conf if [ -f /etc/rsyncd.conf ]
then
echo -e "\033[1;32m The rsync install OK! \033[0m"
else
echo -e "\033[31m \033[05m The rsync install Fail! \033[0m"
fi
fi
shell启动脚本 放在/etc/init.d/ 下 给755权限 chmod 755 /etc/init.d/rsyncd
rsyncd
#!/bin/bash Rsync_Command=`whereis rsync | awk '{print $2}'` function Start()
{
${Rsync_Command} --daemon
if [ $? -eq ]
then
echo -e "\033[1;32m The rsyncd start successful...... \033[0m"
else
echo -e "\033[31m \033[05m The rsyncd start fail !!!!!!!! \033[0m"
fi
} function Stop()
{
if [ -f '/var/run/rsyncd.pid' ]
then
kill - `cat /var/run/rsyncd.pid`
sleep
proce_num=`ps -ef | grep ${Rsync_Command} | grep -v grep | wc -l`
if [ ${proce_num} -gt ]
then
echo -e "\033[31m \033[05m The rsyncd Stop fail !!!!!!!! \033[0m"
else
echo -e "\033[1;32m The rsyncd Stop successful...... \033[0m"
rm /var/run/rsyncd.pid
fi
else
echo -e "\033[31m \033[05m The /var/run/rsyncd.pid file is not exist! Check rsync is Runing ??? \033[0m" fi
} function Restart()
{
Stop
sleep
Start
} case $ in
start)
Start
;;
stop)
Stop
;;
restart)
Restart
;;
*)
echo -e "\033[31m \033[05m Use start|stop|restart \033[0m"
;;
esac
rsync单向同步的更多相关文章
- openstack私有云布署实践【9.3 主从controller单向同步glance-image目录】
采用Rysnc单向同步,而不用双方实时同步,原因是在历史的运行过程中,我们发现,有些镜像包太大,当在主用的glance将镜像保存时,并不是一时半会就把镜像保存好,当主用在保存时,备用节点又在实时同步那 ...
- rsync单项同步
配置rsync+inotify实时单向同步 定期同步的缺点: 执行备份的时间固定,延期明显,实时性差 当同步源长期不变化时,密集的定期任务是不必要的(浪费资源) 实时同步的优点: 一旦同步源出现变化, ...
- ceph 006 rbd高级特性 rbd快照 镜像克隆 rbd缓存 rbd增量备份 rbd镜像单向同步
版本 [root@clienta ~]# ceph -v ceph version 16.2.0-117.el8cp (0e34bb74700060ebfaa22d99b7d2cdc037b28a57 ...
- couchbase单向同步
我们知道,couchbase默认情况下就是N主的HA模式,bucket同时存储在多个节点中.如下所示: 但事实上,有些时候我们希望某些节点只能读,不能写以避免各种副作用以及分布式系统下出于管理和安全性 ...
- Rsync文件同步
Rsync文件同步 本章结构 关于rsync 1.一款增量备份工具,remote sync,远程同步,支持本地复制或者与其他SSH.rsync主机同步,官方网站:http://rsync.samba. ...
- 真正的inotify+rsync实时同步 彻底告别同步慢
真正的inotify+rsync实时同步 彻底告别同步慢 http://www.ttlsa.com/web/let-infotify-rsync-fast/ 背景 我们公司在用in ...
- rsync命令(同步/备份数据)
rsync命令rsync命令是一个远程数据同步工具,可通过 lam/wan快速同步多台主机间的文件.rsync使用所谓的 "rsync算法"来使用本地和远程两个主机之间的文件达到同 ...
- Linux实战教学笔记21:Rsync数据同步工具
第二十一节 Rsync数据同步工具 标签(空格分隔): Linux实战教学笔记-陈思齐 ---本教学笔记是本人学习和工作生涯中的摘记整理而成,此为初稿(尚有诸多不完善之处),为原创作品,允许转载,转载 ...
- 架设rsync服务器同步数据
什么是rsync rsync 是一个快速增量文件传输工具,它可以用于在同一主机备份内部的备分,我们还可以把它作为不同主机网络备份工具之用.本文主要讲述的是如何自架rsync服 务器,以实现文件传输.备 ...
随机推荐
- Mysql学习总结(43)——MySQL主从复制详细配置
环境 操作系统:CentOS-6.6-x86_64-bin-DVD1.iso MySQL版本:mysql-5.6.26.tar.gz 主节点IP:192.168.1.205 主机名:edu-mysql ...
- C51 原创电子琴 (蜂鸣器/计时器/中断/矩阵按键)
需求分析 用C51的16个矩阵按键当作两个八度的琴键 按下时发出相应音调的声音,静态数码管显示相应音符的数字. 为了解锁更多曲目,两个多的琴键设计成#4,显示时加上小数点 下图分别为1和#4的显示,其 ...
- python gdal库安装
yum安装了postgis之后,会安装依赖gdal centos7.5的repo中gdal为1.11.4-3版本
- BNUOJ 5629 胜利大逃亡(续)
胜利大逃亡(续) Time Limit: 2000ms Memory Limit: 32768KB This problem will be judged on HDU. Original ID: 1 ...
- hihoCoder#1042 跑马圈地
原题地址 经网友jokeren提醒,后面给出的代码虽然可以AC原题,但存在bug,主要是在矩形覆盖情况的判断上处理的不够完全. 看似挺复杂的,但是仔细分析一下可以化简: 首先,不用枚举周长,因为更长的 ...
- Nginx 的 server_names_hash_bucket_size 问题
在 Nginx 0.6.35 的版本中,配置多个 server 虚拟主机,必须要在配置文档中 http { 里头加上 server_names_hash_bucket_size 64; 这么一句 ht ...
- linux 常见名词及命令(四)
yum仓库的配置 yum仓库的配置文件存放在/etc/yum.repos.d/目录中. 第一步:切换到/etc/yum.repos.d/目录中. 第二步:使用vim编辑器打开一个名为'rhel7.re ...
- 封装HttpURLConnection
package com.pingyijinren.test; import java.io.BufferedReader; import java.io.InputStream; import jav ...
- [bzoj2287][poj Challenge]消失之物_背包dp_容斥原理
消失之物 bzoj-2287 Poj Challenge 题目大意:给定$n$个物品,第$i$个物品的权值为$W_i$.记$Count(x,i)$为第$i$个物品不允许使用的情况下拿到重量为$x$的方 ...
- 洛谷 U41572 Portal2
U41572 Portal2 题目背景 某地ENLIGHTENED的XM研究所正在研究Portal的处理法则,想要揭示XM能量的来源以及应用XM能量.ENLIGHTENED的首席科学家Jacks发现其 ...