~loggerhead-team/loggerhead/trunk-rich

« back to all changes in this revision

Viewing changes to start-loggerhead

  • Committer: Martin Albisetti
  • Date: 2008-07-29 20:42:35 UTC
  • mto: This revision was merged to the branch mainline in revision 188.
  • Revision ID: argentina@gmail.com-20080729204235-nhhd02ll6vegonqp
Ignore build/

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/env python
 
2
# This program is free software; you can redistribute it and/or modify
 
3
# it under the terms of the GNU General Public License as published by
 
4
# the Free Software Foundation; either version 2 of the License, or
 
5
# (at your option) any later version.
 
6
#
 
7
# This program is distributed in the hope that it will be useful,
 
8
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
9
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
10
# GNU General Public License for more details.
 
11
#
 
12
# You should have received a copy of the GNU General Public License
 
13
# along with this program; if not, write to the Free Software
 
14
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
15
 
 
16
"""A script for starting the loggerhead process."""
 
17
 
 
18
 
 
19
import logging
 
20
import logging.handlers
 
21
from optparse import OptionParser
 
22
import os
 
23
import sys
 
24
import urlparse
 
25
 
 
26
from configobj import ConfigObj
 
27
 
 
28
from paste import httpserver
 
29
from paste.httpexceptions import make_middleware
 
30
from paste.translogger import make_filter
 
31
 
 
32
from loggerhead import daemon, release
 
33
from loggerhead.apps.config import Root
 
34
 
 
35
 
 
36
def make_handler(config, filename):
 
37
    roll = config.get('log.roll', 'never')
 
38
    if roll == 'daily':
 
39
        h = logging.handlers.TimedRotatingFileHandler(filename, 'midnight', 0, 100)
 
40
    elif roll == 'weekly':
 
41
        h = logging.handlers.TimedRotatingFileHandler(filename, 'W0', 0, 100)
 
42
    else:
 
43
        h = logging.FileHandler(filename)
 
44
    return h
 
45
 
 
46
 
 
47
def setup_logging(home, config, foreground):
 
48
    # i hate that stupid logging config format, so just set up logging here.
 
49
 
 
50
    log_folder = os.path.join(home, 'logs')
 
51
    if not os.path.exists(log_folder):
 
52
        os.mkdir(log_folder)
 
53
 
 
54
    f = logging.Formatter('%(levelname)-.3s [%(asctime)s.%(msecs)03d] %(name)s: %(message)s',
 
55
                          '%Y%m%d-%H:%M:%S')
 
56
    debug_log = make_handler(config, os.path.join(log_folder, 'debug.log'))
 
57
    debug_log.setLevel(logging.DEBUG)
 
58
    debug_log.setFormatter(f)
 
59
    if foreground:
 
60
        stdout_log = logging.StreamHandler(sys.stdout)
 
61
        stdout_log.setLevel(logging.DEBUG)
 
62
        stdout_log.setFormatter(f)
 
63
    f = logging.Formatter('[%(asctime)s.%(msecs)03d] %(message)s',
 
64
                          '%Y%m%d-%H:%M:%S')
 
65
    access_log = make_handler(config, os.path.join(log_folder, 'access.log'))
 
66
    access_log.setLevel(logging.INFO)
 
67
    access_log.setFormatter(f)
 
68
 
 
69
    logging.getLogger('').setLevel(logging.DEBUG)
 
70
    logging.getLogger('').addHandler(debug_log)
 
71
    logging.getLogger('wsgi').addHandler(access_log)
 
72
 
 
73
    if foreground:
 
74
        logging.getLogger('').addHandler(stdout_log)
 
75
 
 
76
 
 
77
 
 
78
def main():
 
79
    parser = OptionParser(usage='usage: %prog [options]', version='%prog ' + release.version)
 
80
    parser.add_option('-f', '--foreground', action='store_true', dest='foreground', default=False,
 
81
                      help="run in the foreground; don't daemonize")
 
82
    parser.add_option('-C', '--check', action='store_true', dest='check', default=False,
 
83
                      help="only start if not already running (useful for cron jobs)")
 
84
    options, args = parser.parse_args()
 
85
    if len(args) > 0:
 
86
        parser.error('No filename arguments are used, only options.')
 
87
 
 
88
 
 
89
    home = os.path.realpath(os.path.dirname(__file__))
 
90
    pidfile = os.path.join(home, 'loggerhead.pid')
 
91
 
 
92
    if options.check:
 
93
        if daemon.is_running(pidfile):
 
94
            sys.exit(0)
 
95
        sys.stderr.write('Did not find loggerhead running in %r; restarting...\n' % (pidfile,))
 
96
 
 
97
    # read loggerhead config
 
98
 
 
99
    config = ConfigObj(os.path.join(home, 'loggerhead.conf'), encoding='utf-8')
 
100
    extra_path = config.get('bzrpath', None)
 
101
    if extra_path:
 
102
        sys.path.insert(0, extra_path)
 
103
 
 
104
    #turbogears.update_config(configfile="dev.cfg", modulename="loggerhead.config")
 
105
 
 
106
    potential_overrides = [ ('server.socket_port', int),
 
107
                            ('server.webpath', str),
 
108
                            ('server.thread_pool', int),
 
109
                            ('server.socket_host' ,str) ]
 
110
    server_port = int(config.get('server.socket_port', 8080))
 
111
    nworkers = int(config.get('server.thread_pool', 10))
 
112
    server_host = config.get('server.socket_host', '0.0.0.0')
 
113
    webpath = config.get('server.webpath', None)
 
114
 
 
115
    for key, keytype in potential_overrides:
 
116
        value = config.get(key, None)
 
117
        if value is not None:
 
118
            value = keytype(value)
 
119
            #turbogears.config.update({ key: value })
 
120
 
 
121
    if not options.foreground:
 
122
        sys.stderr.write('\n')
 
123
        sys.stderr.write('Launching loggerhead into the background.\n')
 
124
        sys.stderr.write('PID file: %s\n' % (pidfile,))
 
125
        sys.stderr.write('\n')
 
126
 
 
127
        daemon.daemonize(pidfile, home)
 
128
 
 
129
    setup_logging(home, config, foreground=options.foreground)
 
130
 
 
131
    log = logging.getLogger('loggerhead')
 
132
    log.info('Starting up...')
 
133
 
 
134
    app = Root(config)
 
135
 
 
136
    app = app
 
137
    app = make_middleware(app)
 
138
    app = make_filter(app, None)
 
139
 
 
140
    if webpath:
 
141
        scheme, netloc, path, blah, blah, blah = urlparse.urlparse(webpath)
 
142
        def app(environ, start_response, orig=app):
 
143
            environ['SCRIPT_NAME'] = path
 
144
            environ['HTTP_HOST'] = netloc
 
145
            return orig(environ, start_response)
 
146
 
 
147
    try:
 
148
        httpserver.serve(
 
149
            app, host=server_host, port=server_port,
 
150
            threadpool_workers=nworkers)
 
151
    finally:
 
152
        log.info('Shutdown.')
 
153
        try:
 
154
            os.remove(pidfile)
 
155
        except OSError:
 
156
            pass
 
157
 
 
158
 
 
159
if __name__ == '__main__':
 
160
    main()