Package io.grpc
Class ServerRegistry
- java.lang.Object
-
- io.grpc.ServerRegistry
-
@Internal @ThreadSafe public final class ServerRegistry extends java.lang.Object
Registry ofServerProviders. Thedefault instanceloads providers at runtime through the Java service provider mechanism.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classServerRegistry.ProviderNotFoundExceptionThrown when no suitableServerProviderobjects can be found.private static classServerRegistry.ServerPriorityAccessor
-
Field Summary
Fields Modifier and Type Field Description private java.util.LinkedHashSet<ServerProvider>allProvidersprivate java.util.List<ServerProvider>effectiveProvidersImmutable, sorted version ofallProviders.private static ServerRegistryinstanceprivate static java.util.logging.Loggerlogger
-
Constructor Summary
Constructors Constructor Description ServerRegistry()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description private voidaddProvider(ServerProvider provider)voidderegister(ServerProvider provider)Deregisters a provider.static ServerRegistrygetDefaultRegistry()Returns the default registry that loads providers via the Java service loader mechanism.(package private) static java.util.List<java.lang.Class<?>>getHardCodedClasses()(package private) ServerBuilder<?>newServerBuilderForPort(int port, ServerCredentials creds)(package private) ServerProviderprovider()(package private) java.util.List<ServerProvider>providers()Returns effective providers, in priority order.private voidrefreshProviders()voidregister(ServerProvider provider)Register a provider.
-
-
-
Field Detail
-
logger
private static final java.util.logging.Logger logger
-
instance
private static ServerRegistry instance
-
allProviders
private final java.util.LinkedHashSet<ServerProvider> allProviders
-
effectiveProviders
private java.util.List<ServerProvider> effectiveProviders
Immutable, sorted version ofallProviders. Is replaced instead of mutating.
-
-
Method Detail
-
register
public void register(ServerProvider provider)
Register a provider.If the provider's
isAvailable()returnsfalse, this method will throwIllegalArgumentException.Providers will be used in priority order. In case of ties, providers are used in registration order.
-
addProvider
private void addProvider(ServerProvider provider)
-
deregister
public void deregister(ServerProvider provider)
Deregisters a provider. No-op if the provider is not in the registry.- Parameters:
provider- the provider that was added to the register viaregister(io.grpc.ServerProvider).
-
refreshProviders
private void refreshProviders()
-
getDefaultRegistry
public static ServerRegistry getDefaultRegistry()
Returns the default registry that loads providers via the Java service loader mechanism.
-
providers
java.util.List<ServerProvider> providers()
Returns effective providers, in priority order.
-
provider
ServerProvider provider()
-
getHardCodedClasses
static java.util.List<java.lang.Class<?>> getHardCodedClasses()
-
newServerBuilderForPort
ServerBuilder<?> newServerBuilderForPort(int port, ServerCredentials creds)
-
-