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
 |
|
1
LGA1150 Jun 1, 2018 via Android
iptables DNAT SNAT
|
 |
|
2
h4lbhg1G Jun 1, 2018
@ LGA1150 #1 如果可能还希望顺便拆包一下这个转发的数据,以及一定功能的统计(多少发布者在线,分别多少接受者)。
|
 |
|
5
Philippa Jun 1, 2018 via Android 1
规则自己写一份简单的协议就可以了, 用协程 + protobuf 写一个。CPU 不够这简单, 加机器, Go 挺适合的。代码量也很少, 部署等都很方便直接, 性能很好。通讯层写好了外面加层你自己喜欢的语言写的业余处理就行了。
|
 |
|
7
ryd994 Jun 2, 2018 via Android
rinetd 要更多功能的话自己写 用 select 写一个,一两百行最多了
|