කරකැවීමට කල් ඉකුත් වී තිබේද?


278

මෙතෙක් මට කිසිවක් සොයා ගැනීමට නොහැකි විය, නමුත් එය ඇත්ත curlවශයෙන්ම කාලය ඉවර නොවන බව ඇත්තද?

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

මම ඉල්ලන්නේ පින්තූර සඳහා වන ඕනෑම ඉල්ලීමක් testdirවෙනම Apache මොඩියුලයකට හරවා යවන අතර එම පින්තූර මැස්සන් මත ජනනය කරයි. පින්තූරය සැබවින්ම සූදානම් වී ඉල්ලුම් කරන සේවාදායකයාට ලබා දීමට මිනිත්තු 15 ක් ගතවනු ඇත.

ඇත curlහැම විටම ඉන්න (හෝ එය මානකරනය මත පදනම්ව ය) හෝ එහි කල් ඉකුත්වන, කුමන හෝ ආකාරයක ද?


3
වක්‍රයට සම්බන්ධතා කල් ඉකුත් වීමක් බලාපොරොත්තු වෙමි (වෙන කිසිවක් නොමැති නම්, මෙහෙයුම් පද්ධතිය සහ එහි TCP / IP තොගය නිසැකවම පාහේ සිදු වේ), නමුත් සම්බන්ධතාවය ස්ථාපිත වූ පසු එයට කියවීමේ වේලාව නොතිබෙනු ඇත.
සීවීඑන්

Answers:


373

ඔව්.

කල් ඉකුත් වූ පරාමිතීන්

curlවිකල්ප දෙකක් ඇත: --connect-timeoutසහ --max-time.

මෑන් පිටුවෙන් උපුටා දැක්වීම:

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

පෙරනිමි

මෙන්න (ඩේබියන් මත) එය නිශ්චිතව දක්වා ඇති කාලය නොසලකා මිනිත්තු 2 කට පසුව සම්බන්ධ වීමට උත්සාහ කිරීම නවත්වන අතර lib / connect.h හි සාර්වයට අනුව --connect-timeoutපෙරනිමි සම්බන්ධක කල් ඉකුත් වීමේ අගය මිනිත්තු 5 ක් ලෙස පෙනේ .DEFAULT_CONNECT_TIMEOUT

සඳහා පෙරනිමි අගයක් --max-timeනොපෙනේ, curlආරම්භක සම්බන්ධතාවය සාර්ථක වුවහොත් ප්‍රතිචාරයක් සඳහා සදහටම රැඳී සිටින්න.

භාවිතා කළ යුත්තේ කුමක්ද?

ඔබ බොහෝ විට දෙවන විකල්පය ගැන උනන්දු විය හැකිය --max-time. ඔබගේ නඩුව සඳහා එය 900(මිනිත්තු 15) සකසන්න .

(විනාඩියක්) --connect-timeoutවැනි දෙයකට විකල්පය සඳහන් 60කිරීමද හොඳ අදහසක් විය හැකිය. එසේ නොමැතිනම් curlපෙනෙන පරිදි යම් පසුගාමී ඇල්ගොරිතමයක් භාවිතා කරමින් නැවත නැවතත් සම්බන්ධ වීමට උත්සාහ කරනු ඇත.


3
එයට ස්තුතියි! --max-time පෙරනිමි අගයන් ගැන කිසිවක් නොකියයි, එබැවින් මම අනුමාන කරන්නේ එයට පෙරනිමියෙන් සම්බන්ධ වීමේ කාලය අවසන් වීම හැර වෙනත් කාලයක් නොමැති බවයි ...?
ප්‍රීසෝ

5
ඔව්, නම් කනෙක්ට් සාර්ථක නම් curl ප්රතිචාර සඳහා ඔබට සදාකල් බලා සිටීමට ඇති බව පෙනේ.
ස්කයි

ප්‍රතිචාරය 'උපරිම කාලයට' වඩා වැඩි කාලයක් ගතවන විශාල බාගත කිරීමක් නම් උපරිම කාලය දෙකම ගැටළුවක් බව සලකන්න.
user92979

1
මිනිත්තු 2 ක කල් ඉකුත්වීම මට සේවාදායකයේ කාලය ඉවර වූවාක් මෙන් දැනේ. පෙරනිමි කල් ඉකුත්වීම මිනිත්තු 2 ක කාලයක් ඇති Node.js යෙදුමක http සේවාදායකයට සමාන ගැටළුවක් ඇතිවිය. එය වැඩි කිරීමට, HTTP.server.setTimeout () බලන්න .
තාලිස් කේ.

18

කාල සීමාව ඇත: / usr / bin / timelimit - ක්‍රියාවලියක නිරපේක්ෂ ක්‍රියාත්මක කිරීමේ කාලය effectively ලදායී ලෙස සීමා කරන්න

 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.

1
අවම වශයෙන් macOS 10.13.4 හි පෙරනිමියෙන් ලබා ගත නොහැක.
Thorbjørn Ravn Andersen

13

වඩා යහපත් --max-timeවන්නේ --speed-limitසහ --speed-timeවිකල්ප. කෙටියෙන් කිවහොත්, --speed-limitඔබ පිළිගැනීමට කැමති අවම සාමාන්‍ය වේගය --speed-timeනියම කරන අතර, මාරු වීමේ කාලය අවසන් වීමට පෙර සහ ගබ්සා කිරීමට පෙර හුවමාරු වේගය එම සීමාවට වඩා කොපමණ කාලයක් පැවතිය හැකිද යන්න නියම කරයි.


10
මම හිතන්නේ මේ දෙකම වඩා හොඳ නැත, නමුත් මගේ භාවිතයේදී - මැක්ස්-ටයිම් ඇත්ත වශයෙන්ම වඩාත් සුදුසු වන්නේ තත්පර 10 ට වඩා වැඩි යමක් මගේ වැඩසටහන නිෂ් .ල වනු ඇත.
ජෝර්ජ් බුකරන්

මම ඩෙස්ක්ටොප් යෙදුමක පුස්තකාලයක් ලෙස curl භාවිතා කරමි (එය CLI වෙතින් ඇමතීම පමණක් නොවේ) සහ මට ඔබේ විකල්පය හොඳම සුදුසුකම විය. මගේ යෙදුමට දිගු බාගැනීම් සඳහා සහය දැක්විය යුතුය, එබැවින් සරල - මැක්ස්-වේලාව "සිරවී ඇති බාගැනීම්" හඳුනා ගැනීමට සුදුසු නොවේ (නිදසුනක් ලෙස, බාගැනීමක් තිබියදී පරිශීලකයා නොබැඳිව යන්නේ නම් එය එසේ වේ. ප්‍රගතිය), එබැවින් මේවා හඳුනා ගැනීම සඳහා මම 1024 වේග සීමාවක් සහ වේග 30 ක් සමඟ ගියෙමි.
ඇන්ඩ්‍රේ මොරුජෝ

3
ප්‍රයෝජනවත්ද? නිසැකවම. වඩා හොඳ? මම හිතන්නේ එය ඔබගේ අවශ්‍යතා මත බෙහෙවින් රඳා පවතී
බ්‍රයන් ඇග්නිව්

ප්‍රතිචාරය නොදන්නා (හෝ දන්නා!) විශාල බාගත කිරීමක් විය හැකි නම් කල් ඉකුත්වීම ගැටළුවක් වේ. විශාල බාගත කිරීම සඳහා මිනිත්තු 15 කට වඩා වැඩි කාලයක් ගත වුවහොත් උපරිම කාලය කල් ඉකුත් වේ. ඕනෑම දෙයක් ඉදිරියට යැවීමට පෙර සම්පූර්ණ ප්‍රතිචාරය මුලින්ම රඳවා ගන්නා ප්‍රොක්සි මඟින් වේග සීමාවන් අඩු කළ හැකිය. ඔවුන් සමහර විට විනාඩියකට බයිට් 1 ක් ඉදිරිපත් කරන බවක් පෙනේ, නමුත් එය වේගවත් ජාලයක හැඹිලි-ප්‍රොක්සියක්ද, නැතහොත් නැවත උත්සාහ කළ යුතු ඉතා මන්දගාමී සම්බන්ධතාවයක්දැයි ඔබ කියන්නේ කෙසේද ?? ඉතින් අවසානයේදී මම බාගත විමසුම් සඳහා වේලාව අත්හැර දැමුවෙමි. වඩා හොඳ ක්‍රමයක් තිබේදැයි විශ්වාස නැත.
user92979

3

ඔබ MacOS හි coreutils ස්ථාපනය කර ඇත්නම්, ඔබට එම පැකේජය සමඟ ඇතුළත් කර ඇති GNU කල් ඉකුත් වීමේ විධානය භාවිතා කළ හැකිය. GNU මෙවලම් සියල්ලම gCLI වනු ඇත gtimeout.

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

උදාහරණයක්

$ 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

0

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
}

නියැදි භාවිතය:

අපට නිශ්චිත වරායක් අවශ්‍ය නම් NC භාවිතා කළ බව නිර්දේශ කරන්න

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
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.