三秒就入睡 發表於 2023-11-16 00:00:00

Centos rsync文件同步配置步骤分享

<p>
        rsync是类unix系统下的数据镜像备份工具,从软件的命名上就可以看出来了——remote sync<br><br><strong>它的特性如下:</strong><br>
          可以镜像保存整个目录树和文件系统。<br>
          可以很容易做到保持原来文件的权限、时间、软硬链接等等。<br>
          无须特殊权限即可安装。<br>
          快速:第一次同步时 rsync 会复制全部内容,但在下一次只传输修改过的文件。rsync 在传输数据的过程中可以实行压缩及解压缩操作,因此可以使用更少的带宽。<br>
          安全:可以使用scp、ssh等方式来传输文件,当然也可以通过直接的socket连接。<br>
          支持匿名传输,以方便进行网站镜象。<br><br><br>
        一、服务器端配置:<br><strong># yum -y install xinetd</strong></p>
<p>
        <strong># vi /etc/xinetd.d/rsync</strong><br>
        将如下代码</p>
<div>
        <div class="codetitle">
                <span><u>复制代码</u></span> 代码如下:</div>
        <div class="codebody" id="code52373">
                <br>
                service rsync<br>
                {<br>
                disable = yes<br>
                socket_type = stream<br>
                wait = no<br>
                user = root<br>
                server = /usr/bin/rsync<br>
                server_args = –daemon<br>
                log_on_failure += USERID<br>
                }</div>
        <p>
                <br><br>
                中的 <strong>disable = yes</strong> 改成 <strong>disable = no</strong></p>
</div>
<p>
        然后启动 xinetd<br><strong># /etc/init.d/xinetd start 或 service xinetd restart</strong><br>
        注意:如果服务器上装有防火墙记得要打开端口,默认端口是873</p>
<div>
        <div>
                # telnet 127.0.0.1 873<br>
                Trying 127.0.0.1...<br>
                telnet: connect to address 127.0.0.1: Connection refused<br>
                # iptables -A INPUT -s 192.168.0.0/255.255.255.0 -p tcp -m tcp --dport 873 -j ACCEPT<br>
                # iptables -A INPUT -p tcp -m tcp --dport 873 -j DROP</div>
</div>
<p>
        <strong># vi /etc/rsyncd.conf (这个文件如果不存在自己创建)</strong></p>
<div>
        <div>
                #Global Settings<br>
                uid = root #以什么身份运行rsync<br>
                gid = root<br>
                use chroot = no #不使用chroot<br>
                max connections = 20 #最大连接数<br>
                secrets file = /etc/rsyncd.secrets #密码文件位置,认证文件设置,设置用户名和密码<br>
                log file = /var/log/rsyncd.log #指定rsync的日志文件,而不将日志发送给syslog<br>
                pid file = /var/run/rsyncd.pid #指定rsync的pid文件<br>
                lock file = /var/run/rsync.lock #指定支持max connections参数的锁文件,默认值是/var/run/rsyncd.lock<br>
                comment = hello world<br>
                #motd file = /etc/rsyncd.motd #欢迎信息文件名称和存放位置(此文件没有,可以自行添加)<br><br>
                # 这里是认证的模块名,在client端需要指定<br>
                path = /titan24/www/repos # 需要做镜像的目录<br>
                auth users = rsync # 授权帐号。认证的用户名,如果没有这行,则表明是匿名,多个用户用,分隔<br>
                read only = no # yes只读 <span>值为</span><span>NO</span><span>意思为可读可写模式,数据恢复用</span><span>NO</span><br>
                hosts allow = 192.168.3.128 #允许访问的服务器IP<br>
                hosts deny = * #黑名单<br>
                list = true # 允许列文件<br>
                #ignore errors # 可以忽略一些无关的IO错误<br>
                #exclude = cache/111/ cache/222/ <span>#忽略的目录</span>
</div>
</div>
<p>
        <strong># vi /etc/rsyncd.secrets (设置访问(认证)的用户名密码)</strong></p>
<div>
        <div>
                rsync:111111 #用户名:密碼</div>
</div>
<p>
        给文件正确的权限<br><strong># chown root:root /etc/rsyncd.secrets<br>
        # chmod 600 /etc/rsyncd.secrets <wbr></wbr> #(必须是600)</strong></p>
<p>
        <strong>二、client 端进行同步</strong><br><br>
        客户端默认好像已经装了rsync,没有的话装下:<br><strong># yum -y install rsync</strong></p>
<p>
        执行异步同步操作:</p>
<div>
        <div>
                <p>
                        /usr/bin/rsync -avz --progress <wbr></wbr> rsync@192.168.3.191::backup <wbr></wbr> /www</p>
                <p>
                        # crontab -e #(可以定时每三分钟同步一次文件)</p>
                <div>
                        */3 <wbr></wbr> * * * * rsync -avz --progress <wbr></wbr> rsync@192.168.3.191::backup <wbr></wbr> /www</div>
                <p>
                        下面这个命令完整一点:</p>
                <p>
                        #vi /etc/rsyncd.pas<br>
                        加入密码<br>
                        rsyncofpass<br><span>注意,客户端的密码文件只需要密码,而不需要用户名!</span></p>
                <p>
                        更改文件权限:<br>
                        #chmod 0600 /etc/rsyncd.pas</p>
                <p>
                        #rsync -vzrtopgu --progress --delete --password-file=/etc/rsyncd.pas  <wbr></wbr> rsync_user@192.168.0.2::rsync_module_name1 /www/</p>
                <p>
                        这个命令行中-vzrtopg里的v是verbose,<br>
                        z是压缩传输,<br>
                        r是recursive,<br>
                        topg都是保持文件原有属性如属主、时间的参数。<br>
                        u是只同步已经更新的文件,避免没有更新的文件被重复更新一次,不过要注意两者机器的时钟的同步。<br>
                        –progress是指显示出详细的进度情况,<br>
                        –delete是指如果服务器端删除了这一文件,那么客户端也相应把文件删除,保持真正的一致。<br>
                        后 面的rsync_user@192.168.0.2::rsync_module_name1中,之后的rsync_module_name1是模块名, 也就是在/etc/rsyncd.conf中自定义的名称,rsync_user是指定模块中指定的可以同步的用户名。<br>
                        最后的/www是备份到本地的目录名。<br>
                        在这里面,还可以用-e ssh的参数建立起加密的连接。<br>
                        可以用–password-file=/password/path/file来指定密码文件,这样就可以在脚本中使用而无需交互式地输入验证密码了,这里需要注意的是这份密码文件权限属性要设得只有属主可读。</p>
                <p>
                        #/usr/local/rsync/bin/rsync -vzrtopg –progress –delete <em><span>rsync_user@192.168.0.2::rsync_module_name1</span></em> /tmp/<br>
                        Password:<br>
                        或者你也可以制定password文件<br>
                        由于需要系统crontab执行,所以这里采用读入密码文件的方式,<br>
                        这个时候就成功了。<br><br><strong>同步命令说明:</strong><br><br>
                        1 显示目录内容<br><br>
                        命令<br>
                        ——<br>
                        a) rsync<br>
                        b) rsync -r<br>
                        c) rsync jack@192.168.0.1::<br>
                        d) rsync ssh_user@192.168.0.1:<br><br>
                        命令说明<br>
                        ———<br>
                        a) 显示目录内容(第一层)<br>
                        b) 递归显示目录内容<br>
                        c) 显示远程主机目录内容<br>
                        *注1:端口模式, 基于rsync用户的身份验证<br>
                        *注2:rsync server上的目录必须具有xx7的权限.<br><br>
                        d) 查看远程主机目录内容<br>
                        *注1:remote shell模式, 通过ssh连接的基于系统本地用户的身份验证<br>
                        *注2:这里只使用了一个冒号(:),同时用户名是远程主机的ssh 用户,密码也是ssh用户对应的密码。<br>
                        *注3:使用””,则列出文件夹本身的信息。若要列出文件夹内容,应使用”/”。<br><br>
                        参数说明<br>
                        ———<br>
                        -r 对目录进行递归操作<br><br>
                        2 本地目录之间同步<br><br>
                        命令<br>
                        ——<br>
                        a) rsync -av –progress / *** 注意(/) ***<br>
                        b) rsync -av –progress<br>
                        c) rsync -avu –progress –delete /<br>
                        d) rsync -av –progress –temp-dir=/tmp /<br><br>
                        命令说明<br>
                        ———<br>
                        a) 同步src-dir目录下所有文件到dst-dir目录下<br>
                        b) 同步src-dir目录下所有文件到dst-dir/src-dir目录下<br>
                        c) 对src-dir目录内容向dst-dir目录下进行差异更新,有增加/更新则添加替换,有减少则对其删减<br>
                        d) 比a)多了–temp-dir=/tmp,即指定/tmp为临时交换区,这样可以避免因目标目录空间不够引起的无法同步文件的错误。<br><br>
                        参数说明<br>
                        ———<br>
                        -a 相当于 -rlptgoD 的集合<br>
                        -u 等同于 –update,在目标文件比源文件新的情况下不更新<br>
                        -v 显示同步的文件<br>
                        –progress 显示文件同步时的百分比进度、传输速率<br>
                        –delete 删除目标目录中多于源目录的文件<br><br>
                        3 异地主机之间同步<br>
                        命令<br>
                        ——<br>
                        a) rsync -avz –progress jack@192.168.0.1::/<br>
                        b) rsync -avz –progress jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack<br>
                        c) rsync -avuz –progress –delete jack@192.168.0.1::/ –password-file=/home/jack/rsync.jack<br>
                        d) rsync -avz –progress jack@192.168.0.1::/<br><br>
                        命令说明<br>
                        ———<br>
                        a) 同步本地目录的内容到远程主机192.168.0.1的目录下,jack是rsync数据库用户(参见3. /etc/rsync.secrets)<br>
                        b) 通过自动读取用户密码而实现非交互登录文件同步<br>
                        c) 较b)多了-u和–delete<br>
                        d) 同步远程主机内容到本地目录</p>
        </div>
</div>
<p>
         </p>
頁: [1]
查看完整版本: Centos rsync文件同步配置步骤分享