基于 select+asynico 的基础实现, 上次分享过一个类似的, 这次关注点是 Python 内置包 asynico 是内部是怎么实现这个东西的.

2017-11-02 13:33:47 +08:00
 petelin
基于 select+socket+asynico 的基础实现.

将 asyncio.get_event_loop() 换成自己写的 selfayncio.get_event_loop(), 然后其他调用方法完全一样

每秒能处理 5000 个 index html 请求. ab 并发 2w 没压力, 好像最高只能写-c 20000?


<script src="https://gist.github.com/Petelin/bf2eb99748ce62de0307a0df82077d77.js"></script>
2145 次点击
所在节点    Python
3 条回复
petelin
2017-11-02 13:40:23 +08:00
root@env-pay:~# siege -b -c 200 http://127.0.0.1:8080/
** SIEGE 3.0.8
** Preparing 200 concurrent users for battle.
The server is now under siege...^C
Lifting the server siege... done.

Transactions: 422665 hits
Availability: 100.00 %
Elapsed time: 73.83 secs
Data transferred: 12.50 MB
Response time: 0.03 secs
Transaction rate: 5724.84 trans/sec
Throughput: 0.17 MB/sec
Concurrency: 199.12
Successful transactions: 422665
Failed transactions: 0
Longest transaction: 3.22
Shortest transaction: 0.00
godymho
2017-11-02 21:19:13 +08:00
asynico 跟 多个客户端建立连接之后,服务端如何主动跟客户端发送 tcp 包呢?
petelin
2017-11-02 21:27:52 +08:00
直接创建一个 task, 然后在里面写逻辑就行了,

create_task(muti_handler(client_socket))

更多是通过 epoll 来调度你的服务器处理函数, 想清楚怎么调度就好了...

我写的这个, 就是不管客户端发什么过来, 我都直接 return html, 其实处理逻辑都可以和以前一样的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/402911

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX