mirror of
https://github.com/goharbor/harbor.git
synced 2024-12-31 21:18:21 +01:00
Fall back to local registry when upstream registry is not working
Fixes #14822 When upstream registry not working, but status might stay healthy because the health check interval is 5 minutes, if a pull request comes before registry status turns to unhealthy, the proxy cache middleware might proxy the request to the upstream registry and get a 401 error and this 401 error might translate to a http 500 error to the client eventually. To solve this issue, it fall back all error to local registry when proxying manifest except the NotFoundError from the local registry. Signed-off-by: stonezdj <stonezdj@gmail.com>
This commit is contained in:
parent
e006f4bab5
commit
d7d26c0966
@ -95,7 +95,12 @@ func preCheck(ctx context.Context) (art lib.ArtifactInfo, p *models.Project, ctl
|
|||||||
func ManifestMiddleware() func(http.Handler) http.Handler {
|
func ManifestMiddleware() func(http.Handler) http.Handler {
|
||||||
return middleware.New(func(w http.ResponseWriter, r *http.Request, next http.Handler) {
|
return middleware.New(func(w http.ResponseWriter, r *http.Request, next http.Handler) {
|
||||||
if err := handleManifest(w, r, next); err != nil {
|
if err := handleManifest(w, r, next); err != nil {
|
||||||
httpLib.SendError(w, err)
|
if errors.IsNotFoundErr(err) {
|
||||||
|
httpLib.SendError(w, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
log.Errorf("failed to proxy manifest, fallback to local, request uri: %v, error: %v", r.RequestURI, err)
|
||||||
|
next.ServeHTTP(w, r)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user