Class SearchJob
- java.lang.Object
-
- net.i2p.router.JobImpl
-
- net.i2p.router.networkdb.kademlia.SearchJob
-
- All Implemented Interfaces:
Job
- Direct Known Subclasses:
ExploreJob
class SearchJob extends JobImpl
Search for a particular key iteratively until we either find a value or we run out of peers Note that this is rarely if ever used directly, and is primary used by the ExploreJob extension. FloodOnlySearchJob and FloodSearchJob do not extend this. It also does not update peer profile stats.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description protected classSearchJob.FailedJobCalled when a particular peer failed to respond before the timeout was reached, or if the peer could not be contacted at all.
-
Field Summary
Fields Modifier and Type Field Description protected KademliaNetworkDatabaseFacade_facadeprotected Log_log(package private) static intMAX_CLOSESTonly send the 10 closest "dont tell me about" refs(package private) static longMIN_TIMEOUT(package private) static intPER_FLOODFILL_PEER_TIMEOUTtimeout
-
Constructor Summary
Constructors Constructor Description SearchJob(RouterContext context, KademliaNetworkDatabaseFacade facade, Hash key, Job onSuccess, Job onFailure, long timeoutMs, boolean keepStats, boolean isLease)Create a new search for the routingKey specified
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description (package private) booleanadd(Hash peer)intaddDeferred(Job onFind, Job onFail, long expiration, boolean isLease)protected I2NPMessagebuildMessage(TunnelId replyTunnelId, Hash replyGateway, long expiration, RouterInfo peer)Build the database search messageprotected voidcontinueSearch()Send a series of searches to the next available peers as selected by the routing table, but making sure no more than SEARCH_BREDTH are outstanding at any time(package private) voiddecrementOutstandingFloodfillSearches()protected voidfail()Search totally failedprotected intgetBredth()max # of concurrent searcheslonggetExpiration()protected KademliaNetworkDatabaseFacadegetFacade()StringgetName()Descriptive name of the taskprotected intgetPerPeerTimeoutMs()Let each peer take up to the average successful search RTTprotected intgetPerPeerTimeoutMs(Hash peer)protected SearchStategetState()longgetTimeoutMs()protected voidnewPeersFound(int numNewPeers)We've gotten a search reply that contained the specified number of peers that we didn't know about before.(package private) static booleanonlyQueryFloodfillPeers(RouterContext ctx)this is now misnamed, as it is only used to determine whether to return floodfill peers only(package private) voidreplyFound(DatabaseSearchReplyMessage message, Hash peer)found a replyvoidrunJob()Actually perform the task.protected voidsearchNext()Send the next search, or stop if its completedprotected voidsendLeaseSearch(RouterInfo router)we're (probably) searching for a LeaseSet, so to be (overly) cautious, we're sending the request out through a tunnel w/ reply back through another tunnel.protected voidsendRouterSearch(RouterInfo router)we're searching for a router, so we can just send directprotected voidsendSearch(RouterInfo router)Send a search to the given peer(package private) longtimeoutMs()StringtoString()(package private) booleanwasAttempted(Hash peer)-
Methods inherited from class net.i2p.router.JobImpl
dropped, getAddedBy, getContext, getJobId, getMadeReadyOn, getTiming, madeReady, requeue
-
-
-
-
Field Detail
-
_log
protected final Log _log
-
_facade
protected final KademliaNetworkDatabaseFacade _facade
-
MAX_CLOSEST
static final int MAX_CLOSEST
only send the 10 closest "dont tell me about" refs- See Also:
- Constant Field Values
-
PER_FLOODFILL_PEER_TIMEOUT
static final int PER_FLOODFILL_PEER_TIMEOUT
timeout- See Also:
- Constant Field Values
-
MIN_TIMEOUT
static final long MIN_TIMEOUT
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
SearchJob
public SearchJob(RouterContext context, KademliaNetworkDatabaseFacade facade, Hash key, Job onSuccess, Job onFailure, long timeoutMs, boolean keepStats, boolean isLease)
Create a new search for the routingKey specified
-
-
Method Detail
-
runJob
public void runJob()
Description copied from interface:JobActually perform the task. This call blocks until the Job is complete.
-
getState
protected SearchState getState()
-
getFacade
protected KademliaNetworkDatabaseFacade getFacade()
-
getExpiration
public long getExpiration()
-
getTimeoutMs
public long getTimeoutMs()
-
onlyQueryFloodfillPeers
static boolean onlyQueryFloodfillPeers(RouterContext ctx)
this is now misnamed, as it is only used to determine whether to return floodfill peers only
-
getPerPeerTimeoutMs
protected int getPerPeerTimeoutMs(Hash peer)
-
getPerPeerTimeoutMs
protected int getPerPeerTimeoutMs()
Let each peer take up to the average successful search RTT
-
searchNext
protected void searchNext()
Send the next search, or stop if its completed
-
getBredth
protected int getBredth()
max # of concurrent searches
-
continueSearch
protected void continueSearch()
Send a series of searches to the next available peers as selected by the routing table, but making sure no more than SEARCH_BREDTH are outstanding at any time
-
sendSearch
protected void sendSearch(RouterInfo router)
Send a search to the given peer
-
sendLeaseSearch
protected void sendLeaseSearch(RouterInfo router)
we're (probably) searching for a LeaseSet, so to be (overly) cautious, we're sending the request out through a tunnel w/ reply back through another tunnel.
-
sendRouterSearch
protected void sendRouterSearch(RouterInfo router)
we're searching for a router, so we can just send direct
-
buildMessage
protected I2NPMessage buildMessage(TunnelId replyTunnelId, Hash replyGateway, long expiration, RouterInfo peer)
Build the database search message- Parameters:
replyTunnelId- tunnel to receive replies throughreplyGateway- gateway for the reply tunnelexpiration- when the search should stoppeer- unused here; see ExploreJob extension- Returns:
- a DatabaseLookupMessage
-
replyFound
void replyFound(DatabaseSearchReplyMessage message, Hash peer)
found a reply
-
newPeersFound
protected void newPeersFound(int numNewPeers)
We've gotten a search reply that contained the specified number of peers that we didn't know about before.
-
fail
protected void fail()
Search totally failed
-
wasAttempted
boolean wasAttempted(Hash peer)
-
timeoutMs
long timeoutMs()
-
add
boolean add(Hash peer)
- Returns:
- true if peer was new
-
decrementOutstandingFloodfillSearches
void decrementOutstandingFloodfillSearches()
-
-