mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-19 14:07:01 +01:00
substitute: Cache transient HTTP errors for 10mn.
* guix/scripts/substitute.scm (fetch-narinfos)[handle-narinfo-response]: Cache transient errors for 10mn. (%narinfo-transient-error-ttl): New variable.
This commit is contained in:
parent
14d6ca3e4d
commit
958fb14cdb
1 changed files with 25 additions and 25 deletions
|
@ -113,9 +113,13 @@ (define %narinfo-ttl
|
||||||
(* 36 3600))
|
(* 36 3600))
|
||||||
|
|
||||||
(define %narinfo-negative-ttl
|
(define %narinfo-negative-ttl
|
||||||
;; Likewise, but for negative lookups---i.e., cached lookup failures.
|
;; Likewise, but for negative lookups---i.e., cached lookup failures (404).
|
||||||
(* 3 3600))
|
(* 3 3600))
|
||||||
|
|
||||||
|
(define %narinfo-transient-error-ttl
|
||||||
|
;; Likewise, but for transient errors such as 504 ("Gateway timeout").
|
||||||
|
(* 10 60))
|
||||||
|
|
||||||
(define %narinfo-expired-cache-entry-removal-delay
|
(define %narinfo-expired-cache-entry-removal-delay
|
||||||
;; How often we want to remove files corresponding to expired cache entries.
|
;; How often we want to remove files corresponding to expired cache entries.
|
||||||
(* 7 24 3600))
|
(* 7 24 3600))
|
||||||
|
@ -585,18 +589,17 @@ (define update-progress!
|
||||||
(set! done (+ 1 done)))))
|
(set! done (+ 1 done)))))
|
||||||
|
|
||||||
(define (handle-narinfo-response request response port result)
|
(define (handle-narinfo-response request response port result)
|
||||||
(let* ((len (response-content-length response))
|
(let* ((code (response-code response))
|
||||||
|
(len (response-content-length response))
|
||||||
(cache (response-cache-control response))
|
(cache (response-cache-control response))
|
||||||
(ttl (and cache (assoc-ref cache 'max-age))))
|
(ttl (and cache (assoc-ref cache 'max-age))))
|
||||||
;; Make sure to read no more than LEN bytes since subsequent bytes may
|
;; Make sure to read no more than LEN bytes since subsequent bytes may
|
||||||
;; belong to the next response.
|
;; belong to the next response.
|
||||||
(case (response-code response)
|
(if (= code 200) ; hit
|
||||||
((200) ; hit
|
|
||||||
(let ((narinfo (read-narinfo port url #:size len)))
|
(let ((narinfo (read-narinfo port url #:size len)))
|
||||||
(cache-narinfo! url (narinfo-path narinfo) narinfo ttl)
|
(cache-narinfo! url (narinfo-path narinfo) narinfo ttl)
|
||||||
(update-progress!)
|
(update-progress!)
|
||||||
(cons narinfo result)))
|
(cons narinfo result))
|
||||||
((404) ; failure
|
|
||||||
(let* ((path (uri-path (request-uri request)))
|
(let* ((path (uri-path (request-uri request)))
|
||||||
(hash-part (string-drop-right path 8))) ; drop ".narinfo"
|
(hash-part (string-drop-right path 8))) ; drop ".narinfo"
|
||||||
(if len
|
(if len
|
||||||
|
@ -604,13 +607,10 @@ (define (handle-narinfo-response request response port result)
|
||||||
(read-to-eof port))
|
(read-to-eof port))
|
||||||
(cache-narinfo! url
|
(cache-narinfo! url
|
||||||
(find (cut string-contains <> hash-part) paths)
|
(find (cut string-contains <> hash-part) paths)
|
||||||
#f ttl)
|
#f
|
||||||
(update-progress!)
|
(if (= 404 code)
|
||||||
result))
|
ttl
|
||||||
(else ; transient failure: 504...
|
%narinfo-transient-error-ttl))
|
||||||
(if len
|
|
||||||
(get-bytevector-n port len)
|
|
||||||
(read-to-eof port))
|
|
||||||
(update-progress!)
|
(update-progress!)
|
||||||
result))))
|
result))))
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue