Linux系統(tǒng)中備份和恢復文件權(quán)限設置的教程

你可能聽說或碰到過這樣的事情:一個系統(tǒng)管理員菜鳥不小心輸入"chmod -R 777 /"從而導致了巨大的悲劇,使得整個系統(tǒng)遭到了嚴重的破壞。在日常管理中,我們有許多工具可以用來備份文件權(quán)限,如cp、rsync、etckeeper等。如果你使用了這個備份工具,那么你的確不需要擔心改變的文件權(quán)限問題。
但如果只是想暫時備份文件權(quán)限(而不是文件本身),例如:為了阻止一些目錄的內(nèi)容被覆蓋暫時移除該目錄下所有文件寫的權(quán)限;或是正在排除文件權(quán)限問題的過程中需要對文件進行chmod命令操作。在這些情況下,我們可以在原始文件權(quán)限改變之前對其進行備份,一會我們需要它的時候再將原始權(quán)限還原。在很多情況下,如果你只是想要備份文件的權(quán)限,那么完整的文件備份是不必要的。
在Linux上,實際上備份和恢復文件權(quán)限使用訪問控制列表(ACL)是容易的。ACL根據(jù)不同的屬主和屬組在兼容posix的文件系統(tǒng)上定義了單個文件的權(quán)限。
以下演示如何使用ACL工具備份和恢復Linux的文件權(quán)限
1. 安裝ACL工具
在Debian, Ubuntu,Linux Mint上
$ sudo apt-get install acl
在CentOS,F(xiàn)edora,RHEL上
$ sudo yum install acl
2. 備份當前目錄下(包括子目錄)所有文件的權(quán)限
[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. 修改某一文件權(quán)限,如:修改linuxprobe.txt及install.txt權(quán)限
[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. 恢復原有權(quán)限
1)cd到創(chuàng)建permissions.txt時所在的目錄
2)執(zhí)行以下命令:
setfacl --restore=permissions.txt
可以看到linuxprobe.txt及install.txt權(quán)限恢復了
[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 Mount NTFS分區(qū)造成的權(quán)限問題如何解決?
最近一些朋友問小編Linux Mount NTFS分區(qū)造成的權(quán)限問題如何解決?今天小編將為大家?guī)淼氖荓inux Mount NTFS分區(qū)造成的權(quán)限問題的解決方案,希望對大家會有幫助,有需要的2017-04-19- 最近一些朋友問小編Linux在無root的權(quán)限下如何安裝程序?今天小編將為大家?guī)淼氖荓inux在無root的權(quán)限下安裝程序的方法,希望對大家會有幫助,有需要的朋友一起去看看吧2017-04-18
Linux下設置權(quán)限讓用戶只刪除自己的文件的方法
今天小編為大家?guī)淼氖荓inux下設置權(quán)限讓用戶只刪除自己的文件的方法,希望對大家會有幫助,有需要的朋友一起去看看吧2017-04-08Linux的特殊權(quán)限SUID SGID和SBIT講解
今天小編為大家?guī)淼氖荓inux的特殊權(quán)限SUID、SGID和SBIT講解。希望對大家會有幫助,有需要的朋友一起去看看吧2017-04-04Linux神奇漏洞:長按回車鍵70秒 即可輕松拿到Root權(quán)限
Linux被爆出神奇漏洞,如果你重復93次輸錯密碼,或者持續(xù)按回車鍵大概70秒,就能夠獲得root initramfs (initial RAM filesystem) shell。關鍵是,這個漏洞攻擊的成功率非常2016-11-18Centos(Linux)下用戶權(quán)限委派配置介紹
Centos(Linux)下最大的權(quán)限賬戶為root,類似在windows中環(huán)境中的administrator,都屬于全局管理員,對服務有完全操作權(quán)限;由于近期審核,負責人將root的密碼更改了,新建2016-11-01- Linux自從引入多用戶機制以后,文件權(quán)限的設置功能也日趨細化和完善,這里我們就來詳解Linux系統(tǒng)中的文件權(quán)限設置,需要的朋友可以參考下2016-06-23
在Linux和Unix中使用chmod命令改變文件權(quán)限的用法
這篇文章主要介紹了在Linux和Unix中使用chmod命令改變文件權(quán)限的用法,chmod在Linux和Unix中的用法基本上相同,文中針對兩個系統(tǒng)一起作出講解,需要的朋友可以參考下2016-05-05linux系統(tǒng)與windows系統(tǒng)文件權(quán)限有什么區(qū)別?
linux系統(tǒng)與windows系統(tǒng)文件權(quán)限有什么區(qū)別?大家都知道linux與windows這兩個系統(tǒng)有很大的區(qū)別,今天我們就來看看linux下文件權(quán)限與windows下文件權(quán)限比較,需要的朋友可以2016-04-29Linux下通過受限bash創(chuàng)建指定權(quán)限的賬號代碼詳解
這篇文章主要介紹了Linux下通過受限bash創(chuàng)建指定權(quán)限的賬號,分享了相關代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-01-23