Apakah ikal memiliki batas waktu?

251

Sejauh ini saya tidak bisa menemukan apa-apa, tapi benarkah itu sama curlsekali tidak ada waktu?

 user@host:~# curl http://localhost/testdir/image.jpg

Saya bertanya karena saya mengalihkan permintaan gambar testdirke modul Apache terpisah yang menghasilkan gambar-gambar tersebut dengan cepat. Butuh waktu hingga 15 menit sebelum gambar benar-benar siap dan dikirim ke klien yang meminta.

Akan curlselalu menunggu (atau tergantung pada konfigurasi) atau apakah ada batas waktu?

Preexo
sumber
3
Saya berharap curl memiliki batas waktu koneksi (jika tidak ada yang lain, OS dan TCP / IP stack hampir pasti), tetapi mungkin tidak memiliki batas waktu baca begitu koneksi telah dibuat.
CVn

Jawaban:

340

Iya.

Parameter batas waktu

curlmemiliki dua opsi: --connect-timeoutdan --max-time.

Mengutip dari halaman manual:

--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.

dan:

-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.

Default

Di sini (di Debian) berhenti mencoba terhubung setelah 2 menit, terlepas dari waktu yang ditentukan dengan --connect-timeoutdan meskipun nilai batas waktu koneksi default tampaknya menjadi 5 menit sesuai dengan DEFAULT_CONNECT_TIMEOUTmakro di lib / connect.h .

Nilai default untuk --max-timesepertinya tidak ada, membuat curlmenunggu selamanya untuk respons jika koneksi awal berhasil.

Apa yang harus digunakan?

Anda mungkin tertarik pada opsi yang terakhir --max-time,. Untuk kasus Anda atur ke 900(15 menit).

Menentukan opsi --connect-timeoutuntuk sesuatu seperti 60(satu menit) mungkin juga merupakan ide bagus. Kalau tidak, curlakan mencoba untuk terhubung lagi dan lagi, tampaknya menggunakan beberapa algoritma backoff.

scai
sumber
2
Terima kasih untuk itu! --max-time tidak mengatakan apa-apa tentang nilai default, jadi saya kira tidak ada dan karena itu tidak memiliki timeout kecuali connect-timeout secara default ...?
Preexo
4
Ya, jika koneksi berhasil maka ikal tampaknya menunggu selamanya untuk respons.
scai
Perhatikan bahwa kedua maxtime adalah masalah jika responsnya adalah unduhan besar yang membutuhkan waktu lebih lama dari 'maxtime'.
user92979
1
Batas waktu 2 menit juga bau bagi saya seperti waktu server habis. Hanya memiliki masalah yang sama dengan server http dari aplikasi Node.js yang memiliki batas waktu default 2 menit. Untuk meningkatkannya, lihat HTTP.server.setTimeout () .
Thalis K.
17

Ada timelimit: / usr / bin / timelimit - secara efektif membatasi waktu eksekusi absolut dari suatu proses

 Options:

 -p      If the child process is terminated by a signal, timelimit
         propagates this condition, i.e. sends the same signal to itself. 
         This allows the program executing timelimit to determine 
         whether the child process was terminated by a signal or 
         actually exited with an exit code larger than 128.
 -q      Quiet operation - timelimit does not output diagnostic 
         messages about signals sent to the child process.
 -S killsig
         Specify the number of the signal to be sent to the 
         process killtime seconds after warntime has expired.  
         Defaults to 9 (SIGKILL).
 -s warnsig
         Specify the number of the signal to be sent to the 
         process warntime seconds after it has been started.  
         Defaults to 15 (SIGTERM).
 -T killtime
         Specify the maximum execution time of the process before 
         sending killsig after warnsig has been sent.  Defaults to 120 seconds.
 -t warntime
         Specify the maximum execution time of the process in 
         seconds before sending warnsig.  Defaults to 3600 seconds.

 On systems that support the setitimer(2) system call, the 
 warntime and killtime values may be specified in fractional 
 seconds with microsecond precision.
kelangsungan
sumber
1
Tidak tersedia secara default di macOS 10.13.4 setidaknya.
Thorbjørn Ravn Andersen
14

Lebih baik dari --max-timeadalah --speed-limitdan --speed-timepilihan. Singkatnya, --speed-limittentukan kecepatan rata-rata minimum yang bersedia Anda terima, dan --speed-timetentukan berapa lama kecepatan transfer dapat tetap di bawah batas itu sebelum transfer habis dan dibatalkan.

Alex D
sumber
9
Saya pikir tidak ada yang lebih baik, tetapi dalam kasus penggunaan saya - max-waktu sebenarnya lebih tepat karena apapun lebih dari 10 detik akan membuat program saya tidak berguna.
Jorge Bucaran
Saya menggunakan curl sebagai pustaka dalam aplikasi desktop (tidak hanya memanggilnya dari CLI) dan bagi saya pilihan Anda adalah yang paling cocok. Aplikasi saya harus dapat mendukung unduhan yang lama, jadi --max-time yang sederhana tidak cocok untuk mendeteksi "unduhan yang macet" (yang merupakan kasus jika, misalnya, pengguna offline saat unduhan sedang berlangsung kemajuan), jadi saya pergi dengan batas kecepatan 1024 dan kecepatan waktu 30 untuk mendeteksi ini.
André Morujão
1
Berguna? Pasti. Lebih baik? Saya pikir itu sangat tergantung pada kebutuhan Anda
Brian Agnew
Timeout adalah masalah jika responsnya bisa berupa unduhan besar dengan ukuran yang tidak diketahui (atau bahkan diketahui!). maxtime akan habis jika unduhan besar membutuhkan waktu lebih dari 15 menit. Dan batas kecepatan dapat dijatuhkan oleh proxy yang menyimpan seluruh respons terlebih dahulu sebelum meneruskan apa pun. Mereka kadang-kadang tampaknya meneruskan 1 byte per menit, tetapi bagaimana Anda tahu apakah itu caching-proxy pada jaringan yang cepat, atau koneksi yang sangat lambat yang harus dicoba lagi ?? Jadi pada akhirnya saya menyerah dan mematikan batas waktu untuk permintaan unduhan. Tidak yakin apakah ada cara yang lebih baik.
user92979
3

Jika Anda memiliki coreutils yang diinstal pada MacOS Anda dapat menggunakan perintah timeout GNU yang disertakan dengan paket itu. Semua alat GNU diawali dengan gCLI gtimeout.

gtimeout --help
Usage: gtimeout [OPTION] DURATION COMMAND [ARG]...
 or:  gtimeout [OPTION]
Start COMMAND, and kill it if still running after DURATION.

Contoh

$ gtimeout 1s curl -I http://www.google.com/
HTTP/1.1 200 OK
Date: Wed, 31 Oct 2018 03:36:08 GMT
Expires: -1
Cache-Control: private, max-age=0
Content-Type: text/html; charset=ISO-8859-1
P3P: CP="This is not a P3P policy! See g.co/p3phelp for more info."
Server: gws
X-XSS-Protection: 1; mode=block
X-Frame-Options: SAMEORIGIN
Set-Cookie: 1P_JAR=2018-10-31-03; expires=Fri, 30-Nov-2018 03:36:08 GMT; path=/; domain=.google.com
HttpOnly
Transfer-Encoding: chunked
Accept-Ranges: none
Vary: Accept-Encoding
slm
sumber
0

Beberapa solusi di BASH4 +

# -- server available to check via port xxx ?  --
function isServerAvailableNC() {
    max_secs_run="${3}"
    if timeout $max_secs_run nc -z ${1} ${2} 2>/dev/null >/dev/null; then
        #echo "${1} ✓"
        true
   else
        #echo "${1} ✗"
        return
   fi
}


# -- server available to check via port xxx ?  --
# -- supported protocols (HTTP, HTTPS, FTP, FTPS, SCP, SFTP, TFTP, DICT, TELNET, LDAP or FILE) --
#/usr/bin/curl -sSf --max-time 3 https://ifwewanted.to.confirm.https.com/ --insecure

function isServerAvailableCURL() {

    max_secs_run="${3}"

    proto="http://"
    if [ ! -z ${2} ] || [ ${2} -gt 80 ] ;then
        proto="https://"
    fi

    if /usr/bin/curl -sSf --max-time "${max_secs_run}" "${1}" --insecure 2>/dev/null >/dev/null; then
        #echo "${1} ✓"
        true
    else
        #echo "${1} ✗"
        false
    fi
}

Penggunaan sampel:

MENYARANKAN NC yang digunakan jika kita memerlukan port tertentu

host="1.2.3.4"
if isServerAvailableCURL "$host" "80" "3";then
    check_remote_domain_cert "$host"
fi


host="1.2.3.4"
if isServerAvailableNC "$host" "80" "3";then
    check_remote_domain_cert "$host"
fi
Mike Q
sumber