zoukankan      html  css  js  c++  java
  • Linux rsync 命令详解

    服务器之间常常要保持些文件或目录的一致,比如一些大的软件下载网站,它们通常使用多台服务器来提供下载服务。当一台服务器上的文件更新后,其它的服务器 也需要更新,而且 在更新的时候应该是只对新增或是修改过的文件进行更新,否则会造成网络带宽和时间的浪费。rsync就是能有效的保持文件及目录的一致的优秀软件。

    rsync,remote synchronize

    顾名思意就知道它是一款实现远程同步功能的软件,它在同步文件的同时,可以保持原来文件的权限、时间、软硬链接等附加信息,而且可以通过ssh方式来传输文件,这样其保密性也非常好,另外它还是免费的软件。rysnc的官方网站:http://rsync.samba.org/,可以从上面得到最新的版本。当然,因为rsync是一款如此有用的软件,所以很多Linux的发行版本都将它收录在内了。你的Linux里并没有安装rsync,你可以按以下的安法自行安装:

    一、安装过程

    1.下载rsync

    目前(2003年9月)最新的rsync版本是2.5.6,从rysnc的官方网站上下载一个回来:

    # wget http://ftp.samba.org/ftp/rsync/rsync-2.5.6.tar.gz

    2.解压

    # tar -xzpvf rsync-2.5.6.tar.gz

    3.编译安装

    # cd rsync-2.5.6/

    # ./configure --prefix=/usr/local/rsync

    # make

    # make install

    以上过程没有出现的话就安装好了,现在就有rsync命令可以用了,rsync命令放在

    /usr/local/rsync/bin。用rsync命令可以去运行有rsync服务的服务器上抓取资料。

    如果要把当前的机器变成一台rsync服务器的话,就需要继续进行一些配置了。

    二、配置rsync服务

    配置一个简单的rsync服务并不复杂,你需要修改或建立一些配置文件。

    1.rsyncd.conf

    # vi /etc/rsyncd.motd

    rsyncd.con是rsync服务的主要配置文件,它控制rsync服务的各种属性,下面给出一个

    rsyncd.conf文件的例子:

    #先定义整体变量

    secrets file = /etc/rsyncd.secrets

    motd file = /etc/rsyncd.motd

    read only = yes

    list = yes

    uid = nobody

    gid = nobody

    hosts allow = 192.168.100.90 #哪些电脑可以访问rsync服务

    hosts deny = 192.168.100.0/24 #哪些电脑不可以访问rsync服务

    max connections = 2

    log file = /var/log/rsyncd.log

    pid file = /var/run/rsyncd.pid

    lock file = /var/run/rsync.lock

    #再定义要rsync目录

    [terry]

    comment = Terry 's directory from 192.168.100.21

    path = /home/terry

    auth users = terry,rsync

    [test]

    comment = test rsync

    path = /home/test

    在上面的配置文件中,限定了192.168.100.0/24这个子网中,只有192.168.100.90的机器可以来访问这台rsync服务器的 rsync服务。配置文件的后面部分定义了两个rsync的目录,terry目录是只有知道terry、rsync两个账号的人才能使用的,而text目 录是无需账号就可以访问的。rsync在定义目录时还提供了一些其它选项,可以作更严格的控制。

    2.rsyncd.secrets

    # vi /etc/rsyncd.secrets

    rsyncd.secrets是存储rsync服务的用户名和密码的,它是一个明文的文本文件,下面给出一个rsyncd.secrets文件的例子:

    terry:12345

    rsync:abcde

    因为rsyncd.secrets存储了rsync服务的用户名和密码,所以非常重要,因此文件的属性必须

    设为600,只有所有者可以读写:

    # chmod 600 /etc/rsyncd.secrets

    3.rsyncd.motd

    # vi /etc/rsyncd.motd

    rsyncd.motd记录了rsync服务的欢迎信息,你可以在其中输入任何文本信息,如:

    Welcome to use the rsync services!

    4.services

    # vi /etc/services

    services并不是rsync的配置文件,这一步也可以不做。而修改了services文件的好处就在于

    系统知道873端口对就的服务名为rsync。修改services的方法就是确保services中有如下两行,

    没有的话就自行加入:

    rsync  873/tcp  # rsync

    rsync  873/udp  # rsync

    5./etc/xinetd.d/rsync

    # vi /etc/xinetd.d/rsync

    建立一个名为/etc/xinetd.d/rsync文件,输入以下内容:

    service rsync

    {

    disable = no

    socket_type  = stream

    wait      = no

    user      = root

    server     = /usr/local/rsync/bin/rsync

    server_args  = --daemon

    log_on_failure += USERID

    }

    保存后,就可以运行rsync服务了。输入以下命令:

    # /etc/rc.d/init.d/xinetd reload

    这样rsync服务就在这台机器上(192.168.100.21)运行起来了,接下来就是如何来使用它了。

    三、rsync命令的用法

    在配置完rsync服务器后,就可以从客户端发出rsync命令来实现各种同步的操作。rsync有很

    多功能选项,下面就对介绍一下常用的选项:

    rsync的命令格式可以为:

    1. rsync [OPTION]... SRC [SRC]... [USER@]HOST : DEST]

    2. rsync [OPTION]... [USER@]HOST:SRC DEST]

    3. rsync [OPTION]... SRC [SRC]... DEST]

    4. rsync [OPTION]... [USER@]HOST::SRC [DEST]

    5. rsync [OPTION]... SRC [SRC]... [USER@]HOST :: DEST]

    6. rsync [OPTION]... rsync://[USER@]HOST[:PORT]/SRC [DEST]

    rsync有六种不同的工作模式:

    1. 拷贝本地文件;当SRC和DES路径信息都不包含有单个冒号":"分隔符时就启动这种工作模式。

    2.使用一个远程shell程序(如rsh、ssh)来实现将本地机器的内容拷贝到远程机器。当DST

    路径地址包含单个冒号":"分隔符时启动该模式。

    3.使用一个远程shell程序(如rsh、ssh)来实现将远程机器的内容拷贝到本地机器。当SRC

    地址路径包含单个冒号":"分隔符时启动该模式。

    4. 从远程rsync服务器中拷贝文件到本地机。当SRC路径信息包含"::"分隔符时启动该模式。

    5. 从本地机器拷贝文件到远程rsync服务器中。当DST路径信息包含"::"分隔符时启动该模式。

    6. 列远程机的文件列表。这类似于rsync传输,不过只要在命令中省略掉本地机信息即可。

    下面以实例来说明:

    # rsync -vazu -progress terry@192.168.100.21:/terry/ /home

    v详细提示

    a以archive模式操作,复制目录、符号连接

    z压缩

    u只进行更新,防止本地新文件被重写,注意两者机器的时钟的同时

    -progress指显示

    以上命令是保持客户机192.168.100.90上的/home/terry目录和rsync服务器上的terry目录同

    步。该命令执行同步之前会要求你输入terry账号的密码,这个账号是我们前面在rsyncd.secrets

    文件中定义的。如果想将这条命令写到一个脚本中,然后定时执行它的话,可以使用--password-file

    选项,具体命令如下:

    # rsync -vazu -progress --password-file=/etc/rsync.secret

    terry@192.168.100.21:/terry/ /home

    要使用--password-file选项,就得先建立一个存放密码的文件,这里指定为/etc/rsync.secret。

    其内容很简单,如下:

    terry:12345

    同样要修改文件属性如下:

    # chmod 600 /etc/rsyncd.secrets

    四、利用rsync保持Linux服务器间的文件同步实例

    现在假设有两台Linux服务器A(192.168.100.21)和B(192.168.100.90),服务器A中的

    /home/terry和服务器B中的/home/terry这两个目录需要保持同步,也就是当服务器A中文件发生

    改变后,服务器B中的文件也要对应去改变。

    我们按上面的方法,在服务器A上安装rsync,并将其配置为一台rsync服务器,并将/home/terry

    目录配置成rsync共享出的目录。然后在服务器B上安装rsync,因为B只做客户端,所以无需配置。

    然后在服务器B,建立以下脚本:

    #!/bin/bash

    /usr/loca/rsync/bin/rsync -vazu -progress --delete

    --password-file=/etc/rsync.secret terry@192.168.100.21:/terry/ /home

    将这个脚本保存为AtoB.sh,并加上可执行属性:

    # chmod 755 /root/AtoB.sh

    然后,通过crontab设定,让这个脚本每30分钟运行一次。执行命令:

    # crontab -e

    输入以下一行:

    0,30 * * * * /root/AtoB.sh

    保存退出,这样服务器B每个小时的0分和30分时都会自动运行一次AtoB.sh,AtoB.sh是负责

    保持服务器B和服务器A同步的。这样就保证了服务器A的所有更新在30钟后,服务器B也一样取

    得了和服务器A一样的最新的资料。

    五、其它应用

    rsync除了同步文件及目录之外,还可以利用它来实现对远程网站的远程备份。如果再结合脚本和Crontab就能实现定时自动远程备份。其可以实现与商业化的备份和镜象产品的类似效果,但完全免费。

              附:rsync有六种不同的工作模式:

    1. 拷贝本地文件;当SRC和DES路径信息都不包含有单个冒号":"分隔符时就启动这种工作模式。

    2.使用一个远程shell程序(如rsh、ssh)来实现将本地机器的内容拷贝到远程机器。当DST

    路径地址包含单个冒号":"分隔符时启动该模式。

    3.使用一个远程shell程序(如rsh、ssh)来实现将远程机器的内容拷贝到本地机器。当SRC

    地址路径包含单个冒号":"分隔符时启动该模式。

    4. 从远程rsync服务器中拷贝文件到本地机。当SRC路径信息包含"::"分隔符时启动该模式。

    5. 从本地机器拷贝文件到远程rsync服务器中。当DST路径信息包含"::"分隔符时启动该模式。

    6. 列远程机的文件列表。这类似于rsync传输,不过只要在命令中省略掉本地机信息即可。

  • 相关阅读:
    Laravel使用Eloquent ORM操作数据库
    Laravel查询构造器的使用方法整理
    [wordpress]后台自定义菜单字段和使用wordpress color picker
    Thinkphp kindeditor 内容转义
    WordPress 后台提示输入FTP信息
    [记录]gulp compass
    symonfy 项目根目录下没有 bin/console 文件的解决方法
    [gulp] gulp lint 忽略文件
    [转载]ubuntu Atheros Communications Device 1083 驱动
    SharpDevelop 编译时,任务失败,因为未找到“resgen.exe”的解决方法
  • 原文地址:https://www.cnblogs.com/wspblog/p/4507546.html
Copyright © 2011-2022 走看看