如何限制单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如何guolv

    Linux 中可通过多种方式过滤,如用 grep 根据模式筛选文本内容,用

    2025年8月17日
    10100
  • Debian/Ubuntu更新卡住怎么办?

    准备工作(所有方法通用)更新系统终端执行:sudo apt update && sudo apt upgrade -y # Debian/Ubuntusudo dnf update -y # Fedora/RHEL安装依赖sudo apt install -y build-essential l……

    2025年7月25日
    13700
  • Linux补丁文件如何上传至服务器?

    Linux补丁文件是记录源代码或配置文件修改差异的文本文件,通常以.diff或.patch为后缀,用于将修改应用到目标系统中,上传补丁文件是系统维护、版本控制和问题修复中的常见操作,根据目标环境的不同,上传方式和步骤也存在差异,本文将详细介绍Linux补丁文件的生成、常见上传场景及具体操作步骤,并附上相关注意事……

    2025年10月4日
    10300
  • 在Linux操作系统中,如何通过具体命令或程序耗尽磁盘IO性能?

    在Linux系统中,磁盘I/O是影响系统性能的关键因素之一,当磁盘I/O资源被过度消耗时,会导致系统响应缓慢、进程阻塞,甚至服务完全不可用,要理解如何耗尽磁盘I/O,需要从高并发读写操作、不当的I/O调度策略、文件系统特性、磁盘自身性能限制以及进程异常行为等多个维度进行分析,高并发读写操作:瞬间榨干I/O带宽磁……

    2025年10月2日
    9200
  • Linux如何创建文本文件?常用方法有哪些?

    在Linux系统中,创建文本文件是最基础且高频的操作之一,无论是编写配置文件、Shell脚本,还是记录日志、存储数据,都离不开文本文件的创建,Linux提供了多种创建文本文件的方式,涵盖命令行工具和交互式编辑器,每种方法都有其适用场景和优缺点,本文将详细介绍这些方法,帮助用户根据实际需求选择最合适的操作方式,使……

    2025年8月26日
    13200

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信