一、selinux的功能
selinux:
对于文件的影响:
当selinux开启时,内核会对每个文件及每个开启的程序进行标签加载
标签内记录程序和文件的安全上下文(context)对于程序功能的影响:
当selinux开启会对程序的功能加载开关,并设定此开关的状态为关闭
当需要此功能时需要手动开启功能开关
此开关叫做sebool
二、Selinux的状态及管理
配置实验环境
[root@westoslinux111 ~]# rm -fr /etc/vsftpd/
[root@westoslinux111 ~]# dnf reinstall vsftpd -y
[root@westoslinux111 ~]# vim /etc/vsftpd/vsftpd.conf ##开启匿名登陆和上传
[root@westoslinux111 ~]# systemctl restart vsftpd
[root@westoslinux111 ~]# chmod 775 /var/ftp/pub
[root@westoslinux111 ~]# chgrp ftp /var/ftp/pub
[root@westoslinux111 ~]# lftp 172.25.254.111
lftp 172.25.254.111:~> ls
-rw-r--r-- 1 0 0 988 Nov 04 02:58 group
drwxrwxr-x 2 0 50 65 Feb 17 2020 pub
-rw-r--r-- 1 0 0 0 Nov 04 02:34 westosfile
[root@westoslinux111 ~]# rm -fr /var/ftp/pub/*
[root@westoslinux111 ~]# ls /var/ftp/pub
selinux的开启:
vim /etc/selinux/config
7 SELINUX=disabled #selinux关闭
7 SELINUX=enforcing #selinux开机设定为强制状态此状态为selinux开启
7 SELINUX=permissive #selinux开机设定为警告状态此状态为selinux开启
"selinux开启或关闭需要重启系统"enforcing:
不符合条件一定不能被允许,并会收到警告信息
permissive:
不符合条件被允许,并会收到警告信息selinux状态的查看:getenforce
selinux开启后强制和警告级别的转换
setenforce 0 ##警告
setenforce 1 ##强制
selinux日志位置:/var/log/audit/audit.log
重启之后显示为enforcing状态,建立autorelabel初始化服务(需要在selinux开启的状态下)
三、Selinux的安全上下文
1、查看
ls -Z ##查看文件的安全上下文
ls -Zd ##查看目录的安全上下文
ps axZ ##查看进程的安全上下文
2、修改安全上下文
临时修改
此方式更改的安全上下文在selinux重启后会还原
chcon -t 标签 文件|目录
chcon -t public_content_t /var/ftp/westosfile1
chcon -Rt public_content_t /westosdir #修改目录及目录中的所有子文件的安全上下文
临时更改文件安全上下文
临时更改目录安全上下文
临时更改目录及目录中的所有子文件的安全上下文
永久修改安全上下文
如果需要特殊指定安全上下文需要修改内核安全上下文列表
semanage fcontext -l ##查看内核安全上下文列表
semanage fcontext -a -t public_content_t '/westosdir(/.*)?'
restorecon -RvvF /westosdir/
touch /.autorelabel ##重启系统时selinux初始化文件标签开关文件
四、SEBOOL
getsebool -a ##显示服务的bool值
setsebool -P ftpd_anon_write on #更改
当selinux为强制状态时,不可上传文件,改为警告状态可以上传
加读写权限依然不可以上传
需要更改sebool值
五、SEPORT
semanage port -l | grep ssh ##查看
semanage port -a -t ssh_port_t -p tcp 1111
六、setrouble
[root@westoslinux111 ~]# dnf install setroubleshoot-server.x86_64 -y ##安装此服务才可在日志中看到解决方案
/var/log/audit/audit.log ##selinux警告信息
/var/log/messages ##selinux问题解决方案
setroubleshoot-server ##此软件功能是采集警告信息并分析得到解决方案存放到message中
根据解决方案修改,可查看到westosfile11