Log unhandled exceptions
Enable logging of unhandled exceptions within the WSGI server. In the case of an internal server error a stacktrace will be logged if glance API or registry has the verbose option set to True. Partial-Bug: #1246968 Change-Id: I68390495331ba30dab1cd60584d0ed01357514ae
This commit is contained in:
parent
3428e6d637
commit
4027cd4e70
@ -25,7 +25,6 @@ from __future__ import print_function
|
||||
import datetime
|
||||
import errno
|
||||
import json
|
||||
import logging
|
||||
import os
|
||||
import signal
|
||||
import sys
|
||||
@ -43,7 +42,7 @@ import webob.exc
|
||||
|
||||
from glance.common import exception
|
||||
from glance.common import utils
|
||||
import glance.openstack.common.log as os_logging
|
||||
import glance.openstack.common.log as logging
|
||||
|
||||
|
||||
bind_opts = [
|
||||
@ -88,17 +87,6 @@ CONF.register_opts(socket_opts)
|
||||
CONF.register_opts(eventlet_opts)
|
||||
|
||||
|
||||
class WritableLogger(object):
|
||||
"""A thin wrapper that responds to `write` and logs."""
|
||||
|
||||
def __init__(self, logger, level=logging.DEBUG):
|
||||
self.logger = logger
|
||||
self.level = level
|
||||
|
||||
def write(self, msg):
|
||||
self.logger.log(self.level, msg.strip("\n"))
|
||||
|
||||
|
||||
def get_bind_addr(default_port=None):
|
||||
"""Return the host and port to bind to."""
|
||||
return (CONF.bind_host, CONF.bind_port or default_port)
|
||||
@ -234,7 +222,7 @@ class Server(object):
|
||||
self.sock = get_socket(default_port)
|
||||
|
||||
os.umask(0o27) # ensure files are created with the correct privileges
|
||||
self.logger = os_logging.getLogger('eventlet.wsgi.server')
|
||||
self.logger = logging.getLogger('glance.wsgi.server')
|
||||
|
||||
if CONF.workers == 0:
|
||||
# Useful for profiling, test, debug etc.
|
||||
@ -323,7 +311,7 @@ class Server(object):
|
||||
try:
|
||||
eventlet.wsgi.server(self.sock,
|
||||
self.application,
|
||||
log=WritableLogger(self.logger),
|
||||
log=logging.WritableLogger(self.logger),
|
||||
custom_pool=self.pool,
|
||||
debug=False)
|
||||
except socket.error as err:
|
||||
@ -335,7 +323,8 @@ class Server(object):
|
||||
"""Start a WSGI server in a new green thread."""
|
||||
self.logger.info(_("Starting single process server"))
|
||||
eventlet.wsgi.server(sock, application, custom_pool=self.pool,
|
||||
log=WritableLogger(self.logger), debug=False)
|
||||
log=logging.WritableLogger(self.logger),
|
||||
debug=False)
|
||||
|
||||
|
||||
class Middleware(object):
|
||||
|
Loading…
Reference in New Issue
Block a user