最近我将公司的开发,和测试环境都运行到docker 上面,因为开发,测试基本都是装代码拉到本址,然后,再装目录,挂载到镜像目录中如:我用的是docker-compose
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
# development.yml
version: 2
services:
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的权限,实在感觉不爽,浪迹, 终于找到了解决方案.官方的解决方案是
1
2
from php:5.6-fpm
run usermod -u 1000 www-data
如果 你是mac
1
run usermod -u 1000 www-data && usermod -g staff www-data
这样php生成的缓存生成的权限,就一致了
问题,就这样子,解决鸟
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。