当有来电时,我的 voip 电话适配器会生成一个日志条目。我设法将它转发到我本地 ubuntu 机器的系统日志,到一个名为 /var/log/linksys.log 的文件。
现在我想用它作为即时来电显示。重要的行包括字符串“INVITE sip”,所以我尝试了:
tail /var/log/linksys.log -f | grep "INVITE sip"
但这带来了整条线。我只对来电者姓名和电话的部分感兴趣,在字符串“From:”和它之后的第一个@符号之间。
我的目标是能够使用 tail -f 或类似命令(也尝试过 multitail)跟踪文件,但只有在将新的相关行添加到日志时才显示名称和电话号码。(日志也收到其他行)
这是一个示例行:
Apr 8 01:06:10 INVITE sip: 999999@192.168.0.102:5060 SIP/2.0#015#012Via: SIP/2.0/UDP 111.111.11.111:5060;branch=z9hG4bK5f142476;rport#015#012From: "SMITHSON D" <sip:8885551234@111.111.11.111>;tag=as410515ed#015#012To: <sip:999999@192.168.0.102:5060>#015#012Contact: <sip:8885551234@111.111.11.111>#015#012Call-ID: 50354db42555555555aab68633cbb2e4@111.111.11.111#015#012CSeq: 102 INVITE#015#012User-Agent: VoIPMS/SERAST#015#012Max-Forwards: 70#015#012Remote-Party-ID: "SMITHSON D" <sip:8885551234@111.111.11.111>;privacy=off;screen=no#015#012Date: Sun, 08 Apr 2012 05:06:10 GMT#015#012Allow: INVITE, ACK, CANCEL, OPTIONS, BYE, REFER, SUBSCRIBE, NOTIFY, INFO#015#012Supported: replaces#015#012Content-Type: application/sdp#015#012Content-Length: 291#015#012#015#012v=0#015#012o=root 18702 18702 IN IP4 111.111.11.111#015#012s=session#015#012c=IN IP4 111.111.11.111#015#012t=0 0#015#012m=audio 33100 RTP/AVP 0 18 101#015#012a=rtpmap:0 PCMU/8000#015#012a=rtpmap:18 G729/8000#015#012a=fmtp:18 annexb=no#015#012a=rtpmap:101 telephone-event/8000#015#012a=fmtp:101 0-16#015#012a=silenceSupp:off - - - -#015#012a=ptime:20#015#012a=sendrecv#015
非常感谢您的帮助...