关于 Tcp 服务器编写的一些问题, io 多路复用?多线程?数据库?

2019-08-13 11:11:50 +08:00
 Tracy1997

需求:
会有大概小几千台机器跟服务器 tcp 长链接,大概每台机器每秒发一个数据过来。然后把这个数据处理下保存到数据库中。

想法:
1.因为都是长连接一直比较活跃,想着用 io 多路复用的 select 或者 poll,不知道是否可行? 2.或者用多线程的模式,每个请求过来就开个线程(socket 的 accept 和 recv 都是堵塞的)去处理? 3.目前来说不想每次拿到数据就去存一下这样给数据库压力太大,而是大概拿到个一百条再去 commit 到数据库,不知道还有没有更好的方式?

不知道大家有没有什么其他的方法去实现?如果我的想法很蠢,请务必狠狠的喷我!我太想进步了。

803 次点击
所在节点    问与答
3 条回复
Tracy1997
2019-08-13 11:29:20 +08:00
放在生产环境,难道用 while True 吗。。。
Cbdy
2019-08-13 12:38:16 +08:00
用 Node.js 或 Golang 或 Tokio 或 Vert.x 写一个 TCP Server 完事儿
tt67wq
2019-08-13 13:59:32 +08:00
还是用现有的轮子吧,自己搓,容易有问题

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

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

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

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

© 2021 V2EX