我在网上搜索了可能的解决方案,但这似乎让我越来越陷入困境。
一旦 PHP 创建了一个文件,该文件就不能被删除,同一目录中的其他文件可以被删除。如果一个目录是用PHP创建的,整个目录不能被FTP使用,我可以看到那个目录下的文件,但是不能删除、修改或上传到这个目录。
我确实在这里看到了很多这样的问题,但大多数都涉及权限问题,在这种情况下,所有权限、umask 和属性都与可以通过 FTP 删除的文件相同。
我还认为可能是该文件正在使用中,但事实并非如此,(lsof 结果为空,杀死 apache 和 nginx,通常释放文件也无济于事)。
服务器正在运行 PLESK 11.0.9 FTP 服务器是 ProFTPD。
这是由 PHP、PLESK 或 ProFTPD 本身引起的一些限制吗?
我希望你能帮助我,因为我很沮丧。如果您有任何可能有助于回答此问题的问题,请随时提问:)。
[编辑]更多细节为什么我认为这不是权限问题。
[root@srv domains]# lsattr
-------------e- ./test
-------------e- ./test2
[root@srv domains]# ls -als
total 32
4 drwxrwxrwx. 7 user0041 psacln 4096 Mar 22 06:41 .
4 drwxr-x---. 12 user0041 psaserv 4096 Mar 22 07:28 ..
4 drwxrwxrwx. 2 user0041 psacln 4096 Mar 22 06:30 test
4 drwxrwxrwx. 2 user0041 psacln 4096 Mar 22 06:34 test2
[root@srv domains]# lsof test
[root@srv domains]#
我无法通过 ftp 对目录 test 执行任何操作,但我可以对目录 test2 执行任何操作
test 是使用 php 的 mkdir 命令创建的,而 test2 是通过 ssh 创建的,并且已经被正确的用户所拥有。
我还从输出中删除了一些不相关的条目
有关登录时运行的用户 proftpd 的更多信息:
[root@srv domains]# ps aux | grep ftp
10000 8508 0.5 0.0 152192 3684 ? SNs 08:37 0:00 proftpd: user0041 - x: IDLE
[root@srv domains]# cat /etc/passwd | grep 10000
user0041:x:10000:505::/var/www/vhosts/domain.ltd:/bin/false
出于隐私问题,我已将域名更改为 domain.ltd。