rsync 详解
- 格式:pdf
- 大小:233.35 KB
- 文档页数:22
rsync协议Rsync协议。
Rsync(remote synchronization)是一种远程数据同步工具,它可以在本地和远程计算机之间同步文件和目录。
它被广泛应用于数据备份、镜像站点和软件发布等领域。
Rsync协议是rsync工具所采用的通信协议,它基于TCP协议,通过使用特定的算法实现数据的高效传输和同步。
Rsync协议的特点之一是增量同步。
在进行文件同步时,rsync会根据文件的变化情况,只传输文件的变化部分,而不是整个文件。
这种增量同步的方式大大减少了数据传输的时间和带宽消耗,尤其适用于大文件和大量文件的同步任务。
此外,rsync还支持断点续传,当同步过程中出现网络中断或其他异常情况时,可以在恢复连接后继续进行同步,而不需要重新开始整个同步过程。
另一个重要特点是数据压缩。
在数据传输过程中,rsync会对数据进行压缩,减小数据包的大小,提高传输效率。
这对于网络带宽有限的情况下尤为重要,可以加快数据传输速度,降低网络负载。
除此之外,rsync还具有强大的文件校验功能。
在文件同步过程中,rsync会对源文件和目标文件进行校验比对,确保数据的完整性和一致性。
这种校验机制可以有效避免数据传输过程中的错误和丢失,保障数据的可靠性。
在实际应用中,rsync协议可以通过SSH(Secure Shell)进行加密传输,保障数据的安全性。
同时,rsync还支持对文件权限、时间戳等元数据的同步,确保目标文件系统与源文件系统的一致性。
总的来说,rsync协议作为一种高效、可靠的数据同步协议,在数据备份、数据镜像、文件同步等场景中有着广泛的应用。
它的增量同步、数据压缩、文件校验等特点,使得数据同步过程更加高效、安全。
同时,rsync协议的灵活性和可定制性,也为用户提供了丰富的配置选项,满足不同场景下的需求。
总之,rsync协议在数据同步领域有着广泛的应用前景,它的高效、可靠、安全的特点,使得它成为了许多数据管理和备份方案中不可或缺的一部分。
一、rsync算法概述rsync算法是一种文件同步算法,其主要功能是在两个文件夹之间进行差异化的文件同步操作。
该算法可以快速地找出两个文件夹之间的差异,并且只传输差异的部分,从而实现高效的文件同步操作。
rsync算法通常用于文件备份、文件发布以及分布式文件系统的同步操作。
二、rsync算法原理rsync算法的核心原理是基于块传输和弱校验和的技术。
具体来说,rsync算法首先将源文件和目标文件分成多个块,然后对这些块进行弱校验和的计算,生成校验和数据。
rsync算法就可以通过对比源文件和目标文件中的块的校验和数据,从而筛选出两个文件之间的差异块。
rsync算法通过传输差异块的方式,将源文件和目标文件进行同步。
三、rsync算法的优势rsync算法具有以下几个优势:1. 高效性:rsync算法可以快速地找出文件夹之间的差异,并且只传输差异的部分,从而节约网络带宽和传输时间。
2. 灵活性:rsync算法适用于不同类型的文件,无论是文本文件还是二进制文件,都可以使用rsync算法进行同步操作。
3. 安全性:rsync算法可以通过校验和的方式,确保文件同步的准确性和完整性。
4. 可靠性:rsync算法在传输过程中,具有断点续传的功能,即使在传输过程中出现中断,也可以通过校验和进行部分文件同步,确保数据的完整性。
四、rsync算法的java实现在java中,可以通过使用rsync算法的相关库,来实现文件同步的功能。
下面通过一段示例代码,演示rsync算法的java实现:```javaimport.github.fracpete.rsync4j.Rsync;import.github.fracpete.rsync4j.RsyncVersion;import.github.fracpete.rsync4j.RsyncApi;import.github.fracpete.rsync4j.BlockSum;public class RsyncExample {public static void m本人n(String[] args) {try {RsyncVersion[] versions = Rsync.listVersions("rsync"); if (versions.length > 0) {String path = "/path/to/source/directory";String target = "/path/to/target/directory";RsyncApi rsync = new RsyncApi();rsync.setVerbose(true);rsync.setStats(true);rsync.setDirs(true);rsync.setChecksum(true);rsync.setDelete(true);rsync.setDryRun(false);rsync.setExclude("*.tmp");rsync.setExclude("*.log");rsync.setArchive(true);rsync.setRecursive(true);rsync.setCompress(true);rsync.setUpdate(true);rsync.setTimes(true);rsync.setDryRun(false);rsync.setVerbose(true);rsync.setBlockSize(xxx);rsync.setRemoteShell(false);rsync.setDryRun(false);rsync.execute(path, target);}} catch (Exception e) {e.printStackTrace();}}}```以上代码展示了如何使用rsync4j这个java库,来实现rsync算法的文件同步操作。
rsync的--bwlimit用法Rsync是一个强大的文件同步和备份工具,可以在本地或远程主机之间同步文件和目录。
它可以减少传输量、节省存储空间和时间。
Rsync的bwlimit选项是一个用于限制带宽的选项,可以控制rsync命令在传输文件时所使用的网络带宽。
本文将详细介绍rsync的bwlimit用法,并提供一步一步的指导。
1. Rsync简介Rsync是一个开源的、快速、灵活的文件复制工具,最初由Andrew Tridgell 于1996年开发。
它在UNIX和类UNIX系统上运行,并提供了强大的文件同步和备份功能。
Rsync利用delta算法实现增量复制,只传输文件在源和目标之间的差异部分,从而大大减少了数据传输量,并提高了传输效率。
2. Rsync的bwlimit选项Rsync的bwlimit选项用于限制文件传输过程中使用的带宽。
它可以确保rsync 不会占用过多的网络带宽,从而避免影响其他网络活动。
bwlimit选项接受一个带宽参数,可以用来限制传输速度。
3. bwlimit选项的语法Rsync的bwlimit选项的语法如下:bwlimit=<速度>其中,速度可以用以下单位表示:- 以字节为单位:如100、1000(默认单位是字节)- 以千字节为单位:添加'k'或'K'后缀,如100k、1000K- 以兆字节为单位:添加'm'或'M'后缀,如10m、100M- 以倍数为单位:倍数后跟'c',如1c表示原始链接的速度,2c表示像这样的两倍速度4. 用法示例假设我们要将本地目录/home/user1下的所有文件同步到远程主机的目录/home/user2下,同时限制传输速度为10MB/s。
我们可以执行以下命令:rsync bwlimit=10m /home/user1 user2@remote:/home/user2在这个例子中,我们使用bwlimit=10m选项来限制传输带宽为10MB/s。
rsync命令使用方法rsync命令是一个用于同步文件和目录的工具,它可以在本地和远程系统之间进行文件传输。
以下是rsync命令的使用方法:1. 语法:rsync [选项] 原始位置目标位置2. 常用选项:-a:归档模式,递归并保留对象属性,等同于 -rlptgoD-v:显示同步过程的详细(verbose)信息-z:在传输文件时进行压缩(compress)-H:保留硬链接文件-A:保留ACL属性--delete:删除目标位置有而原始位置没有的文件-r:递归模式,包含目录及子目录中所有文件-l:对于软链接文件仍然复制为软链接文件-p:保留文件的权限标记-t:保留文件的时间标记-g:保留文件的属组标记(仅超级用户使用)-o:保留文件的属主标记(仅超级用户使用)-D:保留设备文件及其他特殊文件3. 使用示例:本地到本地同步:rsync -av /source/directory/ /destination/directory/ 本地到远程同步:rsync -avz /source/directory/ usernameremote:/destination/directory/远程到本地同步:rsync -avz usernameremote:/source/directory//destination/directory/从远程rsync服务器中拷贝文件到本地机:rsync -avz/destination/directory/4. 注意点:rsync命令的路径可以是相对路径或绝对路径。
可以通过SSH协议在本地和远程系统之间进行加密传输。
rsync命令支持增量备份和镜像备份。
5. 总结:rsync命令是一个功能强大的文件同步工具,它可以用于本地和远程系统之间的文件传输,支持各种选项和参数,可以根据需要进行定制。
通过合理使用rsync命令,可以轻松地实现文件和目录的备份、同步和镜像等操作。
rsync 增量传输原理摘要:rsync 是一种常用的文件传输和备份工具,其增量传输功能能够快速、高效地将更新的数据传输到目标位置。
本文将介绍rsync 增量传输的原理和工作流程,以及其在实际应用中的优势。
1. 引言rsync 是一个功能强大的文件传输工具,它能够在本地和远程服务器之间同步文件和目录。
rsync 的增量传输功能是其最重要的特点之一,它能够只传输文件中发生变化的部分,从而大大提高了传输效率和速度。
2. 增量传输原理rsync 的增量传输原理基于两个关键概念:块和校验和。
在传输文件之前,rsync 会将文件分成多个块,并为每个块计算一个校验和。
校验和是根据块的内容计算得出的一个唯一值,用于检测块是否发生变化。
当源文件和目标文件进行比较时,rsync 首先会通过校验和比较确定哪些块发生了变化。
只有发生变化的块才需要传输,而不变的块则可以直接从目标文件复制过来。
这种方式避免了传输整个文件,只传输变化的部分,从而减少了传输的数据量。
3. 增量传输的工作流程rsync 的增量传输工作流程如下:- 首先,rsync 会将源文件和目标文件分成块,并为每个块计算校验和。
- 然后,rsync 会将源文件的校验和列表发送给目标端。
- 目标端收到校验和列表后,会与自己的目标文件进行比较,确定哪些块需要传输。
- 目标端向源端发送需要传输的块的索引。
- 源端根据索引,将相应的块传输给目标端。
- 目标端接收到块后,根据校验和将块插入到目标文件中,完成增量传输。
4. 增量传输的优势rsync 的增量传输具有以下优势:- 传输速度快:只传输变化的部分,减少了传输的数据量,提高了传输速度。
- 节省带宽:只传输变化的部分,节省了带宽资源。
- 灵活性高:rsync 可以在本地和远程服务器之间进行传输,支持多种传输协议。
- 安全性好:rsync 使用SSH 协议进行数据传输,保证了数据的安全性。
- 同步性强:rsync 能够保持源文件和目标文件的一致性,实现文件的实时同步。
rsync的参数-回复rsync的参数- 一个完整的备份和同步工具rsync是一个强大的备份和同步工具,广泛应用于Linux系统和其他Unix-like系统中。
它提供了许多有用的参数,使用户能够根据自己的需求对其进行自定义设置。
在本文中,我们将一步一步地介绍rsync的各种参数及其用法,帮助读者更好地了解这个工具。
1. -a, archive 参数在备份和同步文件时,保持源文件的所有属性和权限。
这包括文件的所有者和所属组、访问控制列表、时间戳等。
使用此参数可以确保目标文件与源文件完全一致,在备份和还原文件时非常有用。
示例:bashrsync -a source/ destination/2. -v, verbose 参数显示详细的进度和日志信息。
这对于监视备份过程和排查问题非常有用。
rsync默认情况下是安静模式,只显示重要的错误和警告消息。
添加-v参数后,它将更详细地报告进度和文件信息。
示例:bashrsync -av source/ destination/3. -z, compress 参数压缩传输数据以减小传输时间和带宽消耗。
在网络传输中,启用压缩功能可以显著提高传输效率,特别是在宽带有限的情况下。
rsync使用zlib库进行数据压缩,所以在传输大文件时使用此参数会节省时间和带宽。
示例:bashrsync -az source/ destination/4. -P, partial 参数如果网络传输中断或意外中断,允许断点续传。
利用这个参数,rsync会将未完成的文件保留在目标文件中,以便下次继续传输而不必重新传输整个文件。
这对于大型文件和不稳定的网络连接非常有用。
示例:bashrsync -aP source/ destination/5. -e, rsh 参数在远程主机上运行rsync时,指定要使用的远程shell。
这允许用户选择不同的远程shell,如ssh、rsh等。
默认情况下,rsync使用rsh作为远程shell。
一、rsync 简介rsync 是一个用于在不同的文件夹或计算机之间同步文件和目录的工具。
它能够快速、有效地复制大量数据,并且只传输或复制那些发生了改变的部分,因而被广泛应用于数据备份和文件同步等场景中。
二、rsync 文件大小一致的问题在使用 rsync 进行文件同步时,有时会出现一个问题,即文件大小在同步前后保持一致,但是占用的空间大小却变大了。
这个问题可能会导致磁盘空间的浪费,因此需要及时处理。
三、可能的原因1. 文件系统类型不同如果源文件系统和目标文件系统不同,特别是其中一个是旧版本的文件系统,可能会导致文件大小一致但占用空间变大的问题。
2. 文件块大小不一致在不同的文件系统中,文件块的大小可能是不一样的。
当使用 rsync进行文件同步时,新的文件系统可能会导致文件块大小的改变,从而间接导致了占用空间变大的情况。
3. 存储空间碎片化文件系统的存储空间碎片化也可能导致占用空间变大的问题。
碎片化会导致文件在磁盘上的存储不是连续的,从而造成了同样大小的文件在不同的文件系统中占用空间大小不同的情况。
四、解决方法1. 使用相同的文件系统为了避免文件系统类型不同导致的问题,可以尽量使用相同的文件系统进行文件同步。
2. 调整 rsync 参数在使用 rsync 进行文件同步时,可以尝试调整参数,例如使用 --inplace 参数,强制 rsync 直接在文件上进行修改而不是创建临时文件,或者使用 --no-whole-file 参数,强制 rsync 对文件的内容进行检查和传输而不是简单地按照文件的修改时间和大小进行判断。
3. 定期进行文件系统整理定期进行文件系统的整理和优化,可以减少存储空间的碎片化问题,从而减少占用空间变大的情况。
五、结语在使用 rsync 进行文件同步的过程中,有时会遇到文件大小一致但占用空间变大的情况。
我们需要认真分析可能的原因,然后采取相应的解决方法来解决这个问题,以充分利用存储空间,保证文件同步的有效性。
在对rsync服务器配置结束以后,下一步就需要在客户端发出rsync命令来实现将服务器端的文件备份到客户端来。
rsync是一个功能非常强大的工具,其命令也有很多功能特色选项,我们下面就对它的选项一一进行分析说明。
Rsync的命令格式可以为以下六种:1)拷贝本地文件。
当SRC和DES路径信息都不包含有单个冒号":"分隔符时就启动这种工作模式。
如:rsync -a /data /backup2)使用一个远程shell程序(如rsh、ssh)来实现将本地机器的内容拷贝到远程机器。
当DST 路径地址包含单个冒号":"分隔符时启动该模式。
如:rsync -avz *.c foo:src3)使用一个远程shell程序(如rsh、ssh)来实现将远程机器的内容拷贝到本地机器。
当SRC 地址路径包含单个冒号":"分隔符时启动该模式。
如:rsync -avz foo:src/bar /data4)从远程rsync服务器中拷贝文件到本地机。
当SRC路径信息包含"::"分隔符时启动该模式。
如:rsync -av root@172.16.78.192::www /databack5)从本地机器拷贝文件到远程rsync服务器中。
当DST路径信息包含"::"分隔符时启动该模式。
如:rsync -av /databack root@172.16.78.192::www6)列远程机的文件列表。
这类似于rsync传输,不过只要在命令中省略掉本地机信息即可。
如:rsync -v rsync://172.16.78.192/wwwrsync参数的具体解释如下:-v, --verbose 详细模式输出-q, --quiet 精简输出模式-c, --checksum 打开校验开关,强制对文件传输进行校验-a, --archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD-r, --recursive 对子目录以递归模式处理-R, --relative 使用相对路径信息-b, --backup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为~filename。
如何使用rsync命令进行高级文件同步和备份文件同步和备份是计算机领域中非常重要的任务,能够确保数据的安全性和可用性。
rsync是一款功能强大的文件同步和备份工具,它在各个操作系统上都有广泛的应用。
本文将介绍如何使用rsync命令进行高级文件同步和备份。
一、rsync命令简介rsync是一个开源工具,主要用于在本地和远程系统之间进行文件的同步和备份。
它能够快速、安全地传输文件,并且能够差异化传输,只传输文件的变化部分,从而减少传输的时间和带宽消耗。
rsync可以在命令行界面使用,也可以通过脚本编写和调用。
二、rsync命令基本用法1. 本地文件同步rsync的基本用法是同步本地文件夹之间的内容。
使用以下命令可以实现本地文件夹(源目录)到另一个本地文件夹(目标目录)的同步:```shellrsync -avz 源目录目标目录```其中,-a参数表示归档模式,保留文件的属性和权限;-v参数表示显示详细过程;-z参数表示使用压缩传输,可以加快传输速度。
2. 远程文件同步rsync还支持在本地和远程系统之间进行文件的同步。
使用以下命令可以实现本地文件夹(源目录)到远程服务器上的文件夹(目标目录)的同步:```shellrsync -avz 源目录远程用户名@远程服务器地址:目标目录```其中,远程用户名@远程服务器地址表示远程服务器的登录凭证,目标目录表示远程服务器上的目标文件夹。
三、rsync命令高级用法1. 使用exclude参数排除文件或文件夹有时候我们希望在同步或备份过程中排除某些文件或文件夹,可以使用exclude参数。
以下是使用exclude参数的命令示例:```shellrsync -avz --exclude '文件名' 源目录目标目录```其中,文件名可以是具体的文件名或匹配模式。
2. 使用delete参数删除目标目录中不存在的文件有时候源目录中的文件已被删除,但目标目录中还存在,我们希望在同步过程中将其删除,可以使用delete参数。
Rsync协议简介Rsync协议是一种用于文件同步和传输的网络协议。
它是一种高效的传输工具,可以快速地将文件从一个地方同步到另一个地方,而且只传输文件的差异部分,大大节省了网络带宽和传输时间。
原理Rsync协议基于TCP/IP协议栈,并使用文件传输协议来完成文件的同步和传输。
它的核心原理是通过比较源文件和目标文件的差异,只传输差异部分,从而实现快速、高效的文件同步。
具体来说,Rsync协议采用了以下几个重要的技术:块级差异算法Rsync协议使用块级差异算法来比较源文件和目标文件的差异。
它将文件分割成多个块,并计算每个块的校验和。
通过比较源文件和目标文件的校验和,可以确定哪些块需要传输。
增量传输Rsync协议采用增量传输的方式,只传输源文件和目标文件之间的差异部分。
这样,在文件传输过程中,只需要传输源文件和目标文件的差异块,而不是整个文件,从而节省了网络带宽和传输时间。
压缩传输Rsync协议还支持压缩传输,可以在传输过程中对数据进行压缩,减小传输的数据量,提高传输的效率。
使用方法要使用Rsync协议进行文件同步和传输,需要以下几个步骤:1.安装Rsync软件:首先需要在源主机和目标主机上安装Rsync软件。
Rsync软件提供了命令行工具和库,可以方便地进行文件同步和传输。
2.配置Rsync服务:在目标主机上配置Rsync服务,包括指定监听的端口、设置访问权限等。
3.启动Rsync服务:在目标主机上启动Rsync服务,等待源主机的连接。
4.执行同步命令:在源主机上执行Rsync命令,指定源文件和目标文件的路径,以及其他相关参数。
Rsync命令会自动连接目标主机,并根据差异部分进行文件同步和传输。
示例下面是一个使用Rsync协议进行文件同步的示例:rsync -avz /path/to/source/ user@remote:/path/to/destination/在这个示例中,/path/to/source/是源文件的路径,user@remote:/path/to/destination/是目标文件的路径。
rsync 详解1、什么是 RsyncRsync(remote synchronize)是一个远程数据同步工具,可通过LAN/WAN快速 同步多台主机间的文件。
Rsync使用所谓的“Rsync算法”来使本地和远程两个 主机之间的文件达到同步,这个算法只传送两个文件的不同部分,而不是每次都 整份传送,因此速度相当快。
Rsync本来是用于替代rcp的一个工具,目前由维护,所以 rsync.conf文件的格式类似于samba 的主配置文件。
Rsync可以通过rsh或ssh使 用,也能以daemon模式去运行,在以daemon 方式运行时Rsync server会打开一 个873端口,等待客户端去连接。
连接时,Rsync server会检查口令是否相符, 若通过口令查核,则可以开始进行文件传输。
第一次连通完成时,会把整份文件 传输一次,以后则就只需进行增量备份。
Rsync支持大多数的类Unix系统,无论是Linux、Solaris还是BSD上都经 过了良好的测试。
此外,它在windows平台下也有相应的版本,如cwRsync和 Sync2NAS等工具。
Rsync的基本特点如下:1.可以镜像保存整个目录树和文件系统;2.可以很容易做到保持原来文件的权限、时间、软硬链接等;3.无须特殊权限即可安装;4.优化的流程,文件传输效率高;5.可以使用rsh、 ssh等方式来传输文件, 当然也可以通过直接的socket 连接;6.支持匿名传输。
2、Rsync 同步算法Rsync只所以同步文件的速度相当快,是因为“Rsync同步算法”能在很短的时 间内计算出需要备份的数据,关于Rsync 的同步算法描述如下:假定在1号和 2号两台计算机之间同步相似的文件 A与B,其中 1号对文件 A 拥有访问权,2号对文件 B拥有访问权。
并且假定主机1号与 2号之间的网络带 宽很小。
那么rsync算法将通过下面的五个步骤来完成:1、2号将文件 B分割成一组不重叠的固定大小为S字节的数据块,最后一块可 能会比S 小。
2、2号对每一个分割好的数据块执行两种校验:一种是32位的滚动弱校验,另 一种是128位的 MD4强校验。
3、2号将这些校验结果发给1号。
4、1号通过搜索文件 A的所有大小为S的数据块(偏移量可以任选,不一定非要 是S的倍数),来寻找与文件 B的某一块有着相同的弱校验码和强校验码的数据 块。
这项工作可以借助滚动校验的特性很快完成。
5、1号发给2号一串指令来生成文件 A在2号上的备份。
这里的每一条指令要 么是对文件B经拥有某一个数据块而不须重传的证明,要么是一个数据块,这 个数据块肯定是没有与文件B的任何一个数据块匹配上的。
3、Rsync 参数说明3.1 rsyncd.conf 配置文件-、全局参数在文件中[module]之前的所有参数都是全局参数,当然也可以在全局参数部分定 义模块参数,这时候该参数的值就是所有模块的默认值。
port指定后台程序使用的端口号,默认为873。
motd file" motd file" 参数用来指定一个消息文件,当客户连接服务器时该文件的内容显 示给客户,默认是没有 motd文件的。
log file" log file" 指定rsync 的日志文件,而不将日志发送给syslog。
比如可指定为 “/var/log/rsyncd.log”。
pid file指定rsync 的pid文件,通常指定为“/var/run/rsyncd.pid”。
syslog facility指定rsync发送日志消息给syslog时的消息级别, 常见的消息级别是: uth, authpriv, cron, daemon, ftp, kern, lpr, mail, news, security, syslog, user, uucp, local0, local1, local2, local3,local4, local5, local6和 local7。
默认值是daemon。
二、模块参数主要是定义服务器哪个目录要被同步。
其格式必须为“[module]”形式,这个名 字就是在rsync 客户端看到的名字,其实有点象Samba服务器提供的共享名。
而服务器真正同步的数据是通过 path 来指定的。
我们可以根据自己的需要,来 指定多个模块,模块中可以定义以下参数:comment给模块指定一个描述,该描述连同模块名在客户连接得到模块列表时显示给客 户。
默认没有描述定义。
path指定该模块的供备份的目录树路径,该参数是必须指定的。
use chroot如果" use chroot" 指定为true,那么rsync在传输文件以前首先chroot 到path参 数所指定的目录下。
这样做的原因是实现额外的安全防护,但是缺点是需要以 roots权限,并且不能备份指向外部的符号连接所指向的目录文件。
默认情况下 chroot 值为true。
uid该选项指定当该模块传输文件时守护进程应该具有的uid,配合gid选项使用可 以确定哪些可以访问怎么样的文件权限,默认值是" nobody" 。
gid该选项指定当该模块传输文件时守护进程应该具有的gid。
默认值为" nobody" 。
max connections指定该模块的最大并发连接数量以保护服务器, 超过限制的连接请求将被告知随 后再试。
默认值是0,也就是没有限制。
list该选项设定当客户请求可以使用的模块列表时,该模块是否应该被列出。
如果设 置该选项为 false,可以创建隐藏的模块。
默认值是true。
read only该选项设定是否允许客户上载文件。
如果为true那么任何上载请求都会失败,如 果为 false并且服务器目录读写权限允许那么上载是允许的。
默认值为true。
exclude用来指定多个由空格隔开的多个文件或目录(相对路径),并将其添加到exclude 列表中。
这等同于在客户端命令中使用exclude来指定模式,一个模块只能指定 一个exclude选项。
但是需要注意的一点是该选项有一定的安全性问题,客户很 有可能绕过exclude列表,如果希望确保特定的文件不能被访问,那就最好结合 uid/gid选项一起使用。
exclude from指定一个包含exclude模式的定义的文件名,服务器从该文件中读取exclude列 表定义。
include用来指定不排除符合要求的文件或目录。
这等同于在客户端命令中使用include 来指定模式,结合 include 和exclude可以定义复杂的exclude/include规则。
include from指定一个包含 include模式的定义的文件名, 服务器从该文件中读取 include列表 定义。
auth users该选项指定由空格或逗号分隔的用户名列表,只有这些用户才允许连接该模块。
这里的用户和系统用户没有任何关系。
如果" auth users" 被设置,那么客户端发 出对该模块的连接请求以后会被rsync请求challenged进行验证身份这里使用的 challenge/response认证协议。
用户的名和密码以明文方式存放在" secrets file" 选 项指定的文件中。
默认情况下无需密码就可以连接模块(也就是匿名方式)。
secrets file该选项指定一个包含定义用户名:密码对的文件。
只有在" auth users" 被定义时, 该文件才有作用。
文件每行包含一个username:passwd对。
一般来说密码最好不 要超过8个字符。
没有默认的 secures file 名,需要限式指定一个(例如:/etc/rsyncd.passwd)。
注意:该文件的权限一定要是600,否则客户端将不能连接 服务器。
strict modes该选项指定是否监测密码文件的权限, 如果该选项值为true那么密码文件只能被 rsync服务器运行身份的用户访问,其他任何用户不可以访问该文件。
默认值为 true。
hosts allow该选项指定哪些IP的客户允许连接该模块。
客户模式定义可以是以下形式:单个IP地址,例如:192.167.0.1整个网段,例如:192.168.0.0/24,也可以是192.168.0.0/255.255.255.0多个IP或网段需要用空格隔开,“*”则表示所有,默认是允许所有主机连接。
hosts deny指定不允许连接rsync服务器的机器,可以使用hosts allow的定义方式来进行定 义。
默认是没有hosts deny定义。
ignore errors指定rsyncd在判断是否运行传输时的删除操作时忽略server上的IO错误,一般 来说rsync在出现IO错误时将将跳过delete 操作,以防止因为暂时的资源不足 或其它IO错误导致的严重问题。
ignore nonreadable指定rysnc服务器完全忽略那些用户没有访问权限的文件。
这对于在需要备份的 目录中有些文件是不应该被备份者得到的情况是有意义的。
lock file指定支持 max connections参数的锁文件,默认值是/var/run/rsyncd.lock。
transfer logging使rsync服务器使用ftp格式的文件来记录下载和上载操作在自己单独的日志中。
log format通过该选项用户在使用transfer logging可以自己定制日志文件的字段。
其格式是 一个包含格式定义符的字符串,可以使用的格式定义符如下所示:%h 远程主机名%a 远程IP地址%l 文件长度字符数%p 该次rsync会话的进程 id%o 操作类型:" send" 或" recv"%f 文件名%P 模块路径%m 模块名%t 当前时间%u 认证的用户名(匿名时是null)%b 实际传输的字节数%c 当发送文件时,该字段记录该文件的校验码默认 log格式为:" %o %h [%a] %m (%u) %f %l" ,一般来说,在每行的头上会添 加" %t [%p] " 。
在源代码中同时发布有一个叫rsyncstats的perl脚本程序来统计 这种格式的日志文件。
timeout通过该选项可以覆盖客户指定的IP超时时间。
通过该选项可以确保rsync服务器 不会永远等待一个崩溃的客户端。
超时单位为秒钟,0表示没有超时定义,这也 是默认值。