ใช่.
พารามิเตอร์การหมดเวลา
curl
มีสองตัวเลือก: และ--connect-timeout
--max-time
ข้อความจาก manpage:
--connect-timeout <seconds>
Maximum time in seconds that you allow the connection to the
server to take. This only limits the connection phase, once
curl has connected this option is of no more use. Since 7.32.0,
this option accepts decimal values, but the actual timeout will
decrease in accuracy as the specified timeout increases in deci‐
mal precision. See also the -m, --max-time option.
If this option is used several times, the last one will be used.
และ:
-m, --max-time <seconds>
Maximum time in seconds that you allow the whole operation to
take. This is useful for preventing your batch jobs from hang‐
ing for hours due to slow networks or links going down. Since
7.32.0, this option accepts decimal values, but the actual time‐
out will decrease in accuracy as the specified timeout increases
in decimal precision. See also the --connect-timeout option.
If this option is used several times, the last one will be used.
ค่าเริ่มต้น
ที่นี่ (ใน Debian) จะหยุดความพยายามที่จะเชื่อมต่อหลังจาก 2 นาทีโดยไม่คำนึงถึงเวลาที่กำหนดด้วย--connect-timeout
และถึงแม้จะเริ่มต้นเชื่อมต่อค่าการหมดเวลาน่าจะเป็น5 นาทีตามDEFAULT_CONNECT_TIMEOUT
แมโครในlib / connect.h
--max-time
ดูเหมือนว่าจะไม่มีค่าเริ่มต้นทำให้curl
รอการตอบกลับหากการเชื่อมต่อเริ่มต้นประสบความสำเร็จ
จะใช้อะไรดี?
คุณอาจสนใจในตัวเลือกหลัง, --max-time
. สำหรับกรณีของคุณตั้งค่าเป็น900
(15 นาที)
การระบุตัวเลือก--connect-timeout
บางอย่างเช่น60
(หนึ่งนาที) อาจเป็นความคิดที่ดี มิฉะนั้นcurl
จะพยายามเชื่อมต่ออีกครั้งและอีกครั้งโดยใช้อัลกอริทึม BackOff บางอย่าง