### 一.Selinux的功能 ###
观察现象
①当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的状态及管理 ###
selinux的开启
vim /etc/selinux/config
7 SELINUX=disabled #selinux关闭
7 SELINUX=enforcing #selinux开机设定为强制状态此状态为selinux开启
7 SELINUX=permissive #selinux开机设定为警告状态此状态为selinux开启
"selinux开启或关闭需要重启系统"
enforcing:
不符合条件一定不能被允许,并会收到警告信息
permissive:
不符合条件被允许,并会收到警告信息
data:image/s3,"s3://crabby-images/2eeb0/2eeb0550acb2bad6ebf88db0fd7353f29cc8d5aa" alt=""
data:image/s3,"s3://crabby-images/6dd87/6dd870ed7b3272a880de85dffea930dd8bb6164d" alt=""
selinux状态的查看:
getenforce
selinux开启后强制和警告级别的转换
setenforce 0 ##警告
setenforce 1 ##强制
selinux日志位置: /var/log/audit/audit.log
data:image/s3,"s3://crabby-images/1b031/1b0318b49e8eec7d7eb3c2a456adcccdc26ac11c" alt=""
data:image/s3,"s3://crabby-images/1b031/1b0318b49e8eec7d7eb3c2a456adcccdc26ac11c" alt=""
data:image/s3,"s3://crabby-images/2e1d4/2e1d4050b9094ab69399fbfbd2d8c201a783111c" alt=""
data:image/s3,"s3://crabby-images/85bb3/85bb3cb3ee15fb0dd41a774783e1dc5d92ef8fbc" alt=""
data:image/s3,"s3://crabby-images/09646/096468b09111d2c6bb90fa8cd587191934a8fcee" alt=""
data:image/s3,"s3://crabby-images/e4e18/e4e1810a8b8890fee81bdf9a17b42fb29e0f4c4a" alt=""
### 三.Selinux的安全上下文 ###
(1)查看
查看
ls -Z ##查看文件的安全上下文
ls -Zd ##查看目录的安全上下文
ps axZ ##查看进程的安全上下文
data:image/s3,"s3://crabby-images/b94cd/b94cdf1667a1c6e0b96eb4db579ccda9eac941d3" alt=""
(2)修改安全上下文
#临时修改
#此方式更改的安全上下文在selinux重启后会还原
chcon -t 标签 文件|目录
chcon -t public_content_t /var/ftp/westosfile1
chcon -Rt public_content_t /westosdir #修改目录及目录中的所有子文件的安全上下文
#永久修改安全上下文
#如果需要特殊指定安全上下文需要修改内核安全上下文列表
semanage fcontext -l ##查看内核安全上下文列表
semanage fcontext -a -t public_content_t '/westosdir(/.*)?'
restorecon -RvvF /westosdir/
touch /.autorelabel ##重启系统时selinux初始化文件标签开关文件
data:image/s3,"s3://crabby-images/3e9fc/3e9fc3a8b7b40ef9b1cf5638f4c924eac9d19be5" alt=""
data:image/s3,"s3://crabby-images/5dee5/5dee505a9426204979fce1efb6c899f892e390bc" alt=""
data:image/s3,"s3://crabby-images/9ed70/9ed700c6dc0b1cce1a0e6a9443f814b4b6c23bda" alt=""
data:image/s3,"s3://crabby-images/1e6a5/1e6a5e96178429a4c64c315eb1781db199a1f7ce" alt=""
### 四.SEBOOL ###
getsebool -a ##现实服务的bool值
setsebool -P ftpd_anon_write on #更改
data:image/s3,"s3://crabby-images/e5a8b/e5a8b96d42d4859cd4ad8b0b2a7858d99cb28d3d" alt=""
### 五.SEPORT ###
semanage port -l | grep ssh
semanage port -a -t ssh_port_t -p tcp 1111
data:image/s3,"s3://crabby-images/f11ae/f11aea870e79a4975046650ec001fe986310e8ec" alt=""
data:image/s3,"s3://crabby-images/ad33f/ad33fc8d3278a887890cf6d491585a47a4f574d3" alt=""
### 六.setrouble ###
#/var/log/audit/audit.log ##selinux警告信息
#/var/log/messages ##selinux问题解决方案
#setroubleshoot-server ##此软件功能是采集警告信息并分析得到解决方案存放到message中
> /var/log/audit/audit.log
>/var/log/messages
data:image/s3,"s3://crabby-images/8cb83/8cb8316255ef0e84bb07e6dca405c04cb8e3e4c9" alt=""
data:image/s3,"s3://crabby-images/bb55d/bb55d22da2f46c0af535ab9c1e725638bf2ab853" alt=""
data:image/s3,"s3://crabby-images/2f4a5/2f4a5e784b546711e27b2ac8488088735612c255" alt=""
data:image/s3,"s3://crabby-images/22f65/22f6550311659d9ba83b09c5e0e837b1a813741d" alt=""
data:image/s3,"s3://crabby-images/12ad7/12ad71e814c9c343771a6ee45bdde47e96533dfc" alt=""
data:image/s3,"s3://crabby-images/448f9/448f9e7604fb4bcd71791ce52e591d2524ef5452" alt=""