ขีดจำกัดการใช้งาน

Google Sheets API เป็นบริการที่แชร์ และเราใช้โควต้าและข้อจำกัดเพื่อปกป้องประสิทธิภาพโดยรวมของระบบ Google Workspace สำหรับผู้ใช้ทุกคน

ขีดจำกัดโควต้า

แม้ว่า Sheets API จะไม่มีขีดจำกัดขนาดที่แน่นอนสำหรับคำขอ API แต่ผู้ใช้อาจพบข้อจำกัดจากคอมโพเนนต์การประมวลผลต่างๆ ที่ Google Sheets ไม่ได้ควบคุม เราขอแนะนำให้ใช้เพย์โหลดสูงสุด 2 MB เพื่อให้คำขอเร็วขึ้น

Sheets API มีโควต้าต่อนาทีและจะเติมโควต้าทุกนาที เช่น มีขีดจำกัดคำขออ่าน 300 รายการต่อนาทีต่อโปรเจ็กต์ หากแอปของคุณส่งคำขอ 350 รายการใน 1 นาที คำขอเพิ่มเติม 50 รายการจะเกินโควต้าและสร้างการตอบกลับรหัสสถานะ HTTP 429: Too many requests หากเกิดเหตุการณ์นี้ขึ้น คุณควรใช้อัลกอริทึม Exponential Backoff หลังจากผ่านไป 1 นาที คุณจะส่งคำขอได้อีกครั้ง

ตารางต่อไปนี้แสดงรายละเอียดขีดจำกัดคำขอ

โควต้า
คำขอที่อ่าน
ต่อนาทีต่อโปรเจ็กต์ 300
ต่อนาทีต่อผู้ใช้ต่อโปรเจ็กต์ 60
คำขอที่เขียน
ต่อนาทีต่อโปรเจ็กต์ 300
ต่อนาทีต่อผู้ใช้ต่อโปรเจ็กต์ 60

โปรดดูรายละเอียดเกี่ยวกับขีดจำกัดไฟล์ที่หัวข้อ ไฟล์ที่คุณเก็บไว้ใน Google ไดรฟ์

ลักษณะการทำงานและข้อจำกัด

เมื่อใช้ Sheets API โปรดทราบลักษณะการทำงานและข้อจำกัดต่อไปนี้ที่จะส่งผลต่อโควต้า

  • คำขอที่อ่านคือการเรียกใช้เมธอดใดก็ตามที่ดึงข้อมูลจากสเปรดชีต เช่น get หรือ search คำขอที่เขียนคือการเรียกใช้เมธอดใดก็ตามที่เปลี่ยนแปลงสเปรดชีต เช่น update, clear หรือ copyTo

  • ผู้ใช้สามารถส่งคำขอหลายรายการพร้อมกันได้ตราบใดที่คำขอเหล่านั้นไม่เกินขีดจำกัดโควต้า ระบบจะนับคำขอแบบกลุ่มแต่ละรายการ รวมถึงคำขอย่อยใดก็ตาม เป็นคำขอ API 1 รายการที่รวมอยู่ในขีดจำกัดการใช้งาน

  • ระบบจะใช้คำขอ Sheets ทั้งหมดแบบอะตอมมิก นั่นคือหากคำขอใดไม่ถูกต้อง การอัปเดตทั้งหมดจะไม่สำเร็จและระบบจะไม่ใช้การเปลี่ยนแปลงใดๆ (ที่อาจขึ้นอยู่กับคำขออื่น)

  • มีขีดจำกัดเวลาสูงสุดสำหรับการประมวลผลคำขอ API 1 รายการ เมื่อ Sheets ประมวลผลคำขอนานกว่า 180 วินาที คำขอจะแสดงข้อผิดพลาดการหมดเวลา

  • ตราบใดที่คุณไม่เกินโควต้าต่อนาที คุณจะส่งคำขอได้ไม่จำกัดจำนวนต่อวัน

แก้ไขข้อผิดพลาดเกี่ยวกับโควต้าตามเวลา

สำหรับข้อผิดพลาดทั้งหมดที่อิงตามเวลา (คำขอสูงสุด N รายการต่อ X นาที) เราขอแนะนำ ให้โค้ดของคุณตรวจจับข้อยกเว้นและใช้ Exponential Backoff แบบย่อ เพื่อให้แน่ใจว่าอุปกรณ์ จะไม่สร้างภาระงานมากเกินไป

Exponential Backoff เป็นกลยุทธ์การจัดการข้อผิดพลาดมาตรฐานสำหรับแอปพลิเคชันเครือข่าย อัลกอริทึม Exponential Backoff จะลองส่งคำขออีกครั้งโดยใช้เวลาในการรอที่เพิ่มขึ้นแบบยกกำลัง ระหว่างคำขอ โดยรอสูงสุดตามเวลา Backoff สูงสุด หากคำขอไม่สำเร็จ คุณควรเพิ่มความล่าช้าระหว่างคำขอเมื่อเวลาผ่านไปจนกว่าคำขอจะสำเร็จ

อัลกอริทึมตัวอย่าง

อัลกอริทึม Exponential Backoff จะลองส่งคำขออีกครั้งแบบยกกำลัง โดยเพิ่มเวลาในการรอ ระหว่างการลองอีกครั้งจนถึงเวลา Backoff สูงสุด เช่น

  1. ส่งคำขอไปยัง Google Sheets API
  2. หากคำขอไม่สำเร็จ ให้รอ 1 + random_number_milliseconds แล้วลองส่งคำขออีกครั้ง
  3. หากคำขอไม่สำเร็จ ให้รอ 2 + random_number_milliseconds แล้วลองส่งคำขออีกครั้ง
  4. หากคำขอไม่สำเร็จ ให้รอ 4 + random_number_milliseconds แล้วลองส่งคำขออีกครั้ง
  5. และอื่นๆ ไปเรื่อยๆ จนถึงเวลา maximum_backoff
  6. รอและลองอีกครั้งต่อไปจนถึงจำนวนการลองอีกครั้งสูงสุด แต่ไม่ต้องเพิ่มระยะเวลารอ ระหว่างการลองอีกครั้ง

โดยที่

  • เวลาในการรอคือ min(((2^n)+random_number_milliseconds), maximum_backoff), โดย n จะเพิ่มขึ้นทีละ 1 สำหรับการทำซ้ำ (คำขอ) แต่ละครั้ง
  • random_number_milliseconds คือจำนวนมิลลิวินาทีแบบสุ่มที่ไม่เกิน 1,000 ซึ่งจะช่วยหลีกเลี่ยงกรณีที่ไคลเอ็นต์จำนวนมากซิงค์กันเนื่องจาก สถานการณ์บางอย่างและลองอีกครั้งพร้อมกันทั้งหมด ทำให้ส่งคำขอเป็นระลอกแบบซิงค์กัน ระบบจะคำนวณค่า random_number_milliseconds ใหม่หลังจากคำขอแต่ละรายการที่ลองอีกครั้ง
  • maximum_backoff โดยทั่วไปคือ 32 หรือ 64 วินาที ค่าที่เหมาะสม จะขึ้นอยู่กับกรณีการใช้งาน

ไคลเอ็นต์สามารถลองอีกครั้งต่อไปได้หลังจากถึงเวลา maximum_backoff การลองอีกครั้งหลังจากจุดนี้ไม่จำเป็นต้องเพิ่มเวลา Backoff ต่อไป เช่น หากไคลเอ็นต์ใช้เวลา maximum_backoff 64 วินาที หลังจากถึงค่า นี้แล้ว ไคลเอ็นต์จะลองอีกครั้งทุกๆ 64 วินาทีได้ ไคลเอ็นต์ควรหยุดลองอีกครั้งอย่างไม่มีกำหนดเมื่อถึงจุดหนึ่ง

เวลาในการรอระหว่างการลองอีกครั้งและจำนวนการลองอีกครั้งจะขึ้นอยู่กับกรณีการใช้งาน และสภาพเครือข่าย

ราคา

การใช้ Google Sheets API ตามมาตรฐานทั้งหมดไม่มีค่าใช้จ่ายเพิ่มเติม การเกินขีดจำกัดคำขอโควต้า จะมีการเรียกเก็บเงินจากบัญชีสำหรับการเรียกเก็บเงินของ Google Cloud ในช่วงปลายปี 2026 ดูข้อมูลเพิ่มเติมได้ที่ โมเดลมาตรฐานของ Google Workspace สำหรับเครื่องมือและ API ของตัวแทน

ขอเพิ่มโควต้า

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

โปรเจ็กต์ทั้งหมดอาจมีโควต้าไม่เท่ากัน เมื่อคุณใช้ Google Cloud มากขึ้นเรื่อยๆ เมื่อเวลาผ่านไป ค่าโควต้าอาจต้องเพิ่มขึ้น หากคาดว่าจะมีการใช้งานเพิ่มขึ้นอย่างเห็นได้ชัดในอนาคตอันใกล้ คุณสามารถ ขอปรับโควต้าล่วงหน้า ได้จากหน้า โควต้าและขีดจำกัดของระบบ ในคอนโซล Google Cloud

ดูข้อมูลเพิ่มเติมได้จากแหล่งข้อมูลต่อไปนี้