blob: b81a522b2283ebf1d0d78f7a853c51e835996dc6 [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
Roger Meier49ff8b12012-04-13 09:12:31 +000020#include <thrift/server/TThreadPoolServer.h>
Marc Slemko35452342006-08-03 19:01:37 +000021
Konrad Grochowski16a23a62014-11-13 15:33:38 +010022namespace apache {
23namespace thrift {
24namespace server {
Marc Slemko35452342006-08-03 19:01:37 +000025
Jim King21b68522015-04-26 18:30:26 -040026using apache::thrift::concurrency::ThreadManager;
27using apache::thrift::protocol::TProtocol;
28using apache::thrift::protocol::TProtocolFactory;
29using apache::thrift::transport::TServerTransport;
30using apache::thrift::transport::TTransport;
31using apache::thrift::transport::TTransportException;
32using apache::thrift::transport::TTransportFactory;
Mark Slee5ea15f92007-03-05 22:55:59 +000033using boost::shared_ptr;
Jim King21b68522015-04-26 18:30:26 -040034using std::string;
35
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020036TThreadPoolServer::TThreadPoolServer(const shared_ptr<TProcessorFactory>& processorFactory,
37 const shared_ptr<TServerTransport>& serverTransport,
38 const shared_ptr<TTransportFactory>& transportFactory,
39 const shared_ptr<TProtocolFactory>& protocolFactory,
40 const shared_ptr<ThreadManager>& threadManager)
41 : TServerFramework(processorFactory, serverTransport, transportFactory, protocolFactory),
Jim King21b68522015-04-26 18:30:26 -040042 threadManager_(threadManager),
43 timeout_(0),
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020044 taskExpiration_(0) {
45}
Jim King21b68522015-04-26 18:30:26 -040046
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020047TThreadPoolServer::TThreadPoolServer(const shared_ptr<TProcessor>& processor,
48 const shared_ptr<TServerTransport>& serverTransport,
49 const shared_ptr<TTransportFactory>& transportFactory,
50 const shared_ptr<TProtocolFactory>& protocolFactory,
51 const shared_ptr<ThreadManager>& threadManager)
52 : TServerFramework(processor, serverTransport, transportFactory, protocolFactory),
Jim King21b68522015-04-26 18:30:26 -040053 threadManager_(threadManager),
54 timeout_(0),
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020055 taskExpiration_(0) {
56}
Jim King21b68522015-04-26 18:30:26 -040057
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020058TThreadPoolServer::TThreadPoolServer(const shared_ptr<TProcessorFactory>& processorFactory,
59 const shared_ptr<TServerTransport>& serverTransport,
60 const shared_ptr<TTransportFactory>& inputTransportFactory,
61 const shared_ptr<TTransportFactory>& outputTransportFactory,
62 const shared_ptr<TProtocolFactory>& inputProtocolFactory,
63 const shared_ptr<TProtocolFactory>& outputProtocolFactory,
64 const shared_ptr<ThreadManager>& threadManager)
65 : TServerFramework(processorFactory,
66 serverTransport,
67 inputTransportFactory,
68 outputTransportFactory,
69 inputProtocolFactory,
70 outputProtocolFactory),
Jim King21b68522015-04-26 18:30:26 -040071 threadManager_(threadManager),
Jim King21b68522015-04-26 18:30:26 -040072 timeout_(0),
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020073 taskExpiration_(0) {
74}
Jim King21b68522015-04-26 18:30:26 -040075
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020076TThreadPoolServer::TThreadPoolServer(const shared_ptr<TProcessor>& processor,
77 const shared_ptr<TServerTransport>& serverTransport,
78 const shared_ptr<TTransportFactory>& inputTransportFactory,
79 const shared_ptr<TTransportFactory>& outputTransportFactory,
80 const shared_ptr<TProtocolFactory>& inputProtocolFactory,
81 const shared_ptr<TProtocolFactory>& outputProtocolFactory,
82 const shared_ptr<ThreadManager>& threadManager)
83 : TServerFramework(processor,
84 serverTransport,
85 inputTransportFactory,
86 outputTransportFactory,
87 inputProtocolFactory,
88 outputProtocolFactory),
Jim King21b68522015-04-26 18:30:26 -040089 threadManager_(threadManager),
Jim King21b68522015-04-26 18:30:26 -040090 timeout_(0),
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020091 taskExpiration_(0) {
92}
Marc Slemko35452342006-08-03 19:01:37 +000093
Konrad Grochowski1f6e3802015-05-18 18:10:06 +020094TThreadPoolServer::~TThreadPoolServer() {
95}
Marc Slemko16698852006-08-04 03:16:10 +000096
Mark Slee794993d2006-09-20 01:56:10 +000097void TThreadPoolServer::serve() {
Jim King21b68522015-04-26 18:30:26 -040098 TServerFramework::serve();
99 threadManager_->join();
Ben Craig1684c422015-04-24 08:52:44 -0500100}
101
Mark Slee9b82d272007-05-23 05:16:07 +0000102int64_t TThreadPoolServer::getTimeout() const {
103 return timeout_;
104}
105
106void TThreadPoolServer::setTimeout(int64_t value) {
107 timeout_ = value;
108}
Marc Slemko3a3b53b2007-05-22 23:59:54 +0000109
Roger Meier5ed5e8b2013-05-06 00:21:04 +0200110int64_t TThreadPoolServer::getTaskExpiration() const {
111 return taskExpiration_;
112}
113
114void TThreadPoolServer::setTaskExpiration(int64_t value) {
115 taskExpiration_ = value;
116}
Jim King21b68522015-04-26 18:30:26 -0400117
Jim King5871d2c2016-04-05 13:00:24 -0400118boost::shared_ptr<apache::thrift::concurrency::ThreadManager>
119TThreadPoolServer::getThreadManager() const {
Jim King79c99112015-04-30 07:10:08 -0400120 return threadManager_;
121}
122
Jim King21b68522015-04-26 18:30:26 -0400123void TThreadPoolServer::onClientConnected(const shared_ptr<TConnectedClient>& pClient) {
Jim King5871d2c2016-04-05 13:00:24 -0400124 threadManager_->add(pClient, getTimeout(), getTaskExpiration());
Jim King21b68522015-04-26 18:30:26 -0400125}
126
Konrad Grochowski1f6e3802015-05-18 18:10:06 +0200127void TThreadPoolServer::onClientDisconnected(TConnectedClient*) {
128}
Jim King5871d2c2016-04-05 13:00:24 -0400129
Konrad Grochowski16a23a62014-11-13 15:33:38 +0100130}
131}
132} // apache::thrift::server