首页 > 解决方案 > 卷 docker 和 wordpress 的许可

问题描述

我创建了一个 docker-composer.yml 文件来运行 wordpress mysql 和 phpmyadmin 的容器。它开始很好,因为我有权限问题。我所有的文件都有用户和组的 www-data:www-data,当我想在 wp-content 中创建一个新主题时,我的权限被拒绝。我在 ubuntu 18.04。

这是我的 docker-compose.yml 文件:

version: '3'

services:
  # Database
  db:
    image: mysql:5.7
    volumes:
      - db_data:/var/lib/mysql
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: password
     MYSQL_DATABASE: wordpress
      MYSQL_USER: wordpress
      MYSQL_PASSWORD: wordpress
    networks:
      - wpsite
  # phpmyadmin
  phpmyadmin:
    depends_on:
      - db
    image: phpmyadmin/phpmyadmin
    restart: always
    ports:
      - '8080:80'
    environment:
      PMA_HOST: db
      MYSQL_ROOT_PASSWORD: password 
    networks:
      - wpsite
  # Wordpress
  wordpress:
    depends_on:
      - db
    image: wordpress:latest
    ports:
     - '8000:80'
    restart: always
    volumes: ['./:/var/www/html']
    environment:
      WORDPRESS_DB_HOST: db:3306
      WORDPRESS_DB_USER: wordpress
      WORDPRESS_DB_PASSWORD: wordpress
    networks:
      - wpsite
networks:
  wpsite:
volumes:
  db_data:

我试图更改为“chown -Rf myname:myname”。所以我可以创建一个文件,但现在无法在 wordpress 中上传文件。所以我想知道如何在 ubuntu 中使用 docker 安装卷正确设置权限。

标签: wordpressdockerdocker-composedocker-volume

解决方案


一种解决方案是将您自己的用户添加mynamewww-data组中

sudo usermod -aG www-data myname

并确保 www-data 组对所有文件/目录具有写入权限,并对目录具有执行权限。

另一种解决方案是让您自己的用户拥有所有文件(myname:www-data作为所有者)和目录,并确保www-data组具有适当的读/写权限,以便 WordPress 容器的网络服务器可以使用组权限来读/写文件。

题外话:还要确保有一个

define('FS_METHOD', 'direct');

在你的wp-config.php.


推荐阅读