- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章python使用epoll实现服务端的方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
如下所示:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
|
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import
socket
import
select
send_data
=
"hello world!"
send_len
=
len
(send_data)
recv_len
=
1024
tcp_socket
=
socket.socket(socket.AF_INET, socket.SOCK_STREAM)
tcp_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR,
1
)
addr
=
(
"0.0.0.0"
,
8765
)
tcp_socket.bind(addr)
tcp_socket.listen(
5
)
tcp_socket.setblocking(
False
)
epoll
=
select.epoll()
'''(边缘触发)select.EPOLLIN | select.EPOLLET'''
epoll.register(tcp_socket.fileno(), select.EPOLLIN)
'''因为epoll返回的触发事件对应的是套接字文件描述符,所以需要在字典中加入对应关系'''
fd_to_socket
=
{tcp_socket.fileno():tcp_socket}
while
True
:
events
=
epoll.poll(
-
1
)
for
fd, event
in
events:
fd_socket
=
fd_to_socket[fd]
if
fd
=
=
tcp_socket.fileno():
while
True
:
try
:
new_socket, new_addr
=
fd_socket.accept()
except
socket.error as e:
(errno, err_msg)
=
e
print
errno
print
err_msg
if
errno
=
=
11
:
break
print
"new accpet:"
, new_addr
new_socket.setblocking(
False
)
new_socket.setsockopt(socket.IPPROTO_TCP, socket.TCP_NODELAY,
1
)
epoll.register(new_socket.fileno(), select.EPOLLIN)
fd_to_socket[new_socket.fileno()]
=
new_socket
elif
event&select.EPOLLIN:
recv_datas
=
[]
recd
=
0
while
(recd < recv_len):
try
:
recv_data
=
fd_socket.recv(recv_len
-
recd)
'''处理读的正常关闭'''
if
recv_data
=
=
"":
print
"close socket"
epoll.unregister(fd)
fd_to_socket[fd].close()
del
fd_to_socket[fd]
break
else
:
recv_datas.append(recv_data)
recd
=
recd
+
len
(recv_data)
'''处理异常关闭(EAGAIN,EINTR)'''
except
socket.error as e:
(errno, err_msg)
=
e
print
errno
print
err_msg
'''因为用的水平触发,EAGAIN我们跳出循环,等待下次触发再读就好了'''
if
errno
=
=
11
:
break
'''软中断打断了还要继续读'''
elif
errno
=
=
4
:
continue
'''其它错误我们直接关闭套接字'''
else
:
print
"close socket"
epoll.unregister(fd)
fd_to_socket[fd].close()
del
fd_to_socket[fd]
break
print
repr
(recv_datas)
total_send
=
0
while
total_send < send_len:
sent
=
fd_socket.send(send_data[total_send:])
if
sent
=
=
0
:
print
"close socket"
epoll.unregister(fd)
fd_to_socket[fd].close()
del
fd_to_socket[fd]
break
else
:
print
repr
(send_data[total_send:])
total_send
=
total_send
+
sent
|
其实这里的异常处理我们也可以用 。
1
2
3
|
except
IOError as e:
print
e.errno
print
e.strerror
|
以上这篇python使用epoll实现服务端的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.
原文链接:https://blog.csdn.net/peng314899581/article/details/78066087 。
最后此篇关于python使用epoll实现服务端的方法的文章就讲到这里了,如果你想了解更多关于python使用epoll实现服务端的方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在使用 epoll 编写媒体服务器。 fds 都设置为非阻塞,我正在使用边缘触发事件。我知道对于 EPOLLIN,我需要循环读取 fd,直到返回 EAGAIN。但是写作呢? 当我想写入时,我将数据
很难说出这里问的是什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或言辞激烈,无法以目前的形式合理回答。如需帮助澄清此问题以便可以重新打开,visit the help center . 8年前关闭
简短的问题,但对我来说很难理解。 为什么 ePoll 的扩展性比 Poll 更好? 最佳答案 poll 系统调用每次都需要将您的文件描述符列表复制到内核。这只会发生一次 epoll_ctl ,但不是每
情况: 多个进程共享同一个文件描述符表。 每个进程监听自己的 epoll 实例。 所有套接字和涉及它们的调用都是非阻塞的。 在这些进程中,只有进程A将监听套接字添加到它的epoll实例。 进程 A 知
我有几个线程,其中一个在循环中调用 epoll_wait,其他线程可以打开需要由第一个线程 epoll 的连接。是否可以只使用 epoll_ctl 添加新套接字,而另一个线程在 epoll_wait
众所周知,我们可以将poll/select与Netmap结合使用:http://info.iet.unipi.it/~luigi/netmap/ 是否可以使用epoll以及将epoll与Netmap一
我正在使用 epoll 和大量 fd 编写应用程序。 为了改进 fd 对应用程序相关 DB 的搜索,我想传递给 epoll 应用程序信息,例如 DB 数组中的索引。 我想过使用data->ptr(ep
我有一个多线程 epoll 服务器。我创建了一个 epoll fd,然后我将让 X 个线程休眠,等待 epoll_wait() 来自 SAME epoll fd 的任何事件。 现在我的问题是:如何唤醒
我有两个线程在 epoll 上运行。一个线程尝试与服务器建立 TCP 连接,使用 EPOLL_CTL_ADD 选项将套接字添加到 epoll-fd。 另一个线程负责等待添加到 epoll-fd 的 S
我正在使用 Cassandra,在启动期间,Netty 会打印一 strip 有堆栈跟踪的警告: Found Netty's native epoll transport in the classpa
epoll_wait、select 和 poll 函数都提供超时。然而使用epoll,其分辨率可达1ms。 Select 和 ppoll 是唯一提供亚毫秒级超时的。 这意味着最好以 1 毫秒的间隔做其
我正在使用 epoll 进行网络编程。我想知道检测用户断开连接的最佳方法。现在,我正在使用带有超时的选择来查看接收缓冲区中是否有信号并且在一定时间内没有信号然后关闭套接字连接。 我认为可能还有其他更适
epoll 是 Linux 系统中常用的多路复用 I/O 组件,一般用于监听 socket 是否能够进行 I/O 操作。那么,epoll 能监听普通文件吗? 我们先通过下面的例子来验证一下,e
我正在使用 epoll 将大消息写入使用 HTTP 协议(protocol)的服务器。 fds 都设置为非阻塞,我正在使用边缘触发事件。我知道对于 EPOLLIN,我需要循环读取 fd,直到返回 EA
我使用python的socket和epoll来制作一个Web服务器。我的操作系统是Linux CentOS 6,我的python版本是python 2.7.8。我的源代码是: # -*-coding:
我的 TCP 服务器中有一个 epoll 事件循环来处理客户端连接并从客户端读取数据。 while(1) { int n, i; n = epoll_wait(efd, events,
我有一个项目,我正在从普通的 select() 转换,但由于我运行的测试有超过 1000 个连接,我决定将其更改为 epoll。 我的代码可以正常工作,但遇到了一个问题,我正在尝试找出解决问题的最佳方
我是 linux 系统编程的新手,所以请多多关照。我必须通过 RS-422 在 8N1 模式下以波特率 921600 从串行端口 (/dev/ttyX) 读取数据,没有奇偶校验。stty 输出信号表示
我从here得到了基础知识关于 epoll。我知道epoll可以监控多个FD并处理。 我的问题是:重事件是否会阻塞服务器,所以我必须使用多线程? 例如,服务器的epoll正在监控2个套接字A和B。现在
我正在使用 epoll 进行网络编程。我想知道如何处理客户端断开连接。我阅读了 api 文档,epoll_wait 有一个超时参数。但是,如果 epoll_wait 函数或正在连接的客户端超时,我会感
我是一名优秀的程序员,十分优秀!