欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2024-02-26 21:02:46
...

一.Selinux的功能

1.观察现象

(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

(2)当selinux开启

在/mnt中建立文件(touch建立)被移动到/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

(3)selinux对于文件的影响

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

(4)selinux对于程序功能的影响

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

二.Selinux的状态及管理

1.selinux的开启

vim /etc/selinux/config
7 SELINUX=disabled						//selinux关闭
7 SELINUX=enforcing					//selinux开机设定为强制状态此状态为selinux开启
7 SELINUX=permissive				//selinux开机设定为警告状态此状态为selinux开启
"selinux开启或关闭需要重启系统"

(1)enforcing:

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

(2)permissive:

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

(3)selinux状态的查看:

getenforce

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

setenforce 0	//警告,不拒绝
setenforce 1	//强制拒绝,并警告

(5)selinux日志位置

/var/log/audit/audit.log

三.Selinux的安全上下文

1.查看

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

2.修改安全上下文

(1)临时修改

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

chcon -t 	标签		文件|目录	
chcon -t 	public_content_t 	/var/ftp/westosfile1
chcon -Rt 	public_content_t	/westosdir		//修改目录及目录中的所有子文件的安全上下文
chcon -t public_content_t /var/ftp/westos*		//例子

(2)永久修改安全上下文

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

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

1、 实验

目的:在selinux运行的情况下,客户端可以匿名上传文件

semanage fcontext -a -t public_content_rw_t '/var/ftp/pub(/.*)?'	  //修改安全上下文,添加rw权限
restorecon -RF /var/ftp/pub/										  //重新加载安全上下文
setsebool -P ftpd_anon_write 1										  //启用匿名上传权限
systemctl restart vsftpd										      //重启服务
chmod 775 /var/ftp/pub/												  //更改目录的权限
chgrp ftp /var/ftp/pub/												  //更改目录所属的组
 然后服务器进/pub上传