文章插图
通过七个简单的步骤来加固你的 linux 服务器 。这篇入门文章将向你介绍基本的 Linux 服务器安全知识 。虽然主要针对 Debian/Ubuntu,但是你可以将此处介绍的所有内容应用于其他 Linux 发行版 。我也鼓励你研究这份材料,并在适用的情况下进行扩展 。
-- Patrick H. Mullins(作者)
1、更新你的服务器保护服务器安全的第一件事是更新本地存储库,并通过应用最新的修补程序来升级操作系统和已安装的应用程序 。
在 Ubuntu 和 Debian 上:
$ sudo apt update && sudo apt upgrade -y在 Fedora、centos 或 RHEL:
$ sudo dnf upgrade2、创建一个新的特权用户接下来,创建一个新的用户帐户 。永远不要以 root 身份登录服务器,而是创建你自己的帐户(用户),赋予它 sudo 权限,然后使用它登录你的服务器 。
首先创建一个新用户:
$ adduser <username>通过将 sudo 组(-G)附加(-a)到用户的组成员身份里,从而授予新用户帐户 sudo 权限:
$ usermod -a -G sudo <username>3、上传你的 SSH 密钥你应该使用 SSH 密钥登录到新服务器 。你可以使用 ssh-copy-id 命令将 预生成的 SSH 密钥 上传到你的新服务器:
$ ssh-copy-id <username>@ip_address现在,你无需输入密码即可登录到新服务器 。
4、安全强化 SSH接下来,进行以下三个更改:
- 禁用 SSH 密码认证
- 限制 root 远程登录
- 限制对 IPv4 或 IPv6 的访问
PasswordAuthentication yesPermitRootLogin yes改成这样:
PasswordAuthentication noPermitRootLogin no接下来,通过修改 AddressFamily 选项将 SSH 服务限制为 IPv4 或 IPv6 。要将其更改为仅使用 IPv4(对大多数人来说应该没问题),请进行以下更改:
AddressFamily inet重新启动 SSH 服务以启用你的更改 。请注意,在重新启动 SSH 服务之前,与服务器建立两个活动连接是一个好主意 。有了这些额外的连接,你可以在重新启动 SSH 服务出错的情况下修复所有问题 。
在 Ubuntu 上:
$ sudo service sshd restart在 Fedora 或 CentOS 或任何使用 Systemd 的系统上:
$ sudo systemctl restart sshd5、启用防火墙现在,你需要安装防火墙、启用防火墙并对其进行配置,以仅允许你指定的网络流量通过 。(Ubuntu 上的) 简单的防火墙 (UFW)是一个易用的 iptables 界面,可大大简化防火墙的配置过程 。
你可以通过以下方式安装 UFW:
$ sudo apt install ufw默认情况下,UFW 拒绝所有传入连接,并允许所有传出连接 。这意味着服务器上的任何应用程序都可以访问互联网,但是任何尝试访问服务器的内容都无法连接 。
首先,确保你可以通过启用对 SSH、HTTP 和 HTTPS 的访问来登录:
$ sudo ufw allow ssh$ sudo ufw allow http$ sudo ufw allow https然后启用 UFW:
$ sudo ufw enable你可以通过以下方式查看允许和拒绝了哪些服务:
$ sudo ufw status如果你想禁用 UFW,可以通过键入以下命令来禁用:
$ sudo ufw disable你还可以(在 RHEL/CentOS 上)使用 firewall-cmd,它已经安装并集成到某些发行版中 。
6、安装 Fail2banFail2ban 是一种用于检查服务器日志以查找重复或自动攻击的应用程序 。如果找到任何攻击,它会更改防火墙以永久地或在指定的时间内阻止攻击者的 IP 地址 。
你可以通过键入以下命令来安装 Fail2ban:
$ sudo apt install fail2ban -y然后复制随附的配置文件:
$ sudo cp /etc/fail2ban/jail.conf /etc/fail2ban/jail.local重启 Fail2ban:
$ sudo service fail2ban restart这样就行了 。该软件将不断检查日志文件以查找攻击 。一段时间后,该应用程序将建立相当多的封禁的 IP 地址列表 。你可以通过以下方法查询 SSH 服务的当前状态来查看此列表:
$ sudo fail2ban-client status ssh7、移除无用的网络服务几乎所有 Linux 服务器操作系统都启用了一些面向网络的服务 。你可能希望保留其中大多数,然而,有一些你或许希望删除 。你可以使用 ss 命令查看所有正在运行的网络服务:(LCTT 译注:应该是只保留少部分,而所有确认无关的、无用的服务都应该停用或删除 。)
$ sudo ss -atpuss 的输出取决于你的操作系统 。下面是一个示例,它显示 SSH(sshd)和 Ngnix(Nginx)服务正在侦听网络并准备连接:
推荐阅读
- 如何解除淘宝限制登陆安全隐患 为什么淘宝账号出现严重的安全风险
- 交易|你的上司是属于什么类型的?
- 深蹲|为啥张含韵林允儿的卧蚕那么美?你的却只能叫眼袋,跟妆容有关系
- 微软|Win11将升级全新安全功能 老用户又成小白鼠:需全新安装
- 十大名茶的传说让你的茶更美味
- 冬天晚上非常冷煮壶茶来温暖你的身心
- 茶叶美容功效多 安全效果好
- 你的“储备心率”够吗?坚持跑步,两个心率相减,看心脏是否强大
- HRG践行科技创新 追求卓越品质 服务中国机器人产业安全
- 腊八节不只有腊八粥 这些美食满足你的吃货欲望