需求:
会有大概小几千台机器跟服务器 tcp 长链接,大概每台机器每秒发一个数据过来。然后把这个数据处理下保存到数据库中。
想法:
1.因为都是长连接一直比较活跃,想着用 io 多路复用的 select 或者 poll,不知道是否可行?
2.或者用多线程的模式,每个请求过来就开个线程(socket 的 accept 和 recv 都是堵塞的)去处理?
3.目前来说不想每次拿到数据就去存一下这样给数据库压力太大,而是大概拿到个一百条再去 commit 到数据库,不知道还有没有更好的方式?
不知道大家有没有什么其他的方法去实现?如果我的想法很蠢,请务必狠狠的喷我!我太想进步了。
1
Tracy1997 OP 放在生产环境,难道用 while True 吗。。。
|
2
Cbdy 2019-08-13 12:38:16 +08:00
用 Node.js 或 Golang 或 Tokio 或 Vert.x 写一个 TCP Server 完事儿
|
3
tt67wq 2019-08-13 13:59:32 +08:00
还是用现有的轮子吧,自己搓,容易有问题
|