UDN-企业互联网技术人气社区

板块导航

浏览  : 1427
回复  : 0

[运维] 如何备份及恢复 Linux 文件权限

[复制链接]
呵呵燕的头像 楼主
发表于 2016-10-7 14:11:45 | 显示全部楼层 |阅读模式
  你可能听说或碰到过这样的事情:一个系统管理员菜鸟不小心输入”chmod -R 777 /”从而导致了巨大的悲剧,使得整个系统遭到了严重的破坏。在日常管理中,我们有许多工具可以用来备份文件权限,如cp、rsync、etckeeper等。如果你使用了这个备份工具,那么你的确不需要担心改变的文件权限问题。

  但如果只是想暂时备份文件权限(而不是文件本身),例如:为了阻止一些目录的内容被覆盖暂时移除该目录下所有文件写的权限;或是正在排除文件权限问题的过程中需要对文件进行chmod命令操作。在这些情况下,我们可以在原始文件权限改变之前对其进行备份,一会我们需要它的时候再将原始权限还原。在很多情况下,如果你只是想要备份文件的权限,那么完整的文件备份是不必要的。

  在Linux上,实际上备份和恢复文件权限使用访问控制列表(ACL)是容易的。ACL根据不同的属主和属组在兼容posix的文件系统上定义了单个文件的权限。

5.jpg


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

  1. 安装ACL工具

  在Debian, Ubuntu,Linux Mint上

 
  1.  $ sudo apt-get install acl
复制代码


  在CentOS,Fedora,RHEL上

 
  1.  $ sudo yum install acl
复制代码


  2. 备份当前目录下(包括子目录)所有文件的权限

  1.   [root@linuxprobe tmp]# ls -l

  2.   total 8

  3.   -rwxr--r--. 1 root root 0 Mar 3 04:40 install.txt

  4.   -rwxr-xr-x. 1 root root 0 Mar 3 04:41 linuxprobe.txt

  5.   [root@linuxprobe tmp]# getfacl -R . > permissions.txt

  6.   ...
复制代码


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

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

  1.   [root@linuxprobe tmp]# cat permissions.txt

  2.   # file: .

  3.   # owner: root

  4.   # group: root

  5.   # flags: --t

  6.   user::rwx

  7.   group::rwx

  8.   other::rwx

  9.   # file: install.txt

  10.   # owner: root

  11.   # group: root

  12.   user::rwx

  13.   group::r--

  14.   other::r--

  15.   # file: linuxprobe.txt

  16.   # owner: root

  17.   # group: root

  18.   user::rwx

  19.   group::r-x

  20.   other::r-x

  21.   # file: permissions.txt

  22.   # owner: root

  23.   # group: root

  24.   user::rw-

  25.   group::r--

  26.   other::r--

  27.   ...
复制代码


  3. 修改某一文件权限,如:修改linuxprobe.txt及install.txt权限

  1.   [root@linuxprobe tmp]# chmod 733 linuxprobe.txt

  2.   [root@linuxprobe tmp]# chmod 573 install.txt

  3.   [root@linuxprobe tmp]# ls -l

  4.   total 8

  5.   -r-xrwx-wx. 1 root root 0 Mar 3 04:40 install.txt

  6.   -rwx-wx-wx. 1 root root 0 Mar 3 04:41 linuxprobe.txt

  7.   -rw-r--r--. 1 root root 4361 Mar 3 04:41 permissions.txt

  8.   ......
复制代码


  4. 恢复原有权限

  1)cd到创建permissions.txt时所在的目录

  2)执行以下命令:

 
  1.  setfacl --restore=permissions.txt
复制代码


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

 
  1.  [root@linuxprobe tmp]# setfacl --restore=permissions.txt

  2.   [root@linuxprobe tmp]# ls -l

  3.   total 8

  4.   -rwxr--r--. 1 root root 0 Mar 3 04:40 install.txt

  5.   -rwxr-xr-x. 1 root root 0 Mar 3 04:41 linuxprobe.txt

  6.   -rw-r--r--. 1 root root 4361 Mar 3 04:41 permissions.txt

  7.   ......
复制代码


原文作者:佚名  来源:开发者头条

相关帖子

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于我们
联系我们
  • 电话:010-86393388
  • 邮件:udn@yonyou.com
  • 地址:北京市海淀区北清路68号
移动客户端下载
关注我们
  • 微信公众号:yonyouudn
  • 扫描右侧二维码关注我们
  • 专注企业互联网的技术社区
版权所有:用友网络科技股份有限公司82041 京ICP备05007539号-11 京公网网备安1101080209224 Powered by Discuz!
快速回复 返回列表 返回顶部