顾乔芝士网

持续更新的前后端开发技术栈

介绍几种OPTIONS检测的方法



概述

日常的VOIP开发中,OPTIONS检测是常用的网络状态检测工具。

OPTIONS原本是作为获取对方能力的消息,也可以检测当前服务状态。正常情况下,UAS收到OPTIONS心跳,直接回复200即可。

与ping不同的是,OPTIONS检测不仅仅针对网络状态,也针对sip server的端口状态进行检测,在VOIP问题定位中更精准。

环境

CentOS release 7.0 (Final)或以上版本

freeswitch v1.10.7

new bing

sipp.3.6.2

sipexer-v1.1.0-linux-amd64

可选方案

freeswitch自带的OPTIONS检测

python脚本

sipp工具

sipexer工具

freeswitch自带的OPTIONS检测

freeswitch自带的OPTIONS检测可以通过配置gateway网关来启动,也可以针对注册的在线用户设置OPTIONS心跳检测,配置方法简单介绍如下。

gateway网关设置。修改
conf/sip_profile/external/gw-137.xml




针对注册的在线用户设置OPTIONS心跳检测,修改
conf/sip_profile/internal.xml


python脚本

github上很多,缺点是需要自己调试,适配符合的场景模式。

下面的脚本是使用new bing自动生成的脚本,未测试仅供参考。

好的,您可以使用Python内置的SIP库`sip`来发送OPTIONS请求。这个库可以在Python 3.7及以上版本中使用。您可以使用以下代码来实现您的需求:


```python

import sip

import sys


def send_options(remoteip, remoteport):

sip.setapi('sip', 2)

from sip import SIPRequest, SIPResponse

from socket import socket, AF_INET, SOCK_DGRAM

import time


# Check if the IP address is valid

try:

socket(AF_INET, SOCK_DGRAM).connect((remoteip, remoteport))

except OSError:

print("Invalid IP address")

return


# Send OPTIONS request

s = socket(AF_INET, SOCK_DGRAM)

s.settimeout(5)

sip_request = SIPRequest('OPTIONS', 'sip:{}:{};transport=udp'.format(remoteip, remoteport), 'SIP/2.0')

sip_request.add_header('Via', 'SIP/2.0/UDP {}:{};branch=z9hG4bK-{}'.format(s.getsockname()[0], s.getsockname()[1], int(time.time())))

sip_request.add_header('From', ';tag=1234'.format(s.getsockname()[0], s.getsockname()[1]))

sip_request.add_header('To', ''.format(remoteip, remoteport))

sip_request.add_header('Call-ID', '{}@{}'.format(int(time.time()), s.getsockname()[0]))

sip_request.add_header('CSeq', '1 OPTIONS')

sip_request.add_header('Contact', ''.format(s.getsockname()[0], s.getsockname()[1]))

sip_request.add_header('Max-Forwards', '70')

s.sendto(bytes(sip_request), (remoteip, remoteport))


# Receive response

try:

data = s.recv(1024)

response = SIPResponse(data.decode())

print("Response received: {}".format(response.status_code))

print(response.headers)

print(response.body)

except Exception as e:

print("Error receiving response: {}".format(e))

```


其中,`send_options()`函数接受两个参数:`remoteip`和`remoteport`。这个函数会发送一个SIP OPTIONS请求到指定的IP地址和端口,并打印响应消息。如果请求失败,则会打印错误消息。


请注意,在使用此代码之前,请确保您已经安装了Python 3.7或更高版本,并且已经安装了`sip`库。


以上内容为new bing自动生成,未经测试。

sipp脚本

配置sipp号码文件call-test.csv,内容如下。

SEQUENTIAL

123456;13712345678;


增加sipp脚本文件uac-options.xml,内容如下。


<![CDATA[


OPTIONS sip:[remote_ip]:[remote_port] SIP/2.0

Via: SIP/2.0/[transport] [local_ip]:[local_port];branch=[branch]

From: [field0] ;tag=[pid]SIPpTag00[call_number]

To: [field1]

Call-ID: [call_id]

CSeq: 10 OPTIONS

Max-Forwards: 10

Content-Length: 0


]]>






使用sipp命令发起OPTIONS检测

sipp -i 10.55.55.138 -p 6666 -inf call-test.csv -sf uac-options.xml 10.55.55.137:5080 -rp 1000 -r 100 -l 8192 -m 1


可以查看sipp结果是成功或失败。

sipexer

sipexer工具内置OPTIONS功能,只需要简单的参数即可测试。

下载sipexer的发布包,并解压,即可得到sipexer的可执行程序。

wget https://github.com/miconda/sipexer/releases/download/v1.1.0/sipexer-v1.1.0-linux-amd64.tar.gz

tar -zxvf sipexer-v1.1.0-linux-amd64.tar.gz

ll

-rwxr-xr-x. 1 admin admin 8637840 6月 30 16:57 sipexer


测试,从本地发送OPTIONS检测到10.55.55.137:5080。

./sipexer sip:10.55.55.137:5080


[info] [sipexer.go:1578] main.SIPExerDialogLoop(): local socket address: 10.55.55.138:45585 (udp)

[info] [sipexer.go:1579] main.SIPExerDialogLoop(): local via address: 10.55.55.138:45585

[info] [sipexer.go:1580] main.SIPExerDialogLoop(): sending to udp 10.55.55.137:5080: [[---

OPTIONS sip:10.55.55.137:5080 SIP/2.0

Via: SIP/2.0/UDP 10.55.55.138:45585;rport;branch=z9hG4bKSG.29529ee2-2cad-47b6-b68e-d26cdccbc940

From: ;tag=d2c84867-447e-4d94-9216-bfb4c81d7441

To:

Call-ID: 8b74f427-6458-407c-ad80-d52157041eee

CSeq: 596582 OPTIONS

Date: Mon, 03 Jul 2023 13:56:33 CST

User-Agent: SIPExer v1.1.0

Max-Forwards: 10

Content-Length: 0



[info] [sipexer.go:1582] main.SIPExerDialogLoop(): ---]]


[info] [sipexer.go:1633] main.SIPExerDialogLoop(): response-received: from=10.55.55.137:5080 bytes=597 data=[[---

SIP/2.0 200 OK

Via: SIP/2.0/UDP 10.55.55.138:45585;rport=45585;branch=z9hG4bKSG.29529ee2-2cad-47b6-b68e-d26cdccbc940

From: ;tag=d2c84867-447e-4d94-9216-bfb4c81d7441

To: ;tag=5Dta8ca41BQBF

Call-ID: 8b74f427-6458-407c-ad80-d52157041eee

CSeq: 596582 OPTIONS

Contact:

User-Agent: FreeSWITCH-mod_sofia/1.6.19~64bit

Accept: application/sdp

Allow: INVITE, ACK, BYE, CANCEL, OPTIONS, MESSAGE, INFO, UPDATE, REGISTER, REFER, NOTIFY

Supported: timer, path, replaces

Allow-Events: talk, hold, conference, refer

Content-Length: 0



[info] [sipexer.go:1635] main.SIPExerDialogLoop(): ---]]

测试成功,OPTIONS正常收到200 OK响应。

总结

OPTIONS心跳检测在voip的应用过程中还是挺重要的,对于线路和sip应用的正常检测必不可少,配合zabbix等监控平台可以及时有效的发现问题。

不同的工具使用方式各有不同,需要根据实际场景确定。


空空如常

求真得真

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言