Package io.grpc
Class Server
java.lang.Object
io.grpc.Server
- Direct Known Subclasses:
ServerImpl
Server for listening for and dispatching incoming calls. It is not expected to be implemented by
application code or interceptors.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionabstract void
Waits for the server to become terminated.abstract boolean
awaitTermination
(long timeout, TimeUnit unit) Waits for the server to become terminated, giving up if the timeout is reached.Returns immutable services registered with the server, or an empty list if not supported by the implementation.List
<? extends SocketAddress> Returns a list of listening sockets for this server.Returns mutable services registered with the server, or an empty list if not supported by the implementation.int
getPort()
Returns the port number the server is listening on.Returns all services registered with the server, or an empty list if not supported by the implementation.abstract boolean
Returns whether the server is shutdown.abstract boolean
Returns whether the server is terminated.abstract Server
shutdown()
Initiates an orderly shutdown in which preexisting calls continue but new calls are rejected.abstract Server
Initiates a forceful shutdown in which preexisting and new calls are rejected.abstract Server
start()
Bind and start the server.
-
Constructor Details
-
Server
public Server()
-
-
Method Details
-
start
Bind and start the server. After this call returns, clients may begin connecting to the listening socket(s).- Returns:
this
object- Throws:
IllegalStateException
- if already started or shut downIOException
- if unable to bind- Since:
- 1.0.0
-
getPort
public int getPort()Returns the port number the server is listening on. This can return -1 if there is no actual port or the result otherwise does not make sense. Result is undefined after the server is terminated. If there are multiple possible ports, this will return one arbitrarily. Implementations are encouraged to return the same port on each call.- Throws:
IllegalStateException
- if the server has not yet been started.- Since:
- 1.0.0
- See Also:
-
getListenSockets
Returns a list of listening sockets for this server. May be different than the originally requested sockets (e.g. listening on port '0' may end up listening on a different port). The list is unmodifiable.- Throws:
IllegalStateException
- if the server has not yet been started.- Since:
- 1.19.0
-
getServices
@ExperimentalApi("https://github.com/grpc/grpc-java/issues/2222") public List<ServerServiceDefinition> getServices()Returns all services registered with the server, or an empty list if not supported by the implementation.- Since:
- 1.1.0
-
getImmutableServices
@ExperimentalApi("https://github.com/grpc/grpc-java/issues/2222") public List<ServerServiceDefinition> getImmutableServices()Returns immutable services registered with the server, or an empty list if not supported by the implementation.- Since:
- 1.1.0
-
getMutableServices
@ExperimentalApi("https://github.com/grpc/grpc-java/issues/2222") public List<ServerServiceDefinition> getMutableServices()Returns mutable services registered with the server, or an empty list if not supported by the implementation.- Since:
- 1.1.0
-
shutdown
Initiates an orderly shutdown in which preexisting calls continue but new calls are rejected. After this call returns, this server has released the listening socket(s) and may be reused by another server.Note that this method will not wait for preexisting calls to finish before returning.
awaitTermination()
orawaitTermination(long, TimeUnit)
needs to be called to wait for existing calls to finish.Calling this method before
start()
will shut down and terminate the server like normal, but prevents starting the server in the future.- Returns:
this
object- Since:
- 1.0.0
-
shutdownNow
Initiates a forceful shutdown in which preexisting and new calls are rejected. Although forceful, the shutdown process is still not instantaneous;isTerminated()
will likely returnfalse
immediately after this method returns. After this call returns, this server has released the listening socket(s) and may be reused by another server.Calling this method before
start()
will shut down and terminate the server like normal, but prevents starting the server in the future.- Returns:
this
object- Since:
- 1.0.0
-
isShutdown
public abstract boolean isShutdown()Returns whether the server is shutdown. Shutdown servers reject any new calls, but may still have some calls being processed.- Since:
- 1.0.0
- See Also:
-
isTerminated
public abstract boolean isTerminated()Returns whether the server is terminated. Terminated servers have no running calls and relevant resources released (like TCP connections).- Since:
- 1.0.0
- See Also:
-
awaitTermination
Waits for the server to become terminated, giving up if the timeout is reached.Calling this method before
start()
orshutdown()
is permitted and does not change its behavior.- Returns:
- whether the server is terminated, as would be done by
isTerminated()
. - Throws:
InterruptedException
-
awaitTermination
Waits for the server to become terminated.Calling this method before
start()
orshutdown()
is permitted and does not change its behavior.- Throws:
InterruptedException
- Since:
- 1.0.0
-