webRtcPingManager.m 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. //
  2. // webRtcPingManager.m
  3. // 双子星云手机
  4. //
  5. // Created by xd h on 2024/12/24.
  6. //
  7. #import "webRtcPingManager.h"
  8. #import "WHPingTester.h"
  9. @interface webRtcPingManager ()<WHPingDelegate>
  10. {
  11. WHPingTester *whPingTester;
  12. NSInteger pingRoomIndex;//开始ping的第x个机房IP
  13. CGFloat allTimeInPingOneIP;//一个IP ping多少次的总延时
  14. NSInteger pingOneIPNumber;//一个IPping多少次
  15. NSInteger pingOneIPErrorNumber;//一个IP 错了多少次
  16. }
  17. @end
  18. @implementation webRtcPingManager
  19. + (instancetype)shareManager {
  20. static webRtcPingManager *_instance;
  21. static dispatch_once_t onceToken;
  22. dispatch_once(&onceToken, ^{
  23. _instance = [[self alloc] init];
  24. });
  25. return _instance;
  26. }
  27. - (instancetype)init {
  28. if (self = [super init]) {
  29. pingRoomIndex = 0;
  30. //[self registeNotification];
  31. }
  32. return self;
  33. }
  34. - (void)startPingNextFun
  35. {
  36. pingRoomIndex++;
  37. [self startPingFun];
  38. }
  39. #pragma mark ---ping-----站点 判断是否是局域网
  40. - (void)startPingFun
  41. {
  42. allTimeInPingOneIP = 0;
  43. pingOneIPNumber = 0;
  44. pingOneIPErrorNumber = 0;
  45. NSString* roomInternetIp = @"";
  46. NSArray<webrtcServerModel>* webrtcServerList = ksharedAppDelegate.DeviceWebRtcMsgMod.data.webrtcServerList;
  47. if (!webrtcServerList || webrtcServerList.count > pingRoomIndex) {
  48. webrtcServerModel *model = webrtcServerList[pingRoomIndex];
  49. roomInternetIp = model.turnIp;
  50. }
  51. else{//完成遍历了
  52. return;
  53. }
  54. //IP 出错
  55. if(!roomInternetIp || roomInternetIp.length ==0){
  56. [self startPingNextFun];
  57. return;
  58. }
  59. if (self->whPingTester)
  60. {
  61. [self->whPingTester stopPing];
  62. self->whPingTester = nil;
  63. }
  64. self->whPingTester = [[WHPingTester alloc] initWithHostName:roomInternetIp];
  65. self->whPingTester.delegate = self;
  66. //self->whPingTester.countdownTime = 1; //1秒ping一次
  67. [self->whPingTester startPing];
  68. /// 启动定时器监听 10秒后 whPingTester的状态
  69. KWeakSelf
  70. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  71. if(self->whPingTester){
  72. [weakSelf didGetPingStateIsOK:NO];
  73. }
  74. });
  75. }
  76. #pragma mark ---ping---- 代理回调
  77. - (void)didPingSucccessWithTime:(float)time withError:(NSError*) error
  78. {
  79. HLog(@"time:%f \n error: %@",time,error)
  80. //if(error.code == 111 || time > 1000) //超时或者延时超过100ms,就要记录数据
  81. if(error != nil)
  82. {
  83. pingOneIPErrorNumber += 1;
  84. }
  85. else if(time > 0){
  86. allTimeInPingOneIP += time;
  87. pingOneIPNumber +=1 ;
  88. //[self didGetPingStateIsOK:YES];
  89. //test code
  90. //[self didGetPingStateIsOK:NO];
  91. }
  92. if(pingOneIPErrorNumber >= 3){
  93. [self didGetPingStateIsOK:NO];
  94. }
  95. else if (pingOneIPNumber >= 9){
  96. [self didGetPingStateIsOK:YES];
  97. }
  98. }
  99. - (void)didPingfialewithError:(NSError*)error
  100. {
  101. HLog(@" error error: %@",error)
  102. pingOneIPErrorNumber += 1;
  103. [self didGetPingStateIsOK:NO];
  104. }
  105. -(void)didGetPingStateIsOK:(BOOL)isOk
  106. {
  107. [self->whPingTester stopPing];
  108. self->whPingTester = nil;
  109. if (allTimeInPingOneIP > 0) {
  110. CGFloat averageDelayedms = allTimeInPingOneIP/pingOneIPNumber;
  111. webrtcServerModel*preBestModel = ksharedAppDelegate.DeviceWebRtcMsgMod;
  112. NSArray<webrtcServerModel>* webrtcServerList = ksharedAppDelegate.DeviceWebRtcMsgMod.data.webrtcServerList;
  113. if (!webrtcServerList || webrtcServerList.count > pingRoomIndex) {
  114. webrtcServerModel *model = webrtcServerList[pingRoomIndex];
  115. model.delayedms = averageDelayedms;
  116. if([model.turnIp isEqualToString:preBestModel.turnIp];)
  117. }
  118. }
  119. }
  120. @end