這篇文章主要介紹了linux備份及恢復及linux文件權限詳解的相關資料,需要的朋友可以參考下
Linux備份及恢復及Linux文件權限詳解
概述
一個系統管理員菜鳥不小心輸入”linux -R 777 /”從而導致了巨大的悲劇,使得整個系統遭到了嚴重的破壞。在日常管理中,我們有許多工具可以用來備份文件權限,如cp、rsync、etckeeper等。如果你使用了這個備份工具,那么你的確不需要擔心改變的文件權限問題。
但如果只是想暫時備份文件權限(而不是文件本身),例如:為了阻止一些目錄的內容被覆蓋暫時移除該目錄下所有文件寫的權限;或是正在排除文件權限問題的過程中需要對文件進行chmod命令操作。在這些情況下,我們可以在原始文件權限改變之前對其進行備份,一會我們需要它的時候再將原始權限還原。在很多情況下,如果你只是想要備份文件的權限,那么完整的文件備份是不必要的。
在Linux上,實際上備份和恢復文件權限使用linux列表(ACL)是容易的。ACL根據不同的屬主和屬組在兼容posix的linux上定義了單個文件的權限。
linuxACL工具
在Debian, Ubuntu,Linux Mint上
$?sudo?apt-get?install?acl
在centos,Fedora,RHEL上
$?sudo?yum?install?acl
備份當前目錄下(包括子目錄)所有文件的權限
[xgj@entel2?shells]$?getfacl?-R?.?>?permissions.txt [xgj@entel2?shells]$? [xgj@entel2?shells]$?ll total?8 -rw-rw-r--?1?xgj?xgj?231?Jan?16?12:32?permissions.txt -rwxrwxr-x?1?xgj?xgj?420?Jan?16?12:14?sys_info.sh
此命令將所有文件的ACL信息全部寫入名為permissions.txt文件。
以下是生成的permissions.txt文件中部分目錄信息
[xgj@entel2?shells]$?cat?permissions.txt? #?file:?. #?owner:?xgj #?group:?xgj user::rwx group::rwx other::r-x #?file:?sys_info.sh #?owner:?xgj #?group:?xgj user::rwx group::rwx other::r-x #?file:?permissions.txt #?owner:?xgj #?group:?xgj user::rw- group::rw- other::r--
修改某一文件權限
[xgj@entel2?shells]$?ll total?8 -rw-rw-r--?1?xgj?xgj?231?Jan?16?12:32?permissions.txt -rwxrwxr-x?1?xgj?xgj?420?Jan?16?12:14?sys_info.sh [xgj@entel2?shells]$?chmod?777?sys_info.sh? [xgj@entel2?shells]$?ll total?8 -rw-rw-r--?1?xgj?xgj?231?Jan?16?12:32?permissions.txt -rwxrwxrwx?1?xgj?xgj?420?Jan?16?12:14?sys_info.sh
恢復原有權限
-
cd到創建sys_info.sh時所在的目錄
-
執行以下命令:
[xgj@entel2?shells]$?setfacl?--restore=permissions.txt [xgj@entel2?shells]$?ll total?8 -rw-rw-r--?1?xgj?xgj?231?Jan?16?12:32?permissions.txt -rwxrwxr-x?1?xgj?xgj?420?Jan?16?12:14?sys_info.sh [xgj@entel2?shells]$