restorecon命令详解

Crq
Crq
管理员
1964
文章
0
粉丝
Linux教程评论86字数 657阅读2分11秒阅读模式
摘要restorecon命令用来恢复SELinux文件属性即恢复文件的安全上下文。具体怎么使用呢?下面让我们详细讲解一下chcon命令的使用方法。
语法
restorecon [-iFnrRv] [-e excludedir ] [-o filename ] [-f filename | pathname...]
选项
-i:忽略不存在的文件。
-f:infilename 文件 infilename 中记录要处理的文件。 
-e:directory 排除目录。 
-R/-r:递归处理目录。 
-n:不改变文件标签。 
-o/outfilename:保存文件列表到 outfilename,在文件不正确情况下。 
-v:将过程显示到屏幕上。 
-F:强制恢复文件安全语境。
实例

假设CentOS安装了apache,网页默认的主目录是/var/www/html,我们经常遇到这样的问题,在其他目录中创建了一个网页文件,然后用mv移动到网页默认目录/var/www/html中,但是在浏览器中却打不开这个文件,这很可能是因为这个文件的SELinux配置信息是继承原来那个目录的,与/var/www/html目录不同,使用mv移动的时候,这个SELinux配置信息也一起移动过来了,从而导致无法打开页面,具体请看下面的实例:

/*使用CentOS举例,如果默认没有安装apache,确保网络连接,使用下面的命令安装*/
[root@linuxde.net ~]# yum install httpd
/*我们在root的家目录新建一个html文件*/ 
[root@linuxde.net ~]# pwd 
/root 
[root@linuxde.net ~]# vi index.html 
/*随便输入一段文字,保存退出*/ 
welcome to www.linuxde.net 
/*将这个文件mv到网页默认目录下*/ 
[root@linuxde.net ~]# mv index.html /var/www/html/ 
/* 
* 这个时候我们使用firefox浏览器输入127.0.0.1/index.html发现打不开, 
* 查看一下SELinux的日志文件,发现了下面这一段报错信息,从这个报错信息不难看出, 
* 进程httpd访问网页主目录中的index.html时被SELinux阻止,原因是因为,SELinux配置信息不正确, 
* 正确的SELinux配置信息应该是scontext=后面的部分, 
* 而index.html文件的SELinux配置信息却是tcontext=后面的部分, 
* 从tcontext=的第三段“admin_home_t”不难看出,这个文件的SELinux配置信息是root用户家目录的。 */ 
type=AVC msg=audit(1378974214.610:465): avc: denied { open } for pid=2359 comm="httpd" path="/var/www/html/index.html" dev="sda1" ino=1317685 scontext=system_u:system_r:httpd_t:s0 tcontext=unconfined_u:object_r:admin_home_t:s0 
tclass=file 
/*使用ls -Z也可以看出,文件和目录的SELinux信息不匹配*/ 
[root@linuxde.net html]# ls -Z /var/www/html/ 
.... unconfined_u:object_r:admin_home_t:s0 index.html 
[root@linuxde.net html]# ls -Zd /var/www/html/ 
.... system_u:object_r:httpd_sys_content_t:s0 /var/www/html/ 
/*使用restorecon来恢复网页主目录中所有文件的SELinux配置信息(如果目标为一个目录,可以添加-R参数递归)*/ 
[root@linuxde.net html]# restorecon -R /var/www/html/

weinxin
我的微信
微信号已复制
我的微信
这是我的微信扫一扫
 
Crq
  • 本文由 Crq 发表于2024年11月12日 02:31:59
  • 转载请注明:https://www.cncrq.com/11633.html
smem – Linux 内存监视软件 Linux教程

smem – Linux 内存监视软件

Linux 系统的内存管理工作中,内存使用情况的监控是十分重要的,在各种 Linux 发行版上你会找到许多这种工具。它们的工作方式多种多样,在这里,我们将会介绍如何安装和使用这样的...
Zookeeper集群搭建 Linux教程

Zookeeper集群搭建

由于公司缓存方案改进,准备采用codis集群作为主要的缓存解决方案(codis:国内豌豆荚开发的redis集群解决方案,已开源,github地址:https://github.co...
匿名

发表评论

匿名网友
:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:
确定

拖动滑块以完成验证