Linux下sersync数据实时同步
<p>sersync其实是利用inotify和rsync两种软件技术来实现数据实时同步功能的,inotify是用于监听sersync所在服务器上的文件变化,结合rsync软件来进行数据同步,将数据实时同步给客户端服务器。</p>
<p>
工作过程:在同步主服务器上开启sersync,负责监听文件系统的变化,然后调用rsync命令把更新的文件同步到目标服务器上,主服务器上安装sersync软件,目标服务器上安装rsync服务。</p>
<p>
<img title="Linux下sersync数据实时同步" alt="Linux下sersync数据实时同步" src="https://zhuji.jb51.net/uploads/img/202305/b96c66903ac6d606c18012bc21b54e0e.jpg"></p>
<p>
1、客户端配置</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_161830">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
<div class="line number11 index10 alt2">
11</div>
<div class="line number12 index11 alt1">
12</div>
<div class="line number13 index12 alt2">
13</div>
<div class="line number14 index13 alt1">
14</div>
<div class="line number15 index14 alt2">
15</div>
<div class="line number16 index15 alt1">
16</div>
<div class="line number17 index16 alt2">
17</div>
<div class="line number18 index17 alt1">
18</div>
<div class="line number19 index18 alt2">
19</div>
<div class="line number20 index19 alt1">
20</div>
<div class="line number21 index20 alt2">
21</div>
<div class="line number22 index21 alt1">
22</div>
<div class="line number23 index22 alt2">
23</div>
<div class="line number24 index23 alt1">
24</div>
<div class="line number25 index24 alt2">
25</div>
<div class="line number26 index25 alt1">
26</div>
<div class="line number27 index26 alt2">
27</div>
<div class="line number28 index27 alt1">
28</div>
<div class="line number29 index28 alt2">
29</div>
<div class="line number30 index29 alt1">
30</div>
<div class="line number31 index30 alt2">
31</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain"></code><code class="bash comments"># cat /etc/rsyncd.conf </code>
</div>
<div class="line number2 index1 alt1">
<code class="bash comments">##created by cai at 2018-2-24</code>
</div>
<div class="line number3 index2 alt2">
<code class="bash plain">uid=</code><code class="bash functions">rsync</code>
</div>
<div class="line number4 index3 alt1">
<code class="bash plain">gid=</code><code class="bash functions">rsync</code>
</div>
<div class="line number5 index4 alt2">
<code class="bash plain">use chroot = no</code>
</div>
<div class="line number6 index5 alt1">
<code class="bash plain">max connections = 200</code>
</div>
<div class="line number7 index6 alt2">
<code class="bash plain">timeout = 300</code>
</div>
<div class="line number8 index7 alt1">
<code class="bash plain">pid </code><code class="bash functions">file</code> <code class="bash plain">= </code><code class="bash plain">/var/run/rsyncd</code><code class="bash plain">.pid</code>
</div>
<div class="line number9 index8 alt2">
<code class="bash plain">lock </code><code class="bash functions">file</code> <code class="bash plain">= </code><code class="bash plain">/var/run/rsync</code><code class="bash plain">.lock</code>
</div>
<div class="line number10 index9 alt1">
<code class="bash plain">log </code><code class="bash functions">file</code> <code class="bash plain">= </code><code class="bash plain">/var/log/rsyncd</code><code class="bash plain">.log</code>
</div>
<div class="line number11 index10 alt2">
<code class="bash plain"></code>
</div>
<div class="line number12 index11 alt1">
<code class="bash plain">path = </code><code class="bash plain">/data/</code>
</div>
<div class="line number13 index12 alt2">
<code class="bash plain">ignore errors</code>
</div>
<div class="line number14 index13 alt1">
<code class="bash functions">read</code> <code class="bash plain">only = </code><code class="bash functions">false</code>
</div>
<div class="line number15 index14 alt2">
<code class="bash plain">list = </code><code class="bash functions">false</code>
</div>
<div class="line number16 index15 alt1">
<code class="bash plain">hosts allow = 192.168.181.128:52000</code><code class="bash plain">/24</code>
</div>
<div class="line number17 index16 alt2">
<code class="bash plain">hosts deny = 0.0.0.0</code><code class="bash plain">/32</code>
</div>
<div class="line number18 index17 alt1">
<code class="bash plain">auth </code><code class="bash functions">users</code> <code class="bash plain">= rsync_body</code>
</div>
<div class="line number19 index18 alt2">
<code class="bash plain">secrets </code><code class="bash functions">file</code> <code class="bash plain">= </code><code class="bash plain">/etc/rsync</code><code class="bash plain">.password</code>
</div>
<div class="line number20 index19 alt1">
<code class="bash plain"></code><code class="bash comments"># ls -ld /data/</code>
</div>
<div class="line number21 index20 alt2">
<code class="bash plain">drwxrwxrwx. 3 </code><code class="bash functions">rsync</code> <code class="bash functions">rsync</code> <code class="bash plain">4096 feb 24 16:58 </code><code class="bash plain">/data/</code>
</div>
<div class="line number22 index21 alt1">
</div>
<div class="line number23 index22 alt2">
<code class="bash plain"></code><code class="bash comments"># cat /etc/rsync.password </code>
</div>
<div class="line number24 index23 alt1">
<code class="bash plain">rsync_body:admin</code>
</div>
<div class="line number25 index24 alt2">
</div>
<div class="line number26 index25 alt1">
<code class="bash plain"></code><code class="bash comments"># ls -ld /etc/rsync.password </code>
</div>
<div class="line number27 index26 alt2">
<code class="bash plain">-rw-------. 1 root root 17 feb 24 16:26 </code><code class="bash plain">/etc/rsync</code><code class="bash plain">.password </code><code class="bash comments">#600权限</code>
</div>
<div class="line number28 index27 alt1">
</div>
<div class="line number29 index28 alt2">
<code class="bash plain"></code><code class="bash comments"># netstat -lntup| grep "rsync"</code>
</div>
<div class="line number30 index29 alt1">
<code class="bash plain">tcp 0 0 0.0.0.0:873 0.0.0.0:* listen 1497</code><code class="bash plain">/rsync</code>
</div>
<div class="line number31 index30 alt2">
<code class="bash plain">tcp 0 0 :::873 :::* listen 1497</code><code class="bash plain">/rsync</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
</div>
<p>
2、主服务器配置</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_654695">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain"></code><code class="bash comments"># cat /etc/rsync.password </code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain">admin</code>
</div>
<div class="line number3 index2 alt2">
<code class="bash plain"></code><code class="bash comments"># ls -ld /etc/rsync.password </code>
</div>
<div class="line number4 index3 alt1">
<code class="bash plain">-rw------- 1 root root 6 feb 24 03:54 </code><code class="bash plain">/etc/rsync</code><code class="bash plain">.password</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
</div>
<p>
3、安装sersync服务</p>
<p>
采用inotify来对文件进行监控,当监控到文件有文件发生改变的时候,就会调用rsync实现触发式实时同步!</p>
<p>
安装sersync(注意sersync是工作在rsync的源服务器上,也就是客户端上)</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_947474">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
<div class="line number11 index10 alt2">
11</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain"></code><code class="bash comments"># cd /usr/local/src/</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain"></code><code class="bash comments"># tar -zxvf sersync2.5.4_64bit_binary_stable_final.tar.gz -c /usr/local/</code>
</div>
<div class="line number3 index2 alt2">
<code class="bash plain">gnu-linux-x86/</code>
</div>
<div class="line number4 index3 alt1">
<code class="bash plain">gnu-linux-x86</code><code class="bash plain">/sersync2</code>
</div>
<div class="line number5 index4 alt2">
<code class="bash plain">gnu-linux-x86</code><code class="bash plain">/confxml</code><code class="bash plain">.xml</code>
</div>
<div class="line number6 index5 alt1">
<code class="bash plain"></code><code class="bash comments"># cd /usr/local/</code>
</div>
<div class="line number7 index6 alt2">
<code class="bash plain"></code><code class="bash comments"># mv gnu-linux-x86 sersync</code>
</div>
<div class="line number8 index7 alt1">
<code class="bash plain"></code><code class="bash comments"># cd sersync/</code>
</div>
<div class="line number9 index8 alt2">
<code class="bash plain"></code><code class="bash comments"># mkdir conf bin log</code>
</div>
<div class="line number10 index9 alt1">
<code class="bash plain"></code><code class="bash comments"># mv confxml.xml conf</code>
</div>
<div class="line number11 index10 alt2">
<code class="bash plain"></code><code class="bash comments"># mv sersync2 bin/sersync</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
</div>
<p>
修改配置文件</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_37044">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
<div class="line number11 index10 alt2">
11</div>
<div class="line number12 index11 alt1">
12</div>
<div class="line number13 index12 alt2">
13</div>
<div class="line number14 index13 alt1">
14</div>
<div class="line number15 index14 alt2">
15</div>
<div class="line number16 index15 alt1">
16</div>
<div class="line number17 index16 alt2">
17</div>
<div class="line number18 index17 alt1">
18</div>
<div class="line number19 index18 alt2">
19</div>
<div class="line number20 index19 alt1">
20</div>
<div class="line number21 index20 alt2">
21</div>
<div class="line number22 index21 alt1">
22</div>
<div class="line number23 index22 alt2">
23</div>
<div class="line number24 index23 alt1">
24</div>
<div class="line number25 index24 alt2">
25</div>
<div class="line number26 index25 alt1">
26</div>
<div class="line number27 index26 alt2">
27</div>
<div class="line number28 index27 alt1">
28</div>
<div class="line number29 index28 alt2">
29</div>
<div class="line number30 index29 alt1">
30</div>
<div class="line number31 index30 alt2">
31</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">***********************************30行开始******************************</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash spaces"> </code><code class="bash plain"><commonparams params=</code><code class="bash string">"-artuz"</code><code class="bash plain">/> </code><code class="bash comments">#-artuz为rsync同步时的参数</code>
</div>
<div class="line number3 index2 alt2">
<code class="bash spaces"> </code><code class="bash plain"><authstart=</code><code class="bash string">"true"</code> <code class="bash functions">users</code><code class="bash plain">=</code><code class="bash string">"rsync的虚拟用户名(rsync_backup)"</code> <code class="bash plain">passwordfile=</code><code class="bash string">"rsync的密码文件"</code><code class="bash plain">/></code>
</div>
<div class="line number4 index3 alt1">
<code class="bash spaces"> </code><code class="bash plain"><userdefinedport start=</code><code class="bash string">"true"</code><code class="bash plain">port=</code><code class="bash string">"873"</code><code class="bash plain">/><!-- port=874 --></code>
</div>
<div class="line number5 index4 alt2">
<code class="bash spaces"> </code><code class="bash plain"><timeout start=</code><code class="bash string">"false"</code> <code class="bash functions">time</code><code class="bash plain">=</code><code class="bash string">"100"</code><code class="bash plain">/><!--timeout=100 --></code>
</div>
<div class="line number6 index5 alt1">
<code class="bash spaces"> </code><code class="bash plain"><sshstart=</code><code class="bash string">"false"</code><code class="bash plain">/></code>
</div>
<div class="line number7 index6 alt2">
<code class="bash spaces"> </code><code class="bash plain">************************************第36行***********************************</code>
</div>
<div class="line number8 index7 alt1">
<code class="bash spaces"> </code><code class="bash plain"><faillogpath=</code><code class="bash string">"自己定义的log文件夹(/usr/local/sersync/log)rsync_fail_log.sh"</code>
</div>
<div class="line number9 index8 alt2">
<code class="bash spaces"> </code><code class="bash plain">timetoexecute=</code><code class="bash string">"60"</code><code class="bash plain">/><!--defaultevery 60mins execute once--></code>
</div>
<div class="line number10 index9 alt1">
<code class="bash spaces"> </code><code class="bash plain">*******************************************************************************</code>
</div>
<div class="line number11 index10 alt2">
<code class="bash spaces"> </code><code class="bash plain">*注:若有多个目录备份可以穿件多个配置文件在启动时的-o参数中添加即可</code>
</div>
<div class="line number12 index11 alt1">
</div>
<div class="line number13 index12 alt2">
<code class="bash plain"></code><code class="bash comments"># diff confxml.xml confxml.xml.bak</code>
</div>
<div class="line number14 index13 alt1">
<code class="bash plain">24,25c24,25</code>
</div>
<div class="line number15 index14 alt2">
<code class="bash plain">< <localpath </code><code class="bash functions">watch</code><code class="bash plain">=</code><code class="bash string">"/data/"</code><code class="bash plain">> </code><code class="bash comments">#data就是本地需要同步的文件夹到服务器端的目录</code>
</div>
<div class="line number16 index15 alt1">
<code class="bash plain">< <remote ip=</code><code class="bash string">"192.168.91.166"</code> <code class="bash plain">name=</code><code class="bash string">"data"</code><code class="bash plain">/> </code><code class="bash comments">#data (server的模块名)是rsync 服务端的文件夹,也就是推送到服务器端的目标文件夹,可以配置多个,</code>
</div>
<div class="line number17 index16 alt2">
<code class="bash plain">---</code>
</div>
<div class="line number18 index17 alt1">
<code class="bash plain">> <localpath </code><code class="bash functions">watch</code><code class="bash plain">=</code><code class="bash string">"/opt/tongbu"</code><code class="bash plain">></code>
</div>
<div class="line number19 index18 alt2">
<code class="bash plain">> <remote ip=</code><code class="bash string">"127.0.0.1"</code> <code class="bash plain">name=</code><code class="bash string">"tongbu1"</code><code class="bash plain">/></code>
</div>
<div class="line number20 index19 alt1">
<code class="bash plain">31c31</code>
</div>
<div class="line number21 index20 alt2">
<code class="bash plain">< <auth start=</code><code class="bash string">"true"</code> <code class="bash functions">users</code><code class="bash plain">=</code><code class="bash string">"rsync_body"</code> <code class="bash plain">passwordfile=</code><code class="bash string">"/etc/rsync.password"</code><code class="bash plain">/> </code><code class="bash comments">#true 才能生效,rsync_body同步时候虚拟账号,后面是密码文件</code>
</div>
<div class="line number22 index21 alt1">
<code class="bash plain">---</code>
</div>
<div class="line number23 index22 alt2">
<code class="bash plain">> <auth start=</code><code class="bash string">"false"</code> <code class="bash functions">users</code><code class="bash plain">=</code><code class="bash string">"root"</code> <code class="bash plain">passwordfile=</code><code class="bash string">"/etc/rsync.pas"</code><code class="bash plain">/></code>
</div>
<div class="line number24 index23 alt1">
<code class="bash plain">33c33</code>
</div>
<div class="line number25 index24 alt2">
<code class="bash plain">< <timeout start=</code><code class="bash string">"true"</code> <code class="bash functions">time</code><code class="bash plain">=</code><code class="bash string">"100"</code><code class="bash plain">/><!-- timeout=100 --> </code><code class="bash comments">#true 才能生效</code>
</div>
<div class="line number26 index25 alt1">
<code class="bash plain">---</code>
</div>
<div class="line number27 index26 alt2">
<code class="bash plain">> <timeout start=</code><code class="bash string">"false"</code> <code class="bash functions">time</code><code class="bash plain">=</code><code class="bash string">"100"</code><code class="bash plain">/><!-- timeout=100 --></code>
</div>
<div class="line number28 index27 alt1">
<code class="bash plain">36c36</code>
</div>
<div class="line number29 index28 alt2">
<code class="bash plain">< <faillog path=</code><code class="bash string">"/usr/local/sersync/log/rsync_fail_log.sh"</code> <code class="bash plain">timetoexecute=</code><code class="bash string">"60"</code><code class="bash plain">/><!--default every 60mins execute once--> </code><code class="bash comments">#检测rsync进程判断,没有自动启</code>
</div>
<div class="line number30 index29 alt1">
<code class="bash plain">---</code>
</div>
<div class="line number31 index30 alt2">
<code class="bash plain">> <faillog path=</code><code class="bash string">"/tmp/rsync_fail_log.sh"</code> <code class="bash plain">timetoexecute=</code><code class="bash string">"60"</code><code class="bash plain">/><!--default evepry 60mins execute once--></code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
</div>
<p>
启动sersync</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_93013">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
<div class="line number11 index10 alt2">
11</div>
<div class="line number12 index11 alt1">
12</div>
<div class="line number13 index12 alt2">
13</div>
<div class="line number14 index13 alt1">
14</div>
<div class="line number15 index14 alt2">
15</div>
<div class="line number16 index15 alt1">
16</div>
<div class="line number17 index16 alt2">
17</div>
<div class="line number18 index17 alt1">
18</div>
<div class="line number19 index18 alt2">
19</div>
<div class="line number20 index19 alt1">
20</div>
<div class="line number21 index20 alt2">
21</div>
<div class="line number22 index21 alt1">
22</div>
<div class="line number23 index22 alt2">
23</div>
<div class="line number24 index23 alt1">
24</div>
<div class="line number25 index24 alt2">
25</div>
<div class="line number26 index25 alt1">
26</div>
<div class="line number27 index26 alt2">
27</div>
<div class="line number28 index27 alt1">
28</div>
<div class="line number29 index28 alt2">
29</div>
<div class="line number30 index29 alt1">
30</div>
<div class="line number31 index30 alt2">
31</div>
<div class="line number32 index31 alt1">
32</div>
<div class="line number33 index32 alt2">
33</div>
<div class="line number34 index33 alt1">
34</div>
<div class="line number35 index34 alt2">
35</div>
<div class="line number36 index35 alt1">
36</div>
<div class="line number37 index36 alt2">
37</div>
<div class="line number38 index37 alt1">
38</div>
<div class="line number39 index38 alt2">
39</div>
<div class="line number40 index39 alt1">
40</div>
<div class="line number41 index40 alt2">
41</div>
<div class="line number42 index41 alt1">
42</div>
<div class="line number43 index42 alt2">
43</div>
<div class="line number44 index43 alt1">
44</div>
<div class="line number45 index44 alt2">
45</div>
<div class="line number46 index45 alt1">
46</div>
<div class="line number47 index46 alt2">
47</div>
<div class="line number48 index47 alt1">
48</div>
<div class="line number49 index48 alt2">
49</div>
<div class="line number50 index49 alt1">
50</div>
<div class="line number51 index50 alt2">
51</div>
<div class="line number52 index51 alt1">
52</div>
<div class="line number53 index52 alt2">
53</div>
<div class="line number54 index53 alt1">
54</div>
<div class="line number55 index54 alt2">
55</div>
<div class="line number56 index55 alt1">
56</div>
<div class="line number57 index56 alt2">
57</div>
<div class="line number58 index57 alt1">
58</div>
<div class="line number59 index58 alt2">
59</div>
<div class="line number60 index59 alt1">
60</div>
<div class="line number61 index60 alt2">
61</div>
<div class="line number62 index61 alt1">
62</div>
<div class="line number63 index62 alt2">
63</div>
<div class="line number64 index63 alt1">
64</div>
<div class="line number65 index64 alt2">
65</div>
<div class="line number66 index65 alt1">
66</div>
<div class="line number67 index66 alt2">
67</div>
<div class="line number68 index67 alt1">
68</div>
<div class="line number69 index68 alt2">
69</div>
<div class="line number70 index69 alt1">
70</div>
<div class="line number71 index70 alt2">
71</div>
<div class="line number72 index71 alt1">
72</div>
<div class="line number73 index72 alt2">
73</div>
<div class="line number74 index73 alt1">
74</div>
<div class="line number75 index74 alt2">
75</div>
<div class="line number76 index75 alt1">
76</div>
<div class="line number77 index76 alt2">
77</div>
<div class="line number78 index77 alt1">
78</div>
<div class="line number79 index78 alt2">
79</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain"></code><code class="bash comments"># echo 'export path=$path:/usr/local/sersync/bin'>>/etc/profile #声明环境变量</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain"></code><code class="bash comments"># source /etc/profile</code>
</div>
<div class="line number3 index2 alt2">
<code class="bash plain"></code><code class="bash comments"># sersync2 -r -d -o /usr/local/sersync/conf/confxml.xml #启动</code>
</div>
<div class="line number4 index3 alt1">
<code class="bash functions">set</code> <code class="bash plain">the system param</code>
</div>
<div class="line number5 index4 alt2">
<code class="bash plain">execute:</code><code class="bash functions">echo</code> <code class="bash plain">50000000 > </code><code class="bash plain">/proc/sys/fs/inotify/max_user_watches</code>
</div>
<div class="line number6 index5 alt1">
<code class="bash plain">execute:</code><code class="bash functions">echo</code> <code class="bash plain">327679 > </code><code class="bash plain">/proc/sys/fs/inotify/max_queued_events</code>
</div>
<div class="line number7 index6 alt2">
<code class="bash plain">parse the </code><code class="bash functions">command</code> <code class="bash plain">param</code>
</div>
<div class="line number8 index7 alt1">
<code class="bash plain">option: -r </code><code class="bash functions">rsync</code> <code class="bash plain">all the </code><code class="bash functions">local</code> <code class="bash plain">files to the remote servers before the sersync work</code>
</div>
<div class="line number9 index8 alt2">
<code class="bash plain">option: -d run as a daemon</code>
</div>
<div class="line number10 index9 alt1">
<code class="bash plain">option: -o config xml name: </code><code class="bash plain">/usr/local/sersync/conf/confxml</code><code class="bash plain">.xml</code>
</div>
<div class="line number11 index10 alt2">
<code class="bash plain">daemon thread num: 10</code>
</div>
<div class="line number12 index11 alt1">
<code class="bash plain">parse xml config </code><code class="bash functions">file</code>
</div>
<div class="line number13 index12 alt2">
<code class="bash plain">host ip : localhost host port: 8008</code>
</div>
<div class="line number14 index13 alt1">
<code class="bash plain">daemon start,sersync run behind the console</code>
</div>
<div class="line number15 index14 alt2">
<code class="bash plain">use </code><code class="bash functions">rsync</code> <code class="bash plain">password-</code><code class="bash functions">file</code> <code class="bash plain">:</code>
</div>
<div class="line number16 index15 alt1">
<code class="bash plain">user is rsync_body</code>
</div>
<div class="line number17 index16 alt2">
<code class="bash plain">passwordfile is </code><code class="bash plain">/etc/rsync</code><code class="bash plain">.password</code>
</div>
<div class="line number18 index17 alt1">
<code class="bash plain">config xml parse success</code>
</div>
<div class="line number19 index18 alt2">
<code class="bash plain">please </code><code class="bash functions">set</code> <code class="bash plain">/etc/rsyncd</code><code class="bash plain">.conf max connections=0 manually</code>
</div>
<div class="line number20 index19 alt1">
<code class="bash plain">sersync working thread 12 = 1(primary thread) + 1(fail retry thread) + 10(daemon sub threads)</code>
</div>
<div class="line number21 index20 alt2">
<code class="bash plain">max threads numbers is: 22 = 12(thread pool nums) + 10(sub threads)</code>
</div>
<div class="line number22 index21 alt1">
<code class="bash plain">please according your cpu ,use -n param to adjust the cpu rate</code>
</div>
<div class="line number23 index22 alt2">
<code class="bash plain">------------------------------------------</code>
</div>
<div class="line number24 index23 alt1">
<code class="bash functions">rsync</code> <code class="bash plain">the directory recursivly to the remote servers once</code>
</div>
<div class="line number25 index24 alt2">
<code class="bash plain">working please wait...</code>
</div>
<div class="line number26 index25 alt1">
<code class="bash plain">execute </code><code class="bash functions">command</code><code class="bash plain">: </code><code class="bash functions">cd</code> <code class="bash plain">/data</code> <code class="bash plain">&& </code><code class="bash functions">rsync</code> <code class="bash plain">-artuz -r --delete ./ --timeout=100 rsync_body@192.168.91.166::data --password-</code><code class="bash functions">file</code><code class="bash plain">=</code><code class="bash plain">/etc/rsync</code><code class="bash plain">.password ></code><code class="bash plain">/dev/null</code> <code class="bash plain">2>&1</code>
</div>
<div class="line number27 index26 alt2">
<code class="bash plain">run the sersync:</code>
</div>
<div class="line number28 index27 alt1">
<code class="bash functions">watch</code> <code class="bash plain">path is: </code><code class="bash plain">/data</code> <code class="bash comments">#此时可以看出sersync已经启动成功了</code>
</div>
<div class="line number29 index28 alt2">
</div>
<div class="line number30 index29 alt1">
<code class="bash comments">#检测脚本</code>
</div>
<div class="line number31 index30 alt2">
<code class="bash plain"></code><code class="bash comments"># pwd</code>
</div>
<div class="line number32 index31 alt1">
<code class="bash plain">/usr/local/sersync/log</code>
</div>
<div class="line number33 index32 alt2">
<code class="bash plain"></code><code class="bash comments"># vim rsync_fail_log.sh</code>
</div>
<div class="line number34 index33 alt1">
<code class="bash plain"></code><code class="bash comments"># chmod +x rsync_fail_log.sh</code>
</div>
<div class="line number35 index34 alt2">
<code class="bash plain"></code><code class="bash comments"># cat /usr/local/sersync/log/rsync_fail_log.sh</code>
</div>
<div class="line number36 index35 alt1">
<code class="bash preprocessor bold">#!/bin/bash</code>
</div>
<div class="line number37 index36 alt2">
<code class="bash comments">#purpose: check sersync whether it is alive</code>
</div>
<div class="line number38 index37 alt1">
<code class="bash comments">#author: cai meng zhi</code>
</div>
<div class="line number39 index38 alt2">
<code class="bash plain">sersync=</code><code class="bash string">"/usr/local/sersync/bin/sersync2"</code>
</div>
<div class="line number40 index39 alt1">
<code class="bash plain">conf_file=</code><code class="bash string">"/usr/local/sersync/conf/confxml.xml"</code>
</div>
<div class="line number41 index40 alt2">
<code class="bash plain">status=$(</code><code class="bash functions">ps</code> <code class="bash plain">aux |</code><code class="bash functions">grep</code> <code class="bash string">'sersync2'</code><code class="bash plain">|</code><code class="bash functions">grep</code> <code class="bash plain">-</code><code class="bash functions">v</code> <code class="bash string">'grep'</code><code class="bash plain">|</code><code class="bash functions">wc</code> <code class="bash plain">-l)</code>
</div>
<div class="line number42 index41 alt1">
<code class="bash keyword">if</code> <code class="bash plain">[ $status -</code><code class="bash keyword">eq</code> <code class="bash plain">0 ];</code>
</div>
<div class="line number43 index42 alt2">
<code class="bash keyword">then</code>
</div>
<div class="line number44 index43 alt1">
<code class="bash spaces"> </code><code class="bash plain">$sersync -d -r -o $conf_file &</code>
</div>
<div class="line number45 index44 alt2">
<code class="bash keyword">else</code>
</div>
<div class="line number46 index45 alt1">
<code class="bash spaces"> </code><code class="bash functions">exit</code> <code class="bash plain">0;</code>
</div>
<div class="line number47 index46 alt2">
<code class="bash keyword">fi</code>
</div>
<div class="line number48 index47 alt1">
<code class="bash plain">脚本写好以后,添加到计划任务中去</code>
</div>
<div class="line number49 index48 alt2">
<code class="bash plain">*</code><code class="bash plain">/1</code> <code class="bash plain">* * * * </code><code class="bash plain">/bin/bash</code> <code class="bash plain">/usr/local/sersync/log/rsync_fail_log</code><code class="bash plain">.sh > </code><code class="bash plain">/dev/null</code> <code class="bash plain">2>&1</code>
</div>
<div class="line number50 index49 alt1">
</div>
<div class="line number51 index50 alt2">
<code class="bash plain">测试同步:</code>
</div>
<div class="line number52 index51 alt1">
<code class="bash plain">客户端新增文件</code>
</div>
<div class="line number53 index52 alt2">
<code class="bash plain"></code><code class="bash comments"># cp /etc/passwd 192.168.91.156.passwd</code>
</div>
<div class="line number54 index53 alt1">
<code class="bash plain"></code><code class="bash comments"># ll</code>
</div>
<div class="line number55 index54 alt2">
<code class="bash plain">total 4</code>
</div>
<div class="line number56 index55 alt1">
<code class="bash plain">-rw-r--r-- 1 root root 1928 nov 10 18:15 192.168.91.156.</code><code class="bash functions">passwd</code>
</div>
<div class="line number57 index56 alt2">
<code class="bash plain">-rw-r--r-- 1 root root 0 nov 10 17:27 3</code>
</div>
<div class="line number58 index57 alt1">
<code class="bash plain">服务端检测</code>
</div>
<div class="line number59 index58 alt2">
<code class="bash plain"></code><code class="bash comments"># cd /data/</code>
</div>
<div class="line number60 index59 alt1">
<code class="bash plain"></code><code class="bash comments"># ll</code>
</div>
<div class="line number61 index60 alt2">
<code class="bash plain">total 8</code>
</div>
<div class="line number62 index61 alt1">
<code class="bash plain">-rw-r--r-- 1 root root 1928 nov 10 18:15 192.168.91.156.</code><code class="bash functions">passwd</code> <code class="bash comments">#说明已经同步过来了</code>
</div>
<div class="line number63 index62 alt2">
<code class="bash plain">-rw-r--r-- 1 root root 0 nov 10 17:27 3</code>
</div>
<div class="line number64 index63 alt1">
<code class="bash plain">drwxr-xr-x 2 root root 4096 nov 10 17:27 data</code>
</div>
<div class="line number65 index64 alt2">
</div>
<div class="line number66 index65 alt1">
<code class="bash plain">客户端测试删除</code>
</div>
<div class="line number67 index66 alt2">
<code class="bash plain"></code><code class="bash comments"># rm rf 192.168.91.156.passwd </code>
</div>
<div class="line number68 index67 alt1">
<code class="bash functions">rm</code><code class="bash plain">: cannot remove `rf': no such </code><code class="bash functions">file</code> <code class="bash plain">or directory</code>
</div>
<div class="line number69 index68 alt2">
<code class="bash functions">rm</code><code class="bash plain">: remove regular </code><code class="bash functions">file</code> <code class="bash plain">`192.168.91.156.</code><code class="bash functions">passwd</code><code class="bash plain">'? y</code>
</div>
<div class="line number70 index69 alt1">
<code class="bash plain"></code><code class="bash comments"># ll</code>
</div>
<div class="line number71 index70 alt2">
<code class="bash plain">total 0</code>
</div>
<div class="line number72 index71 alt1">
<code class="bash plain">-rw-r--r-- 1 root root 0 nov 10 17:27 3</code>
</div>
<div class="line number73 index72 alt2">
<code class="bash plain"></code><code class="bash comments">#</code>
</div>
<div class="line number74 index73 alt1">
</div>
<div class="line number75 index74 alt2">
<code class="bash plain">服务器端:</code>
</div>
<div class="line number76 index75 alt1">
<code class="bash plain"></code><code class="bash comments"># ll</code>
</div>
<div class="line number77 index76 alt2">
<code class="bash plain">total 4</code>
</div>
<div class="line number78 index77 alt1">
<code class="bash plain">-rw-r--r-- 1 root root 0 nov 10 17:27 3 </code><code class="bash comments">#说明已经删除掉了</code>
</div>
<div class="line number79 index78 alt2">
<code class="bash plain">drwxr-xr-x 2 root root 4096 nov 10 17:27 data</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
</div>
<p>
4、常见错误汇总</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_516814">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
<div class="line number11 index10 alt2">
11</div>
<div class="line number12 index11 alt1">
12</div>
<div class="line number13 index12 alt2">
13</div>
<div class="line number14 index13 alt1">
14</div>
<div class="line number15 index14 alt2">
15</div>
<div class="line number16 index15 alt1">
16</div>
<div class="line number17 index16 alt2">
17</div>
<div class="line number18 index17 alt1">
18</div>
<div class="line number19 index18 alt2">
19</div>
<div class="line number20 index19 alt1">
20</div>
<div class="line number21 index20 alt2">
21</div>
<div class="line number22 index21 alt1">
22</div>
<div class="line number23 index22 alt2">
23</div>
<div class="line number24 index23 alt1">
24</div>
<div class="line number25 index24 alt2">
25</div>
<div class="line number26 index25 alt1">
26</div>
<div class="line number27 index26 alt2">
27</div>
<div class="line number28 index27 alt1">
28</div>
<div class="line number29 index28 alt2">
29</div>
<div class="line number30 index29 alt1">
30</div>
<div class="line number31 index30 alt2">
31</div>
<div class="line number32 index31 alt1">
32</div>
<div class="line number33 index32 alt2">
33</div>
<div class="line number34 index33 alt1">
34</div>
<div class="line number35 index34 alt2">
35</div>
<div class="line number36 index35 alt1">
36</div>
<div class="line number37 index36 alt2">
37</div>
<div class="line number38 index37 alt1">
38</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">错误一:</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain">@error: auth failed on module xxxxx</code>
</div>
<div class="line number3 index2 alt2">
<code class="bash functions">rsync</code><code class="bash plain">: connection unexpectedly closed(90 bytes </code><code class="bash functions">read</code> <code class="bash plain">so far)</code>
</div>
<div class="line number4 index3 alt1">
<code class="bash functions">rsync</code> <code class="bash plain">error: error </code><code class="bash keyword">in</code> <code class="bash functions">rsync</code> <code class="bash plain">protocoldata stream (code 12) at io.c(150)</code>
</div>
<div class="line number5 index4 alt2">
<code class="bash plain">说明:这是因为密码设置错了,无法登入成功,检查一下</code><code class="bash functions">rsync</code><code class="bash plain">.</code><code class="bash functions">pwd</code><code class="bash plain">,看客服是否匹配。还有服务器端没启动</code><code class="bash functions">rsync</code> <code class="bash plain">服务也会出现这种情况。</code>
</div>
<div class="line number6 index5 alt1">
<code class="bash spaces"> </code>
</div>
<div class="line number7 index6 alt2">
<code class="bash plain">错误二:</code>
</div>
<div class="line number8 index7 alt1">
<code class="bash plain">password </code><code class="bash functions">file</code> <code class="bash plain">must not beother-accessible</code>
</div>
<div class="line number9 index8 alt2">
<code class="bash plain">continuing without password </code><code class="bash functions">file</code>
</div>
<div class="line number10 index9 alt1">
<code class="bash plain">password:</code>
</div>
<div class="line number11 index10 alt2">
<code class="bash plain">说明:这是因为rsyncd.pwdrsyncd.sec的权限不对,应该设置为600。如:chmod600 rsyncd.</code><code class="bash functions">pwd</code>
</div>
<div class="line number12 index11 alt1">
<code class="bash spaces"> </code>
</div>
<div class="line number13 index12 alt2">
<code class="bash plain">错误三:</code>
</div>
<div class="line number14 index13 alt1">
<code class="bash plain">@error: chroot failed</code>
</div>
<div class="line number15 index14 alt2">
<code class="bash functions">rsync</code><code class="bash plain">: connection unexpectedly closed(75 bytes </code><code class="bash functions">read</code> <code class="bash plain">so far)</code>
</div>
<div class="line number16 index15 alt1">
<code class="bash functions">rsync</code> <code class="bash plain">error: error </code><code class="bash keyword">in</code> <code class="bash functions">rsync</code> <code class="bash plain">protocoldata stream (code 12) at io.c(150)</code>
</div>
<div class="line number17 index16 alt2">
<code class="bash plain">说明:这是因为你在 </code><code class="bash functions">rsync</code><code class="bash plain">.conf中设置的 path 路径不存在,要新建目录才能开启同步</code>
</div>
<div class="line number18 index17 alt1">
<code class="bash spaces"> </code>
</div>
<div class="line number19 index18 alt2">
<code class="bash plain">错误四:</code>
</div>
<div class="line number20 index19 alt1">
<code class="bash functions">rsync</code><code class="bash plain">: failed to connect to218.107.243.2: no route to host (113)</code>
</div>
<div class="line number21 index20 alt2">
<code class="bash functions">rsync</code> <code class="bash plain">error: error </code><code class="bash keyword">in</code> <code class="bash plain">socket io (code10) at clientserver.c(104) </code>
</div>
<div class="line number22 index21 alt1">
<code class="bash plain">说明:防火墙问题导致,这个最好先彻底关闭防火墙,排错的基本法就是这样,无论是s还是c,还有ignore errors选项问题也会导致</code>
</div>
<div class="line number23 index22 alt2">
<code class="bash spaces"> </code>
</div>
<div class="line number24 index23 alt1">
<code class="bash plain">错误五:</code>
</div>
<div class="line number25 index24 alt2">
<code class="bash plain">@error: access denied to www fromunknown (192.168.1.123)</code>
</div>
<div class="line number26 index25 alt1">
<code class="bash functions">rsync</code><code class="bash plain">: connection unexpectedly closed(0 bytes received so far) </code>
</div>
<div class="line number27 index26 alt2">
<code class="bash functions">rsync</code> <code class="bash plain">error: error </code><code class="bash keyword">in</code> <code class="bash functions">rsync</code> <code class="bash plain">protocoldata stream (code 12) at io.c(359)</code>
</div>
<div class="line number28 index27 alt1">
<code class="bash plain">说明:此问题很明显,是配置选项hostallow的问题,初学者喜欢一个允许段做成一个配置,然后模块又是同一个,致使导致</code>
</div>
<div class="line number29 index28 alt2">
<code class="bash spaces"> </code>
</div>
<div class="line number30 index29 alt1">
<code class="bash plain">错误六:</code>
</div>
<div class="line number31 index30 alt2">
<code class="bash functions">rsync</code> <code class="bash plain">error: received sigint,sigterm, or sighup (code 20) at </code><code class="bash functions">rsync</code><code class="bash plain">.c(244) </code>
</div>
<div class="line number32 index31 alt1">
<code class="bash functions">rsync</code> <code class="bash plain">error: received sigusr1 (code19) at main.c(1182) </code>
</div>
<div class="line number33 index32 alt2">
<code class="bash plain">说明:导致此问题多半是服务端服务没有被正常启动,到服务器上去查查服务是否有启动,然后查看下 </code><code class="bash plain">/var/run/rsync</code><code class="bash plain">.pid 文件是否存在,最干脆的方法是杀死已经启动了服务,然后再次启动服务或者让脚本加入系统启动服务级别然后</code><code class="bash functions">shutdown</code> <code class="bash plain">-r now服务器</code>
</div>
<div class="line number34 index33 alt1">
</div>
<div class="line number35 index34 alt2">
<code class="bash plain">错误七:</code>
</div>
<div class="line number36 index35 alt1">
<code class="bash functions">rsync</code><code class="bash plain">: </code><code class="bash functions">read</code> <code class="bash plain">error: connection resetby peer (104)</code>
</div>
<div class="line number37 index36 alt2">
<code class="bash functions">rsync</code> <code class="bash plain">error: error </code><code class="bash keyword">in</code> <code class="bash functions">rsync</code> <code class="bash plain">protocoldata stream (code 12) at io.c(604) </code>
</div>
<div class="line number38 index37 alt1">
<code class="bash plain">说明:原数据目录里没有数据存在</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
</div>
<p>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。</p>
<p>
原文链接:https://www.cnblogs.com/caicairui/archive/2018/02/26/8472888.html</p>
頁:
[1]