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
    • 最新
    • 标签
主页 / ubuntu / 问题 / 1263272
Accepted
Todor
Todor
Asked: 2020-07-31 04:49:13 +0800 CST2020-07-31 04:49:13 +0800 CST 2020-07-31 04:49:13 +0800 CST

777 文件的权限被拒绝

  • 772

我有一个Django配置为将数据库查询写入/tmp/db.log文件的应用程序。

        "debug_console_to_file": {
            "level": "DEBUG",
            "filters": ["require_debug_true"],
            "class": "logging.FileHandler",
            "filename": "/tmp/db.log",
        },

应用程序通常从以用户身份uwsgi使用的服务器启动www-data。python manage.py但是,有时我通过我的用户手动运行它(使用) - tvelichkov。

问题是,当我尝试从我的用户启动它时,我收到一个 Permission denied 错误,/tmp/db.log因为www-data已经创建了它(删除文件可以临时解决问题,但是服务器将收到相同的错误,因为现在我用户拥有该文件)。

    PermissionError: [Errno 13] Permission denied: '/tmp/db.log'

我试图将我的用户添加到www-data组

    $ members www-data
    www-data tvelichkov

我还尝试为777文件授予文件权限。

    $ ls -l /tmp/db.log 
    -rwxrwsrwx 1 www-data www-data 22102 юли 30 15:25 /tmp/db.log

但我仍然不断收到这个Permission denied错误。任何帮助,将不胜感激。

注意:我以前在 Ubuntu 18.04 中对这个设置没有任何问题,但现在我在 Ubuntu 20.04 中有它。

更新:这是该/tmp/文件夹的权限,但请注意,这是在我运行之后chown root:root /tmp并且chmod 777 /tmp正如@adrian vera 所建议的那样,顺便说一句,在此更改之后似乎chmod 777 /tmp/db.log正在工作,因为我不再收到 Permission denied 错误。Ubuntu 是否有可能/tmp/在 18.04 和 20.04 版本之间更改了文件夹的内容?因为我很确定在遇到此问题之前我没有对此文件夹进行任何更改?

    $ ls -l / | grep tmp
    drwxrwxrwx  24 root root       4096 авг  3 10:19 tmp

注意 2:我还有一台安装了干净的 Ubuntu 20.04 的机器,我也遇到了这个问题,回家后我也会仔细检查那里的权限。

UPDATE2:所以在干净的 Ubuntu 20.04 上安装/tmp/文件夹的权限是:

    $ ls -l / | grep tmp
    drwxrwxrwt  23 root root      12288 авг  3 16:41 tmp

这就是它的/tmp/db.log样子:

    $ ls -l /tmp/db.log 
    -rw-r--r-- 1 www-data www-data 0 авг  3 16:54 /tmp/db.log

    $ sudo chmod 777 /tmp/db.log 
    $ ls -l /tmp/db.log 
    -rwxrwxrwx 1 www-data www-data 0 авг  3 16:54 /tmp/db.log

    $ lsattr /tmp/db.log 
    --------------e----- /tmp/db.log

    $ whoami
    tvelichkov

    $ getent group www-data
    www-data:x:33:tvelichkov

    $ python manage.py test --settings=cs.settings.test
    Traceback (most recent call last):
      File "/home/tvelichkov/.pyenv/versions/3.6.10/lib/python3.6/logging/config.py", line 565, in configure
        handler = self.configure_handler(handlers[name])
      File "/home/tvelichkov/.pyenv/versions/3.6.10/lib/python3.6/logging/config.py", line 738, in configure_handler
        result = factory(**kwargs)
      File "/home/tvelichkov/.pyenv/versions/3.6.10/lib/python3.6/logging/__init__.py", line 1032, in __init__
        StreamHandler.__init__(self, self._open())
      File "/home/tvelichkov/.pyenv/versions/3.6.10/lib/python3.6/logging/__init__.py", line 1061, in _open
        return open(self.baseFilename, self.mode, encoding=self.encoding)
    PermissionError: [Errno 13] Permission denied: '/tmp/db.log'
permissions log django
  • 2 2 个回答
  • 4088 Views

2 个回答

  • Voted
  1. KK Patel
    2020-08-03T21:48:54+08:002020-08-03T21:48:54+08:00

    看起来您已将特定用户 ID 设置为文件的组所有权。(请参阅rwxrwsrwx文件权限详细信息中的 s。)这就是您使用 tvelichkov 用户名被拒绝权限的原因。您需要关闭用户 ID 并在文件所有权中设置组 ID。

    sudo chown g-s www-data: /tmp/db.log
    

    我建议您应该使用相同的用户来运行和测试应用程序。这样就可以避免此类问题。

    • 1
  2. Best Answer
    pa4080
    2020-08-04T00:07:37+08:002020-08-04T00:07:37+08:00

    在这种情况下,可能不是处理权限,而是以www-data用户身份执行脚本是一个更好的主意。这是我们用来运行一些 Web 应用程序(如 NextClud、MediaWiki 等)的维护脚本的标准方法。您可以通过以下sudo命令来执行此操作:

    sudo -u www-data python manage.py
    
    • 1

相关问题

  • 如何更改确定有效用户密码的规则?[关闭]

  • 我如何知道 Ubuntu 的安装日期?

  • 无法更新雷鸟

  • Ubuntu 在什么许可证下?可以合法修改和分发吗?

  • 文件权限如何工作?文件权限用户和组

Sidebar

Stats

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

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve