rsync的基本用法 $ rsync [options] src dest
[-t选项]
[-I选项]
[-v选项]这个选项,简单易懂,就是让rsync输出更多的信息,你增加越多的v,就可以获得越多的日志信息。 [-z选项]这是个压缩选项,只要使用了这个选项,rsync就会把发向对端的数据先进行压缩再传输。对于网络环境较差的情况下建议使用。一般情况下,-z的压缩算法会和gzip的一样。 [-r选项]我们在第一次使用rsync时,往往会遇到这样的囧境:
如果你不额外告诉rsync你需要它帮你同步文件夹的话,它是不会主动承担的,这也正是rsync的懒惰之处。所以,如果你真的想同步文件夹,那就要加上-r选项,即recursive(递归的、循环的),像这样:
对于文件夹,rsync是会明察秋毫的,只要你加了-r选项,它就会恪尽职守的进入到文件夹里去检查,而不会只对文件夹本身做“quick check”的。 [-l选项]rsync一旦发现某个文件是软链接,就会无视它,除非我们增加-l选项。使用了-l选项后,rsync会完全保持软链接文件类型,原原本本的将软 链接文件复制到目的端,而不会“follow link”到指向的实体文件。如果我偏偏就想让rsync采取follow link的方式,那就用-L选项就可以了。你可以自己试试效果。 [-p选项]这个选项的全名是“perserve permissions”,顾名思义,就是保持权限。如果你不使用此选项的话,rsync是这样来处理权限问题的:
如果你使用了-p选项,则无论如何,rsync都会让目的端保持与源端的权限一致的。 [-g选项和-o选项]这两个选项是一对,用来保持文件的属组(group)和属主(owner),作用应该很清晰明了。不过要注意的一点是,改变属主和属组,往往只有管理员权限才可以。 [-D选项]-D选项,原文解释是“preserve devices(root only)”,从字面意思看,就是保持设备文件的原始信息。 [-a选项]
[—delete选项、—delete-excluded选项和—delete-after选项]三个选项都是和“删除”有关的:
这个学习可是要小心使用到,一不小心会删除很多东西哦。 可以使用-n选项,它会用受影响的文件列表来警告你,但不会真的去删除,这就让我们有了确认的机会和回旋的余地。 [—exclude选项和—exclude-from选项]如果你不希望同步一些东西到目的端的话,可以使用–exclude选项来隐藏,rsync还是很重视大家隐私的,你可以多次使用–exclude选项来设置很多的“隐私”。 如果你要隐藏的隐私太多的话,在命令行选项中设置会比较麻烦,rsync还是很体贴,它提供了–exclude-from选项,让你可以把隐私一一列在一个文件里,然后让rsync直接读取这个文件就好了。 [—partial选项]这就是传说中的断点续传功能。默认情况下,rsync会删除那些传输中断的文件,然后重新传输。但在一些特别情况下,我们不希望重传,而是续传。 我们在使用中,经常会看到有人会使用-P选项,这个选项其实是为了偷懒而设计的。以前人们总是要手动写–partial –progress,觉得太费劲了,倒不如用一个新的选项来代替,于是-P应运而生了。 [—progress选项]使用这个选项,rsync会显示出传输进度信息,有什么用呢,rsync给了一个很有意思的解释: This gives a bored user something to watch. rsync核心算法rsync的算法十分高效,酷壳上 一篇文章 介绍来其核心算法,就不再赘述来。 rsync服务器架设可以架设rsync服务器,rsync以守护进程运行,客户端将rsync指令写成一个shell脚本,通过crontab定期执行脚本,以实现服务器和客户端间特定文件或目录到同步,这样就不需要你每次手动同步来,而且rsync服务器配置也十分简单。 主要涉及三个文件:
rsyncd.conf文件内容大体如下: # Minimal configuration file for rsync daemon # See rsync(1) and rsyncd.conf(5) man pages for help # This line is required by the /etc/init.d/rsync script pid file = /var/run/rsyncd.pid motd file = /etc/rsyncd.motd port = 873 address = 192.168.20.24 #uid = nobody #gid = nobody uid = root gid = root use chroot = yes read only = no # limit access to private LANs hosts allow = * hosts deny = * max connections = 5 # This will give you a separate log file log file = /var/log/rsync.log # This will log every file transferred - up to 85,000+ per user, per sync # transfer logging = yes log format = %t %a %m %f %b syslog facility = local3 timeout = 300 [test] path = /home/lcl/test list = yes ignore errors auth users = lcl secrets file = /etc/rsyncd.secrets comment = lcl test #exclude = samba/rsync使用到是873好端口,上面到配置中 hosts allow 是允许使用这台rsync服务到机器到IP地址,hosts deny 则是拒绝到,不同IP以空格隔开。
[test]及之后到配置则是,配置rsync目录,包括目录到路径,使用到用户,密码文件,可以使用 rsyncd.secrets这是存储rsync服务用户到用户名和密码,是一个明文文本文件,非常重要,属性需要设为600,只允许所有者读写,文件格式如下: lcl:12345 rsyncd.motd文件记录来rsync服务到欢迎信息,当用户使用该服务时会显示,可以设置为任何文本信息,如: ++++++++++++++++++++++++++++++++++++++ + Welcome to use lcl rsync services! + ++++++++++++++++++++++++++++++++++++++ 配置完以上文件,可以启动rsync服务来: rsync --daemon 客户端可以通过rsync命令活脚本来进行同步数据来 rsync的命令格式可以为:
rsync有六种不同的工作模式:
转载请保留固定链接: https://linuxeye.com/Linux/2010.html |