-
Notifications
You must be signed in to change notification settings - Fork 2k
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
Feature request: dynamic listen/close socket in lua #1690
Comments
Some additional notes here.
The unix socket doesn't support reuseport, so we can't listen on it like the vanilla TCP address.
If we treat the |
@spacewander Thanks for your suggest.
Thanks for your recommend, we could note this in the README.
I think this should be acceptable? Listen a socket must be occupy the memory until close the socket or Nginx exits.
I didn't realize this problem before, do we have some method to solve it so far? |
So far the solution is to avoid creating too much coroutines in a single request. It is, the user of dynamic listen socket need to avoid creating coroutine per accept, or reuse the coroutines like #1215 suggested. |
I like such new APIs for listening and accepting but I don't like the callback function argument design. It should be a synchronous but still nonblocking method call on the listening socket (also it should return local sock_tcp = require "ngx.socket.tcp"
local listen_sock, err = sock_tcp.listen("127.0.0.1", 5050)
local timeout = 3000 -- 3 seconds
local client_sock, err = listen_sock:accept(timeout)
-- then we can use client_sock like existing cosockets, e.g., client_sock:receive("l") Similarly, for unix domain sockets: local sock_unix = require "ngx.socket.unix"
local listen_sock, err = sock_unix.listen("/path/to/unix.sock")
local timeout = 3000 -- 3 seconds
local client_sock, err = listen_sock:accept(timeout)
-- then we can use client_sock like existing cosockets, e.g., client_sock:receive("l") The client socket objects should follow the same restriction and cleanup semantics of existing cosockets (that is, not exceeding the lifetime of the current request handler or timer handler) so that we can avoid socket leaks by design. The listening sockets can outlive the handler contexts creating them though, otherwise it won't be very useful. To simplify the implementation here, we can simply support listening in workers, which is already very useful and also simpler than handling reuseport, binary upgrade, HUP reload, and etc. |
Yeah, we should avoid creating a new coroutine per |
Hi there,
I think many user need the new feature that we can dynamic listen or close a socket in the lua context, such as the discuss here, or some user' PR #1393 .
About the usage of this function, I have some ideas:
And support close the listen by the address, like this:
ngx.socket.listen
for TCP, will bind, listen and accept a socket, and put the socekt into event list, like ngx_event_accept, and for UDP, will bind and recvmsg for the socket, like [ngx_event_recvmsg], and put the socekt into event list(https://github.com/nginx/nginx/blob/master/src/event/ngx_event_udp.c#L32).This should be like
ngx.timer
, can use in each phase. If run it ininit_by_lua
, all worker will bind same address by reuseport.Different worker can bind same address in different time by reuseport.
When the worker exit, all listen will close automatic.
A new independent phase should be build(like
timer
, maybe name aslua_socket
?), some function, such asngx.req.*
can not be use.The text was updated successfully, but these errors were encountered: