mirror of
				https://github.com/caddyserver/caddy.git
				synced 2025-10-26 08:12:43 -04:00 
			
		
		
		
	core: Graceful error handling during heavy load; proper error responses
This commit is contained in:
		
							parent
							
								
									b51e8bc191
								
							
						
					
					
						commit
						b1e1caba29
					
				| @ -41,20 +41,27 @@ func (f *fileHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, er | |||||||
| func (fh *fileHandler) serveFile(w http.ResponseWriter, r *http.Request, name string) (int, error) { | func (fh *fileHandler) serveFile(w http.ResponseWriter, r *http.Request, name string) (int, error) { | ||||||
| 	f, err := fh.root.Open(name) | 	f, err := fh.root.Open(name) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		if os.IsPermission(err) { | 		if os.IsNotExist(err) { | ||||||
| 			return http.StatusForbidden, err | 			return http.StatusForbidden, err | ||||||
| 		} | 		} else if os.IsPermission(err) { | ||||||
| 			return http.StatusNotFound, nil | 			return http.StatusNotFound, nil | ||||||
| 		} | 		} | ||||||
|  | 		// Likely the server is under load and ran out of file descriptors | ||||||
|  | 		w.Header().Set("Retry-After", "5") // TODO: 5 seconds enough delay? Or too much? | ||||||
|  | 		return http.StatusServiceUnavailable, err | ||||||
|  | 	} | ||||||
| 	defer f.Close() | 	defer f.Close() | ||||||
| 
 | 
 | ||||||
| 	d, err1 := f.Stat() | 	d, err1 := f.Stat() | ||||||
| 	if err1 != nil { | 	if err1 != nil { | ||||||
| 		if os.IsPermission(err) { | 		if os.IsPermission(err) { | ||||||
| 			return http.StatusForbidden, err | 			return http.StatusForbidden, err | ||||||
| 		} | 		} else if os.IsNotExist(err) { | ||||||
| 			return http.StatusNotFound, nil | 			return http.StatusNotFound, nil | ||||||
| 		} | 		} | ||||||
|  | 		// Return a different status code than above so as to distinguish these cases | ||||||
|  | 		return http.StatusInternalServerError, err | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	// redirect to canonical path | 	// redirect to canonical path | ||||||
| 	url := r.URL.Path | 	url := r.URL.Path | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user