Linux如何正确关闭网络连接?3种方法

断开特定客户端的TCP连接

当需要终止某个远程客户端(如SSH用户或异常访问IP)的活跃连接时:

  1. 定位目标连接
    使用ssnetstat命令查看活跃连接:

    sudo ss -tunp | grep <客户端IP或端口>  # 示例:sudo ss -tunp | grep 192.168.1.100

    输出示例:

    tcp ESTAB 0 0 192.168.1.10:22  192.168.1.100:54321 users:(("sshd",pid=1234,fd=3))
  2. 终止连接

    • 方法1:通过进程ID(PID)终止
      找到输出中的pid值(如1234),执行:

      sudo kill -9 1234  # 强制结束进程
    • 方法2:使用ss直接断开(需内核≥4.9)
      sudo ss -K dst 192.168.1.100 dport = 54321  # 指定目标IP和端口

通过防火墙禁止客户端访问

使用防火墙永久阻止特定IP的网络访问:

  1. iptables(传统方案)

    sudo iptables -A INPUT -s <客户端IP> -j DROP  # 禁止该IP所有入站流量
    sudo iptables -A OUTPUT -d <客户端IP> -j DROP # 禁止出站流量
    sudo iptables-save > /etc/iptables/rules.v4  # 永久保存规则
  2. firewalld(推荐,适用于CentOS/RHEL)

    sudo firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="<客户端IP>" reject'  # 拒绝IP
    sudo firewall-cmd --reload  # 生效配置
  3. UFW(Ubuntu/Debian)

    sudo ufw deny from <客户端IP> to any  # 禁止IP访问

完全关闭网络接口

临时禁用整张网卡(如eth0):

sudo ip link set eth0 down  # 关闭接口
sudo ifconfig eth0 down     # 传统命令(部分系统兼容)

恢复网络

sudo ip link set eth0 up    # 重新启用

关键注意事项

  1. 风险预防

    • 避免在生产环境直接kill关键服务(如数据库连接)。
    • 防火墙规则错误可能导致自身被锁,操作前确保留有本地控制台访问权限。
  2. 连接状态验证

    • 断开后检查效果:
      sudo ss -tunp | grep <客户端IP>  # 确认连接消失
      ping <客户端IP>                 # 验证防火墙阻断(应无响应)
  3. 持久化配置

    • 防火墙规则需--permanent(firewalld)或iptables-save保存,否则重启失效。
    • 禁用网卡重启后自动恢复,需编辑配置文件(如/etc/network/interfaces)实现永久关闭。

适用场景总结

场景 推荐方法
踢出单个异常用户(如SSH) 终止TCP连接(kill/ss -K
永久封禁恶意IP 防火墙规则(iptables/firewalld)
临时断网维护 关闭网络接口(ip link down

引用说明基于Linux内核文档、iptables官方手册及firewalld Wiki,命令兼容主流发行版(Ubuntu 20.04+/CentOS 7+),操作前建议查阅man手册(如man ssman iptables)获取系统特定说明。

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

(0)
酷番叔酷番叔
上一篇 2025年6月23日 12:50
下一篇 2025年6月23日 13:09

相关推荐

  • 给电脑安装Linux系统时,硬盘分区正确步骤和方法该如何操作?

    在给电脑安装Linux系统时,分区是关键步骤,合理的分区规划能提升系统稳定性和后续管理效率,以下是详细操作流程及注意事项:安装前的准备工作分区前需完成基础准备,避免操作中断或数据丢失,备份重要数据:Linux安装过程中会修改硬盘分区表,若操作不当可能导致原有数据丢失,建议提前将C盘、D盘等重要文件备份至移动硬盘……

    2025年8月21日
    14000
  • Linux操作系统安装终端服务的详细步骤是怎样的?

    在Linux系统中,终端服务是实现远程管理和多用户访问的核心功能,通过终端服务,用户可以在不同设备上安全地连接到Linux服务器,进行命令行操作或图形界面交互,本文将以主流的SSH(Secure Shell)协议为核心,结合图形终端服务(如XRDP),详细介绍Linux终端服务的安装、配置与安全加固流程,涵盖U……

    2025年10月7日
    6900
  • Linux系统如何打开系统盘并访问其内容?

    在Linux系统中,“系统盘”通常指安装操作系统的分区,如根分区(/)、引导分区(/boot)或/home分区等,与Windows不同,Linux的分区管理更强调命令行操作和权限控制,但图形界面也能满足基本需求,以下是详细的开机和访问方法,涵盖图形界面、命令行操作及特殊情况处理,Linux系统盘的识别与基本概念……

    2025年10月2日
    5700
  • Linux如何回到根目录?操作方法与命令步骤详解

    在Linux操作系统中,根目录(用表示)是整个文件系统的起点,所有目录、文件和设备都挂载在根目录或其子目录下,无论是系统管理、文件操作还是脚本编写,回到根目录都是常见的操作,本文将详细讲解Linux中回到根目录的方法、相关概念及注意事项,帮助用户熟练掌握这一基础技能,理解根目录与路径概念在Linux文件系统中……

    2025年8月27日
    9700
  • Linux如何彻底卸载Conky?

    Conky是一款在Linux系统上广泛使用的轻量级系统监视器,它能够以文本或图形化方式实时显示系统资源使用情况,如CPU占用率、内存消耗、网络速度、磁盘I/O等信息,许多用户选择Conky来定制个性化的桌面信息展示,但随着使用需求的改变或系统配置的更新,卸载Conky也成为常见操作,本文将详细介绍在不同Linu……

    2025年8月22日
    10400

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信