项目作者: Thriftpy

项目描述 :
Thrift app and worker for gunicorn!
高级语言: Python
项目地址: git://github.com/Thriftpy/gunicorn_thrift.git
创建时间: 2014-08-03T12:50:12Z
项目社区:https://github.com/Thriftpy/gunicorn_thrift

开源协议:MIT License

下载


gunicorn_thrift

Build Status
Coverage Status

Thrift app and worker for gunicorn! Hence, a multi-process python thrift server!

Why?

  • graceful reload/shutdown.
  • manage worker number at runtime.
  • and everything else gunicorn has to offer.

Supported Platforms

  • Python 2.7, all worker classes
  • Python 3.4+, thriftpy_sync and thriftpy_gevent worker classes (code generated
    using the Thrift toolkit is not supported on Python 3)

Examples

Using thrift

  1. Generate thrift files:

    1. % thrift --out tests/pingpong_sdk --gen py:new_style,utf8strings tests/pingpong.thrift
  2. Write thrift app.

    1. #! /usr/bin/env python
    2. # tests/app.py
    3. # -*- coding: utf-8 -*-
    4. from pingpong_sdk.pingpong import PingService
    5. class PingpongServer(object):
    6. def ping(self):
    7. if os.environ.get('about_to_shutdown') == '1':
    8. raise PingService.AboutToShutDownException
    9. return "pong"
    10. app = PingService.Processor(PingpongServer())
  3. Fire up app.

    1. % gunicorn_thrift tests.app:app -k thrift_sync
    2. % gunicorn_thrift tests.app:app -k thrift_gevent

Using thriftpy2

  1. Write thrift app.

    1. #! /usr/bin/env python
    2. # tests/app.py
    3. # -*- coding: utf-8 -*-
    4. import thriftpy2
    5. from thriftpy2.thrift import TProcessor
    6. class PingPongDispatcher(object):
    7. def ping(self):
    8. return "pong"
    9. pingpong_thrift = thriftpy2.load("pingpong.thrift")
    10. app = TProcessor(pingpong_thrift.PingService, PingPongDispatcher())
  2. Fire up app.

    1. % gunicorn_thrift tests.thriftpy_app:app -k thriftpy_sync \
    2. --thrift-protocol-factory \
    3. thriftpy2.protocol:TCyBinaryProtocolFactory \
    4. --thrift-transport-factory \
    5. thriftpy2.transport:TCyBufferedTransportFactory

Configs

Workers

Parameter: -k, --worker-class
Config file: worker_class
Default 2.7: thrift_sync
Default 3.4+: thriftpy_sync

There are 4 types of workers available.

  • thrift_sync: sync worker.
  • thrift_gevent: gevent worker.
  • thriftpy_sync: sync worker, adapted for thriftpy2
  • thriftpy_gevent: gevent worker, adapted for thriftpy2

note: If you want to use thriftpy_sync or thriftpy_gevent, make sure the following:

  • Version of thriftpy2 should be higher than 0.1.10.
  • --thrift-protocol-factory should be set to either:
    1. thriftpy2.protocol:TCyBinaryProtocolFactory or
    2. thriftpy2.protocol:TBinaryProtocolFactory
  • --thrift-transport-factory should be set to either:
    1. thriftpy2.transport:TCyBufferedTransportFactory or
    2. thriftpy2.transport:TBufferedTransportFactory

Transport factory

The transport factory to use for handling connections.

Parameter: --thrift-transport-factory
Config file: thrift_transport_factory
Default 2.7: thrift.transport.TTransport:TBufferedTransportFactory
Default 3.4+: thriftpy2.transport:TBufferedTransportFactory

Protocol factory

The protocol factory to use for parsing requests.

Parameter: --thrift-protocol-factory
Config file: thrift_protocol_factory
Default 2.7: thrift.protocol.TBinaryProtocol:TBinaryProtocolAcceleratedFactory
Default 3.4+: thriftpy2.protocol:TBinaryProtocolFactory

Client timeout

Seconds to timeout a client if it is silent after this duration.

Parameter: --thrift-client-timeout
Config file: thrift_client_timeout
Default: None (Never time out a client)

Gevent check interval

This config will run a seperate thread to detect gevent ioloop block every
specified seconds.

Parameter: --gevent-check-interval
Config file: gevent_check_interval
Default: 0

Note: DONOT USE this if not running gevent worker.