centos+nginx+php,使用ftp工具后,目录权限设置问题
背景:
网站使用nginx+php-fpm
,运行账户为nginx:nginx
,ftp
账户为test:ftp
;
网站根目录为 /user/share/nginx/html/www
;
ftp
工具为vsftpd
;
现在网站能正常使用,但是本地使用filezilla
无法上传文件,提示553 Could not create file.
,附图如下:
问题:
如何设置www
的目录权限,才能在保证安全的情况下,使nginx
和ftp
都能正常使用?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
虽然可能跑题,但我的建议是每个网站用单独的用户来跑,网站相关的所有文件属于该用户,这样可以做到站点之间,服务之间的权限隔离。FTP 也用所属的用户来登录。
把test添加到www用户组,然后775应该就可以了。
usermod -a -G www test
chmod 775 -R /user/share/nginx/html/www
试试把filezilla的被动模式去掉,或者vsftpd开启一下被动模式
/etc/vsftpd/vsftpd.conf 末尾追加
/etc/sysconfig/iptables 开启端口
重启iptables & vsftpd
题主你好,我今天也是遇到了和你一样的问题,网站使用nginx+php-fpm,运行账户为nginx:nginx,ftp账户为myname:ftp;网站根目录为 /user/share/nginx/html;研究了一下成功了,方法如下,可供参考:
首先编辑“vsftpd.conf”:
在文档最后添加:
完成后按 ESC 输入 :wp 保存并退出。然后进入“vsftpd”目录:
创建一个目录“vu_conf”:
然后进入此目录:
创建一个和虚拟用户名同名的文件“myname”:
然后打开这个文件:
按 i 键盘进入编辑模式,输入这个用户所对应的路径“local_root= /usr/share/nginx/html”然后按保存退出。最后重新启动 vsftpd 即可: