2016-01-19 12:50:03 +00:00
|
|
|
import signal
|
|
|
|
|
|
|
|
from sprockets.mixins import metrics
|
|
|
|
from tornado import gen, ioloop, web
|
|
|
|
|
|
|
|
|
|
|
|
class SimpleHandler(metrics.StatsdMixin, web.RequestHandler):
|
|
|
|
"""
|
|
|
|
Simply emits a timing metric around the method call.
|
|
|
|
|
|
|
|
The metric namespace and StatsD endpoint are configured in
|
|
|
|
the application settings object so there is nothing to do in
|
|
|
|
a request handler.
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
2016-01-27 15:46:23 +00:00
|
|
|
@gen.coroutine
|
|
|
|
def prepare(self):
|
|
|
|
maybe_future = super(SimpleHandler, self).prepare()
|
|
|
|
if gen.is_future(maybe_future):
|
|
|
|
yield maybe_future
|
|
|
|
|
|
|
|
if 'Correlation-ID' in self.request.headers:
|
|
|
|
self.set_metric_tag('correlation_id',
|
|
|
|
self.request.headers['Correlation-ID'])
|
|
|
|
|
2016-01-19 12:50:03 +00:00
|
|
|
@gen.coroutine
|
|
|
|
def get(self):
|
|
|
|
yield gen.sleep(0.25)
|
|
|
|
self.set_status(204)
|
|
|
|
self.finish()
|
|
|
|
|
2016-01-19 15:43:02 +00:00
|
|
|
def post(self):
|
|
|
|
"""Example of increasing a counter."""
|
|
|
|
self.increase_counter('request', 'path')
|
|
|
|
self.set_status(204)
|
|
|
|
|
|
|
|
|
2016-01-19 12:50:03 +00:00
|
|
|
def _sig_handler(*args_):
|
|
|
|
iol = ioloop.IOLoop.instance()
|
|
|
|
iol.add_callback_from_signal(iol.stop)
|
|
|
|
|
|
|
|
|
|
|
|
def make_application():
|
|
|
|
"""
|
|
|
|
Create a application configured to send metrics.
|
|
|
|
|
|
|
|
Metrics will be sent to localhost:8125 namespaced with
|
|
|
|
``webapps``. Run netcat or a similar listener then run this
|
|
|
|
example. HTTP GETs will result in a metric like::
|
|
|
|
|
|
|
|
webapps.SimpleHandler.GET.204:255.24497032165527|ms
|
|
|
|
|
|
|
|
"""
|
|
|
|
settings = {
|
|
|
|
metrics.StatsdMixin.SETTINGS_KEY: {
|
|
|
|
'namespace': 'webapps',
|
|
|
|
'host': '127.0.0.1',
|
|
|
|
'port': 8125,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return web.Application([web.url('/', SimpleHandler)], **settings)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
app = make_application()
|
|
|
|
app.listen(8000)
|
|
|
|
signal.signal(signal.SIGINT, _sig_handler)
|
|
|
|
signal.signal(signal.SIGTERM, _sig_handler)
|
|
|
|
ioloop.IOLoop.instance().start()
|