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 / 问题 / 1132179
Accepted
Tom
Tom
Asked: 2023-05-30 04:22:26 +0800 CST2023-05-30 04:22:26 +0800 CST 2023-05-30 04:22:26 +0800 CST

允许用户创建和写入日志文件夹

  • 772

当收到电子邮件时,我正在使用 Exim4 运行 PHP 脚本。

这个脚本应该在 /var/log/myapp 文件夹中创建一个文件,如果它不存在,否则它应该只读取文件并向日志添加更多内容。

我对文件夹应用 777 权限进行了一些测试,我看到 Exim4 使用的用户是nobody.

但是,在某些情况下,我的管理用户(例如bob)可以通过 PHP CLI 手动运行 PHP 文件并使用这些日志文件。

我运行下面的命令来添加我的用户,但没有人可以写入该文件夹,但只有我的用户可以创建文件,但“没有人”不能。

sudo groupadd eximapplog

sudo usermod -a -G eximapplog bob
sudo usermod -a -G eximapplog nobody

sudo chgrp -R eximapplog /var/log/myapp
sudo chmod g+rwx /var/log/myapp

sudo chmod -R 775 /var/log/myapp

我做错了什么?

ubuntu
  • 1 1 个回答
  • 234 Views

1 个回答

  • Voted
  1. Best Answer
    Saxtheowl
    2023-05-30T07:56:41+08:002023-05-30T07:56:41+08:00

    我认为错误来自您的用户(bob)和“nobody”用户之间的权限级别差异。

    让我们尝试调整 PHP 脚本或 Exim4 配置,使其以特定的非根用户身份运行。

    首先我们创建新用户和新组。

    sudo adduser eximappuser
    sudo groupadd eximappgroup
    

    然后我们将 eximappuser 和 bob 添加到我们的新组

    sudo usermod -a -G eximappgroup eximappuser
    sudo usermod -a -G eximappgroup bob
    

    我们更改所有者权利

    sudo chown -R eximappuser:eximappgroup /var/log/myapp
    

    然后我们修改var/log/myapp的权限,让owner和group可以读、写、执行

    然后你必须配置Exim4或 PHP 脚本以 'eximappuser' 而不是 'nobody' 运行

    • 2

相关问题

  • 无法通过 Ubuntu VPN 访问外部网络

  • ubuntu apt-get upgrade - 如何在 shell 中单击确定?

  • VirtualBox 上 Ubuntu 的访客优化技巧 [关闭]

  • 外部硬盘上的 virtualbox 虚拟硬盘驱动器(Vista 主机上的 ubuntu 客户机)

  • 如何在 Ubuntu 上挂载 LVM 分区?

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