RH135---Linux系统管理及网络服务之 linux中内核及加强型火墙管理 --Selinux

# 一.Selinux的功能 #

1.观察现象

当Selinux未开启时disable

在/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开启:enforcing

在/mnt中建立文件被移动到/var/ftp下不可以被vsftpd服务访问

匿名用户可以通过设置后仍然不能上传文件

当使用ls -Z /var/ftp查看文件时显示信息

testfile2不能被访问

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

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

# 三.Selinux的安全上下文 #

1.查看

ls -Z       查看文件的安全上下文

ls -Zd     查看目录的安全上下文

ps auxZ  查看进程的安全上下文

2.修改安全上下文

临时修改   

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

chcon -t 标签     文件/目录

chcon -t public_content_t /var/ftp/westosfile1

chcon -Rt public_content_t /westosdir  修改目录及目录中的所有子文件的安全上下文

chcon -Rt public_content_t /westosdir  修改目录及目录中的所有子文件的安全上下文

永久修改安全上下文

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

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

semanage fcontext -a -t public_content_t  '/westosdir2(/.*)?'

restorecon -RvvF /westosdir/     刷新

touch  /.autorelabel                    重启系统时selinux初始化文件标签开关文件

# 四.SEBOOL #

getsebool  -a                                  显示服务的bool值

setsebool  -P ftpd_anon_write on   更改

 # 五.SEPORT #

 semanage port -l | grep ssh

semanage port -a -t ssh_port_t -p tcp  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


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值