Centos 5.5 LINUX服务器的安全加固配置方法 忘是亡心i 2022-09-17 13:27 310阅读 0赞 Centos 5.5 LINUX服务器的安全加固配置方法[复制链接] A.J. 电梯直达 楼主 发表于 2013-7-14 20:48:06 | 只看该作者 [size=13.63636302947998px]这篇文章是我在另一个博客里发表的,弄过来,看起来也比较方便,顺便复习一下 [size=13.63636302947998px]CentOS的安全配置 一、系统安全记录文件 操作系统内部的记录文件是检测是否有网络入侵的重要线索。如果您的系统是直接连到Internet,您发现有很多人对您的 系统做Telnet/FTP登录尝试,可以运行”#more /var/log/secure | grep refused”来检查系统所受到的攻击,以便采取相应 的对策,如使用SSH来替换Telnet/rlogin等。 二、启动和登录安全性 1.BIOS安全 设置BIOS密码且修改引导次序禁止从软盘启动系统。 2.用户口令 用户口令是Linux安全的一个基本起点,很多人使用的用户口令过于简单,这等于给侵入者敞开了大门,虽然从理论上说 ,只要有足够的时间和资源可以利用,就没有不能破解的用户口令,但选取得当的口令是难于破解的。较好的用户口令是那些 只有他自己容易记得并理解的一串字符,并且绝对不要在任何地方写出来。 修改改密码长度需要编译login.defs文件 vi /etc/login.defs PASS_MIN_LEN 8 3.注释掉不需要的用户和用户组 应该禁止所有默认的被操作系统本身启动的并且不必要的账号,当您第一次安装系统时就应该这么做,Linux提供了很多 默认账号,而账号越多,系统就越容易受到攻击。 vi /etc/passwd #userdel adm #userdel lp #userdel sync #userdel shutdown #userdel halt #userdel news #userdel uucp #userdel operator #userdel games #userdel gopher #userdel ftp vi /etc/group #groupdel adm #groupdel lp #groupdel news #groupdel uucp #groupdel games #groupdel dip #groupdel pppusers 4.口令文件 chattr命令给下面的文件加上不可更改属性,从而防止非授权用户获得权限。 # chattr +i /etc/passwd # chattr +i /etc/shadow # chattr +i /etc/group # chattr +i /etc/gshadow 5.禁止Ctrl Alt Delete重新启动机器命令 修改/etc/inittab文件,将”ca::ctrlaltdel:/sbin/shutdown -t3 -r now”一行注释掉。然后重新设 置/etc/rc.d/init.d/目录下所有文件的许可权限,运行如下命令: # chmod -R 700 /etc/rc.d/init.d/ 这样便仅有root可以读、写或执行上述所有脚本文件。 6.限制su命令 如果您不想任何人能够su作为root,可以编辑/etc/pam.d/su文件,增加如下两行: auth sufficient /lib/security/pam_rootok.so debug auth required /lib/security/pam_wheel.so group=isd 这时,仅isd组的用户可以su作为root。此后,如果您希望用户admin能够su作为root,可以运行如下命令: # usermod -G10 admin 7.删减登录信息 默认情况下,登录提示信息包括Linux发行版、内核版本名和服务器主机名等。对于一台安全性要求较高的机器来说这样 泄漏了过多的信息。可以编辑/etc/rc.d/rc.local将输出系统信息的如下行注释掉。 # This will overwrite /etc/issue at every boot. So, make any changes you # want to make to /etc/issue here or you will lose them when you reboot. # echo “” > /etc/issue # echo “$R” >> /etc/issue # echo “Kernel $(uname -r) on $a $(uname -m)” >> /etc/issue # cp -f /etc/issue /etc/issue.net # echo >> /etc/issue 然后,进行如下操作: # rm -f /etc/issue # rm -f /etc/issue.net # touch /etc/issue # touch /etc/issue.net 8、更改SSH端口,最好改为10000以上,别人扫描到端口的机率也会下降 不允许使用低版本的SSH协议 vi /etc/ssh/ssd_config 将#protocol 2,1改为 protocol 2 将PORT改为1000以上端口 vi /etc/ssh/sshd_config Port 10000 同时,创建一个普通登录用户,并取消直接root登录 useradd ‘username’ passwd ‘username’ vi /etc/ssh/sshd_config PermitRootLogin no #取消root直接远程登录 9、关闭那些不需要的服务 ,记住少开一个服务,就少一个危险。 以下仅列出需要启动的服务,未列出的服务一律关闭: #setup acpid anacron cpuspeed crond irqbalance \仅当服务器CPU为S.M.P架构或支持双核心、HT技术时,才需开启,否则关闭。 microcode_ctl network random sendmail sshd syslog yum-updatesd 10、启用iptables 防火墙,对增加系统安全有许多好处。设置好防火墙的规则。 vi /etc/sysconf/iptables filter :INPUT DROP [0:0] :FORWARD DROP [0:0] :OUTPUT ACCEPT [0:0] # allow local loopback connections -A INPUT -i lo -j ACCEPT # drop INVALID connections -A INPUT -m state –state INVALID -j DROP -A OUTPUT -m state –state INVALID -j DROP -A FORWARD -m state –state INVALID -j DROP # allow all established and related -A INPUT -m state –state ESTABLISHED,RELATED -j ACCEPT # add anymore rules here COMMIT 三、限制网络访问 1.NFS访问 如果您使用NFS网络文件系统服务,应该确保您的/etc/exports具有最严格的访问权限设置,也就是意味着不要使用任何 通配符、不允许root写权限并且只能安装为只读文件系统。编辑文件/etc/exports并加入如下两行。 /dir/to/export host1.mydomain.com(ro,root_squash) /dir/to/export host2.mydomain.com(ro,root_squash) /dir/to/export 是您想输出的目录,host.mydomain.com是登录这个目录的机器名,ro意味着mount成只读系统, root_squash禁止root写入该目录。为了使改动生效,运行如下命令。 # /usr/sbin/exportfs -a 2.Inetd设置 首先要确认/etc/inetd.conf的所有者是root,且文件权限设置为600。设置完成后,可以使用”stat”命令进行检查。 # chmod 600 /etc/inetd.conf 然后,编辑/etc/inetd.conf禁止以下服务。 ftp telnet shell login exec talk ntalk imap pop-2 pop-3 finger auth 如果您安装了ssh/scp,也可以禁止掉Telnet/FTP。为了使改变生效,运行如下命令: #killall -HUP inetd 默认情况下,多数Linux系统允许所有的请求,而用TCP_WRAPPERS增强系统安全性是举手之劳,您可以修 改/etc/hosts.deny和/etc/hosts.allow来增加访问限制。例如,将/etc/hosts.deny设为”ALL: ALL”可以默认拒绝所有访问 。然后在/etc/hosts.allow文件中添加允许的访问。例如,”sshd: 192.168.1.10/255.255.255.0 gate.openarch.com”表示 允许IP地址192.168.1.10和主机名gate.openarch.com允许通过SSH连接。 配置完成后,可以用tcpdchk检查: # tcpdchk tcpchk是TCP_Wrapper配置检查工具,它检查您的tcp wrapper配置并报告所有发现的潜在/存在的问题。 3.登录终端设置 /etc/securetty文件指定了允许root登录的tty设备,由/bin/login程序读取,其格式是一个被允许的名字列表,您可以 编辑/etc/securetty且注释掉如下的行。 tty1 # tty2 # tty3 # tty4 # tty5 # tty6 这时,root仅可在tty1终端登录。 4.避免显示系统和版本信息。 如果您希望远程登录用户看不到系统和版本信息,可以通过一下操作改变/etc/inetd.conf文件: telnet stream tcp nowait root /usr/sbin/tcpd in.telnetd -h 加-h表示telnet不显示系统信息,而仅仅显示”login:”。 5.修改相应配置文件停止ipv6。 #vi /etc/modprobe.conf alias net-pf-10 off alias ipv6 off #shutdown -r now 四、防止攻击 1.阻止ping 如果没人能ping通您的系统,安全性自然增加了。为此,可以在/etc/rc.d/rc.local文件中增加如下一行 : #echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all 2.防止IP欺骗 编辑host.conf文件并增加如下几行来防止IP欺骗攻击。 order bind,hosts multi off nospoof on 3.防止DoS攻击 对系统所有的用户设置资源限制可以防止DoS类型攻击。如最大进程数和内存使用数量等。例如,可以 在/etc/security/limits.conf中添加如下几行: hard core 0 hard rss 5000 * hard nproc 20 然后必须编辑/etc/pam.d/login文件检查下面一行是否存在。 session required /lib/security/pam_limits.so 上面的命令禁止调试文件,限制进程数为50并且限制内存使用为5MB。 经过以上的设置,您的Linux服务器已经可以对绝大多数已知的安全问题和网络攻击具有免疫能力,但一名优秀的系统管 理员仍然要时刻注意网络安全动态,随时对已经暴露出的和潜在安全漏洞进行修补。 五、内核参数调整 #vi /etc/sysctl.conf sysctl -w net.ipv4.conf.default.accept_source_route=0 sysctl -w net.ipv4.icmp_echo_ignore_broadcasts=1 #sysctl -w net.ipv4.icmp_echo_ignore_all=1 sysctl -w net.ipv4.icmp_ignore_bogus_error_responses=1 sysctl -w net.ipv4.ip_conntrack_max=65535 sysctl -w net.ipv4.tcp_syncookies=1 sysctl -w net.ipv4.tcp_syn_retries=1 sysctl -w net.ipv4.tcp_fin_timeout=5 sysctl -w net.ipv4.tcp_synack_retries=1 sysctl -w net.ipv4.tcp_syncookies=1 sysctl -w net.ipv4.route.gc_timeout=100 sysctl -w net.ipv4.tcp_keepalive_time=500 sysctl -w net.ipv4.tcp_max_syn_backlog=10000 [size=13.63636302947998px]除了开启防火墙外,还要开启SELINUX,不知道怎么开,上图 [size=13.63636302947998px]#setup [size=13.63636302947998px]其次,用防火墙关闭不须要的任何端口,别人PING不到服务器,威胁自 然减少了一大半 [size=13.63636302947998px]防止别人ping的方法: [size=13.63636302947998px]1)命令提示符下打 [size=13.63636302947998px]echo 1 > /proc/sys/net/ipv4/icmp_ignore_all [size=13.63636302947998px]2)用防火墙禁止(或丢弃) icmp 包 [size=13.63636302947998px]iptables -A INPUT -p icmp -j DROP [size=13.63636302947998px]3)对所有用ICMP通讯的包不予响应 [size=13.63636302947998px]比如PING TRACERT [size=13.63636302947998px]首先做到这些,然后我接下来发一篇系统 地配置centos安全的方法
相关 服务器安全加固 - Linux 一、账号和口令 1.1 禁用或删除无用账号 查看 /etc/passwd 文件查看是否有无用的账号,如果存在则删除,降低安全风险。 操作步骤: 使用命令 港控/mmm°/ 2024年03月17日 15:29/ 0 赞/ 129 阅读
相关 Linux安全加固手册 1 身份鉴别 1.1 密码安全策略 操作系统和数据库系统管理用户身份鉴别信息应具有不易被冒用的特点,口令应有复杂度要求并定期更换。 设置 末蓝、/ 2023年07月13日 10:55/ 0 赞/ 44 阅读
相关 服务器安全加固措施总结 一、Nginx加固 隐藏X-Powered-By头和开启日志:在nginx配置文件的 http 段增加或修改为 proxy\_hide\_header X-Powere 雨点打透心脏的1/2处/ 2023年07月11日 12:55/ 0 赞/ 30 阅读
相关 阿里云CentOS服务器的安全设置及防黑加固 > 之前服务器有几次被攻击的事件(ssh暴力破解、恶意程序、挖矿程序等),其中一次严重事件,服务器无法登录,联系阿里云售后也无法恢复,只能重置。所以决定认真学习下安全设置,并整 末蓝、/ 2023年06月11日 15:21/ 0 赞/ 51 阅读
相关 Linux 服务器进行安全加固,防止黑客攻击 文章目录 Linux 服务器进行安全加固,防止黑客攻击 1、账号和口令 1、减少系统无用账号,降低安全风 迷南。/ 2023年06月08日 06:18/ 0 赞/ 40 阅读
相关 linux ssh安全加固方法 linux ssh安全加固方法 来源:互联网 作者:佚名 时间:02-05 12:21:12 【大 中 小】 点评:ssh安全加固,供大家学习参考 \[root@lo 水深无声/ 2022年09月17日 13:27/ 0 赞/ 336 阅读
相关 Centos 5.5 LINUX服务器的安全加固配置方法 Centos 5.5 LINUX服务器的安全加固配置方法 [\[复制链接\]][Link 1] <table> <tbody> <tr> <td>&n 忘是亡心i/ 2022年09月17日 13:27/ 0 赞/ 311 阅读
相关 Linux服务器的部分安全加固措施 chown root:root /etc/passwd /etc/shadow /etc/group /etc/gshadow chmod 0644 /etc/group ╰+哭是因爲堅強的太久メ/ 2022年01月14日 05:35/ 0 赞/ 340 阅读
相关 Windows 服务器操作系统安全设置加固方法 本文档旨在指导系统管理人员或安全检查人员进行Windows操作系统的安全合规性检查和配置,需要的朋友可以参考下 1. 账户管理和认证授权 1.1 账户 默认账户安全禁用 - 日理万妓/ 2021年12月17日 08:09/ 0 赞/ 364 阅读
相关 Linux服务器安全加固10条建议 以下是服务器安全加固的步骤,本文以腾讯云的CentOS7.7版本为例来介绍,如果你使用的是秘钥登录服务器1-5步骤可以跳过。 设置复杂密码 服务器设置大写、小写、特殊字 心已赠人/ 2021年07月27日 00:58/ 0 赞/ 445 阅读
还没有评论,来说两句吧...