34 #ifndef GRPCXX_SERVER_BUILDER_H
35 #define GRPCXX_SERVER_BUILDER_H
46 #include <grpc/compression.h>
47 #include <grpc/support/cpu.h>
48 #include <grpc/support/useful.h>
49 #include <grpc/support/workaround_list.h>
55 class AsyncGenericService;
57 class CompletionQueue;
60 class ServerCompletionQueue;
61 class ServerCredentials;
65 class ServerBuilderPluginTest;
100 max_receive_message_size_ = max_receive_message_size;
106 max_send_message_size_ = max_send_message_size;
162 std::shared_ptr<ServerCredentials> creds,
163 int* selected_port =
nullptr);
188 bool is_frequently_polled =
true);
195 std::unique_ptr<ServerBuilderPlugin> (*CreatePlugin)());
203 friend class ::grpc::testing::ServerBuilderPluginTest;
207 std::shared_ptr<ServerCredentials> creds;
211 struct SyncServerSettings {
213 : num_cqs(GPR_MAX(1, gpr_cpu_num_cores())),
216 cq_timeout_msec(10000) {}
233 typedef std::unique_ptr<grpc::string> HostString;
234 struct NamedService {
235 explicit NamedService(Service* s) : service(s) {}
237 : host(new grpc::
string(h)), service(s) {}
242 int max_receive_message_size_;
243 int max_send_message_size_;
244 std::vector<std::unique_ptr<ServerBuilderOption>> options_;
245 std::vector<std::unique_ptr<NamedService>> services_;
246 std::vector<Port> ports_;
248 SyncServerSettings sync_server_settings_;
251 std::vector<ServerCompletionQueue*> cqs_;
253 std::shared_ptr<ServerCredentials> creds_;
254 std::vector<std::unique_ptr<ServerBuilderPlugin>> plugins_;
256 AsyncGenericService* generic_service_;
260 } maybe_default_compression_level_;
264 } maybe_default_compression_algorithm_;
265 uint32_t enabled_compression_algorithms_bitset_;
270 #endif // GRPCXX_SERVER_BUILDER_H
ServerBuilder & SetMaxMessageSize(int max_message_size)
Definition: server_builder.h:111
ServerBuilder & SetResourceQuota(const ResourceQuota &resource_quota)
Set the attached buffer pool for this server.
ServerBuilder & RegisterAsyncGenericService(AsyncGenericService *service)
Register a generic service.
static void InternalAddPluginFactory(std::unique_ptr< ServerBuilderPlugin >(*CreatePlugin)())
For internal use only: Register a ServerBuilderPlugin factory function.
Maximum number of polling threads.
Definition: server_builder.h:78
std::string string
Definition: config.h:50
std::unique_ptr< ServerBuilderOption > MakeChannelArgumentOption(const grpc::string &name, const grpc::string &value)
ServerBuilder & SetSyncServerOption(SyncServerOption option, int value)
Only useful if this is a Synchronous server.
Desriptor of an RPC service and its various RPC methods.
Definition: service_type.h:71
ServerBuilder & AddListeningPort(const grpc::string &addr, std::shared_ptr< ServerCredentials > creds, int *selected_port=nullptr)
Enlists an endpoint addr (port with an optional IP address) to bind the grpc::Server object to be cre...
ResourceQuota represents a bound on memory usage by the gRPC library.
Definition: resource_quota.h:49
bool is_set
Definition: server_builder.h:258
grpc_compression_level
Compression levels allow a party with knowledge of its peer's accepted encodings to request compressi...
Definition: compression_types.h:83
Definition: async_generic_service.h:60
ServerBuilder & SetMaxSendMessageSize(int max_send_message_size)
Set max send message size in bytes.
Definition: server_builder.h:105
ServerBuilder & SetDefaultCompressionLevel(grpc_compression_level level)
The default compression level to use for all channel calls in the absence of a call-specific level...
ServerBuilder & SetCompressionAlgorithmSupportStatus(grpc_compression_algorithm algorithm, bool enabled)
Set the support status for compression algorithms.
std::unique_ptr< Server > BuildAndStart()
Return a running server which is ready for processing calls.
Number of completion queues.
Definition: server_builder.h:76
grpc_compression_algorithm
The various compression algorithms supported by gRPC.
Definition: compression_types.h:71
ServerBuilder & SetOption(std::unique_ptr< ServerBuilderOption > option)
ServerBuilder & EnableWorkaround(grpc_workaround_list id)
Enable a server workaround.
ServerBuilder & SetMaxReceiveMessageSize(int max_receive_message_size)
Set max receive message size in bytes.
Definition: server_builder.h:99
ServerBuilder & RegisterService(Service *service)
Register a service.
grpc_compression_level level
Definition: server_builder.h:259
SyncServerOption
Options for synchronous servers.
Definition: server_builder.h:75
ServerBuilder & SetDefaultCompressionAlgorithm(grpc_compression_algorithm algorithm)
The default compression algorithm to use for all channel calls in the absence of a call-specific leve...
struct grpc_resource_quota grpc_resource_quota
Definition: grpc_types.h:564
std::unique_ptr< ServerCompletionQueue > AddCompletionQueue(bool is_frequently_polled=true)
Add a completion queue for handling asynchronous services.
Minimum number of polling threads.
Definition: server_builder.h:77
Completion queue timeout in milliseconds.
Definition: server_builder.h:79
ServerBuilder & AddChannelArgument(const grpc::string &arg, const T &value)
Add a channel argument (an escape hatch to tuning core library parameters directly) ...
Definition: server_builder.h:144
A builder class for the creation and startup of grpc::Server instances.
Definition: server_builder.h:69
grpc_compression_algorithm algorithm
Definition: server_builder.h:263