9.linux中内核级加强防火墙的管理

环境配置
vim /etc/selinux/config
dnf install vsftpd -y
systemctl enable --now vsftpd
firewall-cmd --permanent --add-service=ftp
firewall-cmd --reload
reboot

一.Selinux的功能、状态及管理

1.功能

1.观察现象
当Selinux未开启时
在/mnt中建立文件被移动到/var/ftp下可以被vsftpd服务访问
匿名用户可以通过设置后上传文件
selinux:

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

对于程序功能的影响:

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

当使用ls -Z /var/ftp查看文件时显示"?"
ps auxZ  | grep vsftpd 时显示:
-    root  8546  0.0  0.0  26952   408 ?  Ss 10:35  0:00 /usr/sbin/vsftpd /etc/vsftpd/vsftpd.conf
getenforce 
dnf install lftp -y
vim /etc/vsftpd/vsftpd.conf 
chmod 777 /var/ftp/pub/
systemctl restart vsftpd
touch /mnt/westosfile
ls -Z /mnt/westosfile
mv /mnt/westosfile  /var/ftp/
lftp 172.25.254.119

安装vsftpd
在这里插入图片描述
修改配置文件,关闭selinux
在这里插入图片描述启动vsftpd服务
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
当selinux开启:

在/mnt中建立文件被移动到/var/ftp下不可以被vsftpd服务访问
匿名用户可以通过设置后仍然不能上传文件
当使用ls -Z /var/ftp查看文件时显示信息
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

vim /etc/selinux/config 
reboot
touch /mnt/westosfile1
ls -Z /mnt/westosfile1 
mv /mnt/westosfile1  /var/ftp/
lftp 172.25.254.119
ls /var/ftp
lftp 172.25.254.119

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

2.状态及管理

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

getenforce 
setenforce 1
lftp 172.25.254.119
setenforce 0
lftp 172.25.254.119

在这里插入图片描述

3.Selinux的安全上下文

1.查看

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

setenforce 1
ls -Z /var/ftp/
ls -Zd /mnt/
ps axZ

在这里插入图片描述

2.修改安全上下文

临时修改

此方式更改的安全上下文在selinux重启后会还原
chcon -t 标签 文件|目录
chcon -t public_content_t /var/ftp/westosfile1
chcon -Rt public_content_t /westosdir #修改目录及目录中的所有子文件的安全上下文

chcon -t public_content_t /var/ftp/westosfile1
ls -Z /var/ftp/
mkdir /westos
ls -Zd /westos/
chcon -t public_content_t /westos/
ls -Zd /westos/
touch /.autorelabel
reboot
ls -Zd /westos/

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

永久修改安全上下文

如果需要特殊指定安全上下文需要修改内核安全上下文列表

semanage fcontext -l ##查看内核安全上下文列表
semanage fcontext -a -t public_content_t ‘/westos(/.*)?’
restorecon -RvvF /westosdir/
touch /.autorelabel ##重启系统时selinux初始化文件标签开关文件

ls -Z /var/ftp/
semanage fcontext -l
semanage fcontext -a -t public_content_t '/westos(/.*)?'
ls -Zd /westos
restorecon -FvvR /westos/
ls -Zd /westos

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

二、SEBOOL、SEPORT、setrouble

1.SEBOOL

getsebool  -a 				##现实服务的bool值
setsebool  -P ftpd_anon_write on	#更改
ls -Zd /var/ftp/pub/
chcon -t public_content_rw_t /var/ftp/pub/  #临时修改安全上下文
getenforce 
getsebool -a | grep ftp
setsebool -P ftpd_anon_write on
getsebool -a | grep ftp
lftp 172.25.254.119

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

2.SEPORT

semanage port -l | grep ssh
semanage port -a -t ssh_port_t -p tcp  1111
vim /etc/httpd/conf/httpd.conf 
systemctl restart httpd
setenforce 0
systemctl restart httpd
setenforce 1
systemctl restart httpd
semanage port -l | grep http
semanage port -a -t http_port_t -p tcp 82
semanage port -l | grep http
getenforce 
systemctl restart httpd
netstat -antlupe | grep 82  #查看当前端口

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

3.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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值