Tracy1997
V2EX  ›  问与答

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

  •  
  •   Tracy1997 · Aug 13, 2019 · 1324 views
    This topic created in 2510 days ago, the information mentioned may be changed or developed.

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

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

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

    Tracy1997
        1
    Tracy1997  
    OP
       Aug 13, 2019
    放在生产环境,难道用 while True 吗。。。
    Cbdy
        2
    Cbdy  
       Aug 13, 2019
    用 Node.js 或 Golang 或 Tokio 或 Vert.x 写一个 TCP Server 完事儿
    tt67wq
        3
    tt67wq  
       Aug 13, 2019
    还是用现有的轮子吧,自己搓,容易有问题
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2899 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 02:33 · PVG 10:33 · LAX 19:33 · JFK 22:33
    ♥ Do have faith in what you're doing.