<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
xmlns:content="http://purl.org/rss/1.0/modules/content/"
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
xmlns:atom="http://www.w3.org/2005/Atom"
xmlns:wfw="http://wellformedweb.org/CommentAPI/">
<channel>
<title>dwt&#039;s life - rsync</title>
<link>https://dwt.life/tag/rsync/</link>
<atom:link href="https://dwt.life/feed/tag/rsync/" rel="self" type="application/rss+xml" />
<language>zh-CN</language>
<description></description>
<lastBuildDate>Tue, 29 Jun 2021 10:22:00 +0800</lastBuildDate>
<pubDate>Tue, 29 Jun 2021 10:22:00 +0800</pubDate>
<item>
<title>rsync 守护进程的配置</title>
<link>https://dwt.life/archives/10/</link>
<guid>https://dwt.life/archives/10/</guid>
<pubDate>Tue, 29 Jun 2021 10:22:00 +0800</pubDate>
<dc:creator>Ricky</dc:creator>
<description><![CDATA[环境 centos7.21.首先查看是否安装rsync的相关包rpm -qa | grep rsyncrsync-3.1.2-4.el7.x86_64如果没安装就yum install rsyn...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<p>环境 centos7.2</p><p>1.首先查看是否安装rsync的相关包</p><pre><code>rpm -qa | grep rsync
rsync-3.1.2-4.el7.x86_64</code></pre><p>如果没安装就<code>yum install rsync -y</code></p><p>2.配置文件</p><p><code>vi /etc/rsyncd.conf</code></p><pre><code>uid = root 
gid = root 
pid file = /var/run/rsyncd.pid
log file = /var/log/rsyncd.log 

[root]
path=/
ignore errors = yes
read only = no 
hosts allow = 172.172.172.0/24
use chroot = yes
list = yes
auth users = root
secrets file = /etc/rsync.passwd</code></pre><p>解释下配置文件</p><p>uid，gid 指定全局配置为root</p><p>指定pid file 和log file的路径，也是全局变量</p><p>[root]  这个是模块的名称</p><p>path就是传过来的文件存放的位置，默认</p><p>ignore errors 是忽略io问题  这个配置文件中，可以用true ,false  或者yes和no都行</p><p>read only  是否只读，如果是yes的话，存不了文件，所以是no</p><p>hosts allow  允许的ip，也就是白名单，没在列表中的全部禁止</p><p>use chroot  --默认为yes，在传输文件之前首先 chroot 到 path 参数所指定的目录下；优点，安全；缺点，需要 root 权限，不能备份指向 path 外部的符号连接所指向的目录文件</p><p>list --指定当客户请求列出可以使用的模块列表时，该模块是否应该被列出。默认为yes，显示</p><p>auth users = root    指定由空格或逗号分隔的用户名列表，只有这些用户才允许连接该模块,如果有这个的话，才有下面的secrets file<br>secrets file = /etc/rsync.passwd   和上面的auth users照应，将密码写入到该文件，格式为 username:password</p><p>全部完成后，保存退出</p><p>3.启动守护进程</p><p><code>rsync --daemon</code></p><p>检查是否文件启动</p><p><code>ps -ef | grep rsync</code></p><pre><code>root     13193     1  0 13:05 ?        00:00:00 rsync --daemon
root     13382 13334  0 13:32 pts/0    00:00:00 grep --color=auto rsync</code></pre><p>将这个写入到rc.local中开机自启</p><p><code>echo &quot;rsync --daemon&quot; &gt;&gt; /etc/rc.local</code></p><p>配置完成</p>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://dwt.life/archives/10/#comments</comments>
<wfw:commentRss>https://dwt.life/feed/tag/rsync/</wfw:commentRss>
</item>
<item>
<title>rsync使用</title>
<link>https://dwt.life/archives/9/</link>
<guid>https://dwt.life/archives/9/</guid>
<pubDate>Tue, 29 Jun 2021 10:08:00 +0800</pubDate>
<dc:creator>Ricky</dc:creator>
<description><![CDATA[一、简介rsync 是一个常用的 Linux 应用程序，用于文件同步。它可以在本地计算机与远程计算机之间，或者两个本地目录之间同步文件（但不支持两台远程计算机之间的同步）。它也可以当作文件复制工...]]></description>
<content:encoded xml:lang="zh-CN"><![CDATA[
<h1>一、简介</h1><p>rsync 是一个常用的 Linux 应用程序，用于文件同步。</p><p>它可以在本地计算机与远程计算机之间，或者两个本地目录之间同步文件（但不支持两台远程计算机之间的同步）。它也可以当作文件复制工具，替代cp和mv命令。</p><p>它名称里面的r指的是 remote，rsync 其实就是"远程同步"（remote sync）的意思。与其他文件传输工具（如 FTP 或 scp）不同，rsync 的最大特点是会检查发送方和接收方已有的文件，仅传输有变动的部分（默认规则是文件大小或修改时间有变动）。</p><h1>二、安装</h1><p>如果本机或者远程计算机没有安装 rsync，可以用下面的命令安装。</p><pre><code># Debian
$ sudo apt-get install rsync

# Red Hat
$ sudo yum install rsync

# Arch Linux
$ sudo pacman -S rsync</code></pre><p>注意，传输的双方都必须安装 rsync。</p><h1>三、基本用法</h1><h2>3.1 -r 参数</h2><p>本机使用 rsync 命令时，可以作为cp和mv命令的替代方法，将源目录同步到目标目录。<br><code>rsync -r source destination</code><br>上面命令中，-r表示递归，即包含子目录。注意，-r是必须的，否则 rsync 运行不会成功。source目录表示源目录，destination表示目标目录。</p><p>如果有多个文件或目录需要同步，可以写成下面这样。</p><p><code>rsync -r source1 source2 destination</code><br>上面命令中，source1、source2都会被同步到destination目录。</p><h2>3.2 -a 参数</h2><p>-a参数可以替代-r，除了可以<strong>递归同步</strong>以外，还可以<strong>同步元信息</strong>（比如修改时间、权限等）。由于 rsync 默认使用文件大小和修改时间决定文件是否需要更新，所以-a比-r更有用。下面的用法才是常见的写法。<br><code>rsync -a source destination</code><br>目标目录destination如果不存在，rsync 会自动创建。执行上面的命令后，源目录source被完整地复制到了目标目录destination下面，即形成了destination/source的目录结构。</p><p>如果只想同步源目录source里面的内容到目标目录destination，则需要在源目录后面加上斜杠。</p><p><code>rsync -a source/ destination</code><br>上面命令执行后，source目录里面的内容，就都被复制到了destination目录里面，并不会在destination下面创建一个source子目录。</p><h2>3.3 -n 参数</h2><p>如果不确定 rsync 执行后会产生什么结果，可以先用-n或--dry-run参数模拟执行的结果。</p><p><code>rsync -anv source/ destination</code><br>上面命令中，-n参数模拟命令执行的结果，并不真的执行命令。-v参数则是将结果输出到终端，这样就可以看到哪些内容会被同步。</p><h2>3.4 --delete 参数</h2><p>默认情况下，rsync 只确保源目录的所有内容（明确排除的文件除外）都复制到目标目录。它不会使两个目录保持相同，并且不会删除文件。如果要使得目标目录成为源目录的镜像副本，则必须使用--delete参数，这将删除只存在于目标目录、不存在于源目录的文件。</p><p><code>rsync -av --delete source/ destination</code><br>上面命令中，--delete参数会使得destination成为source的一个镜像。</p><h1>四、排除文件</h1><h2>4.1 --exclude 参数</h2><p>有时，我们希望同步时排除某些文件或目录，这时可以用--exclude参数指定排除模式。</p><pre><code>rsync -av --exclude=&#039;*.txt&#039; source/ destination
# 或者
$ rsync -av --exclude &#039;*.txt&#039; source/ destination</code></pre><p>上面命令排除了所有 TXT 文件。</p><p>注意，rsync 会同步以"点"开头的隐藏文件，如果要排除隐藏文件，可以这样写--exclude=".*"。</p><p>如果要排除某个目录里面的所有文件，但不希望排除目录本身，可以写成下面这样。</p><p><code>rsync -av --exclude &#039;dir1/*&#039; source/ destination</code><br>多个排除模式，可以用多个--exclude参数。<br><code>rsync -av --exclude &#039;file1.txt&#039; --exclude &#039;dir1/*&#039; source/ destination</code><br>多个排除模式也可以利用 Bash 的大扩号的扩展功能，只用一个--exclude参数。</p><p><code>rsync -av --exclude={&#039;file1.txt&#039;,&#039;dir1/*&#039;} source/ destination</code><br>如果排除模式很多，可以将它们写入一个文件，每个模式一行，然后用--exclude-from参数指定这个文件。</p><p><code>rsync -av --exclude-from=&#039;exclude-file.txt&#039; source/ destination</code><br>4.2 --include 参数<br>--include参数用来指定必须同步的文件模式，往往与--exclude结合使用。<br><code>rsync -av --include=&quot;*.txt&quot; --exclude=&#039;*&#039; source/ destination</code><br>上面命令指定同步时，排除所有文件，但是会包括 TXT 文件。</p><h1>五、远程同步</h1><h2>5.1 SSH 协议</h2><p>rsync 除了支持本地两个目录之间的同步，也支持远程同步。它可以将本地内容，同步到远程服务器。</p><p><code>rsync -av source/ username@remote_host:destination</code><br>也可以将远程内容同步到本地。</p><p><code>rsync -av username@remote_host:source/ destination</code><br>rsync 默认使用 SSH 进行远程登录和数据传输。</p><p>由于早期 rsync 不使用 SSH 协议，需要用-e参数指定协议，后来才改的。所以，下面-e ssh可以省略。</p><p><code>rsync -av -e ssh source/ user@remote_host:/destination</code></p><p><strong>但是，如果 ssh 命令有附加的参数，则必须使用-e参数指定所要执行的 SSH 命令。</strong></p><p><code>rsync -av -e &#039;ssh -p 2234&#039; source/ user@remote_host:/destination</code><br>上面命令中，-e参数指定 SSH 使用2234端口。</p><h2>5.2 rsync 协议</h2><p>除了使用 SSH，如果另一台服务器<strong>安装并运行了 rsync 守护程序</strong>，则也可以用rsync://协议（默认端口873）进行传输。具体写法是服务器与目标目录之间使用双冒号分隔::。<br><code>rsync -av source/ 192.168.122.32::module/destination</code><br>注意，上面地址中的module并不是实际路径名，而是 rsync 守护程序指定的一个资源名，由管理员分配。</p><p>如果想知道 rsync 守护程序分配的所有 module 列表，可以执行下面命令。<br><code>rsync rsync://192.168.122.32</code><br>rsync 协议除了使用双冒号，也可以直接用rsync://协议指定地址。<br><code>rsync -av source/ rsync://192.168.122.32/module/destination</code></p><h1>六、增量备份</h1><p>rsync 的最大特点就是它可以完成增量备份，也就是默认只复制有变动的文件。</p><p>除了源目录与目标目录直接比较，rsync 还支持使用基准目录，即将源目录与基准目录之间变动的部分，同步到目标目录。</p><p>具体做法是，第一次同步是全量备份，所有文件在基准目录里面同步一份。以后每一次同步都是增量备份，只同步源目录与基准目录之间有变动的部分，将这部分保存在一个新的目标目录。这个新的目标目录之中，也是包含所有文件，但实际上，只有那些变动过的文件是存在于该目录，其他没有变动的文件都是指向基准目录文件的硬链接。</p><p>--link-dest参数用来指定同步时的基准目录。</p><p><code>rsync -a --delete --link-dest /compare/path /source/path /target/path</code><br>上面命令中，--link-dest参数指定基准目录/compare/path，然后源目录/source/path跟基准目录进行比较，找出变动的文件，将它们拷贝到目标目录/target/path。那些没变动的文件则会生成硬链接。这个命令的第一次备份时是全量备份，后面就都是增量备份了。</p><p>下面是一个脚本示例，备份用户的主目录。</p><pre><code>#!/bin/bash
# A script to perform incremental backups using rsync
set -o errexit
set -o nounset
set -o pipefail

readonly SOURCE_DIR=&quot;${HOME}&quot;
readonly BACKUP_DIR=&quot;/mnt/data/backups&quot;
readonly DATETIME=&quot;$(date &#039;+%Y-%m-%d_%H:%M:%S&#039;)&quot;
readonly BACKUP_PATH=&quot;${BACKUP_DIR}/${DATETIME}&quot;
readonly LATEST_LINK=&quot;${BACKUP_DIR}/latest&quot;

mkdir -p &quot;${BACKUP_DIR}&quot;
rsync -av --delete \
  &quot;${SOURCE_DIR}/&quot; \
  --link-dest &quot;${LATEST_LINK}&quot; \
  --exclude=&quot;.cache&quot; \
  &quot;${BACKUP_PATH}&quot;

rm -rf &quot;${LATEST_LINK}&quot;
ln -s &quot;${BACKUP_PATH}&quot; &quot;${LATEST_LINK}&quot;</code></pre><p>上面脚本中，每一次同步都会生成一个新目录${BACKUP_DIR}/${DATETIME}，并将软链接${BACKUP_DIR}/latest指向这个目录。下一次备份时，就将${BACKUP_DIR}/latest作为基准目录，生成新的备份目录。最后，再将软链接${BACKUP_DIR}/latest指向新的备份目录。</p><h1>七、配置项</h1><p>-a、--archive参数表示存档模式，保存所有的元数据，比如修改时间（modification time）、权限、所有者等，并且软链接也会同步过去。</p><p>--append参数指定文件接着上次中断的地方，继续传输。</p><p>--append-verify参数跟--append参数类似，但会对传输完成后的文件进行一次校验。如果校验失败，将重新发送整个文件。</p><p>-b、--backup参数指定在删除或更新目标目录已经存在的文件时，将该文件更名后进行备份，默认行为是删除。更名规则是添加由--suffix参数指定的文件后缀名，默认是~。</p><p>--backup-dir参数指定文件备份时存放的目录，比如--backup-dir=/path/to/backups。</p><p>--bwlimit参数指定带宽限制，默认单位是 KB/s，比如--bwlimit=100。</p><p>-c、--checksum参数改变rsync的校验方式。默认情况下，rsync 只检查文件的大小和最后修改日期是否发生变化，如果发生变化，就重新传输；使用这个参数以后，则通过判断文件内容的校验和，决定是否重新传输。</p><p>--delete参数删除只存在于目标目录、不存在于源目标的文件，即保证目标目录是源目标的镜像。</p><p>-e参数指定使用 SSH 协议传输数据。</p><p>--exclude参数指定排除不进行同步的文件，比如--exclude="*.iso"。</p><p>--exclude-from参数指定一个本地文件，里面是需要排除的文件模式，每个模式一行。</p><p>--existing、--ignore-non-existing参数表示不同步目标目录中不存在的文件和目录。</p><p>-h参数表示以人类可读的格式输出。</p><p>-h、--help参数返回帮助信息。</p><p>-i参数表示输出源目录与目标目录之间文件差异的详细情况。</p><p>--ignore-existing参数表示只要该文件在目标目录中已经存在，就跳过去，不再同步这些文件。</p><p>--include参数指定同步时要包括的文件，一般与--exclude结合使用。</p><p>--link-dest参数指定增量备份的基准目录。</p><p>-m参数指定不同步空目录。</p><p>--max-size参数设置传输的最大文件的大小限制，比如不超过200KB（--max-size='200k'）。</p><p>--min-size参数设置传输的最小文件的大小限制，比如不小于10KB（--min-size=10k）。</p><p>-n参数或--dry-run参数模拟将要执行的操作，而并不真的执行。配合-v参数使用，可以看到哪些内容会被同步过去。</p><p>-P参数是--progress和--partial这两个参数的结合。</p><p>--partial参数允许恢复中断的传输。不使用该参数时，rsync会删除传输到一半被打断的文件；使用该参数后，传输到一半的文件也会同步到目标目录，下次同步时再恢复中断的传输。一般需要与--append或--append-verify配合使用。</p><p>--partial-dir参数指定将传输到一半的文件保存到一个临时目录，比如--partial-dir=.rsync-partial。一般需要与--append或--append-verify配合使用。</p><p>--progress参数表示显示进展。</p><p>-r参数表示递归，即包含子目录。</p><p>--remove-source-files参数表示传输成功后，删除发送方的文件。</p><p>--size-only参数表示只同步大小有变化的文件，不考虑文件修改时间的差异。</p><p>--suffix参数指定文件名备份时，对文件名添加的后缀，默认是~。</p><p>-u、--update参数表示同步时跳过目标目录中修改时间更新的文件，即不同步这些有更新的时间戳的文件。</p><p>-v参数表示输出细节。-vv表示输出更详细的信息，-vvv表示输出最详细的信息。</p><p>--version参数返回 rsync 的版本。</p><p>-z参数指定同步时压缩数据。</p>
]]></content:encoded>
<slash:comments>0</slash:comments>
<comments>https://dwt.life/archives/9/#comments</comments>
<wfw:commentRss>https://dwt.life/feed/tag/rsync/</wfw:commentRss>
</item>
</channel>
</rss>