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

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