إضافة مراقبة مخصّصة لطلبات الشبكة المحدّدة (تطبيقات Apple وAndroid)

تجمع ميزة "مراقبة الأداء" تتبُّع الأداء لمساعدتك في تتبُّع أداء تطبيقك. حاسمة trace هو تقرير لبيانات الأداء التي تم تسجيلها بين نقطتين زمنيتين في تطبيقك.

تشير رسالة الأشكال البيانية تتبُّع طلبات الشبكة التي يتم جمعها تلقائيًا من خلال "مراقبة الأداء" تتضمّن معظم طلبات الشبكة لتطبيقك. ومع ذلك، قد لا يتم تنفيذ بعض الطلبات الإبلاغ عنه، أو يمكنك استخدام مكتبة مختلفة لتقديم طلبات الشبكة. في هذه يمكنك استخدام Performance Monitoring API لضبط تتبُّع طلبات الشبكة المخصّصة: تتبعات طلبات الشبكة المخصصة فقط متوافقة مع تطبيقات Apple وAndroid.

تكون المقاييس التلقائية لتتبُّع طلبات الشبكة المخصَّصة هي نفسها المقاييس الخاصة تتبع طلبات الشبكة التي يتم جمعها تلقائيًا بواسطة أداة مراقبة الأداء، وتحديدًا ووقت الاستجابة وحجم حمولة الطلب والاستجابة للطلب ومعدل النجاح. مُخَصَّصْ لا تتيح عمليات تتبع طلبات الشبكة إضافة المقاييس المخصصة.

تُحدِّد بداية طلب الشبكة المخصَّصة ونهايته في الرمز البرمجي. باستخدام واجهات برمجة التطبيقات التي توفرها حزمة "SDK لمراقبة الأداء".

تظهر عمليات تتبُّع طلبات الشبكة المخصّصة في وحدة تحكُّم Firebase بجانب طلبات الشبكة التي تلتقطها "مراقبة الأداء" تلقائيًا (في علامة التبويب الفرعية طلبات الشبكة ضمن جدول بيانات التتبُّع).

إضافة عمليات تتبع طلبات الشبكة المخصصة

استخدام واجهة برمجة التطبيقات Performance Monitoring HTTPMetric API (سويفت | Obj-C) إضافة عمليات تتبع طلبات شبكة مخصصة لمراقبة طلبات شبكة معينة.

لمعالجة طلبات الشبكة المخصصة يدويًا في "مراقبة الأداء"، أضف رمزًا مشابهًا إلى ما يلي:

Swift

ملاحظة: لا يتوفّر منتج Firebase هذا على أنظمة التشغيل macOS وMac Catalyst وwatchOS.
guard let metric = HTTPMetric(url: "https://www.google.com", httpMethod: .get) else { return }

metric.start()
guard let url = URL(string: "https://www.google.com") else { return }
let request: URLRequest = URLRequest(url:url)
let session = URLSession(configuration: .default)
let dataTask = session.dataTask(with: request) { (urlData, response, error) in
        if let httpResponse = response as? HTTPURLResponse {
         metric.responseCode = httpResponse.statusCode
        }
        metric.stop()
}
dataTask.resume()

Objective-C

ملاحظة: لا يتوفّر منتج Firebase هذا على أنظمة التشغيل macOS وMac Catalyst وwatchOS.
@property (nonatomic) FIRHTTPMetric *metric;

- (void)beginManualNetworkInstrumentation {
  self.metric =
      [[FIRHttpMetric alloc] initWithURL:[NSURL URLWithString:@"https://www.google.com"]
                              HTTPMethod:FIRHTTPMethodGET];

  [self.metric start];

  NSURLRequest *request =
      [NSURLRequest requestWithURL:[NSURL URLWithString:@"https://www.google.com"]];
  NSURLConnection *connection = [[NSURLConnection alloc] initWithRequest:request
                                                                delegate:self];
  [connection resume];
}

- (void)connection:(NSURLConnection *)connection
    didReceiveResponse:(NSURLResponse *) response {
  NSHTTPURLResponse* httpResponse = (NSHTTPURLResponse*)response
  self.metric.responseCode = httpResponse.statusCode;
  [self.metric stop];
}

تتيح عمليات تتبُّع طلبات الشبكة المخصّصة أيضًا إضافة سمات مخصّصة. (Swift | Obj-C) ولكن ليس مقاييس مخصّصة.

الخطوات التالية

  • إعداد التنبيهات لطلبات الشبكة المتراجعة لأداء تطبيقك. على سبيل المثال، يمكنك ضبط تنبيه بريد إلكتروني لما يلي: إذا تجاوز وقت الاستجابة لنمط عنوان URL معيّن الذي تضعه أنت.