mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
net.http: Send entire HTTP request header as one write
When opportunistic writes are enabled this reduces the number of syscalls and TCP packets sent on the wire. Experiments with TCP Fast Open made this even more obvious. That table trick probably wasn't as efficient. Lua generates bytecode for a table with zero array slots and space for two entries in the hash part, plus code to set [2] and [4]. I didn't verify but I suspect it would have had to resize the table when setting [1] and [3], although probably only once. Concatenating the strings directly in Lua is easier to read and involves no extra table or function call.
This commit is contained in:
parent
b40b79873c
commit
3faf5009d9
1 changed files with 3 additions and 5 deletions
|
@ -164,13 +164,11 @@ function listener.onconnect(conn)
|
|||
t_insert(request_line, 4, "?"..req.query);
|
||||
end
|
||||
|
||||
conn:write(t_concat(request_line));
|
||||
local t = { [2] = ": ", [4] = "\r\n" };
|
||||
for k, v in pairs(req.headers) do
|
||||
t[1], t[3] = k, v;
|
||||
conn:write(t_concat(t));
|
||||
t_insert(request_line, k .. ": " .. v .. "\r\n");
|
||||
end
|
||||
conn:write("\r\n");
|
||||
t_insert(request_line, "\r\n")
|
||||
conn:write(t_concat(request_line));
|
||||
|
||||
if req.body then
|
||||
conn:write(req.body);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue