HTTPError.net

The fastest way to diagnose, understand, and fix any HTTP status code

504 Gateway Timeout

Fault: Server
TL;DR

Gateway/proxy timeout waiting for upstream server.

The server did not receive a timely response from the upstream server.

What This Error Means

The server did not receive a timely response from the upstream server.

Gateway/proxy timeout waiting for upstream server.

Common Causes

How to Fix It (For Visitors)

How to Fix It (For Developers/Admins)

Code Examples

Here's how to return a 504 status code in various programming languages:

Python (Flask)

from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/endpoint')
def endpoint():
    return jsonify({"message": "Gateway Timeout"}), 504

Node.js (Express)

const express = require('express');
const app = express();

app.get('/endpoint', (req, res) => {
    res.status(504).json({ message: 'Gateway Timeout' });
});

PHP

<?php
http_response_code(504);
header('Content-Type: application/json');
echo json_encode(['message' => 'Gateway Timeout']);
?>

Go

package main

import (
    "encoding/json"
    "net/http"
)

func handler(w http.ResponseWriter, r *http.Request) {
    w.Header().Set("Content-Type", "application/json")
    w.WriteHeader(504)
    json.NewEncoder(w).Encode(map[string]string{
        "message": "Gateway Timeout",
    })
}

Java (Spring Boot)

@GetMapping("/endpoint")
public ResponseEntity<Map<String, String>> endpoint() {
    Map<String, String> response = new HashMap<>();
    response.put("message", "Gateway Timeout");
    return ResponseEntity.status(504).body(response);
}

Ruby (Sinatra)

get '/endpoint' do
    status 504
    json message: 'Gateway Timeout'
end

Browser Compatibility

Browser Support Notes
Chrome✓ Full SupportAll versions
Firefox✓ Full SupportAll versions
Safari✓ Full SupportAll versions
Edge✓ Full SupportAll versions

Official Specification

This status code is defined in RFC 7231 Section 6.6.5.

View on IANA HTTP Status Code Registry →