blob: c750b8cf7bf4f67399074028bf6f4fe6f63d7e45 [file] [log] [blame]
David Reissea2cba82009-03-30 21:35:00 +00001/*
2 * Licensed to the Apache Software Foundation (ASF) under one
3 * or more contributor license agreements. See the NOTICE file
4 * distributed with this work for additional information
5 * regarding copyright ownership. The ASF licenses this file
6 * to you under the Apache License, Version 2.0 (the
7 * "License"); you may not use this file except in compliance
8 * with the License. You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing,
13 * software distributed under the License is distributed on an
14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15 * KIND, either express or implied. See the License for the
16 * specific language governing permissions and limitations
17 * under the License.
18 */
Mark Slee9f0c6512007-02-28 23:58:26 +000019
Mark Sleed788b2e2006-09-07 01:26:35 +000020#ifndef _THRIFT_SERVER_TTHREADPOOLSERVER_H_
21#define _THRIFT_SERVER_TTHREADPOOLSERVER_H_ 1
Marc Slemko35452342006-08-03 19:01:37 +000022
Jim King5871d2c2016-04-05 13:00:24 -040023#include <boost/atomic.hpp>
Roger Meier49ff8b12012-04-13 09:12:31 +000024#include <thrift/concurrency/ThreadManager.h>
Jim King21b68522015-04-26 18:30:26 -040025#include <thrift/server/TServerFramework.h>
Marc Slemko35452342006-08-03 19:01:37 +000026
Konrad Grochowski16a23a62014-11-13 15:33:38 +010027namespace apache {
28namespace thrift {
29namespace server {
Marc Slemko16698852006-08-04 03:16:10 +000030
Jim King21b68522015-04-26 18:30:26 -040031/**
32 * Manage clients using a thread pool.
33 */
34class TThreadPoolServer : public TServerFramework {
Konrad Grochowski16a23a62014-11-13 15:33:38 +010035public:
Jim King21b68522015-04-26 18:30:26 -040036 TThreadPoolServer(
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020037 const boost::shared_ptr<apache::thrift::TProcessorFactory>& processorFactory,
38 const boost::shared_ptr<apache::thrift::transport::TServerTransport>& serverTransport,
39 const boost::shared_ptr<apache::thrift::transport::TTransportFactory>& transportFactory,
40 const boost::shared_ptr<apache::thrift::protocol::TProtocolFactory>& protocolFactory,
41 const boost::shared_ptr<apache::thrift::concurrency::ThreadManager>& threadManager
42 = apache::thrift::concurrency::ThreadManager::newSimpleThreadManager());
Marc Slemko16698852006-08-04 03:16:10 +000043
Jim King21b68522015-04-26 18:30:26 -040044 TThreadPoolServer(
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020045 const boost::shared_ptr<apache::thrift::TProcessor>& processor,
46 const boost::shared_ptr<apache::thrift::transport::TServerTransport>& serverTransport,
47 const boost::shared_ptr<apache::thrift::transport::TTransportFactory>& transportFactory,
48 const boost::shared_ptr<apache::thrift::protocol::TProtocolFactory>& protocolFactory,
49 const boost::shared_ptr<apache::thrift::concurrency::ThreadManager>& threadManager
50 = apache::thrift::concurrency::ThreadManager::newSimpleThreadManager());
Bryan Duxbury7a9fb812011-09-01 18:31:53 +000051
Jim King21b68522015-04-26 18:30:26 -040052 TThreadPoolServer(
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020053 const boost::shared_ptr<apache::thrift::TProcessorFactory>& processorFactory,
54 const boost::shared_ptr<apache::thrift::transport::TServerTransport>& serverTransport,
55 const boost::shared_ptr<apache::thrift::transport::TTransportFactory>& inputTransportFactory,
56 const boost::shared_ptr<apache::thrift::transport::TTransportFactory>& outputTransportFactory,
57 const boost::shared_ptr<apache::thrift::protocol::TProtocolFactory>& inputProtocolFactory,
58 const boost::shared_ptr<apache::thrift::protocol::TProtocolFactory>& outputProtocolFactory,
59 const boost::shared_ptr<apache::thrift::concurrency::ThreadManager>& threadManager
60 = apache::thrift::concurrency::ThreadManager::newSimpleThreadManager());
Bryan Duxbury7a9fb812011-09-01 18:31:53 +000061
Jim King21b68522015-04-26 18:30:26 -040062 TThreadPoolServer(
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020063 const boost::shared_ptr<apache::thrift::TProcessor>& processor,
64 const boost::shared_ptr<apache::thrift::transport::TServerTransport>& serverTransport,
65 const boost::shared_ptr<apache::thrift::transport::TTransportFactory>& inputTransportFactory,
66 const boost::shared_ptr<apache::thrift::transport::TTransportFactory>& outputTransportFactory,
67 const boost::shared_ptr<apache::thrift::protocol::TProtocolFactory>& inputProtocolFactory,
68 const boost::shared_ptr<apache::thrift::protocol::TProtocolFactory>& outputProtocolFactory,
69 const boost::shared_ptr<apache::thrift::concurrency::ThreadManager>& threadManager
70 = apache::thrift::concurrency::ThreadManager::newSimpleThreadManager());
Aditya Agarwal9abb0d62007-01-24 22:53:54 +000071
Marc Slemko16698852006-08-04 03:16:10 +000072 virtual ~TThreadPoolServer();
73
Jim King5ec805b2015-04-26 07:52:40 -040074 /**
Jim King5ec805b2015-04-26 07:52:40 -040075 * Post-conditions (return guarantees):
Jim King21b68522015-04-26 18:30:26 -040076 * There will be no clients connected.
Jim King5ec805b2015-04-26 07:52:40 -040077 */
Mark Slee794993d2006-09-20 01:56:10 +000078 virtual void serve();
Marc Slemko3a3b53b2007-05-22 23:59:54 +000079
Mark Slee9b82d272007-05-23 05:16:07 +000080 virtual int64_t getTimeout() const;
Mark Slee9b82d272007-05-23 05:16:07 +000081 virtual void setTimeout(int64_t value);
Mark Sleeb4d3e7b2007-11-28 01:51:43 +000082
Roger Meier5ed5e8b2013-05-06 00:21:04 +020083 virtual int64_t getTaskExpiration() const;
Roger Meier5ed5e8b2013-05-06 00:21:04 +020084 virtual void setTaskExpiration(int64_t value);
85
Jim King79c99112015-04-30 07:10:08 -040086 virtual boost::shared_ptr<apache::thrift::concurrency::ThreadManager> getThreadManager() const;
87
Konrad Grochowski16a23a62014-11-13 15:33:38 +010088protected:
Jim King21b68522015-04-26 18:30:26 -040089 virtual void onClientConnected(const boost::shared_ptr<TConnectedClient>& pClient) /* override */;
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020090 virtual void onClientDisconnected(TConnectedClient* pClient) /* override */;
Jim King21b68522015-04-26 18:30:26 -040091
92 boost::shared_ptr<apache::thrift::concurrency::ThreadManager> threadManager_;
Jim King5871d2c2016-04-05 13:00:24 -040093 boost::atomic<int64_t> timeout_;
94 boost::atomic<int64_t> taskExpiration_;
Marc Slemko16698852006-08-04 03:16:10 +000095};
Jim King5871d2c2016-04-05 13:00:24 -040096
Konrad Grochowski16a23a62014-11-13 15:33:38 +010097}
98}
99} // apache::thrift::server
Marc Slemko35452342006-08-03 19:01:37 +0000100
Mark Sleed788b2e2006-09-07 01:26:35 +0000101#endif // #ifndef _THRIFT_SERVER_TTHREADPOOLSERVER_H_