Interface NodeRegistry
- All Superinterfaces:
- AutoCloseable,- Closeable,- HasReadyState
- All Known Implementing Classes:
- LocalNodeRegistry
Maintains a registry of the nodes available for a 
Distributor. Implementations may store nodes in memory or
 in an external data store to allow for high availability configurations.- 
Method SummaryModifier and TypeMethodDescriptionvoidAdd a node to this registry.booleanSet a node to draining state.intGet the number of active slots.Gets all available nodes that are not DOWN or DRAINING and has free slots.longGets the total number of nodes that are DOWN.intGet the number of idle slots.Get node by URI.Gets a node by its ID.Gets a snapshot of all registered nodes.longGets the total number of nodes that are UP.Get all nodes that are UP.voidrefresh()Refreshes all nodes by running a health check on each one.voidregister(NodeStatus status) Register a node status received from an event.voidRemoves a node from this registry.booleanReserve a slot for a session.voidRun health checks on all nodes.voidsetSession(SlotId slotId, Session session) Set a session for a particular slot.voidupdateNodeAvailability(URI nodeUri, NodeId id, Availability availability) Updates a node's availability status.Methods inherited from interface org.openqa.selenium.status.HasReadyStateisReady
- 
Method Details- 
registerRegister a node status received from an event.- Parameters:
- status- The node status to register.
 
- 
addAdd a node to this registry.- Parameters:
- node- The node to add.
 
- 
removeRemoves a node from this registry.- Parameters:
- nodeId- The id of the node to remove.
 
- 
drainSet a node to draining state.- Parameters:
- nodeId- The id of the node to drain.
- Returns:
- true if the node was set to draining, false otherwise.
 
- 
updateNodeAvailabilityUpdates a node's availability status.- Parameters:
- nodeUri- The URI of the node.
- id- The id of the node.
- availability- The new availability status.
 
- 
refreshvoid refresh()Refreshes all nodes by running a health check on each one.
- 
getStatusDistributorStatus getStatus()Gets a snapshot of all registered nodes.- Returns:
- The current status of the distributor.
 
- 
getUpNodesSet<NodeStatus> getUpNodes()Get all nodes that are UP.- Returns:
- Set of UP node statuses.
 
- 
getAvailableNodesSet<NodeStatus> getAvailableNodes()Gets all available nodes that are not DOWN or DRAINING and has free slots.- Returns:
- Set of available node statuses.
 
- 
getNodeGets a node by its ID.- Parameters:
- id- The node ID to look up.
- Returns:
- The node, or null if not found.
 
- 
getUpNodeCountlong getUpNodeCount()Gets the total number of nodes that are UP.- Returns:
- The number of UP nodes.
 
- 
getDownNodeCountlong getDownNodeCount()Gets the total number of nodes that are DOWN.- Returns:
- The number of DOWN nodes.
 
- 
runHealthChecksvoid runHealthChecks()Run health checks on all nodes.
- 
reserveReserve a slot for a session.- Parameters:
- slotId- The slot ID to reserve.
- Returns:
- Whether the reservation was successful.
 
- 
setSessionSet a session for a particular slot.- Parameters:
- slotId- The slot ID.
- session- The session to associate with the slot, or null to clear.
 
- 
getActiveSlotsint getActiveSlots()Get the number of active slots.
- 
getIdleSlotsint getIdleSlots()Get the number of idle slots.
- 
getNodeGet node by URI.- Parameters:
- uri- The node URI to look up.
- Returns:
- The node if found, null otherwise.
 
 
-