Liunx服务器的几个安全防护措施
前言
很多服务器不时地被黑客入侵。因此,我决定编写一个简短的教程,向您展示如何轻松地保护Linux服务器。
这并不是一个全面的安全指南。
然而,它可以帮助您阻止几乎90%的流行后端攻击,如蛮力登录尝试和DDoS。
准备
- 一台linux服务器
- 一台本地计算机
- 对命令行有一个基本的了解。
一、配置SSH Keys
要访问远程服务器,您必须使用密码登录或使用SSH密钥。
密码的问题在于它们很容易被强行破解(您将在下面进一步了解如何防止这种情况)。此外,在需要访问服务器的任何时候,都必须通过这两种方法登录。
为了避免上述缺点,您必须设置SSH密钥身份验证。它比密码更安全,因为黑客无法强行破解密码。
由于不需要输入密码,连接到服务器也更容易更快。
下面是如何为您的服务器设置SSH身份验证。
在本地计算机上,输入以下命令生成SSH密钥对:
ssh-keygen
上面的命令将通过几个步骤来生成SSH密钥。
使用以下命令将公钥添加到服务器:
ssh-copy-id username@remote_host
确保用真实的用户名和服务器的IP地址替换用户名和remote_host。系统会提示您输入密码。
尝试登录到您的服务器与命令:
ssh username@remote_host
这次不会提示您输入密码。
二、实时同步系统时间
许多安全协议利用您的系统时间来运行cron作业、日期日志和执行其他关键任务。
如果系统时间不正确,可能会对服务器造成负面影响。为了防止这种情况发生,您可以安装一个NTP客户机。该客户机将使您的系统时间与全局NTP服务器同步。
使用以下命令安装NTP客户端:
sudo apt install ntp
完成后, 您将不再需要担心再次设置系统日期。
三、查看活动端口
服务器上的应用程序公开某些端口,以便网络中的其他应用程序可以访问它们。
黑客还可以在您的服务器上安装后门,并公开一个端口,通过该端口他们可以控制服务器。
由于这个原因,我们不希望您的服务器侦听我们不知道的端口上的请求。
要查看活动端口,请使用以下命令:
sudo ss -lntup
查看输出并研究您不熟悉的任何端口或进程。
尝试发现并跟踪潜在的有害服务和流程。
这里列举出一些可能被人利用的有害的TCP/UDP端口列表。
31/tcp Agent 31, Hackers Paradise, Masters Paradise
1170/tcp Psyber Stream
1234/tcp Ultors Trojan
1243/tcp SubSeven server (default for V1.0-2.0)
1981/tcp ShockRave
2001/tcp Trojan Cow
2023/tcp Ripper Pro
2140/udp Deep Throat, Invasor
2989/tcp Rat backdoor
3024/tcp WinCrash
3150/tcp Deep Throat, Invasor
3700/tcp Portal of Doom
4950/tcp ICQ Trojan
6346/tcp Gnutella
6400/tcp The Thing
6667/tcp Trinity intruder-to-master and master-to-daemon
SubSeven server (default for V2.1 Icqfix and beyond)
6670/tcp Deep Throat
12345/tcp NetBus 1.x, GabanBus, Pie Bill Gates, X-Bill
12346/tcp NetBus 1.x
16660/tcp Stacheldraht intruder-to-master
18753/udp Shaft master-to-daemon
20034/tcp NetBus 2 Pro
20432/tcp Shaft intruder-to-master
20433/udp Shaft daemon-to-master
27374/tcp SubSeven server (default for V2.1-Defcon)
27444/udp Trinoo master-to-daemon
27665/tcp Trinoo intruder-to-master
30100/tcp NetSphere
31335/udp Trinoo daemon-to-master
31337/tcp Back Orifice, Baron Night, Bo Facil
33270/tcp Trinity master-to-daemon
33567/tcp Backdoor rootshell via inetd (from Lion worm)
33568/tcp Trojaned version of SSH (from Lion worm)
40421/tcp Masters Paradise Trojan horse
60008/tcp Backdoor rootshel via inetd (from Lion worm)
65000/tcp Stacheldraht master-to-daemon
四、设置防火墙
防火墙允许您阻止/允许来自服务器上特定端口的流量。为此,我通常使用UFW。
UFW的工作原理是让您配置规则如下:
- 允许或拒绝
- 输入或输出流量
- 流量来源和流量去处
- 特定或所有端口
以下介绍中,配置将将阻塞除显式允许外的所有网络流量。安装其他程序时,请记住启用运行程序所需的必要端口。
设置UFW
install UFW:
sudo apt-get install ufw
您可以拒绝所有输出流量:
sudo ufw default deny outgoing comment 'deny all outgoing traffic'
或者允许所有输出流量
sudo ufw default allow outgoing comment 'allow all outgoing traffic'
接下来,我们要拒绝所有传入的流量:
sudo ufw default deny incoming comment 'deny all incoming traffic'
当然要排除SSH连接,以便我们可以访问系统。
sudo ufw limit in ssh comment 'allow SSH connections in'
如果您将UFW配置为拒绝所有输出流量,请不要忘记根据您的需要允许特定的流量。以下是一些例子:
# allow traffic out on port 53 -- DNS
sudo ufw allow out 53 comment 'allow DNS calls out'
# allow traffic out on port 123 -- NTP
sudo ufw allow out 123 comment 'allow NTP out'
# allow traffic out for HTTP, HTTPS, or FTP
# apt might needs these depending on which sources you're using
sudo ufw allow out http comment 'allow HTTP traffic out'
sudo ufw allow out https comment 'allow HTTPS traffic out'
sudo ufw allow out ftp comment 'allow FTP traffic out'
# allow whois
sudo ufw allow out whois comment 'allow whois'
# allow traffic out on port 68 -- the DHCP client
# you only need this if you're using DHCP
sudo ufw allow out 68 comment 'allow the DHCP client to update'
若要拒绝端口99上的任何流量,请使用以下命令:
sudo ufw deny 99
最后,使用下面的命令启动UFW:
sudo ufw enable
使用以下命令查看UFW状态:
sudo ufw status
五、防止自动攻击
有两个实用程序可以用来防止大多数自动攻击:
- PSAD
- Fail2Ban
PSAD和Fail2Ban的区别
我们了解到端口提供对服务器上应用程序的访问。
攻击者可能决定扫描您的服务器,寻找打开的端口,然后使用这些端口访问服务器。
PSAD监控网络活动,以检测和选择性地阻止此类扫描和其他类型的可疑流量,如DDoS或OS指纹尝试。
而Fail2Ban扫描各种应用程序(如FTP)的日志文件,并自动禁止显示恶意迹象(如自动登录尝试)的ip。
下面的指南将向您展示如何安装和配置PSAD和Fail2Ban,以便它们与UFW一起工作。
install Fail2Ban
对于 Debian 或 Ubuntu 使用以下命令:
sudo apt install fail2ban
CentOS/RHEL使用以下命令:
sudo yum install fail2ban
配置Fail2Ban
# 备份默认配置
cp /etc/fail2ban/jail.conf /etc/fail2ban/jail.local
nano /etc/fail2ban/jail.local
在配置文件中查找 banaction =,将其设为 ufw。
banaction = ufw
然后重新加载 fail2ban 配置:
fail2ban-client reload
这样简单配置之后,来自同一 IP 的三次错误登录尝试将封禁该 IP 10 分钟。我个人将封禁期限调成了 7 天。
以下命令可以查看 fail2ban 的状态:
fail2ban-client status sshd
Status for the jail: sshd
|- Filter
| |- Currently failed: 1
| |- Total failed: 6
| `- File list: /var/log/auth.log
`- Actions
|- Currently banned: 1
|- Total banned: 2
`- Banned IP list: xxx.xxx.xxx.xxx
如以下所见,有一个 IP 已经被防火墙封禁了。我们也可以通过 ufw 的报告确认这一点:
ufw status
Status: active
To Action From
-- ------ ----
Anywhere REJECT xxx.xxx.xxx.xxx
80/tcp ALLOW Anywhere
22 ALLOW Anywhere
443 ALLOW Anywhere
install PSAD
项目主页: http://www.cipherdyne.org/psad/
apt-get安装:
sudo apt-get install psad
检查当前的状态:
sudo psad -S
六、安装logwatch
服务器上的应用程序常常将日志消息保存到日志文件中。除非您打算手动监视日志文件,否则需要安装logwatch。
logwatch扫描系统日志文件并总结。
您可以直接从命令行运行它,或者将其调度为按循环调度运行。例如,您可以配置logwatch,将日志文件的每日摘要通过电子邮件发送给您。请注意,您的服务器将需要能够发送电子邮件使其工作。
logwatch使用服务文件来了解如何读取和总结日志文件。您可以在/usr/share/logwatch/scripts/services
.中看到所有的服务文件
logwatch的配置文件/usr/share/logwatch/default.conf/logwatch.conf
指定了默认选项。您可以通过命令行参数覆盖它们。
要在Ubuntu或Debian上安装logwatch,请运行以下命令:
apt-get install logwatch
CentOS可以使用命令:
yum install logwatch
您可以尝试直接运行logwatch,以防需要查看它收集的样本。
sudo /usr/sbin/logwatch --output stdout --format text --range yesterday --service all
最后,配置logwatch给我们发送一封包含日志文件摘要的每日电子邮件。为此,打开文件/etc/cron.daily/00logwatch
,找到执行行,修改为:
/usr/sbin/logwatch --output mail --format html --mailto root --range yesterday --service all
注意:服务器需要安装Sendmail服务,这里就不累赘安装步骤, 网上有很多教程。
七、执行安全审计
在保护了Linux服务器之后,应该执行安全审计,以便发现您可能错过的任何安全漏洞。
要做到这一点,你可以使用Lynis,一个开源软件,可以执行:
- 安全审计
- 依从性测试(例如PCI、HIPAA、SOx)
- 渗透测试
- 漏洞检测
- 系统硬化
Lynis的使用
首先,通过git clone 来安装Lynis。确保您安装了最新版本的Lynis。
git clone https://github.com/CISOfy/lynis
切换到lynis目录
cd lynis
最后,使用以下命令运行审计:
lynis audit system
本文参考:How To Secure Your Linux Server In 7 Easy Steps
喜欢可以关注wx公众号:终身幼稚园
qrCode.gif