zoukankan      html  css  js  c++  java
  • nginx request_body 为空 没有参数 ;关于client_max_body_size client_body_buffer_size配置

    最近生产环境在这两个参数之间遇到过几次坑。这里记录下。

    client_max_body_size

    client_max_body_size 默认 1M,表示 客户端请求服务器最大允许大小,在“Content-Length”请求头中指定。如果请求的正文数据大于client_max_body_size,HTTP协议会报错 413 Request Entity Too Large。就是说如果请求的正文大于client_max_body_size,一定是失败的。如果需要上传大文件,一定要修改该值。

    client_body_buffer_size

    Nginx分配给请求数据的Buffer大小,如果请求的数据小于client_body_buffer_size直接将数据先在内存中存储。如果请求的值大于client_body_buffer_size小于client_max_body_size,就会将数据先存储到临时文件中,在哪个临时文件中呢?
    client_body_temp 指定的路径中,默认该路径值是/tmp/.
    所以配置的client_body_temp地址,一定让执行的Nginx的用户组有读写权限。否则,当传输的数据大于client_body_buffer_size,写进临时文件失败会报错。
    这个问题我们遇到过。

    20648 open() "/usr/local/openresty-1.9.7.5/nginx/client_body_temp/0000000019" failed (13: Permission denied)
    

    /usr/local/openresty-1.9.7.5/nginx/client_body_temp/这个文件夹权限改为执行Nginx的用户群组就可以解决。
    在这个问题上和语言就相关了,如果使用的是PHP,PHP会自己将临时文件读取出来,放置到请求数据里面,这是没有问题的,开发者也不需要关心。肯定是完整的数据。
    如果使用的openresty lua 开发的话,就需要开发者自己读取出来,让后续的逻辑使用。

                    function getFile(file_name)
                        local f = assert(io.open(file_name, 'r'))
                        local string = f:read("*all")
                        f:close()
                        return string
                    end
    
                    ngx.req.read_body()
                    local data = ngx.req.get_body_data()
                    if nil == data then
                        local file_name = ngx.req.get_body_file()
                        ngx.say(">> temp file: ", file_name)
                        if file_name then
                            data = getFile(file_name)
                        end
                    end
    
                    ngx.say("hello ", data)

    传输的数据大于client_max_body_size,一定是传不成功的。小于client_body_buffer_size直接在内存中高效存储。如果大于client_body_buffer_size小于client_max_body_size会存储临时文件,临时文件一定要有权限。
    如果追求效率,就设置 client_max_body_size client_body_buffer_size相同的值,这样就不会存储临时文件,直接存储在内存了。

  • 相关阅读:
    Spark小课堂Week3 FirstSparkApp(RDD开发)
    Catalyst揭秘 Day5 optimizer解析
    Spark小课堂Week2 Hello Streaming
    Spark小课堂Week1 Hello Spark
    Catalyst揭秘 Day4 analyzer解析
    Catalyst揭秘 Day3 sqlParser解析
    Catalyst揭秘 Day2 Catalyst源码初探
    Catalyst揭秘 Day1 Catalyst本地解析
    java泛型
    java中数组以及集合
  • 原文地址:https://www.cnblogs.com/lgj8/p/13999628.html
Copyright © 2011-2022 走看看