0

0

Linux系统环境隔离方法_多业务并行运行解析【教程】

舞姬之光

舞姬之光

发布时间:2026-01-05 18:15:08

|

951人浏览过

|

来源于php中文网

原创

systemd --scope 是最轻量的运行时环境隔离手段,无需改服务配置或依赖容器,通过绑定进程到独立 cgroup 实现 CPU、内存、IO 限制并自动清理。

linux系统环境隔离方法_多业务并行运行解析【教程】

systemd --scope 快速隔离进程资源

不需要改服务配置、不依赖容器,systemd --scope 是最轻量的运行时环境隔离手段。它把一组进程绑定到独立的 cgroup 下,能限制 CPU、内存、IO,且自动清理——进程退出后 cgroup 自动销毁。

  • 适合临时跑测试脚本、并行执行多个同名服务(如不同端口python app.py
  • 必须用 root 或有 org.freedesktop.systemd1.manage-units 权限的用户执行
  • 内存限制需内核开启 cgroup_memory(现代发行版默认开启),检查:cat /proc/cgroups | grep memory
  • 别直接在 shell 中后台运行(&),否则会脱离 scope;要用 --scope 包裹整个命令链
sudo systemd-run --scope -p MemoryMax=512M -p CPUQuota=50% --scope python3 server.py --port 8001

unshare 实现文件系统与网络命名空间隔离

unshare 不依赖 systemd,适合无特权容器化场景(如 CI 环境中普通用户需要隔离 /tmp/etc/hosts)。但它默认不设资源限制,仅提供命名空间隔离,需配合 cgexec 或手动挂载 cgroup 才能控 CPU/内存。

  • 常见错误:只用 unshare -r 做 user namespace,却没映射 UID/GID,导致 ls /proc 报错 “Permission denied”
  • 网络隔离要加 --net 并手动配置 veth + iptables,否则新 netns 默认无网络
  • 挂载隔离(--mount)必须搭配 --user 或先 mount --make-rprivate /,否则会提示 “Operation not permitted”
unshare --user --pid --mount --fork --root=/tmp/myroot chroot /tmp/myroot /bin/sh

避免误用 chroot 当作完整隔离方案

chroot 只改变根目录路径,不隔离进程、网络、用户、cgroup —— 它不是安全边界,更不是容器替代品。生产环境若仅靠 chroot 隔离多业务,极易发生 PID 冲突、端口抢占、日志混写等问题。

ChatMind
ChatMind

ChatMind是一款AI生成思维导图的效率工具,可以通过AI对话生成和编辑思维导图。

下载
  • 无法防止子进程逃逸:只要进程有 cap_sys_chroot 或 root 权限,chroot 可被 chroot("..") 绕过
  • 所有业务仍共享同一内核调度器,一个业务夯住 CPU,其他全卡死
  • /dev/proc/sys 若未手动 bind-mount,很多程序(如 pssystemctl)直接失效
  • 真正需要的是组合:比如 chroot + unshare --user + cgexec -g memory:/myapp

选型关键:看业务是否需要跨主机迁移或强安全边界

如果只是同一台机器上跑多个 Python/Node.js 服务,互不干扰即可,systemd --scope 足够;如果要防恶意代码读宿主文件或建反向连接,就必须上 podman run --isolation=chrootdocker run --read-only --tmpfs;若连内核模块都不能信(比如多租户 SaaS),就得考虑 KVM 虚拟机级隔离。

  • 别为“看起来高级”选 Docker:纯本地 CLI 工具链并行运行,systemd-run 启动快、无镜像体积、日志直通 journal
  • Podman 的 --isolation=chroot 模式其实仍用 unshare,但自动处理了 /dev 和 /proc 挂载,比手写 unshare 更稳
  • 所有方案都绕不开 cgroup v2 —— 如果 /sys/fs/cgroup/cgroup.controllers 为空,说明系统还在用 v1,部分限制(如 memory.high)不可用
实际部署时,最容易被忽略的是 cgroup 版本兼容性和 mount propagation 设置。哪怕命令全对,MemoryMax 在 cgroup v1 下是无效字段,而 unshare --mount 在默认 mount propagation 为 shared 的系统上会失败。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

734

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

631

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

752

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1258

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

577

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

705

2023.08.11

漫蛙2入口地址合集
漫蛙2入口地址合集

本专题整合了漫蛙2入口汇总,阅读专题下面的文章了解更多详细内容。

162

2026.01.06

热门下载

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

精品课程

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

共48课时 | 6.7万人学习

Git 教程
Git 教程

共21课时 | 2.5万人学习

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

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