Package net.i2p.router.peermanager
Class PeerProfile
java.lang.Object
net.i2p.router.peermanager.PeerProfile
Copied from http://www.i2p2.i2p/how_peerselection.html
See also main() below for additional commentary by zzz.
Currently, there is no 'ejection' strategy to get rid of the profiles for peers that
are no longer active (or when the network consists of thousands of peers, to get rid
of peers that are performing poorly). However, the size of each profile is fairly small,
and is unrelated to how much data is collected about the peer, so that a router can
keep a few thousand active peer profiles before the overhead becomes a serious concern.
Once it becomes necessary, we can simply compact the poorly performing profiles
(keeping only the most basic data) and maintain hundreds of thousands of profiles
in memory. Beyond that size, we can simply eject the peers (e.g. keeping the best 100,000).
TODO most of the methods should be synchronized.
-
Field Summary
FieldsModifier and TypeFieldDescription(package private) static final boolean -
Constructor Summary
ConstructorsConstructorDescriptionPeerProfile(RouterContext context, Hash peer) Caller should call setLastHeardAbout() and setFirstHeardAbout() -
Method Summary
Modifier and TypeMethodDescription(package private) voidcoalesceOnly(boolean shouldDecay) Caller must next call updateValues()(package private) voidUpdate the stats and rates.(package private) voiddataPushed(int size) (package private) voiddataPushed1m(int size) the tunnel pushed that much data in a 1 minute periodbooleanvoidFor floodfillsvoidWhen the given peer is performing well enough that we want to keep detailed stats on them again, call this to set up the info we dropped during shrinkProfile.intextra factor added to the capacity ranking - this can be updated in the profile written to disk to affect how the algorithm ranks capacity.floatHow many tunnels do we think this peer can handle over the next hour?(package private) RouterContextHelper for calculatorshistory of db activity with the peer Warning - may return null if !getIsExpandedDB()how many new peers we get from dbSearchReplyMessages or dbStore messages, calculated over a 1 hour, 1 day, and 1 week period Warning - may return null if !getIsExpandedDB()how long it takes to get a db response from the peer (in milliseconds), calculated over a 1 minute, 1 hour, and 1 day period Warning - may return null if !getIsExpandedDB()longWhen did we first hear about this peer?intextra factor added to the integration ranking - this can be updated in the profile written to disk to affect how the algorithm ranks integration.floatHow well integrated into the network is this peer (as measured by how much they've told us that we didn't already know).booleanIs this peer active at the moment (sending/receiving messages within the last 5 minutes)booleangetIsActive(long period) Is this peer active at the moment (sending/receiving messages within the given period?) Also mark active if it is connected, as this will tend to encourage use of already-connected peers.booleanare we keeping an expanded profile on the peer, or just the bare minimum.booleanbooleanis this peer actively failing (aka not worth touching)? deprecated - unused - always falselongwhen did we last hear about this peer?longwhen did we last hear from the peer?longwhen did we last have a problem sending to this peer?longwhen did we last send to this peer successfully?floatfloatThis is the speed valuefloatgetPeer()what peer is being profiled, non-nullintextra factor added to the speed ranking - this can be updated in the profile written to disk to affect how the algorithm ranks speed.floatHow fast is the peer, taking into consideration both throughput and latency.how long it takes to get a tunnel create response from the peer (in milliseconds), calculated over a 1 minute, 1 hour, and 1 day period Warning - may return null if !getIsExpanded()history of tunnel activity with the peer Warning - may return null if !getIsExpanded()Deprecated.unusedfloatDeprecated.unused(package private) intFor now, just a one-byte comparisoninthashCode()(package private) boolean(package private) booleanvoidsetCapacityBonus(int bonus) voidsetDBHistory(DBHistory hist) (package private) voidsetFirstHeardAbout(long when) Set when did we first heard about this peer, only if older.voidsetIntegrationBonus(int bonus) (package private) voidsetIsFailing(boolean val) deprecated - unused - always falsevoidsetLastHeardAbout(long when) Set when did we last hear about this peer, only if unset or newer Also sets FirstHeardAbout if earliervoidsetLastHeardFrom(long when) voidsetLastSendFailed(long when) voidsetLastSendSuccessful(long when) (package private) voidsetPeakThroughputKBps(float kBps) Only for restoration from persisted profile.(package private) voidsetPeakTunnel1mThroughputKBps(float kBps) Only for restoration from persisted profile.(package private) voidsetPeakTunnelThroughputKBps(float kBps) Only for restoration from persisted profile.voidsetSpeedBonus(int bonus) voidsetTunnelHistory(TunnelHistory history) (package private) voidsetTunnelTestTimeAverage(float avg) Deprecated.unusedtoString()(package private) voidtunnelDataTransferred(long tunnelByteLifetime) the tunnel pushed that much data in its lifetime(package private) voidupdateTunnelTestTimeAverage(long ms) Deprecated.unused(package private) voidCopy over the new values generated by coalesceOnly()(package private) boolean
-
Field Details
-
ENABLE_TUNNEL_TEST_RESPONSE_TIME
static final boolean ENABLE_TUNNEL_TEST_RESPONSE_TIME- See Also:
-
-
Constructor Details
-
PeerProfile
Caller should call setLastHeardAbout() and setFirstHeardAbout()- Parameters:
peer- non-null
-
-
Method Details
-
getPeer
what peer is being profiled, non-null -
getIsExpanded
public boolean getIsExpanded()are we keeping an expanded profile on the peer, or just the bare minimum. If we aren't keeping the expanded profile, all of the rates as well as the TunnelHistory and DBHistory will not be available. -
getIsExpandedDB
public boolean getIsExpandedDB() -
getIsActive
public boolean getIsActive()Is this peer active at the moment (sending/receiving messages within the last 5 minutes) -
isEstablished
boolean isEstablished()- Since:
- 0.8.11
-
wasUnreachable
boolean wasUnreachable()- Since:
- 0.8.11
-
isSameCountry
boolean isSameCountry()- Since:
- 0.8.11
-
getXORDistance
int getXORDistance()For now, just a one-byte comparison- Returns:
- -127 to +128, lower is closer
- Since:
- 0.8.11
-
getIsActive
public boolean getIsActive(long period) Is this peer active at the moment (sending/receiving messages within the given period?) Also mark active if it is connected, as this will tend to encourage use of already-connected peers. Note: this appears to be the only use for these two RateStats. Update: Rewritten so we can get rid of the two RateStats. This also helps by not having it depend on coalesce boundaries.- Parameters:
period- must be one of the periods in the RateStat constructors below (5*60*1000 or 60*60*1000)
-
getFirstHeardAbout
public long getFirstHeardAbout()When did we first hear about this peer?- Returns:
- greater than zero, set to now in consturctor
-
setFirstHeardAbout
void setFirstHeardAbout(long when) Set when did we first heard about this peer, only if older. Package private, only set by profile management subsystem. -
getLastHeardAbout
public long getLastHeardAbout()when did we last hear about this peer?- Returns:
- 0 if unset
-
setLastHeardAbout
public void setLastHeardAbout(long when) Set when did we last hear about this peer, only if unset or newer Also sets FirstHeardAbout if earlier -
getLastSendSuccessful
public long getLastSendSuccessful()when did we last send to this peer successfully? -
setLastSendSuccessful
public void setLastSendSuccessful(long when) -
getLastSendFailed
public long getLastSendFailed()when did we last have a problem sending to this peer? -
setLastSendFailed
public void setLastSendFailed(long when) -
getLastHeardFrom
public long getLastHeardFrom()when did we last hear from the peer? -
setLastHeardFrom
public void setLastHeardFrom(long when) -
getTunnelHistory
history of tunnel activity with the peer Warning - may return null if !getIsExpanded() -
setTunnelHistory
-
getDBHistory
history of db activity with the peer Warning - may return null if !getIsExpandedDB() -
setDBHistory
-
getDbResponseTime
how long it takes to get a db response from the peer (in milliseconds), calculated over a 1 minute, 1 hour, and 1 day period Warning - may return null if !getIsExpandedDB() -
getTunnelCreateResponseTime
how long it takes to get a tunnel create response from the peer (in milliseconds), calculated over a 1 minute, 1 hour, and 1 day period Warning - may return null if !getIsExpanded() -
getTunnelTestResponseTime
Deprecated.unusedHow long it takes to successfully test a tunnel this peer participates in (in milliseconds), calculated over a 10 minute, 1 hour, and 1 day period Warning - may return null if !getIsExpanded()- Returns:
- null always
-
getDbIntroduction
how many new peers we get from dbSearchReplyMessages or dbStore messages, calculated over a 1 hour, 1 day, and 1 week period Warning - may return null if !getIsExpandedDB() -
getSpeedBonus
public int getSpeedBonus()extra factor added to the speed ranking - this can be updated in the profile written to disk to affect how the algorithm ranks speed. Negative values are penalties -
setSpeedBonus
public void setSpeedBonus(int bonus) -
getCapacityBonus
public int getCapacityBonus()extra factor added to the capacity ranking - this can be updated in the profile written to disk to affect how the algorithm ranks capacity. Negative values are penalties -
setCapacityBonus
public void setCapacityBonus(int bonus) -
getIntegrationBonus
public int getIntegrationBonus()extra factor added to the integration ranking - this can be updated in the profile written to disk to affect how the algorithm ranks integration. Negative values are penalties -
setIntegrationBonus
public void setIntegrationBonus(int bonus) -
getSpeedValue
public float getSpeedValue()How fast is the peer, taking into consideration both throughput and latency. This may even be made to take into consideration current rates vs. estimated (or measured) max rates, allowing this speed to reflect the speed /available/. -
getCapacityValue
public float getCapacityValue()How many tunnels do we think this peer can handle over the next hour? -
getIntegrationValue
public float getIntegrationValue()How well integrated into the network is this peer (as measured by how much they've told us that we didn't already know). Higher numbers means better integrated -
getIsFailing
public boolean getIsFailing()is this peer actively failing (aka not worth touching)? deprecated - unused - always false -
getTunnelTestTimeAverage
Deprecated.unused- Returns:
- 0 always
-
setTunnelTestTimeAverage
Deprecated.unused -
updateTunnelTestTimeAverage
Deprecated.unused -
getPeakThroughputKBps
public float getPeakThroughputKBps() -
setPeakThroughputKBps
void setPeakThroughputKBps(float kBps) Only for restoration from persisted profile. -
dataPushed
void dataPushed(int size) -
tunnelDataTransferred
void tunnelDataTransferred(long tunnelByteLifetime) the tunnel pushed that much data in its lifetime -
getPeakTunnelThroughputKBps
public float getPeakTunnelThroughputKBps() -
setPeakTunnelThroughputKBps
void setPeakTunnelThroughputKBps(float kBps) Only for restoration from persisted profile. -
dataPushed1m
void dataPushed1m(int size) the tunnel pushed that much data in a 1 minute period -
getPeakTunnel1mThroughputKBps
public float getPeakTunnel1mThroughputKBps()This is the speed value- Returns:
- the average of the three fastest one-minute data transfers, on a per-tunnel basis, through this peer. Ever. Except that the peak values are cut in half periodically by coalesceThroughput().
-
setPeakTunnel1mThroughputKBps
void setPeakTunnel1mThroughputKBps(float kBps) Only for restoration from persisted profile. -
expandProfile
public void expandProfile()When the given peer is performing well enough that we want to keep detailed stats on them again, call this to set up the info we dropped during shrinkProfile. This will not however overwrite any existing data, so it can be safely called repeatedly -
expandDBProfile
public void expandDBProfile()For floodfills -
coalesceStats
void coalesceStats()Update the stats and rates. This is only called by addProfile() -
coalesceOnly
void coalesceOnly(boolean shouldDecay) Caller must next call updateValues()- Since:
- 0.9.4
-
updateValues
void updateValues()Copy over the new values generated by coalesceOnly()- Since:
- 0.9.4
-
setIsFailing
void setIsFailing(boolean val) deprecated - unused - always false -
getContext
RouterContext getContext()Helper for calculators- Since:
- 0.9.2
-
hashCode
public int hashCode() -
equals
-
toString
-