网站首页 美食营养 游戏数码 手工爱好 生活家居 健康养生 运动户外 职场理财 情感交际 母婴教育 时尚美容

Linux如何解决root用户Operation not permitted

时间:2024-10-18 00:39:48

在Linux系统中,拥有最高权限的用户root,在执行文件权限的修改,或者修改文件时也会出现如下错误:1. chmod: changing permissions of 'xxx': Operation not permitted;2. E45: 'readonly' option is set (add ! to override)接下来本文主要介绍如何解决root用户无权限修改文件的问题。

工具/原料

Linux

一、问题背景

1、Linux环境下,在安装Oracle数据库时需要修改内核参数,这时就需要改动系统文件/etc/sysctl.conf,切换到root用户修改此文件,进行保存时报了如下错误:E45: 'readonly' option is set (add ! to override)

Linux如何解决root用户Operation not permitted

2、执行chmod 777 /etc/sysctl.conf时会报出错误:chmod: changing permissions of '/etc/sysctl.conf': Operation not permitted

Linux如何解决root用户Operation not permitted

3、一般我们都知道,Linux下root用户的权限是最大了,难道还有root用户操作不了的文件?(Linux下UID数值越小的用户,权限越大,可以看到最小值为0,即root用户)

Linux如何解决root用户Operation not permitted

二、问题修复

1、上面我们执行的chmod命令,其底层实现是chattr命令,用此命的功能更为强大,甚至可以锁定文件,即使root用户也操作不了此文件。

Linux如何解决root用户Operation not permitted

2、chattr是用来更改文件属性,lsattr可用来查看文件的属性,执行命令lsattr /etc/sysctl.conff便可以看到当前文件的属性;可以发现当前文件有个i属性,查阅命令帮助文档可以看到有i属性的文件是不能修改的,更不可被删除,即使是root用户也不可。

Linux如何解决root用户Operation not permittedLinux如何解决root用户Operation not permitted

3、既然知道了文件不能操作的原因是加了i属性,所以相应的解决方案就是把文件的i属性去除,然后对此文件内容进行修改,最好在操作完成后恢复文件的i属性。去除i属性:chattr -i /etc/sysctl.conf添加i属性:chattr +i /etc/sysctl.conf

Linux如何解决root用户Operation not permittedLinux如何解决root用户Operation not permitted
© 2025 一点知道
信息来自网络 所有数据仅供参考
有疑问请联系站长 site.kefu@gmail.com