Linux中内核级加强防火墙的管理

实验环境:
还原ftp
rm -rf /var/vsftpd
dnf install vsftpd -y
chmod 775 /var/ftp/pub
chgrp ftp /var/ftp/pub
编辑配置文件,允许用户匿名登陆和上传文件
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

一、Selinux的功能

1.观察现象
selinux未开启时
在/mnt中建立文件被移动到/var/ftp下可以被vsftpd服务访问
匿名用户可以通过设置后上文件
当使用ls -Z /var/ 查看文件时显示?
ps auxZ | grep vsftpd 时显示:
_ root 8546 0.0 0.0 26952 408 ? Ss 10:35 0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf

selinux开启时
在/mnt中建立文件被移动到/var/ftp下不可以被vsftpd服务访问
匿名用户不可以通过设置后上传文件
当使用ls -Z /var/ 查看文件时显示信息
ps auxZ | grep vsftpd 时显示:
system_u:system_r:ftpd_t:s0-s0:c0.c1023 root 8546 0.0 0.0 26952 408 ? Ss 10:35 0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf

selinux:
对于文件的影响
当selinux开启时,内核会对每个文件及每个开启的程序进行标签加载
标间内记录程序和文件的安全上下文

对于程序功能的影响:
当selinux开启时会对程序的功能加载开关,并设定此开关的状态为关闭
当需要此功能是需要手动打开功能开关
此开关叫做sebool

只读安全上下文
修改为可写依旧不可上传

二、Selinux的状态及管理

1.selinux的开启
vim /etc/selinux/config
SELINUX=disabled ###selinux关闭
SELINUX=permissive ###selinux状态为开机设定为警告模式selinux开启
SELINUX=enforcing ###selinux状态为开机设定为强制模式selinux开启
更改完需重启系统,否则不生效
在这里插入图片描述
在这里插入图片描述

getenforce ##查看selinux状态
在这里插入图片描述

enforcing 不符合条件一定不能被允许,并会受到警告信息
permisive 不符合条件被允许,并受到警告信息

selinux开启后强制和警告级别的转换
setenforce 0 ##警告
setenforce 1 ##强制
在这里插入图片描述

selinux 日志位置
/var/log/audit/audit.log

三、selinux的安全文上下文

1.查看

ls -Z ##查看文件的安全上下文
ls -Zd ##查看目录的安全上下文
ps axz ##查看进程的安全上下文

  mkdir /westosdir1
   ls -Zd /westosdir1
   touch /westosdir1/file1
   ls -Z /westosdir1

在这里插入图片描述

2.修改安全上下文

1.临时修改

此方式的更改的安全上下文会在seliux重启后还原

chcon -t public_content_t /westosdir1
ls -Zd /westosdir1
ls -Z /westosdir1
chcon -Rt public_content_t /westosdir1 ##修改目录及,目录中的所有子文件
ls -Z /westosdir1
ls -Zd /westosdir1
在这里插入图片描述

touch /.autorelabel ##重启系统时selinux初始化文件标签开关文件
reboot
ls -Zd /westosdir1/
ls -Zd /var/ftp
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.永久修改

semanage fcontext -l | grep /var/ftp  ##查看内核安全上下文列表
semanage fcontext -a -t public_content_t '/westosdir1(/.*)?'

semanage fcontext -l | grep /westosdir  
restorecon -RvvF /westosdir1  ##查看细节

在这里插入图片描述
在这里插入图片描述

四、SEBOOL
getsebool -a ##现实服务的bool值
setsebool -P ftpd_anon_write on ##更改

   getsebool -a | grep ftp
   setsebool -P ftpd_anon_write on
   getsebool -a | grep ftp
   setsebool -P ftpd_anon_write off
   getsebool -a | grep ftp

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

五、SEPORT

semanage port -a -t ssh_port_t 1111 -p tcp ##增加端口
semanage port -d -t ssh_port_t 1111 -p tcp ##减少端口
semanage port -l | grep ssh ##端口查看

 systemctl restart sshd
  vim /etc/ssh/sshd_config 
    systemctl restart sshd
   semanage port -l | grep ssh
   port -a -t ssh_port_t 1111 -p tcp
   semanage port -a -t ssh_port_t 1111 -p tcp
  semanage port -l | grep ssh
    systemctl restart sshd
    getenforce
   semanage port -d -t ssh_port_t 1111 -p tcp
   getenforce
    semanage port -l | grep ssh

在这里插入图片描述
在这里插入图片描述

六、setrouble
/var/log/audit/audit.log ##selinux警告信息
/var/log/messages ##selinux问题解决
setroubleshoot-server ##此软件功能时采集警告信息

> /var/log/audit/audit.log ##清空日志
> /var/log/messages ##清空警告信息

setroubleshoot-server-3.3.22-2.el8.x86_64
删除分析警告信息并提供解决方案软件,无法得到解决方案

test:
可查找到解决方案

\> /var/log/messages
\> /var/log/audit/audit.log 
 touch /mnt/lee
 mv /mnt/lee /var/ftp
 systemctl restart vsftpd
 lftp 172.25.254.212
cat /var/log/audit/audit.log
cat /var/log/messages   ##找到解决方案
restorecon -RvvF /var/ftp/lee
lftp 172.25.254.212   ##可查看到lee

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

删除软件

dnf remove setroubleshoot-server-3.3.22-2.el8.x86_64  
###卸载分析警告信息软件
rpm -qa |grep setrouble  ##查看软件
\> /var/log/audit/audit.log 
\> /var/log/messages
touch /mnt/lee1
mv /mnt/lee1 /var/ftp
lftp 172.25.254.212
cat /var/log/audit/audit.log 
cat /var/log/messages    ##无法查到解决方案

在这里插入图片描述在这里插入图片描述无解决问题方法

猜你喜欢

转载自blog.csdn.net/weixin_44632711/article/details/113982911