เพิ่มการตรวจสอบแบบกำหนดเองสำหรับคำขอเครือข่ายเฉพาะ (แอป Apple และ Android)

การตรวจสอบประสิทธิภาพจะรวบรวม การติดตาม เพื่อช่วยคุณตรวจสอบประสิทธิภาพของแอปของคุณ การติดตามคือรายงานข้อมูลประสิทธิภาพที่บันทึกระหว่างเวลา 2 จุดในแอปของคุณ

การติดตามคำขอเครือข่ายที่รวบรวมโดยอัตโนมัติโดยการตรวจสอบประสิทธิภาพ จะรวมคำขอเครือข่ายส่วนใหญ่สำหรับแอปของคุณ อย่างไรก็ตาม คำขอบางรายการอาจไม่ได้รับการรายงานหรือคุณอาจใช้ไลบรารีอื่นเพื่อส่งคำขอเครือข่าย ในกรณีเหล่านี้ คุณสามารถใช้ Performance Monitoring API เพื่อ ติดตามคำขอเครือข่ายที่กำหนด เองได้ด้วยตนเอง การติดตามคำขอเครือข่ายแบบกำหนดเองรองรับเฉพาะแอป Apple และ Android เท่านั้น

ตัววัดเริ่มต้นสำหรับการติดตามคำขอเครือข่ายแบบกำหนดเองจะเหมือนกับตัววัดสำหรับการติดตามคำขอเครือข่ายที่รวบรวมโดยอัตโนมัติโดยการตรวจสอบประสิทธิภาพ โดยเฉพาะเวลาตอบสนอง ขนาดเพย์โหลดการตอบสนองและคำขอ และอัตราความสำเร็จ การติดตามคำขอเครือข่ายที่กำหนดเองไม่รองรับการเพิ่มเมตริกที่กำหนดเอง

ในโค้ดของคุณ คุณกำหนดจุดเริ่มต้นและจุดสิ้นสุดของการติดตามคำขอเครือข่ายแบบกำหนดเองโดยใช้ API ที่ได้รับจาก Performance Monitoring SDK

การติดตามคำขอเครือข่ายที่กำหนดเองจะปรากฏในคอนโซล Firebase ควบคู่ไปกับคำขอเครือข่ายที่การตรวจสอบประสิทธิภาพจับโดยอัตโนมัติ (ในแท็บย่อย คำขอเครือข่าย ของตารางการติดตาม)

เพิ่มการติดตามคำขอเครือข่ายที่กำหนดเอง

ใช้ Performance Monitoring HTTPMetric API ( Swift | Obj-C ) เพื่อเพิ่มการติดตามคำขอเครือข่ายที่กำหนดเองเพื่อตรวจสอบคำขอเครือข่ายเฉพาะ

เมื่อต้องการใช้คำขอเครือข่ายแบบกำหนดเองด้วยตนเองในการตรวจสอบประสิทธิภาพ ให้เพิ่มโค้ดที่คล้ายกับต่อไปนี้:

สวิฟท์

หมายเหตุ: ผลิตภัณฑ์ 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()

วัตถุประสงค์-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 เฉพาะเจาะจงเกินเกณฑ์ที่คุณตั้งไว้