Home > Article > Backend Development > Introduction to epoll about python network programming learning IO multiplexing
What is epoll? In network programming in linux, select has been used for event triggering for a long time. In the new Linux kernel, there is a mechanism to replace it, which is epoll. Of course, this is not unique to the 2.6 kernel, it was introduced in the 2.5.44 kernel (epoll(4) is a new API introduced in Linux kernel 2.5.44) , it has almost all the advantages mentioned before, and is recognized as the best-performing multiplexed I/O ready notification method under Linux2.6.
Compared with select, the biggest advantage of epoll is that it will not reduce efficiency as the number of listening fds increases. Because in the select implementation in the kernel, it is processed by polling. The more fds polled, the more time it will take.
epoll also only notifies those ready file descriptors, and when we call epoll_wait() to obtain a ready file descriptor, what is returned is not the actual descriptor, but A value representing the number of ready descriptors. You only need to obtain the corresponding number of file descriptors in sequence from an array specified by epoll. Memory mapping (mmap) technology is also used here, so that it is completely This eliminates the overhead of copying these file descriptors during system calls.
Another essential improvement is that epoll adopts an event-based readiness notification method. In select/poll, the kernel scans all monitored file descriptors only after the process calls a certain method, while epoll registers a file descriptor through epoll_ctl() in advance. Once a certain file descriptor is ready, , the kernel will use a callback-like mechanism to quickly activate this file descriptor, and will be notified when the process calls epoll_wait().
As can be seen from the above, epoll is an improvement on the select and poll models, which improves the performance of network programming and is widely used in large-scale concurrent requests. In C/S architecture.
2. Schematic diagram
3. General steps
——Create 1 epollObjectTell the epoll object to monitor specific events on specific sockets——Tell the epoll object to monitor specific events on the specified socket
Ask the epoll object which sockets may have had the specified event since the last query——Ask the epoll object, which sockets have had the specified event since the last query
Perform some
actionon those sockets—— Perform some operations on these socketsTell the epoll object to modify the
listof sockets and/or events to monitor——Tell the epoll object to modify the socket list and/or events, and MonitorRepeat steps 3 through 5 until finished——Repeat steps 3-5 until finished
Destroy the epoll object——Destroy the epoll object
4, related usage
epoll = select.epoll() creates an epoll object
epoll.register(file handle, event type) registers the file handle to be monitored and Event
Event type:
select.EPOLLIN Readable event
select.EPOLLOUT Writable event
select.EPOLLERR Error event
Select.EPOLLHUP Client disconnect event
epoll.unregister(file handle) Destroy file handle
epoll.poll(timeout) When the file handle changes, it will be automatically displayed in the form of a list Report to the user process, timeout
is the timeout, the default -1, that is, wait until the file handle changes. If there is no change, it will return empty
epoll.fileno() Returns the epoll control file descriptor (
Returnthe epoll control file descriptor)
The above is the detailed content of Introduction to epoll about python network programming learning IO multiplexing. For more information, please follow other related articles on the PHP Chinese website!