• Docker 创建php 开发环境遇到的权限问题解决方案


    最近我将公司的开发,和测试环境都运行到docker 上面,因为开发,测试基本都是装代码拉到本址,然后,再装目录,挂载到镜像目录中如:我用的是docker-compose

    # development.yml
    version: '2'
    services:
      php-fpm:
        image: jackluo/php-fpm:5.6.3
        restart: always
        volumes:
          - ./www:/var/www/html
          - ./data:/usr/local/var/log
        extra_hosts:
          - "cache.redis.com:192.168.9.111"
          - "192.168.9.111:192.168.9.111"   
      web:
        image: index.alauda.cn/library/nginx
        restart: always
        links:
          - php-fpm
        volumes:
          - ./config:/etc/nginx/conf.d
          - ./data:/var/log/nginx
        volumes_from:
          - php-fpm
        ports:
          - 80:80
        expose:
          - 80

    上面的

    jackluo/php-fpm:5.6.3 这个是我自己拉的官方镜像下来添加了一些东西,具体在github有 docker-library 里面

    目前公司的php 框架用的是 thinkphp ,thinkphp 会生成 缓存文件和目录,php镜像官方的运行用户是www-data,以前的解决方案是只要两个用户一致就可以了,于是,我就在我本地创建了一个www-data的用户如

    全部都给的是www-data 权限,再看看Runtime 上面宿主机的生成的是啥权限

     

    全部都是33 ,33是啥用户????,我看看docker 里面是啥权限

    发现挂载进去的权限是1000,而且php 生成的变成www-data 这个

    然后我再访问,网页

    网页显示 ,没有写入的权限,这个是麻意思呢?

    其实,这个问题,困扰了我很久,我一般的解决方案是直接就Runtime 给777的权限,但是,如果是新生成的php页面,每次都要去执行给777的权限,实在感觉不爽,浪迹,http://stackoverflow.com/ 终于找到了解决方案.官方的解决方案是

    FROM php:5.6-fpm
    RUN usermod -u 1000 www-data

    如果 你是mac

    RUN usermod -u 1000 www-data && usermod -G staff www-data

    这样php生成的缓存生成的权限,就一致了 

    问题,就这样子,解决鸟

  • 相关阅读:
    微信小程序 如何让button按钮长度变为100%
    使用%在搜索框中进行模糊查询
    vsCode中输入wx没有提示?
    uniapp的页面的生命周期:onLoad、onShow、onReady
    MySQL报错:1130Host 'LAPTOPJRI45NVC' is not allowed to connect to this Mysql server
    URLEncoder和URLDecoder
    super和this
    把MIT的算法课程看一遍
    单节点hadoop部署成功
    suse的ssh服务
  • 原文地址:https://www.cnblogs.com/jackluo/p/5952953.html
Copyright © 2020-2023  润新知