0

0

大量残留网络 namespace 的 ip netns list 批量自动清理脚本

舞夢輝影

舞夢輝影

发布时间:2026-01-23 18:59:02

|

618人浏览过

|

来源于php中文网

原创

根本原因是network namespace基于bind mount实现,/var/run/netns/下文件仅为挂载点;进程退出但挂载未清理时,内核仍持有namespace,导致ip netns list显示残留却无法删除。

大量残留网络 namespace 的 ip netns list 批量自动清理脚本

为什么 ip netns list 显示一堆残留 namespace 却删不掉?

根本原因是:Linux 的 network namespace 是基于 bind mount 实现的,/var/run/netns/ 下的文件只是挂载点。如果进程已退出但挂载未清理,namespace 仍被内核持有,ip netns list 就会列出它,但 ip netns delete 会报 Cannot remove namespace file: No such file or directory 或静默失败。

常见诱因包括:容器运行时异常退出、unshare --net 测试后忘记清理、CI/CD 中 ip netns exec 段错误导致挂载点残留。

关键判断依据:ls -l /var/run/netns/ 看到类似 netns_foo -> /proc/12345/ns/net 的软链,而 ps -p 12345 显示进程不存在 —— 这就是典型残留。

find + readlink 批量识别真实残留 namespace

不能只靠 ip netns list 输出,得逐个检查挂载点指向的 /proc//ns/net 是否还存在:

通义千问
通义千问

阿里巴巴推出的全能AI助手

下载
  • find /var/run/netns -type l -exec sh -c 'for f; do pid=$(readlink "$f" | sed "s|/proc/\\([0-9]\\+\\)/ns/net|\\1|"); [ -z "$pid" ] || [ ! -d "/proc/$pid/ns" ] && echo "$f"; done' _ {} \;
  • 该命令只输出那些软链指向已消亡进程的 namespace 文件路径(如 /var/run/netns/testns
  • 注意:部分系统(如旧版 CentOS 7)/var/run 是 tmpfs,重启即清,但长期运行的服务器必须主动清理

安全删除残留 namespace 的三步操作

确认残留后,不能直接 rm,否则可能破坏正在使用的 namespace(比如 Docker 容器还在用同名挂载点)。必须先 unmount 再删文件:

  • 对每个残留路径 $ns_path,执行 sudo umount "$ns_path" —— 失败说明有进程正用它,跳过
  • 成功 unmount 后,再 sudo rm "$ns_path"
  • 最后验证:ip netns list | grep -q "$ns_name" && echo "still there" || echo "gone"
  • 可封装为一行清理命令(加 -f 避免交互):sudo umount /var/run/netns/* 2>/dev/null; find /var/run/netns -type l -delete 2>/dev/null,但慎用,建议先用上一步识别出的列表精准操作

写成可复用脚本要注意的三个细节

一个可靠脚本必须处理边界情况,不是简单循环 ip netns list

  • 避免误删:检查 /var/run/netns/ 是否为目录,防止路径不存在时报错中断
  • 兼容不同挂载方式:有些环境用 mount --bind 而非符号链接,需补充 mount | awk '/^ns:/ {print $3}' 扫描实际挂载点
  • 权限问题:umountrm 必须用 sudo,但脚本开头应检测是否已有 root 权限,没权限则直接 exit 并提示 sudo ./clean-netns.sh
  • 示例核心逻辑片段:
    if [ -d /var/run/netns ]; then
      for ns in /var/run/netns/*; do
        [ -L "$ns" ] || continue
        target=$(readlink "$ns")
        if [[ "$target" =~ ^/proc/[0-9]+/ns/net$ ]] && ! [ -d "${target%/ns/net}" ]; then
          sudo umount "$ns" 2>/dev/null && sudo rm "$ns"
        fi
      done
    fi

真正麻烦的是那些被长期占用却无对应进程的 namespace —— 往往是内核模块或驱动残留,这种得查 ls -la /proc/*/ns/net 2>/dev/null | grep ,但绝大多数场景只需处理挂载点即可。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.09.27

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

233

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

437

2024.03.01

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

393

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

574

2023.08.10

数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

274

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

211

2023.12.29

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

252

2023.07.24

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.6万人学习

Git 教程
Git 教程

共21课时 | 2.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号