记PHP下载大文件失败的一次坑
说明
php提供文件的储存和下载,nginx作为web服务器,fpm做解析。
现象
当下载一个5M大小的图片时,总提示下载失败,或下载下来的文件不完整,仅显示部分图像(每次下载不一样)
php下载相关代码
$file = BASE_PATH . '/public/files/IMG_5727.jpg';
$size = filesize($file);
header( "Content-type: application/octet-stream" );
header("Accept-Ranges: bytes");
header("Accept-Length: {$size}");
header("Content-Disposition: attachment; filename=IMG_5727.jpg");
$fp = fopen($file, 'rb');
$readBuffer = 4096;
while (!feof($fp)) {
echo fread($fp, $readBuffer);
}
fclose($fp);
解决
-
找了一圈后去服务器上查看了nginx日志,确实有报错信息
2020/05/06 13:09:13 [crit] 1482#0: *23258 open() "/aichenk/soft/nginx/fastcgi_temp/4/17/0000000174" failed (13: Permis sion denied) while reading upstream, client: 172.21.0.12, server: 192.168.5.5, request: "GET /temp/t2 HTTP/1.1", upstr eam: "fastcgi://127.0.0.1:9001", host: "192.168.5.5:8080"
-
nginx显示权限问题,最终把nginx运行身份与fpm进行统一
# fpm配置 [www] user = daemon group = daemon # 查看到fpm运行身份为`daemon`,编辑nginx配置设置身份 # nginx配置 #user nobody; user daemon;
-
之前路径归属用户更改
chown -R daemon /aichenk/soft/nginx/fastcgi_temp/
-
测试通过
解释
个人分析这次错误其实是数据放到缓冲区才体现,理论上不光是大文件,数据传输量超过一定值也会有这个问题,在搭建环境的时候注意就可以了