如何限制单IP10个并发连接

限制新连接数(预防性控制)

通过防火墙规则限制单个IP的连接数,防止资源滥用:

# 使用更现代的nftables(示例:限制SSH连接)
sudo nft add table inet filter
sudo nft add chain inet filter input { type filter hook input priority 0; }
sudo nft add rule inet filter input tcp dport 22 ct count over 5 reject

适用场景:防御DDoS攻击或防止单个IP耗尽资源。


通过Web服务器配置限制连接

针对Nginx/Apache等服务的连接控制:

  • Nginx配置(修改nginx.conf):

    http {
        limit_conn_zone $binary_remote_addr zone=perip:10m;
        server {
            location / {
                limit_conn perip 5;  # 每个IP最多5个连接
            }
        }
    }

    重启服务:sudo systemctl restart nginx

  • Apache配置(需启用mod_ratelimit):

    <IfModule mod_ratelimit.c>
        <Location "/">
            SetOutputFilter RATE_LIMIT
            MaxRate 100   # 每秒最多100个连接
        </Location>
    </IfModule>

强制关闭现有连接

使用网络工具断开已建立的连接:

  1. 查找目标连接(以SSH为例):
    sudo ss -tpn dst :22  # 查看所有SSH连接(含PID和IP)
  2. 关闭连接
    • 通过进程ID终止:
      sudo kill -9 <PID>   # 结束对应进程
    • 使用tcpkill(需安装dsniff包):
      sudo tcpkill -i eth0 host 192.168.1.100  # 断开指定IP的所有连接

调整系统级连接参数

修改内核参数优化连接管理:

# 降低TIME_WAIT状态连接的回收时间(秒)
sudo sysctl -w net.ipv4.tcp_fin_timeout=15
# 限制半连接队列大小(防御SYN Flood)
sudo sysctl -w net.ipv4.tcp_max_syn_backlog=2048
# 持久化配置:将参数写入/etc/sysctl.conf
echo "net.ipv4.tcp_fin_timeout=15" | sudo tee -a /etc/sysctl.conf
sudo sysctl -p

注意事项

  1. 操作风险:强制断开连接可能导致用户数据丢失,生产环境需谨慎。
  2. 性能影响:过度限制连接数可能误伤正常流量,建议监控后调整(工具:netstat, ss, nload)。
  3. 安全原则:优先通过防火墙或服务配置预防问题,而非事后处理。
  4. 备份配置:修改关键文件前备份(如cp /etc/nginx/nginx.conf ~/nginx.conf.bak)。

引用说明

  • Linux内核参数文档:man tcp(终端查看)
  • iptables官方指南:netfilter.org
  • Nginx连接限制模块:nginx.org/docs
  • 系统工具手册页:man ss, man sysctl, man tcpkill

重要提示:本文方法需root权限操作,建议在测试环境验证后再部署到生产服务器,对于复杂攻击场景,建议结合专业防火墙(如Cloudflare)或安全团队协作处理。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/5411.html

(0)
酷番叔酷番叔
上一篇 2025年6月23日 13:02
下一篇 2025年6月23日 13:33

相关推荐

  • Linux环境下如何打开.db文件的具体方法是什么?

    在Linux操作系统中,.db文件通常是SQLite数据库文件的扩展名,SQLite是一种轻量级、基于文件的嵌入式数据库,无需独立服务进程,广泛应用于本地数据存储场景,少数情况下,.db文件也可能是其他数据库(如MySQL的MyISAM表文件)的存储格式,但Linux下最常见的是SQLite数据库,打开.db文……

    2025年8月30日
    12100
  • 如何在linux打开文件夹权限设置

    在Linux系统中,文件夹权限设置是保障系统安全和数据访问控制的核心操作,主要通过命令行工具和图形界面两种方式实现,无论是限制用户访问、管理共享资源,还是修复权限错误,掌握正确的权限设置方法都至关重要,以下将详细介绍具体操作步骤、常用命令及注意事项,命令行方式修改文件夹权限命令行是Linux系统管理的高效工具……

    2025年9月15日
    9300
  • 你的临时IP配置重启失效了吗?

    在Linux系统中配置IP地址是网络管理的基础操作,无论是搭建服务器、连接互联网还是调试网络环境都至关重要,以下是几种常用方法,涵盖临时配置与永久配置,操作前请确保具备管理员权限(使用sudo或切换root用户),适用于快速测试或临时网络调整,使用ip或ifconfig命令(部分新系统需安装net-tools……

    2025年7月5日
    10700
  • 你的权限够用吗?

    文件只读的解决方法(用户权限层面)适用场景:用户无法修改或删除自己的文件(提示 “Read-only file system” 或 “Permission denied”),核心命令:chmod(修改文件权限)步骤:# 添加写权限(所有者)chmod u+w filename.txt# 或直接赋予所有者完整权限……

    2025年8月7日
    11500
  • 如何格式化Linux系统?操作步骤与注意事项有哪些?

    格式化Linux系统通常指在安装或重装操作系统时,对磁盘进行分区并创建文件系统的过程,这是系统部署的关键步骤,直接影响数据存储结构、访问效率和系统稳定性,整个过程需谨慎操作,尤其是涉及数据安全时,必须提前备份重要信息,以下从准备工作、分区基础、格式化工具选择及操作步骤等方面详细说明如何格式化Linux系统,格式……

    2025年9月8日
    11300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信