记录使用SOCAT在端口上接收的消息

use*_*937 12 linux bash port tcp socat

我有一个带有开放端口的服务器,每秒接收50到1000条消息.通过消息我的意思是发送一行文本.

基本上我们希望将这些消息记录在每小时(或x分钟)处理的文件中.

我创建了一个bash脚本(见下文),它在后台运行,除非我杀死socat进程(因此我可以将文件进行处理,它可以启动一个新文件),我们会收到一条消息,我确信我们在分裂的第二天就失去了消息,即socat失败了.

DELAY="3600"
while true
do  
    NEXT_STOP=`date +%s --date "$DELAY second"`
    (
        while [ "$(date +%s)" -lt "$NEXT_STOP" ]
        do
            killall socat
            socat -u TCP-LISTEN:6116,reuseaddr,keepalive,rcvbuf=131071,reuseaddr OPEN:/var/ais/out_v4.txt,creat,append
        done
    ) & sleep $DELAY ; killall socat

    mv /var/ais/out_v4.txt "/var/ais/_socat_received/"$(date +"%Y-%m-%d-%T")"__out_v4.txt"
done
Run Code Online (Sandbox Code Playgroud)

有办法:

  1. 让socat旋转其输出文件而不会终止进程
  2. 或者我们可以在SOCAT写入文件时清除文件的内容.例如,将前10000行剪切成另一个文件,因此输出文件仍然是可管理的大小?

提前谢谢了

use*_*937 5

对于感兴趣的任何人,最终解决方案如下所示,与下面的Nicholas解决方案的主要区别在于,我需要grep socat进程的PID,而不是使用$ ?:

#!/bin/bash
DELAY=600
SOCAT_PID=$(/bin/ps -eo pid,args | grep "socat -u TCP-LISTEN:12456" | grep -v grep | awk '{ print $1 }')

while `kill -0 $SOCAT_PID`
do  
  touch /var/ais/out.txt
  NEXT_STOP=`date +%s --date "$DELAY second"`
  while  `kill -0 $SOCAT_PID` && [ "$(date +%s)" -lt "$NEXT_STOP" ]
  do
    head -q - >> /var/ais/out.txt
  done
  mv /var/ais/out.txt "/var/ais/_socat_received/"$(date +"%Y-%m-%d-%T")"__out.txt"
done
Run Code Online (Sandbox Code Playgroud)

另外,在无限的while循环中添加启动脚本,以便当客户端断开连接时,我们重新启动socat并等待下一次连接尝试:

while true
do
socat -u TCP-LISTEN:12456,keepalive,reuseaddr,rcvbuf=131071 STDOUT | /var/ais/socat_write.sh
done
Run Code Online (Sandbox Code Playgroud)