关于CentOS/RHEL中SELinux的相关学习记录整理

很多运维人出于方便,将selinux默认给关闭了,我以前也这样干,后来发现,在内网这样干的确挺省事儿,但公网服务器这样干了,的确有点SB,所以这儿分享一些关于SELinux的学习笔记的整理文档

配置文件路径

/etc/sysconfig/seLinux

SELinux配置文件中可修改项有两项
开机的三种状态

SELINUX = Enforcing  (默认)

Disabled    : 停用SELinux功能
Permissive  : 仅显示警告信息,不阻止
Enforcing   : 强制执行SELinux功能,产生警告信息
SELINUXTYPE=targeted

strict    : 完整的保护功能,包含网络服务,一般指令及应用程序
targeted  : 保护网络相关服务

网络相关服务包括

dhcpd
httpd
mysqld
named
nscd
ntpd
portmap
postgres
snmpd
squid
syslogd

SELinux相关命令

sestatus #查看SELinux的状态
sestatus -b#查看application管理状态
getenforce #显示目前SELinux工作模式
setenforce 0#临时将SELinux模式设为宽容模式
setenforce 1#临时将SELinux模式设为强制模式
注:setenforce必需在SELinux enable状态才有用
ls -Z 文档名#查看SELinux对档案管理状态
ls -dZ 资料夹#查看SELinux对资料夹管理状态
chcon#变更档案、资料夹管理
getsebool#查看application管理状态
setsebool#变更application管理
restorecon#恢复成原有的SELinux type
semanage#安全性文件的查询与修改
semanage port -l |grep http#查看SELinux管理http套件所使用的端口
semanage port -a -t http_port_t -p tcp 90#加入90端口给httpd使用
注:必需安装policycoreutils-python套件,在加入Port时需先检查该port是否已经被使用了。
seinfo#查看政策中规则数量
注:必需安装setools-console套件
sealert -l **#SELinux错误信息详细列出,**为错误代码。
注:必需安装setroubleshoot及setroubleshoot-server套件,安装完后需要重启系统。

查看SELinux状态

sestatus

getenforce

SELinux 使用思路 在SELinux开启的情况下,配置vsftpd服务

1】设置SELinux 允许模式

setenforce  Permissive

2】安装启动vsftpd 服务

yum install vsftpd -y
service vsftpd start

3】测试
匿名登录并下载
使用本地用户登录,并下载,上传
4】设置SELinux 强制模式

setenforce Enforcing

5】再次测试相关功能
匿名用户登录并下载 仍然可以
使用本地用户登录,并下载,上传 --- 被拒绝
6】配置SELinux,放行需要的功能
6.1】方法一 看日志
正常情况下 日志会在服务器的 /var/log/messages 文件中存在
还会在 /var/log/audit/audit.log 存在
查看日志

tail /var/log/messages
sealert -l xxxxxxxxxxxxxxxxxxxx
sealert -a /var/log/audit/audit.log

日志中提示说

setsebool -P ftp_home_dir=1

6.2】方法二 看man手册

man -k ftp | grep selinux
man 8 ftp_selinux
最后修改时间为:2016 年 12 月 19 日 09 时 50 分 AM
如果觉得我的文章对你有用,请随意赞赏

1 条评论

  1. zhaoliang0112

    希望能够有个系统的教程,就不要在去网上找了,直接这里学习!! :)

发表评论