阿芬吖 發表於 2023-12-6 00:00:00

详解如何备份及恢复 Linux 文件权限

<p>
        你可能听说或碰到过这样的事情:一个系统管理员菜鸟不小心输入"chmod -R 777 /"从而导致了巨大的悲剧,使得整个系统遭到了严重的破坏。在日常管理中,我们有许多工具可以用来备份文件权限,如cp、rsync、etckeeper等。如果你使用了这个备份工具,那么你的确不需要担心改变的文件权限问题。</p>
<p>
        但如果只是想暂时备份文件权限(而不是文件本身),例如:为了阻止一些目录的内容被覆盖暂时移除该目录下所有文件写的权限;或是正在排除文件权限问题的过程中需要对文件进行chmod命令操作。在这些情况下,我们可以在原始文件权限改变之前对其进行备份,一会我们需要它的时候再将原始权限还原。在很多情况下,如果你只是想要备份文件的权限,那么完整的文件备份是不必要的。</p>
<p>
        在Linux上,实际上备份和恢复文件权限使用访问控制列表(ACL)是容易的。ACL根据不同的属主和属组在兼容posix的文件系统上定义了单个文件的权限。</p>
<p>
        以下演示如何使用ACL工具备份和恢复Linux的文件权限</p>
<p>
        <strong>1. 安装ACL工具</strong></p>
<p>
        在Debian, Ubuntu,Linux Mint上</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_65148">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash plain">$ </code><code class="bash functions">sudo</code> <code class="bash plain">apt-get </code><code class="bash functions">install</code> <code class="bash plain">acl</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        在CentOS,Fedora,RHEL上</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_473274">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash plain">$ </code><code class="bash functions">sudo</code> <code class="bash plain">yum </code><code class="bash functions">install</code> <code class="bash plain">acl</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        <strong>2. 备份当前目录下(包括子目录)所有文件的权限</strong></p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_741347">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash plain"></code><code class="bash comments"># ls -l</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="bash plain">total 8</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="bash plain">-rwxr--r--. 1 root root 0 Mar 3 04:40 </code><code class="bash functions">install</code><code class="bash plain">.txt</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="bash plain">-rwxr-xr-x. 1 root root 0 Mar 3 04:41 linuxprobe.txt</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="bash plain"></code><code class="bash comments"># getfacl -R . &gt; permissions.txt</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="bash plain">...</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        此命令将所有文件的ACL信息全部写入名为permissions.txt文件。</p>
<p>
        以下是生成的permissions.txt文件中部分目录信息</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_478887">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash plain"></code><code class="bash comments"># cat permissions.txt</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="bash comments"># file: .</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="bash comments"># owner: root</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="bash comments"># group: root</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="bash comments"># flags: --t</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="bash plain">user::rwx</code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="bash plain">group::rwx</code>
</div>
                                                                <div class="line number8 index7 alt1">
                                                                        <code class="bash plain">other::rwx</code>
</div>
                                                                <div class="line number9 index8 alt2">
                                                                        <code class="bash comments"># file: install.txt</code>
</div>
                                                                <div class="line number10 index9 alt1">
                                                                        <code class="bash comments"># owner: root</code>
</div>
                                                                <div class="line number11 index10 alt2">
                                                                        <code class="bash comments"># group: root</code>
</div>
                                                                <div class="line number12 index11 alt1">
                                                                        <code class="bash plain">user::rwx</code>
</div>
                                                                <div class="line number13 index12 alt2">
                                                                        <code class="bash plain">group::r--</code>
</div>
                                                                <div class="line number14 index13 alt1">
                                                                        <code class="bash plain">other::r--</code>
</div>
                                                                <div class="line number15 index14 alt2">
                                                                        <code class="bash comments"># file: linuxprobe.txt</code>
</div>
                                                                <div class="line number16 index15 alt1">
                                                                        <code class="bash comments"># owner: root</code>
</div>
                                                                <div class="line number17 index16 alt2">
                                                                        <code class="bash comments"># group: root</code>
</div>
                                                                <div class="line number18 index17 alt1">
                                                                        <code class="bash plain">user::rwx</code>
</div>
                                                                <div class="line number19 index18 alt2">
                                                                        <code class="bash plain">group::r-x</code>
</div>
                                                                <div class="line number20 index19 alt1">
                                                                        <code class="bash plain">other::r-x</code>
</div>
                                                                <div class="line number21 index20 alt2">
                                                                        <code class="bash comments"># file: permissions.txt</code>
</div>
                                                                <div class="line number22 index21 alt1">
                                                                        <code class="bash comments"># owner: root</code>
</div>
                                                                <div class="line number23 index22 alt2">
                                                                        <code class="bash comments"># group: root</code>
</div>
                                                                <div class="line number24 index23 alt1">
                                                                        <code class="bash plain">user::rw-</code>
</div>
                                                                <div class="line number25 index24 alt2">
                                                                        <code class="bash plain">group::r--</code>
</div>
                                                                <div class="line number26 index25 alt1">
                                                                        <code class="bash plain">other::r--</code>
</div>
                                                                <div class="line number27 index26 alt2">
                                                                        <code class="bash plain">...</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        <strong>3. 修改某一文件权限,如:修改linuxprobe.txt及install.txt权限</strong></p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_888177">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash plain"></code><code class="bash comments"># chmod 733 linuxprobe.txt </code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="bash plain"></code><code class="bash comments"># chmod 573 install.txt </code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="bash plain"></code><code class="bash comments"># ls -l</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="bash plain">total 8</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="bash plain">-r-xrwx-wx. 1 root root  0 Mar 3 04:40 </code><code class="bash functions">install</code><code class="bash plain">.txt</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="bash plain">-rwx-wx-wx. 1 root root  0 Mar 3 04:41 linuxprobe.txt</code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="bash plain">-rw-r--r--. 1 root root 4361 Mar 3 04:41 permissions.txt</code>
</div>
                                                                <div class="line number8 index7 alt1">
                                                                        <code class="bash plain">......</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        <strong>4. 恢复原有权限</strong></p>
<p>
        1)cd到创建permissions.txt时所在的目录</p>
<p>
        2)执行以下命令:</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_44713">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash plain">setfacl --restore=permissions.txt</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        可以看到linuxprobe.txt及install.txt权限恢复了</p>
<div class="jb51code">
        <div>
                <div class="syntaxhighlighterbash" id="highlighter_108175">
                        <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>
                                                </td>
                                                <td class="code">
                                                        <div class="container">
                                                                <div class="line number1 index0 alt2">
                                                                        <code class="bash plain"></code><code class="bash comments"># setfacl --restore=permissions.txt</code>
</div>
                                                                <div class="line number2 index1 alt1">
                                                                        <code class="bash plain"></code><code class="bash comments"># ls -l</code>
</div>
                                                                <div class="line number3 index2 alt2">
                                                                        <code class="bash plain">total 8</code>
</div>
                                                                <div class="line number4 index3 alt1">
                                                                        <code class="bash plain">-rwxr--r--. 1 root root  0 Mar 3 04:40 </code><code class="bash functions">install</code><code class="bash plain">.txt</code>
</div>
                                                                <div class="line number5 index4 alt2">
                                                                        <code class="bash plain">-rwxr-xr-x. 1 root root  0 Mar 3 04:41 linuxprobe.txt</code>
</div>
                                                                <div class="line number6 index5 alt1">
                                                                        <code class="bash plain">-rw-r--r--. 1 root root 4361 Mar 3 04:41 permissions.txt</code>
</div>
                                                                <div class="line number7 index6 alt2">
                                                                        <code class="bash plain">......</code>
</div>
                                                        </div>
                                                </td>
                                        </tr></tbody></table>
</div>
        </div>
        <div class="codetool" id="codetool">
                <div class="code_n">
                        <textarea></textarea>
</div>
        </div>
</div>
<p>
        以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。</p>
頁: [1]
查看完整版本: 详解如何备份及恢复 Linux 文件权限