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

相关推荐

  • 为何需要锁来守护安全?

    在多用户或多线程环境中,锁用于协调对共享资源(如数据、文件)的并发访问,防止冲突操作导致数据不一致、错误或资源损坏,确保系统正确性和数据完整性。

    2025年6月22日
    1300
  • Linux内核模块如何安全操作?

    调用内核模块的前提条件环境要求:Root权限(sudo或root用户)已安装对应内核版本的开发工具包(如build-essential、linux-headers-$(uname -r))模块需与当前内核兼容(通过uname -r查看内核版本)模块文件验证:仅使用可信来源的.ko文件(如官方驱动或开源社区审核的……

    2025年7月13日
    700
  • 树莓派运行Kali Linux?打造便携渗透测试平台!

    准备工作硬件要求树莓派型号:3B/3B+/4B(推荐4B,2GB+内存)存储:Class 10 MicroSD卡(≥16GB)电源:5V/3A USB-C电源(树莓派4需官方电源)外设:HDMI线、键盘、鼠标、网线(或Wi-Fi适配器)软件资源Kali Linux镜像:从Kali官网下载ARM版镜像(选择Ras……

    2025年6月18日
    1300
  • 如何快速查看Linux网卡驱动?

    方法 1:通过 lspci 命令(推荐)原理:列出 PCI 设备详情,直接关联网卡型号与驱动名称,操作步骤:lspci -v | grep -iA 10 "network\|ethernet"输出示例:00:1f.6 Ethernet controller: Intel Corporatio……

    2025年6月15日
    1500
  • 如何轻松安装FTP客户端?

    在Linux系统中上传文件到FTP服务器是常见的操作,可通过命令行工具或图形界面实现,以下是详细方法及注意事项,确保操作安全高效:命令行工具(推荐掌握)使用 ftp 基础工具sudo yum install ftp # CentOS/RHEL# 连接服务器ftp ftp.example.com# 输入用户名和密……

    2025年6月23日
    1000

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信