人生最大的错误是不断担心会犯错 [登录·注册]

吕滔博客

首页 开发 运维 工具 摄影

关于CentOS/RHEL中SELinux的相关学习记录整理

linux入门教程 memory发布于December 19, 2016 标签: CentOS, Linux

很多运维人出于方便,将selinux默认给关闭了,我以前也这样干,后来发现,在内网这样干的确挺省事儿,但公网服务器这样干了,的确有点SB,所以这儿分享一些关于SELinux的学习笔记的整理文档

配置文件路径

/etc/sysconfig/seLinux

SELinux配置文件中可修改项有两项
开机的三种状态

SELINUX = Enforcing  (默认)

Disabled    : 停用SELinux功能
Permissive  : 仅显示警告信息,不阻止
Enforcing   : 强制执行SELinux功能,产生警告信息
SELINUXTYPE=targeted

strict    : 完整的保护功能,包含网络服务,一般指令及应用程序
targeted  : 保护网络相关服务

网络相关服务包括

dhcpd
httpd
mysqld
named
nscd
ntpd
portmap
postgres
snmpd
squid
syslogd

SELinux相关命令

sestatus #查看SELinux的状态
sestatus -b#查看application管理状态
getenforce #显示目前SELinux工作模式
setenforce 0#临时将SELinux模式设为宽容模式
setenforce 1#临时将SELinux模式设为强制模式
注:setenforce必需在SELinux enable状态才有用
ls -Z 文档名#查看SELinux对档案管理状态
ls -dZ 资料夹#查看SELinux对资料夹管理状态
chcon#变更档案、资料夹管理
getsebool#查看application管理状态
setsebool#变更application管理
restorecon#恢复成原有的SELinux type
semanage#安全性文件的查询与修改
semanage port -l |grep http#查看SELinux管理http套件所使用的端口
semanage port -a -t http_port_t -p tcp 90#加入90端口给httpd使用
注:必需安装policycoreutils-python套件,在加入Port时需先检查该port是否已经被使用了。
seinfo#查看政策中规则数量
注:必需安装setools-console套件
sealert -l **#SELinux错误信息详细列出,**为错误代码。
注:必需安装setroubleshoot及setroubleshoot-server套件,安装完后需要重启系统。

查看SELinux状态

sestatus

getenforce

SELinux 使用思路 在SELinux开启的情况下,配置vsftpd服务

1】设置SELinux 允许模式

setenforce  Permissive

2】安装启动vsftpd 服务

yum install vsftpd -y
service vsftpd start

3】测试
匿名登录并下载
使用本地用户登录,并下载,上传
4】设置SELinux 强制模式

setenforce Enforcing

5】再次测试相关功能
匿名用户登录并下载 仍然可以
使用本地用户登录,并下载,上传 --- 被拒绝
6】配置SELinux,放行需要的功能
6.1】方法一 看日志
正常情况下 日志会在服务器的 /var/log/messages 文件中存在
还会在 /var/log/audit/audit.log 存在
查看日志

tail /var/log/messages
sealert -l xxxxxxxxxxxxxxxxxxxx
sealert -a /var/log/audit/audit.log

日志中提示说

setsebool -P ftp_home_dir=1

6.2】方法二 看man手册

man -k ftp | grep selinux
man 8 ftp_selinux

相关推荐

添加新评论

全部评论:仅有一条评论

zhaoliang0112

zhaoliang01122017-01-02 12:10:21 回复

希望能够有个系统的教程,就不要在去网上找了,直接这里学习!! :)

网站状态

  • 栏目分类:35个
  • 发布文章:1089篇
  • 用户评论:582条

最新回复

  • 嘿嘿: 高大上 嘿嘿
  • 嘿嘿: 呦西~~
  • memory: 实在是抱歉,我昨天找了一下我WIN电脑上的编译,发现当时编译完测...
  • kavid: 楼主发到我的邮箱呗 kavid@sina.com
  • 凯哥自媒体: 这个很不错,谢谢分享
  • memory: 在单位WINPC上,周一吧,我努力记着想死这事儿,到时候打包了发上来!
  • kavid: 楼主能把dll分享出来吗??正好我用的php 7.1php官方的...
  • zhaoliang0112: 厉害了,我哥的!!
  • zhaoliang0112: 希望能够有个系统的教程,就不要在去网上找了,直接这里学习!! :)
  • memory: 这是13年淘宝dba分享的一片文章,网上应该还有,我拿过来还没有...
  • wqintel: 而net.ipv4.tcp_mem则是配置tcp的内存大小,其单...
  • memory: 我这个站不是java写的哟~~~这是typecho开源博客程序改...
  • memory: 可以使用nginx反向代理后台的这个5000端口。
  • jarjar: 博主的java站好快啊
  • 凤凰山草民: java站这么快,厉害
  • 若铭: psdash可以部署到nginx上吗?
  • PHP程序员雷雪松: 很实用的PHP代码块!!!
  • codes: 把 .dll 发出来让我试试啊
  • 凯哥自媒体: 这个挺不错的
  • php: 怎么解密????