Linux服务器的安全防护都有哪些措施?

很多服务器不时地被黑客入侵。因此,这里向您展示如何轻松地保护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 Paradise1170/tcp    Psyber Stream1234/tcp    Ultors Trojan1243/tcp    SubSeven server(defaultforV1.0-2.0)1981/tcp    ShockRave2001/tcp    Trojan Cow2023/tcp    Ripper Pro2140/udp    Deep Throat, Invasor2989/tcp    Rat backdoor3024/tcp    WinCrash3150/tcp    Deep Throat, Invasor3700/tcp    Portal of Doom4950/tcp    ICQ Trojan6346/tcp    Gnutella6400/tcp    The Thing6667/tcp    Trinity intruder-to-master and master-to-daemonSubSeven server(defaultforV2.1 Icqfix and beyond)6670/tcp    Deep Throat12345/tcp   NetBus 1.x, GabanBus, Pie Bill Gates,X-Bill12346/tcp   NetBus 1.x16660/tcp   Stacheldraht intruder-to-master18753/udp   Shaft master-to-daemon20034/tcp   NetBus 2 Pro20432/tcp   Shaft intruder-to-master20433/udp   Shaft daemon-to-master27374/tcp   SubSeven server(defaultforV2.1-Defcon)27444/udp   Trinoo master-to-daemon27665/tcp   Trinoo intruder-to-master30100/tcp   NetSphere31335/udp   Trinoo daemon-to-master31337/tcp   Back Orifice, Baron Night, Bo Facil33270/tcp   Trinity master-to-daemon33567/tcp   Backdoor rootshell via inetd(from Lion worm)33568/tcp   Trojaned version ofSSH(from Lion worm)40421/tcp   Masters Paradise Trojan horse60008/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--DNSsudo ufw allow out 53 comment 'allow DNS calls out'# allow traffic out on port 123--NTPsudo ufw allow out 123 comment 'allow NTP out'# allow traffic out forHTTP,HTTPS, or FTP# apt might needs these depending on which sources you're usingsudo 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 whoissudo ufw allow out whois comment 'allow whois'# allow traffic out on port 68-- the DHCP client# you only need thisif you're using DHCPsudo 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.localnano /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 IPlist:   xxx.xxx.xxx.xxx

如以下所见,有一个 IP 已经被防火墙封禁了。我们也可以通过 ufw 的报告确认这一点:

ufw statusStatus: activeTo                         Action      From------------Anywhere                   REJECT      xxx.xxx.xxx.xxx80/tcp                     ALLOW       Anywhere22ALLOW       Anywhere443ALLOW       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://xxx.com/CISOfy/lynis

切换到lynis目录

cd lynis

最后,使用以下命令运行审计:

lynis audit system


国内免备案VPS301跳转服务器国内免备案服务器域名被墙跳转301,绕过信息安全中心不放违反法律法规内容!(北京免备案 镇江免备案 江苏免备案 辽宁免备案vps 山东联通免备案
 
在线咨询