(原创)使用exosip5.0版本实现GB28181中的bug

在使用exosip5.0实现GB28181时碰到了一个问题,描述是这样的,先开下级,等待几分钟之后,在开启上级后,这个时候上级收到下级的注册指令并返回401,这时下级回调上来的response为空,造成下级无法正确的打包授权信息,从而无法正常的注册到上级,另外,会发现下级刚起来时,内存会暴涨,待内存稳定后,CPU占用率就会上升直到占满(绝望的是,这方面居然在网上没有找到任何参考资料,最后还是靠公司的杜神来解决),修改信息如下
eXtl_udp.c
udp_tl_read_message函数中

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 du)remark errno=0 to fixed bug
      if (/*errno==0 ||*/ errno==34) {
        //(2018-11-09 du)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函数中

      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 du)remark errno=0 to fixed bug
      if (/*errno==0 ||*/ errno==34) {
        //(2018-11-09 du)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);
      }
    }

你可能感兴趣的:((原创)使用exosip5.0版本实现GB28181中的bug)