webRtcPingManager.m 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  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. NSString *logstr = [[NSString alloc] initWithFormat:@"ping 结束 当前最佳机房IP:%@--延时:%.02fms",ksharedAppDelegate.bestWebrtcServerModel.turnIp,ksharedAppDelegate.bestWebrtcServerModel.delayedms];
  53. HLog(@"%@",logstr)
  54. [cachesFileManager writeLogsWithMsg:logstr];
  55. NSDictionary *bestdict = [ksharedAppDelegate.bestWebrtcServerModel toDictionary];
  56. if(bestdict){
  57. [HWDataManager setObjectWithKey:@"Const_best_webRtc_IPRoom" value:bestdict];
  58. }
  59. [[webRtcManager shareManager] relinkWebRtcFun];
  60. [[NSNotificationCenter defaultCenter] postNotificationName:didPingBestWebRtcIPRoomNotification object:nil];
  61. return;
  62. }
  63. //IP 出错
  64. if(!roomInternetIp || roomInternetIp.length ==0){
  65. [self startPingNextFun];
  66. return;
  67. }
  68. if (self->whPingTester)
  69. {
  70. [self->whPingTester stopPing];
  71. self->whPingTester = nil;
  72. }
  73. self->whPingTester = [[WHPingTester alloc] initWithHostName:roomInternetIp];
  74. self->whPingTester.delegate = self;
  75. //self->whPingTester.countdownTime = 1; //1秒ping一次
  76. [self->whPingTester startPing];
  77. /// 启动定时器监听 10秒后 whPingTester的状态
  78. KWeakSelf
  79. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  80. if(self->whPingTester){
  81. [weakSelf didGetPingStateIsOK:NO];
  82. }
  83. });
  84. }
  85. #pragma mark ---ping---- 代理回调
  86. - (void)didPingSucccessWithTime:(float)time withError:(NSError*) error
  87. {
  88. HLog(@"time:%f \n error: %@",time,error)
  89. //if(error.code == 111 || time > 1000) //超时或者延时超过100ms,就要记录数据
  90. if(error != nil)
  91. {
  92. pingOneIPErrorNumber += 1;
  93. }
  94. else if(time > 0){
  95. allTimeInPingOneIP += time;
  96. pingOneIPNumber +=1 ;
  97. //[self didGetPingStateIsOK:YES];
  98. //test code
  99. //[self didGetPingStateIsOK:NO];
  100. }
  101. if(pingOneIPErrorNumber >= 3){
  102. [self didGetPingStateIsOK:NO];
  103. }
  104. else if (pingOneIPNumber >= 9){
  105. [self didGetPingStateIsOK:YES];
  106. }
  107. }
  108. - (void)didPingfialewithError:(NSError*)error
  109. {
  110. HLog(@" error error: %@",error)
  111. pingOneIPErrorNumber += 1;
  112. [self didGetPingStateIsOK:NO];
  113. }
  114. -(void)didGetPingStateIsOK:(BOOL)isOk
  115. {
  116. [self->whPingTester stopPing];
  117. self->whPingTester = nil;
  118. if (allTimeInPingOneIP > 0) {
  119. CGFloat averageDelayedms = allTimeInPingOneIP/pingOneIPNumber;
  120. webrtcServerModel*preBestModel = ksharedAppDelegate.bestWebrtcServerModel;
  121. NSArray<webrtcServerModel>* webrtcServerList = ksharedAppDelegate.DeviceWebRtcMsgMod.data.webrtcServerList;
  122. if (!webrtcServerList || webrtcServerList.count > pingRoomIndex) {
  123. webrtcServerModel *model = webrtcServerList[pingRoomIndex];
  124. model.delayedms = averageDelayedms;
  125. NSString *logstr = [[NSString alloc] initWithFormat:@"time: 平均:%f --%@",averageDelayedms,model.turnIp];
  126. HLog(@"%@",logstr)
  127. [cachesFileManager writeLogsWithMsg:logstr];
  128. if([model.turnIp isEqualToString:preBestModel.turnIp]){
  129. preBestModel.delayedms = averageDelayedms;
  130. }
  131. else{
  132. if(preBestModel.delayedms > 0 && model.delayedms < preBestModel.delayedms){
  133. //找到耗时更短的机房
  134. ksharedAppDelegate.bestWebrtcServerModel = model;
  135. }
  136. }
  137. }
  138. }
  139. [self startPingNextFun];
  140. }
  141. @end