CentOS系统因其稳定性和安全性而广受欢迎,但为了确保其坚不可摧,需要进行一系列的安全配置。以下是一些关键的CentOS Apache安全设置:
1. 禁用非必要的超级用户
- 检测具有超级用户权限的账户:
cat /etc/passwd | awk -F ':' '{print$1,$3}' | grep ' 0$'
- 备份并锁定或解锁这些账户:
- 备份:
cp -p /etc/passwd /etc/passwd_bak
- 锁定账户:
passwd -l <用户名>
- 解锁账户:
passwd -u <用户名>
- 备份:
- 删除不必要的账户,如adm, lp, sync等。
2. 强化用户口令
- 设置复杂的口令,包含大写字母、小写字母、数字和特殊字符,长度大于10位。
- 通过修改
/etc/login.defs
文件来强制执行这些要求:PASS_MIN_LEN 10
- 检查并强化空口令账户。
3. 保护口令文件
- 使用
chattr
命令给/etc/passwd
,/etc/shadow
,/etc/group
, 和/etc/gshadow
文件加上不可更改属性:chattr +i /etc/passwd
chattr +i /etc/shadow
chattr +i /etc/group
chattr +i /etc/gshadow
4. 设置root账户自动注销时限
- 通过修改
/etc/profile
文件中的TMOUT
参数,设置root账户的自动注销时限:TMOUT=300
5. 限制su命令
- 编辑
/etc/pam.d/su
文件,限制只有特定组的用户才能使用su命令切换为root。
6. 限制普通用户的敏感操作
- 删除或修改
/etc/security/console.apps
下的相应程序的访问控制文件,如halt、reboot、poweroff、shutdown等。
7. 禁用ctrl+alt+delete重启命令
- 修改
/etc/inittab
文件,将"ca::ctrlaltdel:/sbin/shutdown-t3-rnow"一行注释掉。
8. 设置开机启动服务权限
- 设置
/etc/rc.d/init.d/
目录下所有文件的权限,确保只有root用户可以操作这些服务。
9. 避免登录时显示系统信息
- 避免在登录时显示系统和版本信息。
10. 限制NFS网络访问
- 确保
/etc/exports
文件具有最严格的访问权限设置。
11. 登录终端设置
- 通过编辑
/etc/securetty
文件,限制root用户只能在特定的tty设备上登录。
12. 防止攻击
- 编辑
host.conf
文件和设置资源限制,如最大进程数和内存使用量。 - 调整系统的网络参数,如
tcp_max_syn_backlog
,tcp_syncookies
,tcp_synack_retries
和tcp_syn_retries
。
13. Apache特定安全设置
- 关闭目录浏览:在
httpd.conf
中设置Options -Indexes
。 - 禁止显示服务器信息:设置
ServerSignature Off
和ServerTokens Prod
。 - 限制访问日志:配置日志文件路径和格式。
以上设置可以显著提高CentOS Apache服务器的安全性。请根据实际需求和环境调整配置。