]>
git.proxmox.com Git - ceph.git/blob - ceph/src/jaegertracing/thrift/contrib/zeromq/TZmqServer.h
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
10 * http://www.apache.org/licenses/LICENSE-2.0
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
20 #ifndef _THRIFT_SERVER_TZMQSERVER_H_
21 #define _THRIFT_SERVER_TZMQSERVER_H_ 1
25 #include <thrift/server/TServer.h>
27 namespace apache
{ namespace thrift
{ namespace server
{
29 class TZmqServer
: public TServer
{
32 std::shared_ptr
<TProcessor
> processor
,
33 zmq::context_t
& ctx
, const std::string
& endpoint
, int type
)
35 , processor_(processor
)
39 if(zmq_type_
== ZMQ_SUB
) {
40 sock_
.setsockopt(ZMQ_SUBSCRIBE
, "", 0) ; // listen to all messages
41 sock_
.connect(endpoint
.c_str()) ;
44 sock_
.bind(endpoint
.c_str());
48 bool serveOne(int recv_flags
= 0);
55 zmq::socket_t
& getSocket() {
60 std::shared_ptr
<TProcessor
> processor_
;
66 class TZmqMultiServer
{
68 void serveOne(long timeout
= -1);
71 std::vector
<TZmqServer
*>& servers() {
76 zmq::pollitem_t
* setupPoll();
77 void serveActive(zmq::pollitem_t
* items
, long timeout
);
78 std::vector
<TZmqServer
*> servers_
;
82 }}} // apache::thrift::server
84 #endif // #ifndef _THRIFT_SERVER_TZMQSERVER_H_