Linux入门 19_Linux中内核级加强型火墙的管理

一.Selinux的功能

1.观察现象
当Selinux未开启时

在/mnt中建立文件被移动到/var/ftp下可以被vsftpd服务访问
匿名用户可以通过设置后上传文件
当使用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

当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

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

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

二.Selinux的状态及管理

1.selinux的开启
vim /etc/selinux/config

SELINUX=disabled			#selinux关闭
SELINUX=enforcing			#selinux开机设定为强制状态此状态为selinux开启
SELINUX=permissive			#selinux开机设定为警告状态此状态为selinux开启

在这里插入图片描述

“selinux开启或关闭需要重启系统”

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

permissive:不符合条件被允许,并会收到警告信息

selinux状态的查看:

getenforce

selinux开启后强制和警告级别的转换

setenforce 0	##警告
setenforce 1	##强制

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

三.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	#修改目录及目录中的所有子文件的安全上下文

3.永久修改安全上下文
#如果需要特殊指定安全上下文需要修改内核安全上下文列表

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 #更改

五.SEPORT

getenforce 查看selinux状态
打开linux 重启
setenforce 0|1 (0–enforcing 1–permissive)
默认端口22

semanage port -l | grep ssh		查看ssh端口
semanage port -a -t ssh_port_t -p tcp  1111	#将ssh端口改为1111
semanage port -d -t ssh_port_t -p tcp  1111	#删除1111这个端口

六.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				#查看解决方案(注意:这里日志提供的解决方案可以解决当下问题,但是有可能会影响其他文件或者系统配置)
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿王不想秃头

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值