linux/centos rsync安装配置教程

一、服务器端配置:

# yum -y install xinetd

# vi /etc/xinetd.d/rsync

将如下代码

service rsync

{

disable = yes

socket_type = stream

wait = no

user = root

server = /usr/bin/rsync

server_args = –daemon

log_on_failure += USERID

}

中的 disable = yes 改成 disable = no

然后启动 xinetd

# /etc/init.d/xinetd start 或 service xinetd restart

注意:如果服务器上装有防火墙记得要打开端口,默认端口是873

# telnet 127.0.0.1 873

Trying 127.0.0.1...

telnet: connect to address 127.0.0.1: Connection refused

# iptables -A INPUT -s 192.168.0.0/255.255.255.0 -p tcp -m tcp --dport 873 -j ACCEPT

# iptables -A INPUT -p tcp -m tcp --dport 873 -j DROP

# vi /etc/rsyncd.conf (这个文件如果不存在自己创建)

#Global Settings

uid = root #以什么身份运行rsync

gid = root

use chroot = no #不使用chroot

max connections = 20 #最大连接数

secrets file = /etc/rsyncd.secrets #密码文件位置,认证文件设置,设置用户名和密码

log file = /var/log/rsyncd.log #指定rsync的日志文件,而不将日志发送给syslog

pid file = /var/run/rsyncd.pid #指定rsync的pid文件

lock file = /var/run/rsync.lock #指定支持max connections参数的锁文件,默认值是/var/run/rsyncd.lock

comment = hello world

#motd file = /etc/rsyncd.motd #欢迎信息文件名称和存放位置(此文件没有,可以自行添加)

[backup] # 这里是认证的模块名,在client端需要指定

path = /titan24/www/repos # 需要做镜像的目录

auth users = rsync # 授权帐号。认证的用户名,如果没有这行,则表明是匿名,多个用户用,分隔

read only = no # yes只读 值为NO意思为可读可写模式,数据恢复用NO

hosts allow = 192.168.3.128 #允许访问的服务器IP

hosts deny = * #黑名单

list = true # 允许列文件

#ignore errors # 可以忽略一些无关的IO错误

#exclude = cache/111/ cache/222/ #忽略的目录

# vi /etc/rsyncd.secrets (设置访问(认证)的用户名密码)

rsync:111111 #用户名:密?

给文件正确的权限

# chown root:root /etc/rsyncd.secrets

# chmod 600 /etc/rsyncd.secrets #(必须是600)

二、client 端进行同步

客户端默认好像已经装了rsync,没有的话装下:

# yum -y install rsync

执行异步同步操作:

/usr/bin/rsync -avz --progress rsync@192.168.3.191::backup /www

# crontab -e #(可以定时每三分钟同步一次文件)

*/3 * * * * rsync -avz --progress rsync@192.168.3.191::backup /www

下面这个命令完整一点:

#vi /etc/rsyncd.pas

加入密码

rsyncofpass

注意,客户端的密码文件只需要密码,而不需要用户名!

更改文件权限:

#chmod 0600 /etc/rsyncd.pas

#rsync -vzrtopgu --progress --delete --password-file=/etc/rsyncd.pas rsync_user@192.168.0.2::rsync_module_name1 /www/

这个命令行中-vzrtopg里的v是verbose,

z是压缩传输,

r是recursive,

topg都是保持文件原有属性如属主、时间的参数。

u是只同步已经更新的文件,避免没有更新的文件被重复更新一次,不过要注意两者机器的时钟的同步。

–progress是指显示出详细的进度情况,

–delete是指如果服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致。

后 面的rsync_user@192.168.0.2::rsync_module_name1中,之后的rsync_module_name1是模块名, 也就是在/etc/rsyncd.conf中自定义的名称,rsync_user是指定模块中指定的可以同步的用户名。

最后的/www是备份到本地的目录名。

在这里面,还可以用-e ssh的参数建立起加密的连接。

可以用–password-file=/password/path/file来指定密码文件,这样就可以在脚本中使用而无需交互式地输入验证密码了,这里需要注意的是这份密码文件权限属性要设得只有属主可读。

#/usr/local/rsync/bin/rsync -vzrtopg –progress –delete rsync_user@192.168.0.2::rsync_module_name1/tmp/

Password:

或者你也可以制定password文件

由于需要系统crontab执行,所以这里采用读入密码文件的方式,

这个时候就成功了。

请继续浏览下一页:同步命令说明

---------------------------------同步命令说明:---------------------------------

1 显示目录内容

命令

——

a) rsync

b) rsync -r

c) rsync jack@192.168.0.1::

d) rsync ssh_user@192.168.0.1:

命令说明

———

a) 显示目录内容(第一层)

b) 递归显示目录内容

c) 显示远程主机目录内容

*注1:端口模式, 基于rsync用户的身份验证

*注2:rsync server上的目录必须具有xx7的权限.

d) 查看远程主机目录内容

*注1:remote shell模式, 通过ssh连接的基于系统本地用户的身份验证

*注2:这里只使用了一个冒号(:),同时用户名是远程主机的ssh 用户,密码也是ssh用户对应的密码。

*注3:使用””,则列出文件夹本身的信息。若要列出文件夹内容,应使用”/”。

参数说明

———

-r 对目录进行递归操作

2 本地目录之间同步

命令

——

a) rsync -av –progress / *** 注意(/) ***

b) rsync -av –progress

c) rsync -avu –progress –delete /

d) rsync -av –progress –temp-dir=/tmp /

命令说明

———

a) 同步src-dir目录下所有文件到dst-dir目录下

b) 同步src-dir目录下所有文件到dst-dir/src-dir目录下

c) 对src-dir目录内容向dst-dir目录下进行差异更新,有增加/更新则添加替换,有减少则对其删减

d) 比a)多了–temp-dir=/tmp,即指定/tmp为临时交换区,这样可以避免因目标目录空间不够引起的无法同步文件的错误。

参数说明

———

-a 相当于 -rlptgoD 的集合

-u 等同于 –update,在目标文件比源文件新的情况下不更新

-v 显示同步的文件

–progress 显示文件同步时的百分比进度、传输速率

–delete 删除目标目录中多于源目录的文件

3 异地主机之间同步

命令

——

a) rsync -avz –progress jack@192.168.0.1::/

b) rsync -avz –progress jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack

c) rsync -avuz –progress –delete jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack

d) rsync -avz –progress jack@192.168.0.1::/

命令说明

———

a) 同步本地目录的内容到远程主机192.168.0.1的目录下,jack是rsync数据库用户(参见3. /etc/rsync.secrets)

b) 通过自动读取用户密码而实现非交互登录文件同步

c) 较b)多了-u和–delete

d) 同步远程主机内容到本地目录

(0)

相关推荐

  • CentOS下安装配置Tomcat环境

    CentOS下安装配置Tomcat 演示环境 系统:Linux CentOS 6.3 32位 环境:无安装apache、php、mysql 账号:Root 一、下载相关安装包 注:可以先进入 #cd ...

  • 热部署Jrebel for Eclipse激活破解及安装配置教程(附下载)

    JRebel是一款JavaEE开发工具.JRebel允许开发团队在有限的时间内完成更多的任务修正更多的问题,发布更高质量的软件产品.Jrebel 可快速实现热部署,节省了大量重启时间,提高了个人开发效 ...

  • Atlas怎么安装配置 Atlas安装配置教程

    atlas是编写丰富的.可交互的和个性化的Web浏览器应用程序的最好方式.Atlas安装配置教程来啦!很多网友对于Atlas的安装配置还不是很清楚,那么Atlas怎么安装配置呢?下文给大家介绍一下! ...

  • Vmware ESXi 5.5 Server安装配置教程

    说起虚拟化最近几年特别火热,因为整合IT资源,节约成本,容易维护.这些好处我就不多讲了.其中Vmware就是非常有名虚拟化厂商,下面我将介绍Vmware ESXi 5.5 Server安装配置教程. ...

  • 在Linux服务器上安装配置socks5代理的教程

    socks5 SOCKS5 是一个代理协议,它在使用 TCP/IP协议通讯的前端机器和服务器机器之间扮演一个中介角色,使得内部网中的前端机器变得能够访问Internet网中的服务器,或者使通讯更加安全 ...

  • CentOS 操作系统安装图文教程

    首先要下载CentOS操作系统的ISO,下载地址点这里,目前最新版为5.3,下载文件有两种形式,一种是光盘CD版,要六张盘,要下载的文件为CentOS-5.3-i386-bin-1of6.iso、Ce ...

  • 详解在CentOS中安装配置FTP服务器软件VSFTP的流程

    安装 VSFTP 复制代码 代码如下: yum -y install vsftpd 创建FTP日志文件路径 复制代码 代码如下: touch /var/log/vsftpd.log 启动配置 复制代码 ...

  • GlusterFS分布式文件系统的安装配置教程

    GlusterFS主要应用在集群系统中,具有很好的可扩展性。软件的结构设计良好,易于扩展和配置,通过各个模块的灵活搭配以得到针对性的解决方案。可解决以下问题:网络存储,联合存储(融合多个节点上的存储空 ...

  • 在Linux系统上安装配置DNS服务器的教程

    简介 DNS 是计算机域名系统 (Domain Name System 或Domain Name Service) 的缩写,它是由解析器和域名服务器组成的.域名服务器是指保存有该网络中所有主机的域名和 ...