Linux中内核级加强型火墙selinux的管理和使用

Selinux的功能

观察现象
此实验前需将/etc/vsftpd/vsftpd.conf还原如下
Linux中内核级加强型火墙selinux的管理和使用
 
当Selinux未开启时
 
/mnt中建立文件被移动到/var/ftp下可以被vsftpd服务访问
Linux中内核级加强型火墙selinux的管理和使用
 
匿名用户可以通过设置后上传文件
 
当使用ls -Z /var/ftp查看文件时显示"?"
Linux中内核级加强型火墙selinux的管理和使用
 
ps auxZ | grep vsftpd 时显示:
-                                          root                        8546 0.0 0.0 26952 408 ? Ss 10:35 0:00 /usr/sbin/vsftpd     /etc/vsftpd/vsftpd.conf
Linux中内核级加强型火墙selinux的管理和使用
 
当selinux开启时
 
/mnt中建立文件被移动到/var/ftp下不可以被vsftpd服务访问
Linux中内核级加强型火墙selinux的管理和使用
 
匿名用户通过设置后仍然不能上传文件
 
 
当使用ls -Z /var/ftp查看文件时显示信息
Linux中内核级加强型火墙selinux的管理和使用
 
ps auxZ | grep vsftpd 时显示:
system_u:system_r:ftpd_t:s0-s0:c0.c1023 root 6577 0.0 0.0 26952
412 ? Ss 10:50 0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf
Linux中内核级加强型火墙selinux的管理和使用
 
selinux对于文件的影响
selinux开启时,内核会对每个文件及每个开启的程序进行标签加载
标签内记录程序和文件的安全上下文(context
 
对于程序功能的影响
selinux开启会对程序的功能加载开关,并设定此开关的状态为关闭
当需要此功能时需要手动开启功能开关
此开关叫做sebool

 

Selinux的状态及管理

selinux的开启
vim /etc/selinux/config
7 SELINUX=disabled        selinux关闭
7 SELINUX=enforcing      selinux开机设定为强制状态此状态为selinux开启
7 SELINUX=permissive    selinux开机设定为警告状态此状态为selinux开启
"selinux开启或关闭需要重启系统"
 
enforcing
不符合条件被拒绝,并会收到警告信息
如下图强制模式下访问westosfile1时,无法访问并被警告
Linux中内核级加强型火墙selinux的管理和使用
 
permissive
不符合条件被允许,并会收到警告信息
Linux中内核级加强型火墙selinux的管理和使用

selinux状态的查看:
getenforce
Linux中内核级加强型火墙selinux的管理和使用
 
selinux开启后强制和警告级别的转换
setenforce 0    警告
setenforce 1    强制
Linux中内核级加强型火墙selinux的管理和使用
 
selinux日志位置:
/var/log/audit/audit.log

 

Selinux的安全上下文

查看安全上下文
ls -Z             查看文件的安全上下文
ls -Zd           查看目录的安全上下文
ps auxZ       查看进程的安全上下文
Linux中内核级加强型火墙selinux的管理和使用
 
修改安全上下文
1.临时修改
此方式更改的安全上下文在selinux重启后会还原
chcon   -t                  标签                            文件|目录
chcon   -t         public_content_t            /var/ftp/westosfile1
Linux中内核级加强型火墙selinux的管理和使用
chcon   -Rt      public_content_t            /westosdir                     修改目录及目录中的所有子文件的安全上下文
Linux中内核级加强型火墙selinux的管理和使用
Linux中内核级加强型火墙selinux的管理和使用
 
 
 
2.永久修改安全上下文
如果需要特殊指定安全上下文需要修改内核安全上下文列表
semanage fcontext -l                                 查看内核安全上下文列表
semanage fcontext -a -t public_content_t  '/westosdir(/.*)?'                (/.*)会使目录本身和内容都被记录
Linux中内核级加强型火墙selinux的管理和使用
restorecon -RvvF /westosdir/
touch /.autorelabel                 重启系统时selinux初始化文件标签开关文件(建立此文件后只需重启一次
Linux中内核级加强型火墙selinux的管理和使用
reboot

Linux中内核级加强型火墙selinux的管理和使用


SEBOOL

getsebool -a      现实服务的bool
Linux中内核级加强型火墙selinux的管理和使用
setsebool -P ftpd_anon_write on   更改
Linux中内核级加强型火墙selinux的管理和使用

 

SEPORT

 vim /etc/ssh/sshd_config
 
Linux中内核级加强型火墙selinux的管理和使用
警告模式下sshd服务可以重启,强制模式下不能重启
Linux中内核级加强型火墙selinux的管理和使用
为解决此问题,需添加端口1111
semanage port -l | grep ssh
semanage port -a -t ssh_port_t -p tcp 1111
Linux中内核级加强型火墙selinux的管理和使用
 
 

setrouble

/var/log/audit/audit.log         存放selinux警告信息
/var/log/messages               存放selinux问题解决方案
setroubleshoot-server         此软件功能是采集警告信息并分析得到解决方案存放到message
 
实验:
semanage port -d -t ssh_port_t -p tcp 1111   删除上一实验中创造的端口
> /var/log/audit/audit.log
> /var/log/messages
 
systemctl restart sshd
systemctl stop sshd
 
cat /var/log/messages           此时可在/var/log/messages中查看到解决方案
Linux中内核级加强型火墙selinux的管理和使用