1

如果它们包含某种文件类型,我希望 rsync 跳过整个目录。

我知道如何排除某种类型的文件。但是由于我不知道要排除的所有文件类型,因此如果存在一种类型,则应该排除整个目录,这对我没有多大帮助。

4

2 回答 2

2

我会这样:

  • 构建一个列出所有文件的文件: find . > allfiles

  • 获取不被 rsynced 的目录列表。由于您没有指定您的标准,我们假设它是一个文件后缀,如fop

    find . -path '*fop' | xargs -r -n1 dirname

会给你“禁止目录”的列表。在这里,您必须适应您的情况。

  • 然后grep -v是整个文件列表中的禁止目录,构建过滤后的文件列表

  • --files-from=然后使用过滤后的文件列表与开关进行 rsync

于 2012-08-29T08:23:15.813 回答
0

好吧,这有点难看,但是您总是可以添加反引号并运行带有一些 sed 工作的 find 命令。例如,如果我想忽略所有具有扩展名的文件的目录.dist,那么我可以这样做:

rsync -vvaR `find /etc -name '*.dist' | sed -e 's:/[^/]*$:/:' | sort | uniq | sed -e 's:^/:--exclude /:'` /etc rsync://hostname.com/

我得到一些如下所示的输出:

[client] add_rule(- /etc/config-archive/etc/)
[client] add_rule(- /etc/config-archive/etc/bash/)
[client] add_rule(- /etc/config-archive/etc/bind/)
[client] add_rule(- /etc/config-archive/etc/conf.d/)
[client] add_rule(- /etc/config-archive/etc/cron.daily/)
[client] add_rule(- /etc/config-archive/etc/eclean/)
[client] add_rule(- /etc/config-archive/etc/init.d/)
[client] add_rule(- /etc/config-archive/etc/logrotate.d/)
[client] add_rule(- /etc/config-archive/etc/modprobe.d/)
[client] add_rule(- /etc/config-archive/etc/mysql/)
[client] add_rule(- /etc/config-archive/etc/pam.d/)
[client] add_rule(- /etc/config-archive/etc/portage/bin/)
[client] add_rule(- /etc/config-archive/etc/portage/postsync.d/)
[client] add_rule(- /etc/config-archive/etc/portage/savedconfig/sys-apps/)
[client] add_rule(- /etc/config-archive/etc/profile.d/)
[client] add_rule(- /etc/config-archive/etc/security/)
[client] add_rule(- /etc/config-archive/etc/ssh/)
[client] add_rule(- /etc/config-archive/etc/ssl/)
[client] add_rule(- /etc/config-archive/etc/ssl/certs/)
[client] add_rule(- /etc/config-archive/etc/ssl/misc/)
[client] add_rule(- /etc/config-archive/etc/ssmtp/)
[client] add_rule(- /etc/config-archive/etc/syslog-ng/)
[client] add_rule(- /etc/config-archive/etc/udev/)
[client] add_rule(- /etc/config-archive/etc/udev/rules.d/)
[client] add_rule(- /etc/config-archive/etc/vim/)
opening tcp connection to hostname.com port 873
于 2012-08-29T08:20:19.830 回答