二、Linux进阶——Selinux

目录

  • 一.Selinux的功能
    • 1.1 Selinux关闭状态
    • 1.2 selinux开启状态
    • 1.3 Selinux功能
  • 二.Selinux的状态及管理
    • 2.1 状态查看
    • 2.2 selinux的切换
    • 2.3 selinux日志位置
  • 三.Selinux的安全上下文
    • 3.1 查看
    • 3.2 修改安全上下文
      • 临时修改
      • 永久修改安全上下文
  • 四.SEBOOL
  • 五.SEPORT
  • 六.setrouble

一.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
    二、Linux进阶——Selinux_第1张图片
    在这里插入图片描述

1.2 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
    如果实验效果不行,更改vsftpd的配置文件打开匿名用户可上传,给/pub权限,重启服务,上传文件不行
    二、Linux进阶——Selinux_第2张图片

1.3 Selinux功能

  • 对于文件的影响:
    当selinux开启时,内核会对每个文件及每个开启的程序进行标签加载
    标签内记录程序和文件的安全上下文(context)
  • 对于程序功能的影响:
    当selinux开启,会对程序的功能加载开关sebool,并设定此开关的状态为关闭,当需要此功能时需要超级用户手动调节

二.Selinux的状态及管理

2.1 状态查看

getenforce 状态查看
setenforce 0|1 警告和强制模式的转换,0表示警告模式1表示强制模式
状态类型:
disabled 关闭
enforcing 不符合条件一定不能被允许,并会收到警告信息
permissive不符合条件被允许,并会收到警告信息
二、Linux进阶——Selinux_第3张图片强制模式下,在lftp中看不到文件setestfile2,切换为警告模式则可以看到

2.2 selinux的切换

vim /etc/selinux/config
7 SELINUX=disabled #selinux关闭
7 SELINUX=enforcing #selinux开机设定为强制状态,为selinux开启
7 SELINUX=permissive #selinux开机设定为警告状态,为selinux开启
注意:“selinux开启或关闭需要重启系统”

2.3 selinux日志位置

/var/log/audit/audit.log
二、Linux进阶——Selinux_第4张图片

三.Selinux的安全上下文

3.1 查看

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

3.2 修改安全上下文

临时修改

chcon -t 标签 文件|目录
注意:此方式更改的安全上下文在selinux重启后会还原
chcon -t public_content_t /var/ftp/westosfile1
chcon -Rt public_content_t /westosdir #修改目录及目录中的所有子文件的安全上下文
二、Linux进阶——Selinux_第5张图片

永久修改安全上下文

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

semanage fcontext -l 查看内核安全上下文列表

semanage fcontext -a -t public_content_t '/westosdir(/.*)?'
(/.*)?表示目录内的内容,同时改变目录和目录内文件上下文,此命令只添加列表信息,当前不生效

restorecon -RvvF /westosdir/ 刷新文件安全上下文
touch /.autorelabel ##重启系统时selinux初始化文件标签开关文件
二、Linux进阶——Selinux_第6张图片

四.SEBOOL

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

getsebool -a | grep ftp 查看ftp的功能开关
setsebool ftpd_anon_write=1|on 表示开启此匿名用户写的功能
setsebool -P ftpd_anon_write=1|on 表示永久开启此匿名用户写的功能
二、Linux进阶——Selinux_第7张图片

五.SEPORT

semanage port -l | grep ssh
semanage port -a -t ssh_port_t -p tcp 1111

实验:

  • 编辑sshd_config文件,修改服务器端口为1111
  • 改为警告模式
  • 重启ssh服务,修改成功
    二、Linux进阶——Selinux_第8张图片
  • 改为强制模式
  • 重启sshd失败
    在这里插入图片描述
  • 强制模式下,semange设置ssh端口,重启sshd成功
    在这里插入图片描述

六.setrouble

/var/log/audit/audit.log ##selinux警告信息
/var/log/messages ##selinux问题解决方案

setroubleshoot-server ##服务功能是采集警告信息并分析得到解决方案存放到message中

实验:

semanage port -d -t ssh_port_t -p tcp 1111 ##删除ssh端口
> /var/log/audit/audit.log  ##清空 
> /var/log/messages
systemctl restart sshd
systemctl stop sshd

二、Linux进阶——Selinux_第9张图片
二、Linux进阶——Selinux_第10张图片
实验:对于排错工具的理解
二、Linux进阶——Selinux_第11张图片二、Linux进阶——Selinux_第12张图片

你可能感兴趣的:(二、Linux进阶——Selinux)