นี่คือเวิร์กโฟลว์ที่แนะนำในการยืนยันประสิทธิภาพของการอัปโหลดเหตุการณ์และกลุ่มเป้าหมาย รวมถึงระบุปัญหาเกี่ยวกับข้อมูล
ออกคำขอเพื่อส่งกิจกรรม หรือส่งหรือนำสมาชิกในกลุ่มเป้าหมายออก
ตรวจสอบสถานะโดยรวมของคำขอแต่ละรายการ คำขอที่สำเร็จจะมี
Statusโดยมีcodeเท่ากับ0(ค่า enumOK, การตอบกลับ HTTP200 OK) และแสดงผลIngestEventsResponse,IngestAudienceMembersResponseหรือRemoveAudienceMembersResponseหากคำขอไม่สำเร็จ ให้แก้ไขคำขอเพื่อแก้ไขข้อผิดพลาด แล้วส่งคำขออีกครั้ง
หากคำขอสำเร็จ ให้บันทึก
request_idของการตอบกลับเพื่อให้คุณใช้ดึงข้อมูลการวินิจฉัยในขั้นตอนถัดไปได้รอ 30 นาที แล้วส่ง
RetrieveRequestStatusคำขอสำหรับแต่ละrequest_idที่สำเร็จทำขั้นตอนนี้ซ้ำเป็นระยะๆ สำหรับแต่ละ
request_idจนกว่าสถานะ ปลายทางของแต่ละปลายทางจะถึงSUCCESS,PARTIAL_SUCCESSหรือFAILUREใช้อัลกอริทึม Exponential Backoff เพื่อรอระหว่างคำขอแต่ละรายการตรวจสอบ
RetrieveRequestStatusResponseแต่ละรายการเพื่อยืนยัน ว่าการอัปโหลดทำงานได้อย่างถูกต้องและระบุปัญหาเกี่ยวกับข้อมูลแก้ไขปัญหาเกี่ยวกับข้อมูล
กลับไปที่ขั้นตอนที่ 1 แล้วทำซ้ำจนกว่าจะแก้ไขปัญหาทั้งหมดเกี่ยวกับการอัปโหลด
ส่งคำขอ
RetrieveRequestStatusRequest ต้องมีค่า request_id เดียว ส่งคำขอสถานะแยกต่างหากสำหรับรหัสคำขอแต่ละรายการที่คุณ
บันทึกจากคำขอการส่งผ่านข้อมูลที่สำเร็จ
ส่ง RetrieveRequestStatusRequest เป็นระยะๆ
โดยใช้อัลกอริทึม Exponential Backoff จนกว่า request_status จะถึง
SUCCESS, FAILURE หรือ PARTIAL_SUCCESS สําหรับปลายทางทุกแห่งในคําขอ
เดิม การดำเนินการนี้อาจใช้เวลาถึง 24 ชั่วโมง แม้ว่า Data Manager API อาจประมวลผลคำขอบางรายการเสร็จภายในเวลาเพียง 30 นาที
ตัวอย่างการกำหนดค่าเวลาในการรอเริ่มต้นที่เหมาะสมและการกำหนดค่าการลองใหม่ ซึ่งจะช่วยรักษาสถานะการทำงานและโควต้าการใช้งานให้สมดุลมีดังนี้
| การตั้งค่า | ค่า |
|---|---|
| เวลารอก่อนคำขอการวินิจฉัยแรก (นาที) | 30 |
| ตัวคูณ Backoff | 1.3 |
| Backoff สูงสุด (นาที) | 60 (1 ชั่วโมง) |
| เวลารวมสูงสุด (นาที) | 1440 (24 ชั่วโมง) |
ต่อไปนี้คือลำดับคำขอและเวลาที่ผ่านไปด้วยการกำหนดค่านี้
กราฟของฟังก์ชัน

ข้อมูล
| ความพยายาม | เวลาตั้งแต่ส่งคำขอส่งผ่านข้อมูล (hh:mm) | หน่วงเวลาก่อนพยายาม | หมายเหตุ |
|---|---|---|---|
| 1 | 00:30 | 30.0 นาที | ก่อนอื่นให้ตรวจสอบความพร้อมใช้งานของสถานะ |
| 2 | 01:09 | 39.0 นาที | |
| 3 | 01:59 | 50.7 นาที | |
| 4 | 02:59 | 60.0 นาที | ตอนนี้การหน่วงเวลาจะจำกัดไว้ที่ 1 ชั่วโมง |
| 5 | 03:59 | 60.0 นาที | |
| 6 | 04:59 | 60.0 นาที | |
| 7 | 05:59 | 60.0 นาที | |
| 8 | 06:59 | 60.0 นาที | |
| 9 | 07:59 | 60.0 นาที | |
| 10 | 08:59 | 60.0 นาที | |
| 11 | 09:59 | 60.0 นาที | |
| 12 | 10:59 | 60.0 นาที | |
| 13 | 11:59 | 60.0 นาที | เครื่องหมาย 12 ชั่วโมง |
| 14 | 12:59 | 60.0 นาที | |
| 15 | 13:59 | 60.0 นาที | |
| 16 | 14:59 | 60.0 นาที | |
| 17 | 15:59 | 60.0 นาที | |
| 18 | 16:59 | 60.0 นาที | |
| 19 | 17:59 | 60.0 นาที | |
| 20 | 18:59 | 60.0 นาที | |
| 21 | 19:59 | 60.0 นาที | |
| 22 | 20:59 | 60.0 นาที | |
| 23 | 21:59 | 60.0 นาที | |
| 24 | 22:59 | 60.0 นาที | |
| 25 | 23:59 | 60.0 นาที | คำขอสุดท้ายก่อนถึงเวลาสูงสุดรวม 24 ชั่วโมง |
เพิ่มJitter จำนวนเล็กน้อยแบบสุ่มลงใน การหน่วงเวลา Backoff เพื่อป้องกันปัญหา "Thundering Herd" ที่ไคลเอ็นต์จำนวนมากพยายามอีกครั้ง พร้อมกัน
ตรวจสอบคำตอบ
request_status_per_destination ใน RetrieveRequestStatusResponse มีรายการแยกต่างหากสำหรับ
แต่ละปลายทางในคำขอส่งผ่านข้อมูลที่เกี่ยวข้อง
เช่น หาก IngestAudienceMembersRequest
มีรายการ 3 รายการในรายการ destinations เพื่อส่งข้อมูลไปยังกลุ่มเป้าหมาย 3 กลุ่มที่แตกต่างกัน
การตอบกลับสถานะจะมีรายการ 3 รายการใน request_status_per_destination (1 รายการต่อกลุ่มเป้าหมาย)
ตรวจสอบสถานะปลายทางโดยรวม
ขั้นตอนแรก ให้ตรวจสอบฟิลด์ request_status เพื่อดูว่า Data Manager API ประมวลผลข้อมูลสำหรับ destination ของ RequestStatusPerDestination เสร็จแล้วหรือไม่
ค่าที่เป็นไปได้ของ request_status มีดังนี้
PROCESSING: ระบบยังคงประมวลผลข้อมูลสำหรับปลายทางอยู่ ระบบจะไม่แสดงคำเตือนและข้อผิดพลาดสำหรับปลายทาง ในขั้นตอนนี้SUCCESS: ดำเนินการตามคำขอสำหรับปลายทางเสร็จสมบูรณ์โดยไม่มีข้อผิดพลาด ตรวจสอบคำเตือนที่ได้รับแจ้งระหว่างการประมวลผลFAILURE: บันทึกทั้งหมดสำหรับปลายทางล้มเหลวเนื่องจากข้อผิดพลาด ตรวจสอบคำเตือนและข้อผิดพลาดเพื่อดูสาเหตุที่ระเบียนทั้งหมด ล้มเหลว นอกจากนี้ ให้ตรวจสอบคำเตือนที่แจ้งระหว่างการประมวลผลด้วยPARTIAL_SUCCESS: บันทึกบางรายการสำหรับปลายทางสำเร็จ แต่ รายการอื่นๆ ไม่สำเร็จเนื่องจากมีข้อผิดพลาด ตรวจสอบข้อผิดพลาดเพื่อ ดูว่าทำไมบางระเบียนจึงไม่สำเร็จ และตรวจสอบคำเตือนที่แจ้งระหว่าง การประมวลผลด้วย
ตรวจสอบสถานะเหตุการณ์หรือกลุ่มเป้าหมายต่อปลายทาง
ตรวจสอบช่องสถานะที่สอดคล้องกับประเภทคำขอส่งผ่านข้อมูล ตั้งค่าฟิลด์ต่อไปนี้เพียงฟิลด์เดียวในแต่ละ RequestStatusPerDestination
สถานะการนำเข้าเหตุการณ์
ระบบจะป้อนข้อมูลในฟิลด์ events_ingestion_status หากคำขอเป็น
IngestEventsRequest
ตรวจสอบrecord_countของIngestEventStatus
เพื่อยืนยันว่าจำนวนระเบียนทั้งหมดที่ได้รับตรงกับ
ที่คุณคาดไว้ record_count มีทั้งบันทึกที่สำเร็จและไม่สำเร็จ
สถานะการนำเข้าสมาชิกในกลุ่มเป้าหมาย
ระบบจะป้อนข้อมูลในฟิลด์ audience_members_ingestion_status หากคำขอเป็น
IngestAudienceMembersRequest ฟิลด์IngestAudienceMembersStatusที่คุณต้องตรวจสอบสำหรับข้อมูลผู้ชมแต่ละประเภทมีดังนี้
ตั้งค่าช่องเหล่านี้เพียงช่องเดียว
user_data_ingestion_statusตรวจสอบ
record_countของIngestUserDataStatusเพื่อยืนยันว่าจำนวนระเบียนทั้งหมดที่ได้รับตรงกับที่คุณคาดไว้record_countรวมทั้งบันทึกที่สำเร็จและไม่สำเร็จตรวจสอบ
user_identifier_countเพื่อยืนยันว่าจำนวนตัวระบุผู้ใช้ที่ได้รับตรงกับความคาดหวังของคุณหากคำขอมีจำนวนระเบียนเพียงพอ
upload_match_rate_rangeจะมีช่วงอัตราการจับคู่สำหรับระเบียนในคำขอmobile_data_ingestion_statusตรวจสอบ
record_countของIngestMobileDataStatusเพื่อยืนยันว่าจำนวนระเบียนทั้งหมดที่ได้รับตรงกับที่คุณคาดไว้ โดยrecord_countรวมทั้งบันทึกที่สำเร็จและไม่สำเร็จตรวจสอบ
mobile_id_countเพื่อยืนยันว่าจำนวนรหัสอุปกรณ์เคลื่อนที่ที่ได้รับ ตรงกับที่คุณคาดไว้pair_data_ingestion_statusตรวจสอบ
record_countของIngestPairDataStatusเพื่อยืนยันว่าจำนวนระเบียนทั้งหมดที่ได้รับตรงกับที่คุณคาดไว้record_countรวมทั้งบันทึกที่สำเร็จและไม่สำเร็จตรวจสอบ
pair_id_countเพื่อยืนยันว่าจำนวนรหัส PAIR ที่ได้รับ ตรงกับที่คุณคาดไว้ppid_data_ingestion_statusตรวจสอบ
record_countของIngestPpidDataStatusเพื่อยืนยันว่าจำนวนระเบียนทั้งหมดที่ได้รับตรงกับที่คุณคาดไว้record_countรวมทั้งบันทึกที่สำเร็จและไม่สำเร็จตรวจสอบ
ppid_countเพื่อยืนยันว่าจำนวน PPID ที่ได้รับ ตรงกับที่คุณคาดไว้user_id_data_ingestion_statusตรวจสอบ
record_countของIngestUserIdDataStatusเพื่อยืนยันว่าจำนวนระเบียนทั้งหมดที่ได้รับตรงกับที่คุณคาดไว้record_countรวมทั้งบันทึกที่สำเร็จและไม่สำเร็จตรวจสอบ
user_id_countเพื่อยืนยันว่าจำนวน User-ID ที่ได้รับ ตรงกับที่คุณคาดไว้
สถานะการนำสมาชิกในกลุ่มเป้าหมายออก
ระบบจะป้อนข้อมูลในฟิลด์ audience_members_removal_status หากคำขอเป็นRemoveAudienceMembersRequest ต่อไปนี้คือฟิลด์ RemoveAudienceMembersStatus ที่ต้องตรวจสอบสำหรับข้อมูลกลุ่มเป้าหมายแต่ละประเภท ตั้งค่าช่องเหล่านี้เพียงช่องเดียว
user_data_removal_status- สถานะการนำข้อมูลผู้ใช้ออก
mobile_data_removal_status- สถานะการนำออกสำหรับอินเทอร์เน็ตมือถือ
pair_data_removal_status- สถานะการนำข้อมูล PAIR ออก
ppid_data_removal_status- สถานะการนำออกสำหรับข้อมูล PPID
user_id_data_removal_status- สถานะการนำออกสำหรับข้อมูลรหัสผู้ใช้
ตรวจสอบ record_count เพื่อยืนยันว่าจำนวนระเบียนทั้งหมด
ที่ได้รับตรงกับที่คุณคาดไว้ record_count ประกอบด้วยทั้งระเบียนที่สำเร็จและไม่สำเร็จ
นอกจากนี้ ให้ตรวจสอบ user_identifier_count, mobile_id_count หรือ
pair_id_count เพื่อยืนยันจำนวนรวมของตัวระบุผู้ใช้ รหัสอุปกรณ์เคลื่อนที่
หรือรหัส PAIR ที่ได้รับ
ตรวจสอบคำเตือนและข้อผิดพลาด
นอกจากฟิลด์สถานะสำหรับปลายทางและประเภทคำขอแล้ว RetrieveRequestStatusResponse ยังมีรายละเอียดของคำเตือนและข้อผิดพลาดสำหรับคำขอด้วย
- ข้อผิดพลาดบ่งบอกว่า API ปฏิเสธระเบียนโดยสมบูรณ์
- คำเตือนบ่งชี้ว่า API ไม่ได้ปฏิเสธระเบียน แต่ต้องละเว้นส่วนต่างๆ ของข้อมูลระเบียน
เช่น หาก Event สำหรับ Conversion ออฟไลน์ของ Google Ads มีข้อมูล UserIdentifier ที่เข้ารหัสและ AdIdentifiers เช่น gclid และถอดรหัสข้อมูล UserIdentifier ไม่ได้ API ของ Data Manager จะยังคงประมวลผลระเบียนโดยใช้ AdIdentifiers แต่จะแสดงประกาศเตือน PROCESSING_WARNING_REASON_USER_IDENTIFIER_DECRYPTION_ERROR
อย่างไรก็ตาม หาก Event ไม่มี AdIdentifiers และถอดรหัสข้อมูล UserIdentifier
ไม่ได้ Data Manager API จะปฏิเสธระเบียนทั้งหมดและรายงานข้อผิดพลาด PROCESSING_ERROR_REASON_USER_IDENTIFIER_DECRYPTION_ERROR
เนื่องจาก Conversion ออฟไลน์ของ Google Ads ที่ถูกต้อง Event ต้องมี ad_identifiers หรือ user_data อย่างน้อย 1 รายการ
ฟิลด์การตอบกลับที่มีข้อมูลคำเตือนและข้อผิดพลาดมีดังนี้ ระบบจะป้อนข้อมูลในช่องเหล่านี้เมื่อสถานะปลายทางโดยรวม
เปลี่ยนเป็น SUCCESS, PARTIAL_SUCCESS หรือ FAILURE
warning_infoรายการออบเจ็กต์
WarningCountแต่ละWarningCountจะมีreasonที่มีประเภทคำเตือน และrecord_countที่ระบุจำนวนระเบียนที่มีคำเตือนประเภทนั้นตรวจสอบ
warning_infoแม้ว่าสถานะของจุดหมายโดยรวมจะเป็นSUCCESSerror_infoรายการออบเจ็กต์
ErrorCountErrorCountแต่ละรายการ จะมีreasonที่มีประเภทข้อผิดพลาด และrecord_countที่ระบุ จำนวนระเบียนที่ล้มเหลวเนื่องจากข้อผิดพลาดประเภทนั้น