2010-08-31 16:58:41 +00:00
|
|
|
/*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
* or more contributor license agreements. See the NOTICE file
|
|
|
|
* distributed with this work for additional information
|
|
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
|
|
* to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance
|
|
|
|
* with the License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing,
|
|
|
|
* software distributed under the License is distributed on an
|
|
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
|
|
* KIND, either express or implied. See the License for the
|
|
|
|
* specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _THRIFT_SERVER_TZMQSERVER_H_
|
|
|
|
#define _THRIFT_SERVER_TZMQSERVER_H_ 1
|
|
|
|
|
2019-01-05 08:43:55 +00:00
|
|
|
#include <memory>
|
2010-08-31 16:58:41 +00:00
|
|
|
#include <zmq.hpp>
|
2012-04-13 09:12:31 +00:00
|
|
|
#include <thrift/server/TServer.h>
|
2010-08-31 16:58:41 +00:00
|
|
|
|
|
|
|
namespace apache { namespace thrift { namespace server {
|
|
|
|
|
|
|
|
class TZmqServer : public TServer {
|
|
|
|
public:
|
|
|
|
TZmqServer(
|
2019-01-05 08:43:55 +00:00
|
|
|
std::shared_ptr<TProcessor> processor,
|
2010-08-31 16:58:41 +00:00
|
|
|
zmq::context_t& ctx, const std::string& endpoint, int type)
|
|
|
|
: TServer(processor)
|
2014-12-22 21:21:24 +00:00
|
|
|
, processor_(processor)
|
2010-08-31 16:58:41 +00:00
|
|
|
, zmq_type_(type)
|
|
|
|
, sock_(ctx, type)
|
|
|
|
{
|
|
|
|
if(zmq_type_ == ZMQ_SUB) {
|
|
|
|
sock_.setsockopt(ZMQ_SUBSCRIBE, "", 0) ; // listen to all messages
|
|
|
|
sock_.connect(endpoint.c_str()) ;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
sock_.bind(endpoint.c_str());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bool serveOne(int recv_flags = 0);
|
|
|
|
void serve() {
|
|
|
|
while (true) {
|
|
|
|
serveOne();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
zmq::socket_t& getSocket() {
|
|
|
|
return sock_;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2019-01-05 08:43:55 +00:00
|
|
|
std::shared_ptr<TProcessor> processor_;
|
2010-08-31 16:58:41 +00:00
|
|
|
int zmq_type_;
|
|
|
|
zmq::socket_t sock_;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class TZmqMultiServer {
|
|
|
|
public:
|
|
|
|
void serveOne(long timeout = -1);
|
|
|
|
void serveForever();
|
|
|
|
|
|
|
|
std::vector<TZmqServer*>& servers() {
|
|
|
|
return servers_;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
zmq::pollitem_t* setupPoll();
|
|
|
|
void serveActive(zmq::pollitem_t* items, long timeout);
|
|
|
|
std::vector<TZmqServer*> servers_;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
}}} // apache::thrift::server
|
|
|
|
|
|
|
|
#endif // #ifndef _THRIFT_SERVER_TZMQSERVER_H_
|