Skip to content

Commit

Permalink
Reverting CLI changes in apache#1713 (apache#1964)
Browse files Browse the repository at this point in the history
  • Loading branch information
mistercrunch authored Jan 13, 2017
1 parent 24728b8 commit 99b84d2
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 77 deletions.
79 changes: 2 additions & 77 deletions superset/bin/superset
Original file line number Diff line number Diff line change
Expand Up @@ -4,82 +4,7 @@ from __future__ import division
from __future__ import print_function
from __future__ import unicode_literals

import argparse
import sys

import gunicorn.app.base


class GunicornSupersetApplication(gunicorn.app.base.BaseApplication):
def __init__(self, address, port, workers, timeout):
self.options = {
'bind': '%s:%s' % (address, port),
'workers': workers,
'timeout': timeout,
'limit-request-line': 0,
'limit-request-field_size': 0
}

super(GunicornSupersetApplication, self).__init__()

def load_config(self):
config = [(key, value) for key, value in self.options.items()
if key in self.cfg.settings and value is not None]
for key, value in config:
self.cfg.set(key.lower(), value)

def load(self):
from superset import app

return app


def run_server():
parser = argparse.ArgumentParser(description='Run gunicorn for superset')
subparsers = parser.add_subparsers()
gunicorn_parser = subparsers.add_parser('runserver')

gunicorn_parser.add_argument(
'-d', '--debug', action='store_true',
help='Start the web server in debug mode')
gunicorn_parser.add_argument(
'-a', '--address', type=str, default='0.0.0.0',
help='Specify the address to which to bind the web server')
gunicorn_parser.add_argument(
'-p', '--port', type=int, default=8088,
help='Specify the port on which to run the web server')
gunicorn_parser.add_argument(
'-w', '--workers', type=int, default=4,
help='Number of gunicorn web server workers to fire up')
gunicorn_parser.add_argument(
'-t', '--timeout', type=int, default=30,
help='Specify the timeout (seconds) for the gunicorn web server')

args = parser.parse_args()

if args.debug:
from superset import app

app.run(
host='0.0.0.0',
port=int(args.port),
threaded=True,
debug=True)
else:
gunicorn_app_obj = GunicornSupersetApplication(
args.address, args.port, args.workers, args.timeout)
gunicorn_app_obj.run()

from superset.cli import manager

if __name__ == "__main__":
if len(sys.argv) > 1 and sys.argv[1] == 'runserver':
# In the runserver case, don't go through the manager so that superset
# import is deferred until the app is loaded; this allows for the app to be run via pex
# and cleanly forked in the gunicorn case.
#
# TODO: Refactor cli so that gunicorn can be started without first importing superset;
# this will allow us to move the runserver logic back into cli module.
run_server()
else:
from superset.cli import manager
manager.run()
manager.run()
37 changes: 37 additions & 0 deletions superset/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,43 @@ def init():
security.sync_role_definitions()


@manager.option(
'-d', '--debug', action='store_true',
help="Start the web server in debug mode")
@manager.option(
'-a', '--address', default=config.get("SUPERSET_WEBSERVER_ADDRESS"),
help="Specify the address to which to bind the web server")
@manager.option(
'-p', '--port', default=config.get("SUPERSET_WEBSERVER_PORT"),
help="Specify the port on which to run the web server")
@manager.option(
'-w', '--workers', default=config.get("SUPERSET_WORKERS", 2),
help="Number of gunicorn web server workers to fire up")
@manager.option(
'-t', '--timeout', default=config.get("SUPERSET_WEBSERVER_TIMEOUT"),
help="Specify the timeout (seconds) for the gunicorn web server")
def runserver(debug, address, port, timeout, workers):
"""Starts a Superset web server"""
debug = debug or config.get("DEBUG")
if debug:
app.run(
host='0.0.0.0',
port=int(port),
threaded=True,
debug=True)
else:
cmd = (
"gunicorn "
"-w {workers} "
"--timeout {timeout} "
"-b {address}:{port} "
"--limit-request-line 0 "
"--limit-request-field_size 0 "
"superset:app").format(**locals())
print("Starting server with command: " + cmd)
Popen(cmd, shell=True).wait()


@manager.option(
'-v', '--verbose', action='store_true',
help="Show extra information")
Expand Down

0 comments on commit 99b84d2

Please sign in to comment.