AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 847156
Accepted
Jonathan S. Fisher
Jonathan S. Fisher
Asked: 2017-04-29 06:05:00 +0800 CST2017-04-29 06:05:00 +0800 CST 2017-04-29 06:05:00 +0800 CST

有没有办法用 systemd 控制文件系统访问?

  • 772

因此,我正在深入研究 systemd 的复杂性,以及它使用 cpu、io 和内存等 cgroup 来计量资源的能力。

还有一种方法可以控制进程可以使用 systemd 访问的目录吗?例如,/usr/bin通常标记为o+rX,我希望将网络服务器进程锁定在该目录之外。已经有很多软件漏洞,您可以从磁盘读取任意文件,这将增强分层的安全性方法。

我确信这可以通过一些非常花哨的文件系统权限来完成,但想知道是否有更好的方法。感谢服务器故障!

systemd
  • 1 1 个回答
  • 1082 Views

1 个回答

  • Voted
  1. Best Answer
    HBruijn
    2017-04-29T06:43:12+08:002017-04-29T06:43:12+08:00

    实际上,您有许多选项,您可以在单元文件中为您的服务定义这些选项。它们都以相同的原理工作,通过在为服务设置的命名空间 systemd 中使用绑定挂载。文件系统的某些部分要么以只读方式挂载,要么通过挂载空目录呈现为完全不可见/不可访问。

    PrivateTmp可以说是最常见的。
    启用PrivateTmp为已执行的进程设置一个新的文件系统命名空间,并在其中挂载私有目录/tmp和/var/tmp目录,这些目录不被命名空间外的进程共享。

    ProtectSystem
    如果,则为本单元调用的进程以只读方式true挂载/usr和目录。 如果设置为,则该目录也以只读方式挂载。如果设置为“strict”,则整个文件系统层次结构以只读方式挂载,API 文件系统子树 /dev、/proc 和 /sys 除外/boot
    full/etc

    ProtectHome
    接受布尔参数或“只读”。如果,true目录和被本单元调用的进程设为不可访问且为空。如果设置为“ ”,则三个目录改为只读/home/root/run/userread-only

    ProtectKernelTunables
    如果为真,内核变量可通过/proc/sys, /sys, /proc/sysrq-trigger, /proc/latency_stats, /proc/acpi,和访问/proc/timer_stats,并将设为只读。/proc/fs/proc/irq

    ReadOnlyPaths
    列出的路径ReadOnlyPaths=只能以只读方式访问,即使通常的文件访问控制允许这样做,也会拒绝写入。

    InaccessiblePaths
    InaccessiblePaths=命名空间内的进程(以及文件系统层次结构中它们下面的所有内容)将无法访问其中 列出的路径。

    不过可能还有更多选择。

    更分层的访问策略可能需要 SELinux,并且您可能需要对它有非常透彻的了解,并且您可能需要熟练使用多级安全策略。

    • 6

相关问题

  • SSH 会话在关机/重启时挂起

  • 我可以使用 systemd 重新启动依赖服务吗?

  • 让我的旧初始化脚本在 systemd 中工作的最简单方法是什么?

  • 在 CentOS 7 上为 systemd 启动的进程增加 nproc

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve