10 |
import javax.servlet.http.HttpServletRequest; |
import javax.servlet.http.HttpServletRequest; |
11 |
import javax.servlet.http.HttpServletResponse; |
import javax.servlet.http.HttpServletResponse; |
12 |
|
|
13 |
|
import dk.thoerup.curcuitbreaker.CircuitBreakerException; |
14 |
|
|
15 |
/** |
/** |
16 |
* Servlet implementation class TimetableServlet |
* Servlet implementation class TimetableServlet |
17 |
*/ |
*/ |
45 |
} catch (java.net.SocketTimeoutException ste) { |
} catch (java.net.SocketTimeoutException ste) { |
46 |
logger.warning("(timetable) Read timed out, train="+train); |
logger.warning("(timetable) Read timed out, train="+train); |
47 |
response.sendError(500, "Backend timed out"); |
response.sendError(500, "Backend timed out"); |
48 |
} catch (Exception e) { |
} catch (CircuitBreakerException cbe) { |
49 |
|
logger.warning("Circuitbreaker - failing fast"); |
50 |
|
response.sendError(500); |
51 |
|
}catch (Throwable e) { |
52 |
logger.log(Level.WARNING, "failure looking up timetable: train=" +train, e); |
logger.log(Level.WARNING, "failure looking up timetable: train=" +train, e); |
53 |
response.sendError(500); |
response.sendError(500); |
54 |
} |
} |