grpcpp/server_builder.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2015-2016 gRPC authors.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  */
18 
19 #ifndef GRPCPP_SERVER_BUILDER_H
20 #define GRPCPP_SERVER_BUILDER_H
21 
23 
24 #include <climits>
25 #include <map>
26 #include <memory>
27 #include <vector>
28 
29 #include <grpc/compression.h>
30 #include <grpc/support/cpu.h>
37 #include <grpcpp/server.h>
38 #include <grpcpp/support/config.h>
39 
40 struct grpc_resource_quota;
41 
42 namespace grpc {
43 
44 class CompletionQueue;
45 class Server;
46 class ServerCompletionQueue;
47 class AsyncGenericService;
48 class ResourceQuota;
49 class ServerCredentials;
50 class Service;
51 namespace testing {
52 class ServerBuilderPluginTest;
53 } // namespace testing
54 
55 namespace internal {
56 class ExternalConnectionAcceptorImpl;
57 } // namespace internal
58 
59 class CallbackGenericService;
60 
61 namespace experimental {
62 class OrcaServerInterceptorFactory;
63 // EXPERIMENTAL API:
64 // Interface for a grpc server to build transports with connections created out
65 // of band.
66 // See ServerBuilder's AddExternalConnectionAcceptor API.
68  public:
70  int listener_fd = -1;
71  int fd = -1;
72  ByteBuffer read_buffer; // data intended for the grpc server
73  };
75  // If called before grpc::Server is started or after it is shut down, the new
76  // connection will be closed.
77  virtual void HandleNewConnection(NewConnectionParameters* p) = 0;
78 };
79 
80 } // namespace experimental
81 } // namespace grpc
82 
83 namespace grpc {
84 
87  public:
88  ServerBuilder();
89  virtual ~ServerBuilder();
90 
92  // Primary API's
93 
104  virtual std::unique_ptr<grpc::Server> BuildAndStart();
105 
111 
128  const std::string& addr_uri,
129  std::shared_ptr<grpc::ServerCredentials> creds,
130  int* selected_port = nullptr);
131 
162  std::unique_ptr<grpc::ServerCompletionQueue> AddCompletionQueue(
163  bool is_frequently_polled = true);
164 
166  // Less commonly used RegisterService variants
167 
174 
181 
183  // Fine control knobs
184 
187  ServerBuilder& SetMaxReceiveMessageSize(int max_receive_message_size) {
188  max_receive_message_size_ = max_receive_message_size;
189  return *this;
190  }
191 
194  ServerBuilder& SetMaxSendMessageSize(int max_send_message_size) {
195  max_send_message_size_ = max_send_message_size;
196  return *this;
197  }
198 
200  ServerBuilder& SetMaxMessageSize(int max_message_size) {
201  return SetMaxReceiveMessageSize(max_message_size);
202  }
203 
210  grpc_compression_algorithm algorithm, bool enabled);
211 
215 
221 
224 
225  ServerBuilder& SetOption(std::unique_ptr<grpc::ServerBuilderOption> option);
226 
233  };
234 
237 
240  template <class T>
243  }
244 
246  static void InternalAddPluginFactory(
247  std::unique_ptr<grpc::ServerBuilderPlugin> (*CreatePlugin)());
248 
253 
258  public:
260 
262  std::vector<std::unique_ptr<
264  interceptor_creators) {
265  builder_->interceptor_creators_ = std::move(interceptor_creators);
266  }
267 
269  FROM_FD = 0 // in the form of a file descriptor
270  };
271 
276  std::unique_ptr<grpc::experimental::ExternalConnectionAcceptor>
278  std::shared_ptr<ServerCredentials> creds);
279 
283  std::shared_ptr<experimental::AuthorizationPolicyProviderInterface>
284  provider);
285 
286  private:
288  };
289 
293  std::unique_ptr<grpc::ContextAllocator> context_allocator);
294 
301 
306 
307  protected:
309  struct Port {
311  std::shared_ptr<ServerCredentials> creds;
313  };
314 
316  typedef std::unique_ptr<std::string> HostString;
317  struct NamedService {
318  explicit NamedService(grpc::Service* s) : service(s) {}
320  : host(new std::string(h)), service(s) {}
323  };
324 
326  std::vector<Port> ports() { return ports_; }
327 
329  std::vector<NamedService*> services() {
330  std::vector<NamedService*> service_refs;
331  for (auto& ptr : services_) {
332  service_refs.push_back(ptr.get());
333  }
334  return service_refs;
335  }
336 
338  std::vector<grpc::ServerBuilderOption*> options() {
339  std::vector<grpc::ServerBuilderOption*> option_refs;
340  for (auto& ptr : options_) {
341  option_refs.push_back(ptr.get());
342  }
343  return option_refs;
344  }
345 
347  void set_fetcher(grpc_server_config_fetcher* server_config_fetcher) {
348  server_config_fetcher_ = server_config_fetcher;
349  }
350 
353 
354  private:
357 
360  : num_cqs(1), min_pollers(1), max_pollers(2), cq_timeout_msec(10000) {}
361 
363  int num_cqs;
364 
368 
372 
375  };
376 
379  std::vector<std::unique_ptr<grpc::ServerBuilderOption>> options_;
380  std::vector<std::unique_ptr<NamedService>> services_;
381  std::vector<Port> ports_;
382 
384 
386  std::vector<grpc::ServerCompletionQueue*> cqs_;
387 
388  std::shared_ptr<grpc::ServerCredentials> creds_;
389  std::vector<std::unique_ptr<grpc::ServerBuilderPlugin>> plugins_;
392  std::unique_ptr<ContextAllocator> context_allocator_;
394 
395  struct {
396  bool is_set;
399  struct {
400  bool is_set;
404  std::vector<
405  std::unique_ptr<grpc::experimental::ServerInterceptorFactoryInterface>>
407  std::vector<
408  std::unique_ptr<grpc::experimental::ServerInterceptorFactoryInterface>>
410  std::vector<std::shared_ptr<grpc::internal::ExternalConnectionAcceptorImpl>>
413  std::shared_ptr<experimental::AuthorizationPolicyProviderInterface>
415 };
416 
417 } // namespace grpc
418 
419 #endif // GRPCPP_SERVER_BUILDER_H
grpc::experimental::ServerInterceptorFactoryInterface
Definition: impl/codegen/server_interceptor.h:45
grpc::experimental::ExternalConnectionAcceptor::NewConnectionParameters
Definition: grpcpp/server_builder.h:69
ptr
char * ptr
Definition: abseil-cpp/absl/base/internal/low_level_alloc_test.cc:45
compression.h
testing
Definition: aws_request_signer_test.cc:25
grpc::ServerBuilder::experimental_type::AddExternalConnectionAcceptor
std::unique_ptr< grpc::experimental::ExternalConnectionAcceptor > AddExternalConnectionAcceptor(ExternalConnectionType type, std::shared_ptr< ServerCredentials > creds)
Definition: server_builder.cc:145
grpc::AsyncGenericService
Definition: grpcpp/impl/codegen/async_generic_service.h:70
grpc::ServerBuilder::sync_server_settings_
SyncServerSettings sync_server_settings_
Definition: grpcpp/server_builder.h:383
grpc::ServerBuilder::experimental_type::ExternalConnectionType::FROM_FD
@ FROM_FD
grpc
Definition: grpcpp/alarm.h:33
grpc_resource_quota
struct grpc_resource_quota grpc_resource_quota
Definition: grpc_types.h:729
grpc_server_config_fetcher
Definition: src/core/lib/surface/server.h:497
grpc::ServerBuilder::BuildAndStart
virtual std::unique_ptr< grpc::Server > BuildAndStart()
Definition: server_builder.cc:275
grpc::ServerBuilder::options
std::vector< grpc::ServerBuilderOption * > options()
Experimental, to be deprecated.
Definition: grpcpp/server_builder.h:338
grpc::ServerBuilder::SetSyncServerOption
ServerBuilder & SetSyncServerOption(SyncServerOption option, int value)
Only useful if this is a Synchronous server.
Definition: server_builder.cc:169
grpc::testing::ServerBuilderPluginTest
Definition: server_builder_plugin_test.cc:137
grpc::experimental::ExternalConnectionAcceptor::NewConnectionParameters::fd
int fd
Definition: grpcpp/server_builder.h:71
grpc::ServerBuilder::AddChannelArgument
ServerBuilder & AddChannelArgument(const std::string &arg, const T &value)
Definition: grpcpp/server_builder.h:241
grpc::ServerBuilder::level
grpc_compression_level level
Definition: grpcpp/server_builder.h:397
workaround_list.h
grpc_compression_algorithm
grpc_compression_algorithm
Definition: compression_types.h:60
testing::internal::string
::std::string string
Definition: bloaty/third_party/protobuf/third_party/googletest/googletest/include/gtest/internal/gtest-port.h:881
grpc::ServerBuilder::NamedService
Definition: grpcpp/server_builder.h:317
framework.rpc.grpc_channelz.Server
Server
Definition: grpc_channelz.py:42
grpc::ServerBuilder::options_
std::vector< std::unique_ptr< grpc::ServerBuilderOption > > options_
Definition: grpcpp/server_builder.h:379
grpc::ResourceQuota
Definition: include/grpcpp/resource_quota.h:34
grpc::experimental::OrcaServerInterceptorFactory
Definition: orca_interceptor.h:40
server_interceptor.h
grpc::ServerBuilder::services_
std::vector< std::unique_ptr< NamedService > > services_
Definition: grpcpp/server_builder.h:380
grpc::ServerBuilder::maybe_default_compression_algorithm_
struct grpc::ServerBuilder::@7 maybe_default_compression_algorithm_
grpc::ServerBuilder::experimental
experimental_type experimental()
Definition: grpcpp/server_builder.h:305
grpc::ServerBuilder::SetOption
ServerBuilder & SetOption(std::unique_ptr< grpc::ServerBuilderOption > option)
Definition: server_builder.cc:163
env.new
def new
Definition: env.py:51
grpc::ServerBuilder::experimental_type::experimental_type
experimental_type(ServerBuilder *builder)
Definition: grpcpp/server_builder.h:259
grpc::ServerBuilder::Port
Experimental, to be deprecated.
Definition: grpcpp/server_builder.h:309
grpc::ServerBuilder::RegisterService
ServerBuilder & RegisterService(grpc::Service *service)
Definition: server_builder.cc:101
resource_quota
ResourceQuotaRefPtr resource_quota
Definition: filter_fuzzer.cc:145
T
#define T(upbtypeconst, upbtype, ctype, default_value)
grpc::ServerBuilder::NamedService::host
HostString host
Definition: grpcpp/server_builder.h:321
grpc::ServerBuilder::ports
std::vector< Port > ports()
Experimental, to be deprecated.
Definition: grpcpp/server_builder.h:326
grpc::experimental::ExternalConnectionAcceptor::NewConnectionParameters::listener_fd
int listener_fd
Definition: grpcpp/server_builder.h:70
grpc::ServerBuilder::set_fetcher
void set_fetcher(grpc_server_config_fetcher *server_config_fetcher)
Experimental API, subject to change.
Definition: grpcpp/server_builder.h:347
grpc::Service
Desriptor of an RPC service and its various RPC methods.
Definition: grpcpp/impl/codegen/service_type.h:58
grpc::ServerBuilder::SyncServerSettings
Definition: grpcpp/server_builder.h:358
grpc::ServerBuilder::RegisterAsyncGenericService
ServerBuilder & RegisterAsyncGenericService(grpc::AsyncGenericService *service)
Definition: server_builder.cc:112
uint32_t
unsigned int uint32_t
Definition: stdint-msvc2008.h:80
grpc::ServerBuilder::SetResourceQuota
ServerBuilder & SetResourceQuota(const grpc::ResourceQuota &resource_quota)
Set the attached buffer pool for this server.
Definition: server_builder.cc:212
grpc::ServerBuilder::SyncServerSettings::max_pollers
int max_pollers
Definition: grpcpp/server_builder.h:371
grpc::experimental::ExternalConnectionAcceptor::~ExternalConnectionAcceptor
virtual ~ExternalConnectionAcceptor()
Definition: grpcpp/server_builder.h:74
grpc::ServerBuilder::MAX_POLLERS
@ MAX_POLLERS
Maximum number of polling threads.
Definition: grpcpp/server_builder.h:231
server_builder_plugin.h
grpc::ServerBuilder::callback_generic_service_
grpc::CallbackGenericService * callback_generic_service_
Definition: grpcpp/server_builder.h:393
grpc::ServerBuilder::AddListeningPort
ServerBuilder & AddListeningPort(const std::string &addr_uri, std::shared_ptr< grpc::ServerCredentials > creds, int *selected_port=nullptr)
Definition: server_builder.cc:222
profile_analyzer.builder
builder
Definition: profile_analyzer.py:159
grpc::ServerBuilder::ports_
std::vector< Port > ports_
Definition: grpcpp/server_builder.h:381
grpc::ServerBuilder::creds_
std::shared_ptr< grpc::ServerCredentials > creds_
Definition: grpcpp/server_builder.h:388
grpc::ServerBuilder::MIN_POLLERS
@ MIN_POLLERS
Minimum number of polling threads.
Definition: grpcpp/server_builder.h:230
absl::move
constexpr absl::remove_reference_t< T > && move(T &&t) noexcept
Definition: abseil-cpp/absl/utility/utility.h:221
grpc::ServerBuilder::experimental_type::SetAuthorizationPolicyProvider
void SetAuthorizationPolicyProvider(std::shared_ptr< experimental::AuthorizationPolicyProviderInterface > provider)
Definition: server_builder.cc:157
grpc::ServerBuilder::plugins_
std::vector< std::unique_ptr< grpc::ServerBuilderPlugin > > plugins_
Definition: grpcpp/server_builder.h:389
grpc::ServerBuilder::CQ_TIMEOUT_MSEC
@ CQ_TIMEOUT_MSEC
Completion queue timeout in milliseconds.
Definition: grpcpp/server_builder.h:232
grpc::ServerBuilder::NamedService::NamedService
NamedService(const std::string &h, grpc::Service *s)
Definition: grpcpp/server_builder.h:319
grpc::ServerBuilder::authorization_provider_
std::shared_ptr< experimental::AuthorizationPolicyProviderInterface > authorization_provider_
Definition: grpcpp/server_builder.h:414
grpc::ServerBuilder
A builder class for the creation and startup of grpc::Server instances.
Definition: grpcpp/server_builder.h:86
grpc::ServerBuilder::SetDefaultCompressionAlgorithm
ServerBuilder & SetDefaultCompressionAlgorithm(grpc_compression_algorithm algorithm)
Definition: server_builder.cc:205
grpc::ServerBuilder::SetMaxSendMessageSize
ServerBuilder & SetMaxSendMessageSize(int max_send_message_size)
Definition: grpcpp/server_builder.h:194
grpc::ServerBuilder::internal_interceptor_creators_
std::vector< std::unique_ptr< grpc::experimental::ServerInterceptorFactoryInterface > > internal_interceptor_creators_
Definition: grpcpp/server_builder.h:409
grpc::ServerBuilder::experimental_type
Definition: grpcpp/server_builder.h:257
grpc::ServerBuilder::NamedService::service
grpc::Service * service
Definition: grpcpp/server_builder.h:322
grpc::ServerBuilder::BuildChannelArgs
virtual ChannelArguments BuildChannelArgs()
Experimental API, subject to change.
Definition: server_builder.cc:237
grpc::ServerBuilder::server_config_fetcher_
grpc_server_config_fetcher * server_config_fetcher_
Definition: grpcpp/server_builder.h:412
grpc::ServerBuilder::ServerBuilder
ServerBuilder()
Definition: server_builder.cc:66
grpc::ServerBuilder::Port::selected_port
int * selected_port
Definition: grpcpp/server_builder.h:312
cpu.h
arg
Definition: cmdline.cc:40
grpc::ByteBuffer
A sequence of bytes.
Definition: include/grpcpp/impl/codegen/byte_buffer.h:61
grpc::ServerBuilder::SyncServerOption
SyncServerOption
Options for synchronous servers.
Definition: grpcpp/server_builder.h:228
grpc::ServerBuilder::SyncServerSettings::SyncServerSettings
SyncServerSettings()
Definition: grpcpp/server_builder.h:359
grpc::ServerBuilder::generic_service_
grpc::AsyncGenericService * generic_service_
Definition: grpcpp/server_builder.h:391
server_builder_option.h
grpc::ServerBuilder::HostString
std::unique_ptr< std::string > HostString
Experimental, to be deprecated.
Definition: grpcpp/server_builder.h:316
grpc::ServerBuilder::cqs_
std::vector< grpc::ServerCompletionQueue * > cqs_
List of completion queues added via AddCompletionQueue method.
Definition: grpcpp/server_builder.h:386
grpc::ServerBuilder::SetMaxReceiveMessageSize
ServerBuilder & SetMaxReceiveMessageSize(int max_receive_message_size)
Definition: grpcpp/server_builder.h:187
grpc::ServerBuilder::SetCompressionAlgorithmSupportStatus
ServerBuilder & SetCompressionAlgorithmSupportStatus(grpc_compression_algorithm algorithm, bool enabled)
Definition: server_builder.cc:188
config.h
grpc::CallbackGenericService
Definition: grpcpp/impl/codegen/async_generic_service.h:104
grpc::ServerBuilder::AddCompletionQueue
std::unique_ptr< grpc::ServerCompletionQueue > AddCompletionQueue(bool is_frequently_polled=true)
Definition: server_builder.cc:91
grpc::experimental::ExternalConnectionAcceptor
Definition: grpcpp/server_builder.h:67
grpc::ServerBuilder::experimental_type::builder_
ServerBuilder * builder_
Definition: grpcpp/server_builder.h:287
value
const char * value
Definition: hpack_parser_table.cc:165
grpc::ServerBuilder::~ServerBuilder
virtual ~ServerBuilder()
Definition: server_builder.cc:85
grpc::experimental::ExternalConnectionAcceptor::HandleNewConnection
virtual void HandleNewConnection(NewConnectionParameters *p)=0
grpc::ServerBuilder::NamedService::NamedService
NamedService(grpc::Service *s)
Definition: grpcpp/server_builder.h:318
grpc::ServerBuilder::context_allocator_
std::unique_ptr< ContextAllocator > context_allocator_
Definition: grpcpp/server_builder.h:392
grpc::ChannelArguments
Definition: grpcpp/support/channel_arguments.h:39
grpc::ServerBuilder::max_receive_message_size_
int max_receive_message_size_
Definition: grpcpp/server_builder.h:377
grpc::ServerBuilder::SetDefaultCompressionLevel
ServerBuilder & SetDefaultCompressionLevel(grpc_compression_level level)
Definition: server_builder.cc:198
grpc::experimental::ExternalConnectionAcceptor::NewConnectionParameters::read_buffer
ByteBuffer read_buffer
Definition: grpcpp/server_builder.h:72
grpc::ServerBuilder::SyncServerSettings::cq_timeout_msec
int cq_timeout_msec
The timeout for server completion queue's AsyncNext call.
Definition: grpcpp/server_builder.h:374
grpc::ServerBuilder::Port::creds
std::shared_ptr< ServerCredentials > creds
Definition: grpcpp/server_builder.h:311
grpc::ServerBuilder::is_set
bool is_set
Definition: grpcpp/server_builder.h:396
grpc::MakeChannelArgumentOption
std::unique_ptr< ServerBuilderOption > MakeChannelArgumentOption(const std::string &name, const std::string &value)
Definition: channel_argument_option.cc:31
port_platform.h
grpc_workaround_list
grpc_workaround_list
Definition: workaround_list.h:26
grpc_compression_level
grpc_compression_level
Definition: compression_types.h:72
std
Definition: grpcpp/impl/codegen/async_unary_call.h:407
grpc::ServerBuilder::maybe_default_compression_level_
struct grpc::ServerBuilder::@6 maybe_default_compression_level_
grpc::ServerBuilder::NUM_CQS
@ NUM_CQS
Number of completion queues.
Definition: grpcpp/server_builder.h:229
grpc::ServerBuilder::interceptor_creators_
std::vector< std::unique_ptr< grpc::experimental::ServerInterceptorFactoryInterface > > interceptor_creators_
Definition: grpcpp/server_builder.h:406
grpc::ServerBuilder::resource_quota_
grpc_resource_quota * resource_quota_
Definition: grpcpp/server_builder.h:390
grpc::ServerBuilder::Port::addr
std::string addr
Definition: grpcpp/server_builder.h:310
grpc::ServerBuilder::EnableWorkaround
ServerBuilder & EnableWorkaround(grpc_workaround_list id)
Definition: server_builder.cc:464
internal
Definition: benchmark/test/output_test_helper.cc:20
grpc::ServerBuilder::experimental_type::ExternalConnectionType
ExternalConnectionType
Definition: grpcpp/server_builder.h:268
authorization_policy_provider.h
grpc::ServerBuilder::experimental_type::SetInterceptorCreators
void SetInterceptorCreators(std::vector< std::unique_ptr< grpc::experimental::ServerInterceptorFactoryInterface >> interceptor_creators)
Definition: grpcpp/server_builder.h:261
asyncio_get_stats.type
type
Definition: asyncio_get_stats.py:37
grpc.beta.implementations.ServerCredentials
ServerCredentials
Definition: implementations.py:231
server.h
grpc::ServerBuilder::SyncServerSettings::num_cqs
int num_cqs
Number of server completion queues to create to listen to incoming RPCs.
Definition: grpcpp/server_builder.h:363
service
__attribute__((deprecated("Please use GRPCProtoMethod."))) @interface ProtoMethod NSString * service
Definition: ProtoMethod.h:25
grpc::ServerBuilder::SyncServerSettings::min_pollers
int min_pollers
Definition: grpcpp/server_builder.h:367
grpc::ServerBuilder::services
std::vector< NamedService * > services()
Experimental, to be deprecated.
Definition: grpcpp/server_builder.h:329
grpc::ServerBuilder::InternalAddPluginFactory
static void InternalAddPluginFactory(std::unique_ptr< grpc::ServerBuilderPlugin >(*CreatePlugin)())
For internal use only: Register a ServerBuilderPlugin factory function.
Definition: server_builder.cc:458
grpc::ServerBuilder::acceptors_
std::vector< std::shared_ptr< grpc::internal::ExternalConnectionAcceptorImpl > > acceptors_
Definition: grpcpp/server_builder.h:411
grpc::ServerBuilder::SetMaxMessageSize
ServerBuilder & SetMaxMessageSize(int max_message_size)
Definition: grpcpp/server_builder.h:200
grpc::ServerBuilder::RegisterCallbackGenericService
ServerBuilder & RegisterCallbackGenericService(grpc::CallbackGenericService *service)
Definition: server_builder.cc:125
channel_argument_option.h
google_benchmark.option
option
Definition: third_party/benchmark/bindings/python/google_benchmark/__init__.py:115
grpc::ServerBuilder::SetContextAllocator
ServerBuilder & SetContextAllocator(std::unique_ptr< grpc::ContextAllocator > context_allocator)
Definition: server_builder.cc:138
grpc::ServerBuilder::max_send_message_size_
int max_send_message_size_
Definition: grpcpp/server_builder.h:378
grpc::ServerBuilder::enabled_compression_algorithms_bitset_
uint32_t enabled_compression_algorithms_bitset_
Definition: grpcpp/server_builder.h:403
grpc::ServerBuilder::algorithm
grpc_compression_algorithm algorithm
Definition: grpcpp/server_builder.h:401


grpc
Author(s):
autogenerated on Thu Mar 13 2025 03:01:16