mirror of
https://github.com/frappe/gunicorn.git
synced 2026-01-14 11:09:11 +08:00
Add logging level command line options.
Refactored the scripts to be more DRY as well. gunicorn_django needs testing as I don't have a django environ handy to test with.
This commit is contained in:
parent
ec301fd43d
commit
aa30df9e26
1
.gitignore
vendored
1
.gitignore
vendored
@ -1,6 +1,7 @@
|
||||
*.gem
|
||||
*.swp
|
||||
*.pyc
|
||||
*#*
|
||||
build
|
||||
dist
|
||||
setuptools-*
|
||||
|
||||
36
bin/gunicorn
36
bin/gunicorn
@ -25,38 +25,24 @@
|
||||
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
# OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
import optparse as op
|
||||
import os
|
||||
import sys
|
||||
|
||||
sys.path.insert(0, os.getcwd())
|
||||
|
||||
import gunicorn
|
||||
from gunicorn import util
|
||||
from gunicorn.main import main
|
||||
from gunicorn.util import import_app
|
||||
|
||||
__usage__ = "%prog [OPTIONS] APP_MODULE"
|
||||
|
||||
def options():
|
||||
return [
|
||||
op.make_option('--host', dest='host', default='127.0.0.1',
|
||||
help='Host to listen on. [%default]'),
|
||||
op.make_option('--port', dest='port', default=8000, type='int',
|
||||
help='Port to listen on. [%default]'),
|
||||
op.make_option('--workers', dest='workers', default=1, type='int',
|
||||
help='Number of workers to spawn. [%default]')
|
||||
]
|
||||
|
||||
def main():
|
||||
parser = op.OptionParser(usage=__usage__, option_list=options())
|
||||
opts, args = parser.parse_args()
|
||||
|
||||
def get_app(parser, opts, args):
|
||||
if len(args) != 1:
|
||||
parser.error("No application module specified.")
|
||||
|
||||
app = util.import_app(args[0])
|
||||
|
||||
arbiter = gunicorn.Arbiter((opts.host, opts.port), opts.workers, app)
|
||||
arbiter.run()
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
||||
|
||||
try:
|
||||
return import_app(args[0])
|
||||
except:
|
||||
parser.error("Failed to import application module.")
|
||||
|
||||
main(__usage__, get_app)
|
||||
|
||||
|
||||
31
bin/gunicorn_django
Normal file → Executable file
31
bin/gunicorn_django
Normal file → Executable file
@ -25,12 +25,8 @@
|
||||
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
# OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
import optparse as op
|
||||
import os
|
||||
import sys
|
||||
|
||||
import django.core.handlers.wsgi
|
||||
import gunicorn
|
||||
from gunicorn.main import main
|
||||
|
||||
__usage__ = "%prog [OPTIONS]"
|
||||
|
||||
@ -41,25 +37,8 @@ PROJECT_NAME = os.path.split(PROJECT_PATH)[-1]
|
||||
sys.path.insert(0, os.path.join(PROJECT_PATH, ".."))
|
||||
os.environ['DJANGO_SETTINGS_MODULE'] = '%s.settings' % PROJECT_NAME
|
||||
|
||||
# django wsgi app
|
||||
app = django.core.handlers.wsgi.WSGIHandler()
|
||||
def get_app(parser, opts, args):
|
||||
# django wsgi app
|
||||
return django.core.handlers.wsgi.WSGIHandler()
|
||||
|
||||
def options():
|
||||
return [
|
||||
op.make_option('--host', dest='host', default='127.0.0.1',
|
||||
help='Host to listen on. [%default]'),
|
||||
op.make_option('--port', dest='port', default=8000, type='int',
|
||||
help='Port to listen on. [%default]'),
|
||||
op.make_option('--workers', dest='workers', default=1, type='int',
|
||||
help='Number of workers to spawn. [%default]')
|
||||
]
|
||||
|
||||
def main():
|
||||
parser = op.OptionParser(usage=__usage__, option_list=options())
|
||||
opts, args = parser.parse_args()
|
||||
|
||||
arbiter = gunicorn.Arbiter((opts.host, opts.port), opts.workers,app)
|
||||
arbiter.run()
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
||||
main(__usage__, get_app)
|
||||
|
||||
@ -25,5 +25,3 @@
|
||||
# OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
__version__ = "0.1"
|
||||
|
||||
from arbiter import Arbiter
|
||||
@ -36,7 +36,6 @@ import time
|
||||
|
||||
from worker import Worker
|
||||
|
||||
logging.basicConfig(level=logging.DEBUG, format="%(levelname)s: %(message)s")
|
||||
log = logging.getLogger(__name__)
|
||||
|
||||
class Arbiter(object):
|
||||
|
||||
79
gunicorn/main.py
Normal file
79
gunicorn/main.py
Normal file
@ -0,0 +1,79 @@
|
||||
# -*- coding: utf-8 -
|
||||
#
|
||||
# 2009 (c) Benoit Chesneau <benoitc@e-engura.com>
|
||||
# 2009 (c) Paul J. Davis <paul.joseph.davis@gmail.com>
|
||||
#
|
||||
# Permission is hereby granted, free of charge, to any person
|
||||
# obtaining a copy of this software and associated documentation
|
||||
# files (the "Software"), to deal in the Software without
|
||||
# restriction, including without limitation the rights to use,
|
||||
# copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
# copies of the Software, and to permit persons to whom the
|
||||
# Software is furnished to do so, subject to the following
|
||||
# conditions:
|
||||
#
|
||||
# The above copyright notice and this permission notice shall be
|
||||
# included in all copies or substantial portions of the Software.
|
||||
#
|
||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||||
# OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||
# HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||
# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
# OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
import logging
|
||||
import optparse as op
|
||||
import os
|
||||
import sys
|
||||
|
||||
from arbiter import Arbiter
|
||||
|
||||
LOG_LEVELS = {
|
||||
"critical": logging.CRITICAL,
|
||||
"error": logging.ERROR,
|
||||
"warning": logging.WARNING,
|
||||
"info": logging.INFO,
|
||||
"debug": logging.DEBUG
|
||||
}
|
||||
|
||||
def options():
|
||||
return [
|
||||
op.make_option('--host', dest='host', default='127.0.0.1',
|
||||
help='Host to listen on. [%default]'),
|
||||
op.make_option('--port', dest='port', default=8000, type='int',
|
||||
help='Port to listen on. [%default]'),
|
||||
op.make_option('--workers', dest='workers', default=1, type='int',
|
||||
help='Number of workers to spawn. [%default]'),
|
||||
op.make_option('--log-level', dest='loglevel', default='info',
|
||||
help='Log level below which to silence messages. [%default]'),
|
||||
op.make_option('--log-file', dest='logfile', default='-',
|
||||
help='Log to a file. - is stdout. [%default]')
|
||||
]
|
||||
|
||||
def configure_logging(opts):
|
||||
handlers = []
|
||||
if opts.logfile != "-":
|
||||
handlers.append(logging.FileHandler(opts.logfile))
|
||||
else:
|
||||
handlers.append(logging.StreamHandler())
|
||||
|
||||
loglevel = LOG_LEVELS.get(opts.loglevel.lower(), logging.INFO)
|
||||
|
||||
logger = logging.getLogger()
|
||||
logger.setLevel(loglevel)
|
||||
for h in handlers:
|
||||
h.setFormatter(logging.Formatter("%(levelname)s %(message)s"))
|
||||
logger.addHandler(h)
|
||||
|
||||
def main(usage, get_app):
|
||||
parser = op.OptionParser(usage=usage, option_list=options())
|
||||
opts, args = parser.parse_args()
|
||||
configure_logging(opts)
|
||||
|
||||
app = get_app(parser, opts, args)
|
||||
arbiter = Arbiter((opts.host, opts.port), opts.workers, app)
|
||||
arbiter.run()
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user