记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/
    
  • 测试通过

解释

个人分析这次错误其实是数据放到缓冲区才体现,理论上不光是大文件,数据传输量超过一定值也会有这个问题,在搭建环境的时候注意就可以了

posted @ 2020-05-06 14:08  aiChenK  阅读(645)  评论(0编辑  收藏  举报