外部数据提供者与我们的其中一台服务器建立 tcp 连接。
我想使用 socat 来“多路复用”传入的数据,以便多个程序可以接收从外部数据提供者发送的数据。
socat -u TCP4-LISTEN:42000,reuseaddr,fork OPEN:/home/me/my.log,creat,append
愉快地接受传入的数据并将其放入文件中。
我想做的是允许本地程序连接到 TCP 端口并开始接收从连接到外部端口的数据。我试过
socat -u TCP4-LISTEN:42000,reuseaddr,fork TCP4-LISTEN:43000,reuseaddr
但这不起作用。我无法在 socat doco 中找到任何与背靠背 TCP 服务器相关的示例。
有人可以指出我正确的方向吗?
最佳答案
使用 Bash 进程替换
通常可以使用 coreutils tee
实现来自 shell 的多路复用。和 Bash process-substitution .例如,要将 socat-stream 多路复用到多个管道,请执行以下操作:
socat -u tcp-l:42000,fork,reuseaddr system:'bash -c \"tee >(sed s/foo/bar/ > a) >(cat > b) > /dev/null\"'
现在如果您发送 foobar
到服务器:socat - tcp:localhost:42000 <<<fobar
文件 a
和 b
将包含:一种
barbar
乙
foobar
使用命名管道
如果管道很复杂和/或您想避免使用 Bash,您可以使用命名管道来提高可读性和可移植性:
mkfifo x y
创建读取器进程:sed s/foo/bar/ x > a &
cat y > b &
启动服务器:socat -u tcp-l:42000,fork,reuseaddr system:'tee x y > /dev/null'
再次发送 foobar
到服务器:echo foobar | socat - tcp:localhost:42000
结果和上面一样。
关于socat - 使用 socat 复用传入的 tcp 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17480967/