原文地址:https://lydit.github.io/
在使用exosip5.0实现GB28181时碰到了一个问题,描述是这样的,先开下级,等待几分钟之后,在开启上级后,这个时候上级收到下级的注册指令并返回401,这时下级回调上来的response为空,造成下级无法正确的打包授权信息,从而无法正常的注册到上级,另外,会发现下级刚起来时,内存会暴涨,待内存稳定后,CPU占用率就会上升直到占满(绝望的是,这方面居然在网上没有找到任何参考资料,最后还是靠公司的杜神来解决),修改信息如下
eXtl_udp.c
udp_tl_read_message函数中1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22else if (i < 0) {
#ifdef _WIN32_WCE
int my_errno = 0;
#else
int my_errno = errno;
#endif
OSIP_TRACE (osip_trace (__FILE__, __LINE__, OSIP_ERROR, NULL, "Could not read socket (%i) (%i) (%s)\n", i, my_errno, strerror (my_errno)));
//(2018-11-09 duwenyong)remark errno=0 to fixed bug
if (/*errno==0 ||*/ errno==34) {
//(2018-11-09 duwenyong)add to fixed bug
printf("errno=%d udp_message_max_length=%d\n",errno, udp_message_max_length);
if(udp_message_max_length<64*1024 )
{
udp_message_max_length = udp_message_max_length*2;
osip_free(reserved->buf);
reserved->buf = (char *) osip_malloc (udp_message_max_length * sizeof (char) + 1);
}
}
if (my_errno == 57) {
_udp_tl_reset (excontext);
}
}
udp_tl_read_message函数中1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 else if (i < 0) {
#ifdef _WIN32_WCE
int my_errno = 0;
#else
int my_errno = errno;
#endif
OSIP_TRACE (osip_trace (__FILE__, __LINE__, OSIP_ERROR, NULL, "Could not read socket (%i) (%i) (%s)\n", i, my_errno, strerror (my_errno)));
//(2018-11-09 duwenyong)remark errno=0 to fixed bug
if (/*errno==0 ||*/ errno==34) {
//(2018-11-09 duwenyong)add to fixed bug
printf("errno=%d udp_message_max_length=%d\n",errno, udp_message_max_length);
if(udp_message_max_length<64*1024 )
{
udp_message_max_length = udp_message_max_length*2;
osip_free(reserved->buf);
reserved->buf = (char *) osip_malloc (udp_message_max_length * sizeof (char) + 1);
}
}
if (my_errno == 57) {
_udp_tl_reset_oc (excontext);
}
}