Home Arrow Icon Knowledge base Arrow Icon Global Arrow Icon ฉันจะป้องกันไม่ให้งานหายไปจากคิว SQS หลังจากลองอีกครั้งได้อย่างไร


ฉันจะป้องกันไม่ให้งานหายไปจากคิว SQS หลังจากลองอีกครั้งได้อย่างไร


เพื่อป้องกันไม่ให้งานหายไปจากคิว SQS หลังจากลองอีกครั้ง คุณสามารถลองใช้วิธีต่อไปนี้:

1. เพิ่มขีดจำกัดการรับสูงสุดใน SQS:
- ตามค่าเริ่มต้น SQS มีขีดจำกัด "การรับสูงสุด" ซึ่งจะกำหนดจำนวนครั้งสูงสุดที่สามารถรับข้อความจากคิวได้ก่อนที่จะถูกย้ายไปยัง Dead-Letter Queue (DLQ)
- เพิ่มขีดจำกัด "การรับสูงสุด" สำหรับคิว SQS ของคุณให้เป็นค่าที่สูงขึ้น เช่น 10 หรือ 20 เพื่อให้ลองอีกครั้งได้มากขึ้นก่อนที่งานจะถูกย้ายไปยัง DLQ

2. ปิดการใช้งาน Dead-Letter Queue (DLQ):
- หากคุณไม่ต้องการฟังก์ชัน DLQ คุณสามารถปิดการใช้งานสำหรับคิว SQS ของคุณได้ วิธีนี้จะป้องกันไม่ให้งานถูกย้ายไปยัง DLQ หลังจากลองใหม่ครบจำนวนสูงสุดแล้ว
- หากต้องการปิดใช้งาน DLQ คุณสามารถสร้างคิว SQS ใหม่โดยไม่มี DLQ หรือแก้ไขการกำหนดค่าของคิวที่มีอยู่เพื่อลบ DLQ

3. เพิ่มระยะหมดเวลาการมองเห็น:
- การหมดเวลาการมองเห็นใน SQS จะกำหนดระยะเวลาที่ข้อความจะไม่ปรากฏแก่ผู้บริโภครายอื่นหลังจากได้รับข้อความแล้ว
- เพิ่มการหมดเวลาการมองเห็นเป็นค่าที่สูงขึ้น เช่น 1 ชั่วโมงหรือ 2 ชั่วโมง เพื่อให้งานมีเวลาในการประมวลผลมากขึ้นก่อนที่จะมองเห็นได้อีกครั้งเพื่อลองอีกครั้ง

4. ใช้ตรรกะลองใหม่แบบกำหนดเอง:
- แทนที่จะอาศัยเมธอด 'retryUntil' เพียงอย่างเดียว คุณสามารถใช้ตรรกะการลองซ้ำแบบกำหนดเองในเมธอด 'handle' ของงานของคุณได้
- สิ่งนี้อาจเกี่ยวข้องกับการตรวจสอบจำนวนครั้งที่พยายามและปล่อยงานกลับไปยังคิวด้วยตนเองโดยมีความล่าช้าแบบกำหนดเอง แทนที่จะปล่อยให้ระบบคิวจัดการการลองใหม่

5. ใช้ไดรเวอร์คิว SQS แบบกำหนดเอง:
- ตามที่กล่าวไว้ในการตอบกลับก่อนหน้านี้ คุณสามารถสร้างไดรเวอร์คิว SQS แบบกำหนดเองที่ขยายคลาส 'SqsQueue' เริ่มต้นและเพิ่มฟังก์ชันการทำงานเพิ่มเติมเพื่อจัดการกับการลองใหม่ และป้องกันไม่ให้งานหายไป
- สิ่งนี้ช่วยให้คุณควบคุมพฤติกรรมการลองใหม่ได้มากขึ้น และรับประกันว่างานจะไม่สูญหายหรือถูกลบออกจากคิวก่อนเวลาอันควร

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

การอ้างอิง:
[1] https://dev.to/ichtrojan/configuring-laravel-queues-with-aws-sqs-3f0n
[2] https://www.honeybadger.io/blog/laravel-queues-deep-dive/
[3] https://stackoverflow.com/questions/71411471/laravel-retryuntil-job-exits-after-4th-retry-without-failing
[4] https://laracasts.com/discuss/channels/laravel/queue-job-retry-after-x- minutes-if-failed
[5] https://github.com/shiftonelabs/laravel-sqs-fifo-queue
-