h4lbhg1G
V2EX  ›  问与答

tcp 数据转发

  •  
  •   h4lbhg1G · Jun 1, 2018 · 2479 views
    This topic created in 2905 days ago, the information mentioned may be changed or developed.
    现在遇到一个需求,需要侦听几十个 tcp 端口,用于接收 tcp 数据,这每个端口都只允许一个发布者;然后也要侦听几十个 tcp 端口用于转发从上面接收端口收到的数据,一个端口允许有多个接受者。接收端口与发布端口之间有对应关系。有点类似主播、直播间的样子。

    请问下大佬们有什么推荐的方案么?目前有一个效率比较低的,就是运行几十次一个转发程序,但是 CPU 很快被占满。

    数据量不大,速率受串口传输速率限制。
    7 replies    2018-06-02 10:12:57 +08:00
    LGA1150
        1
    LGA1150  
       Jun 1, 2018 via Android
    iptables DNAT SNAT
    h4lbhg1G
        2
    h4lbhg1G  
    OP
       Jun 1, 2018
    @LGA1150 #1 如果可能还希望顺便拆包一下这个转发的数据,以及一定功能的统计(多少发布者在线,分别多少接受者)。
    ThirdFlame
        3
    ThirdFlame  
       Jun 1, 2018   ❤️ 1
    socat??
    ThirdFlame
        4
    ThirdFlame  
       Jun 1, 2018
    还要拆包统计的话,那估计只能自己写了。
    Philippa
        5
    Philippa  
       Jun 1, 2018 via Android   ❤️ 1
    规则自己写一份简单的协议就可以了, 用协程 + protobuf 写一个。CPU 不够这简单, 加机器, Go 挺适合的。代码量也很少, 部署等都很方便直接, 性能很好。通讯层写好了外面加层你自己喜欢的语言写的业余处理就行了。
    dushixiang
        6
    dushixiang  
       Jun 1, 2018 via Android   ❤️ 1
    @LGA1150 这不就是 netns 嘛
    ryd994
        7
    ryd994  
       Jun 2, 2018 via Android
    rinetd
    要更多功能的话自己写
    用 select 写一个,一两百行最多了
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   933 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 38ms · UTC 20:01 · PVG 04:01 · LAX 13:01 · JFK 16:01
    ♥ Do have faith in what you're doing.