Centos下“無法打開並寫入文件”問題

摘要

當前是root用戶,去編輯/etc/ssh/sshd_config 卻提示沒有權限修改。報錯如"/etc/ssh/sshd_config" E212: 無法打開並寫入文件


問題思考

既然提示沒有權限,又是root用戶,看肯定是給該文件設置了特殊的權限。檢查特殊權限設置:

  • getfacl
  • lsattr

getfacl 結果正常

root@pts/1 $ getfacl /etc/ssh/sshd_config
getfacl: Removing leading '/' from absolute path names
# file: etc/ssh/sshd_config
# owner: root
# group: root
user::rw-
group::---
other::---

lsattr提示錯誤-bash: lsattr: command not found 沒有該命令,奇怪。當前系統是CentOS release 6.5 (Final),那就嘗試安裝。

查找得知lsattrchattr屬於安裝包e2fsprogs,安裝之。

root@pts/1 $ yum install e2fsprogs
設置安裝進程
解決依賴關係
--> 執行事務檢查
---> Package e2fsprogs.x86_64 0:1.41.12-18.el6_5.1 will be 升級
---> Package e2fsprogs.x86_64 0:1.41.12-23.el6 will be an update
--> 處理依賴關係 libss = 1.41.12-23.el6,它被軟件包 e2fsprogs-1.41.12-23.el6.x86_64 需要

... ...

更新完畢:
  e2fsprogs.x86_64 0:1.41.12-23.el6

作爲依賴被升級:
  e2fsprogs-libs.x86_64 0:1.41.12-23.el6      libcom_err.x86_64 0:1.41.12-23.el6      libcom_err-devel.x86_64 0:1.41.12-23.el6
  libss.x86_64 0:1.41.12-23.el6

完畢!

lsattr 檢查

root@pts/1 $ lsattr  /etc/ssh/sshd_config
----i--------e- /etc/ssh/sshd_config

這裏的i 表示immutable,在文件上啓用這個屬性時,我們不能更改、重命名或者刪除這個文件。
這裏的e 表示extent format,它表明該文件使用磁盤上的塊的映射擴展。屬於“正常”規則

chattr刪除不可修改屬性

root@pts/1 $ chattr -i /etc/ssh/sshd_config
iZ25zjpz5pqZ [~] 2017-12-16 10:59:14
root@pts/1 $ lsattr  /etc/ssh/sshd_config
-------------e- /etc/ssh/sshd_config
iZ25zjpz5pqZ [~] 2017-12-16 10:59:17
root@pts/1 $ vim /etc/ssh/sshd_config
iZ25zjpz5pqZ [~] 2017-12-16 10:59:26
root@pts/1 $

從上面的操作可以看到我們取消i設置之後可以成功修改該文件。
如果完成修改你可以讓其恢復不可修改屬性,可以執行chattr +i /etc/ssh/sshd_config

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章