Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Set_keepalive alway return "closed while sending to client" #323

Open
SandraWang-SH opened this issue Oct 30, 2024 · 0 comments
Open

Set_keepalive alway return "closed while sending to client" #323

SandraWang-SH opened this issue Oct 30, 2024 · 0 comments

Comments

@SandraWang-SH
Copy link

SandraWang-SH commented Oct 30, 2024

We plan to use Lua code blocks to call external services to record some logs in Nginx services, But the pressure test found poor performance and high latency.

I found that http.set_keepalive has error response and keepalive is not taking effect. I have pasted some code as follow, could you please help me analyze it?

Error response:
*1375 [lua] content_by_lua(nginx.conf:97):27: failed to set keepalive: closed while sending to client, client: 192.168.71.11, server: _, request: "POST /v2/models/aiml_model/infer HTTP/1.1", host: "aiplatform.dev51.cbf.dev.paypalinc.com-shadow"

`

   location / {
        mirror /mirror1;
        resolver 192.168.36.10 valid=10s;
        proxy_pass  http://backends;
        proxy_method $request_method;
        mirror_request_body on;
        proxy_pass_request_body on;

        proxy_set_header Host $host:$server_port;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Real-PORT $remote_port;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        content_by_lua_block {
            local http = require "resty.http"
            local ngx_log = ngx.log
            local ngx_ERR = ngx.ERR
            local httpc = http.new()
            httpc:set_timeout(5000)

            local url = "https://aiplatform.dev52.cbf.dev.paypalinc.com/bizlogging/insert?model_id=model_id"
            local body = '{"metadata_schema": ["request_body"],"variable_schema": ["response_body"]}'
            local headers = {
                ["Content-Type"] = "application/json",
                ["accept"] = "*/*",
            }

           local res, err = httpc:request_uri(url, {
               method = "POST",
               body = body,
               headers = headers,
               ssl_verify = false,
               timeout = 1000,
           })

           ngx_log(ngx_ERR, "success to request: ", res.status)

            local ok, err1 = httpc:set_keepalive(60000, 100)
            if not ok then
                ngx_log(ngx_ERR, "failed to set keepalive: ", err1)
            end
        }
    }`
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant