SElinux

SELinux 是Security-Enhanced Linux的缩写,意思是安全强化的linux

SELinux 主要由美国国家安全局(NSA)开发,当初开发的目的是为了避免资源的误用传统的访问控制在我们开启权限后,系统进程可以直接访问

当我们对权限设置不严谨时,这种访问方式就是系统的安全漏洞

在开启SElinux后

会对进程本身部署安全上下文

会对文件部署安全上下文

会对服务使用端口进行限制

会对程序本身的不安全功能做限制

root@localhost \~# grubby --update-kernel ALL --args selinux=1

root@localhost \~# reboot

root@localhost \~# dnf install vsftpd -y

root@localhost \~# vim /etc/vsftpd/vsftpd.conf

root@localhost \~# systemctl enable --now vsftpd

root@localhost \~# dnf install lftp -y

root@localhost \~# touch /mnt/file

root@localhost \~# mv /mnt/file /var/ftp/

root@localhost \~# cd /var/ftp/

root@localhost ftp# ls

file pub

root@localhost ftp# ls -Z

unconfined_u:object_r:mnt_t:s0 file system_u:object_r:public_content_t:s0 pub

root@localhost ftp# chcon -t public_content_t file

Selinux 重启的标识文件 文件存在 在重启系统后会重新初始化

root@localhost ftp# touch /mnt/leefile

root@localhost ftp# ls -Z /mnt/leefile

unconfined_u:object_r:mnt_t:s0 /mnt/leefile

root@localhost mnt# semanage fcontext -a -t public_content_t '/mnt/leefile(/.*)?'

root@localhost mnt# semanage fcontext -l | grep leefile

永久设置安全上下文

root@localhost mnt# ls -Z /mnt/leefile

unconfined_u:object_r:mnt_t:s0 /mnt/leefile

root@localhost mnt# restorecon -RvvF /mnt/leefile

Relabeled /mnt/leefile from unconfined_u:object_r:mnt_t:s0 to system_u:object_r:public_content_t:s0

selinux 对linux服务的影响

服务的功能影响

在系统SElinux开启后会为服务添加新的功能开关,我们把这个开关叫做sebool

root@localhost mnt# setsebool -P ftpd_anon_write on 修改sebool值

root@localhost mnt# getsebool -a | grep ftp 查看sebool

ftpd_anon_write --> on

ftpd_connect_all_unreserved --> off

ftpd_connect_db --> off

ftpd_full_access --> off

ftpd_use_cifs --> off

ftpd_use_fusefs --> off

ftpd_use_nfs --> off

ftpd_use_passive_mode --> off

httpd_can_connect_ftp --> off

httpd_enable_ftp_server --> off

tftp_anon_write --> off

tftp_home_dir --> off

服务的端口影响

在系统SElinux开启后会规定服务使用端口

查看服务被允许使用的端口

root@localhost \~# semanage port -l | grep ssh

ssh_port_t tcp 22

root@localhost \~# semanage port -a -t ssh_port_t -p tcp 8888

root@localhost \~# semanage port -l | grep ssh

ssh_port_t tcp 8888, 22

相关推荐
杨了个杨89827 分钟前
HAproxy+Keepalive的简介及安装
运维·服务器
一叶知秋dong9 分钟前
llama.cpp 启动脚本
linux·服务器·llama
桌面运维家14 分钟前
校园机房vDisk IDV云桌面建设方案价格参考
linux·服务器·数据库
utf8mb4安全女神17 分钟前
【shell函数】【shell脚本】定期自动检查服务器磁盘使用情况并发出告警
运维·服务器
憧憬成为java架构高手的小白19 分钟前
计算机网络管理
服务器·网络·计算机网络
Cx330❀21 分钟前
【MySQL基础】库与表的全面操纵指南
linux·服务器·网络·数据库·c++·mysql
凡人叶枫23 分钟前
Effective C++ 条款03:尽可能使用 const
linux·开发语言·c++·嵌入式开发
tedcloud12324 分钟前
Understand-Anything部署教程:打造AI代码理解平台
服务器·人工智能·学习·自动化·powerpoint
程序员佳佳26 分钟前
我在 Windows 和低配 Linux 上做 RAG:Milvus、FAISS、向量 API 中转的中立实测
linux·人工智能·windows·gpt·aigc·milvus·faiss
加成BUFF30 分钟前
第六天 ROS 《Action 通信实验》
linux·机器人·ros