zoukankan      html  css  js  c++  java
  • 如何备份及恢复Linux文件权限

    你可能听说或碰到过这样的事情:一个系统管理员菜鸟不小心输入"chmod -R 777 /"从而导致了巨大的悲剧,使得整个系统遭到了严重的破坏。在日常管理中,我们有许多工具可以用来备份文件权限,如cp、rsync、etckeeper等。如果你使用了这个备份工具,那么你的确不需要担心改变的文件权限问题。

    但如果只是想暂时备份文件权限(而不是文件本身),例如:为了阻止一些目录的内容被覆盖暂时移除该目录下所有文件写的权限;或是正在排除文件权限问题的过程中需要对文件进行chmod命令操作。在这些情况下,我们可以在原始文件权限改变之前对其进行备份,一会我们需要它的时候再将原始权限还原。在很多情况下,如果你只是想要备份文件的权限,那么完整的文件备份是不必要的。
    在Linux上,实际上备份和恢复文件权限使用访问控制列表(ACL)是容易的。ACL根据不同的所主和所组在兼容posix的文件系统上定义了单个文件的权限。

    以下演示如何使用ACL工具备份和恢复Linux的文件权限

    1. 安装ACL工具

    在Debian, Ubuntu,Linux Mint上

    $ sudo apt-get install acl

    在CentOS,Fedora,RHEL上

    $ sudo yum install acl
    2. 备份当前目录下(包括子目录)所有文件的权限
    [root@linuxprobe tmp]#  ls -l
    total 8
    -rwxr--r--. 1 root root  0 Mar  3 04:40 install.txt
    -rwxr-xr-x. 1 root root  0 Mar  3 04:41 linuxprobe.txt
    [root@linuxprobe tmp]# getfacl -R . > permissions.txt
    ...
    

    此命令将所有文件的ACL信息全部写入名为permissions.txt文件。

    以下是生成的permissions.txt文件中部分目录信息

    [root@linuxprobe tmp]# cat permissions.txt
    # file: .
    # owner: root
    # group: root
    # flags: --t
    user::rwx
    group::rwx
    other::rwx
    # file: install.txt
    # owner: root
    # group: root
    user::rwx
    group::r--
    other::r--
    
    # file: linuxprobe.txt
    # owner: root
    # group: root
    user::rwx
    group::r-x
    other::r-x
    
    # file: permissions.txt
    # owner: root
    # group: root
    user::rw-
    group::r--
    other::r--
    ...
    
    3. 修改某一文件权限,如:修改linuxprobe.txt及install.txt权限
    [root@linuxprobe tmp]# chmod 733 linuxprobe.txt 
    [root@linuxprobe tmp]#  chmod 573 install.txt 
    [root@linuxprobe tmp]# ls -l
    total 8
    -r-xrwx-wx. 1 root root    0 Mar  3 04:40 install.txt
    -rwx-wx-wx. 1 root root    0 Mar  3 04:41 linuxprobe.txt
    -rw-r--r--. 1 root root 4361 Mar  3 04:41 permissions.txt
    ......
    
    4. 恢复原有权限

    1)cd到创建permissions.txt时所在的目录
    2)执行以下命令:

    setfacl --restore=permissions.txt

    可以看到linuxprobe.txt及install.txt权限恢复了

    [root@linuxprobe tmp]# setfacl --restore=permissions.txt
    [root@linuxprobe tmp]# ls -l
    total 8
    -rwxr--r--. 1 root root    0 Mar  3 04:40 install.txt
    -rwxr-xr-x. 1 root root    0 Mar  3 04:41 linuxprobe.txt
    -rw-r--r--. 1 root root 4361 Mar  3 04:41 permissions.txt
    ......

     免费提供最新Linux技术教程书籍,为开源技术爱好者努力做得更多更好:https://www.linuxprobe.com/

  • 相关阅读:
    MySQL:数据库优化,看这篇就够了
    不使用synchronized和lock,如何实现一个线程安全的单例
    理解Spring:IOC的原理及手动实现
    终于放弃了单调的swagger-ui了,选择了这款神器—knife4j
    TP5.0.24 验证器内置规则中max 如果输入中文 验证长度错误的问题
    laravel 5.5 api接口开发:JWT安装+实现API token 认证
    homestead 代码与本地代码不同步的解决方法
    laravel 5.5 api接口开发: 安装dingo/api
    php base_decode 函数将base64编码转换图片遇到的问题
    thinkphp 5.0 部署新网空间隐藏index.php入口
  • 原文地址:https://www.cnblogs.com/linuxprobe/p/5343625.html
Copyright © 2011-2022 走看看