首页 > 系统相关 >使用 iptables 限制 SSH 连接并允许特定来源 IP 访问的完整指南

使用 iptables 限制 SSH 连接并允许特定来源 IP 访问的完整指南

时间:2024-09-13 08:54:49浏览次数:11  
标签:iptables IP ACCEPT SSH INPUT 服务器 连接

在保护服务器安全时,限制 SSH 连接是一项重要措施。通过 iptables,你可以有效地控制哪些 IP 地址可以访问你的服务器,从而减少潜在的安全威胁。本文将介绍如何使用 iptables 禁止所有类型的连接,并允许特定来源 IP 的连接,提供实战案例和相关的 Shell 脚本。

一、默认拒绝所有连接

首先,我们需要设置 iptables 使其默认拒绝所有的输入和转发连接,只允许输出连接。这样可以确保没有任何未经许可的连接能够进入服务器。

iptables -P INPUT DROP
iptables -P FORWARD DROP
iptables -P OUTPUT ACCEPT

二、允许特定来源 IP 的连接

假设我们只允许 IP 地址为 192.168.1.100 的设备访问服务器。我们需要添加一条规则来允许这个 IP 地址的所有连接。

iptables -A INPUT -s 192.168.1.100 -j ACCEPT

如果你只想允许该 IP 地址通过 SSH 连接(通常是端口 22),可以添加以下规则:

sh
复制代码
iptables -A INPUT -p tcp -s 192.168.1.100 --dport 22 -j ACCEPT

三、允许本地回环接口连接

本地回环接口(localhost)是服务器自身的网络接口,通常用于本地通信。为了确保服务器的正常运作,必须允许本地回环接口的连接。

iptables -A INPUT -i lo -j ACCEPT

四、允许已有连接和相关连接

为了确保现有的连接和相关连接不被中断,我们需要添加以下规则:

iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT

五、保存 iptables 规则

设置完这些规则后,需要保存它们以确保在服务器重启后依然有效。

CentOS / RHEL
service iptables save
Ubuntu / Debian
iptables-save > /etc/iptables/rules.v4

六、实战案例

假设你有一台服务器,其 IP 地址为 203.0.113.1。你希望只允许 IP 地址 192.168.1.100 的计算机通过 SSH 连接到这台服务器,并且设置好 iptables 规则使其生效。以下是完整的 Shell 脚本示例:

#!/bin/bash
# 默认拒绝所有连接
iptables -P INPUT DROP
iptables -P FORWARD DROP
iptables -P OUTPUT ACCEPT

# 允许特定来源 IP 的连接
ALLOWED_IP="192.168.1.100"
iptables -A INPUT -s $ALLOWED_IP -j ACCEPT

# 允许本地回环接口连接
iptables -A INPUT -i lo -j ACCEPT

# 允许已有连接和相关连接
iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT

# 保存规则
if [ -f /etc/redhat-release ]; then
  service iptables save
elif [ -f /etc/debian_version ]; then
  iptables-save > /etc/iptables/rules.v4
else
  echo "Unknown distribution. Please save the iptables rules manually."
fi

echo "iptables rules have been configured and saved."

将上述脚本保存为 setup_iptables.sh,并赋予执行权限:

chmod +x setup_iptables.sh

然后运行脚本:

./setup_iptables.sh

七、总结

通过本文介绍的方法,你可以有效地使用 iptables 限制 SSH 连接,只允许特定的 IP 地址访问你的服务器。此举能够显著提高服务器的安全性,防止未经授权的访问。希望本文能够帮助你更好地保护你的服务器安全。

标签:iptables,IP,ACCEPT,SSH,INPUT,服务器,连接
From: https://blog.csdn.net/qq_40797754/article/details/142199916

相关文章

  • TypeScript:函数
    一、简介函数是JavaScript应用程序的基础。它帮助你实现抽象层,模拟类,信息隐藏和模块。在TypeScript里,虽然已经支持类,命名空间和模块,但函数仍然是主要的定义行为的地方。TypeScript为JavaScript函数添加了额外的功能,让我们可以更容易地使用。和JavaScript一样,TypeScr......
  • 数据库tips17
    (十)、约束及索引类型约束的作用是为了防止可预见的错误的数据进入数据库中,是保障数据一致性的一种机制。UNIQUE约束是列级约束,表示关系中的记录在该列上的取值不重复。索引是通过建立索引列上的索引表,索引表中的査找项是索引列上的所有值的排序或散列(目的是为了快速查找),索引表中......
  • 【TS】TypeScript配置详解【三】
    简介TypeScript代码最终都会被编译成JavaScript代码来运行。这个编译的过程需要使用TypeScript编译器,我们可以为该编译器配置一些编译选项。在TypeScript项目的根目录下执行“tsc-init”命令,快速创建一个tsconfig.json文件。该文件用于配置TypeScript编译项目时编......
  • JavaScript语法入门五 常量
    常量声明一个常量就是声明一个常数。声明之后就不能修改(不能通过重新赋值进行修改)。使用const关键字。该关键字是ES6新增加的关键字。用const声明常量时,必须初始化。例子1:constmyBirthday='18.06.1981';例子2:<script> constPERSON='jack' {   constPERSON='tom' ......
  • 【TS】TypeScript高级详解【二】
    TypeScript类的使用进行ES5开发的时候,需要使用函数和原型链实现类和继承。ES6引入了class关键字,我们可以更加方便地定义和使用类。作为JavaScript的超集,TypeScript同样支持使用class关键字,并且可以对类的属性和方法等进行静态类型检测。类的定义具体的类定义方式如下:......
  • 【TS】TypeScript基础详解【一】
    Javascript类型缺陷类型引发的问题在编程开发中,有一个共识:错误越早发现,就越容易解决。例如:能在代码编写时发现错误,就不要等到代码编译时才发现(这也是IDE的优势之一)。能在代码编译时发现错误,就不要在代码运行时才发现(类型检测可以帮助我们在这方面做得很好)。能在开发......
  • P1091 [NOIP2004 提高组] 合唱队形
    [NOIP2004提高组]合唱队形题目描述$n$位同学站成一排,音乐老师要请其中的$n-k$位同学出列,使得剩下的$k$位同学排成合唱队形。合唱队形是指这样的一种队形:设$k$位同学从左到右依次编号为$1,2,$…$,k$,他们的身高分别为$t_1,t_2,$…$,t_k$,则他们的身高满足$t_1<\c......
  • 搭建ipv6并发代理池
    声明本文章中所有内容仅供学习交流,抓包内容、敏感网址、数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除!学习目标ounter(lineipv6代理池学习前置环境配置要求linux系统。我是pve下的ubuntugolang的环境我......
  • [NOIP 2024 模拟2]矩阵学说
    [NOIP2024模拟2]矩阵学说题意给出\(n\)行\(m\)列的矩阵,第\(i\)行第\(j\)列的元素为\(a_{i,j}\),找出满足以下条件的三元组\((i,j,x)\)的数量:\(1≤i≤n\),\(1≤j\lem\),\(1≤x≤\min(n−i+1,m−j+1)\)矩阵的左上角\((i,j)\)到右下角......
  • [NOIP 2024 模拟2]数组操作
    [NOIP2024模拟2]数组操作题意有\(n+2\)个整数\(a_0,a_1,...,a_n,a_{n+1}\),\(a_0=a_{n+1}=0\)。你需要做确切地\(n\)次操作,每次数组操作为以下形式:选择一个整数\(x\)满足\(a_x\ne0\),使得\(a_x=0\),令\(l=\max_{i<x,a_i=0}i,r=\min_{i>x,a_i=0}i\)......