Week 2024-50

Filecoin Report Cal. Week 50 - 2024 #

General Information #

The following results show measurement data that were collected in calendar week 50 in 2024 from 2024-12-09 to 2024-12-16.

  • Number of crawls 84
  • Number of visits 528,713

    Visiting a peer means dialing or connecting to it. Every time the crawler or monitoring process tries to dial or connect to a peer we consider this as visiting it. Regardless of errors that may occur.

  • Number of unique peer IDs visited 956
  • Number of unique peer IDs discovered in the DHT 956
  • Number of unique IP addresses found 686

Timestamps are in UTC if not mentioned otherwise.

Agents #

This bar chart represents the distribution of various user agents within the Filecoin DHT. Each bar corresponds to a different client implementation and indicates its relative prevalence within the network for the given reporting period.

This plot shows the distribution of various user agents over time.

Churn Analysis #

This plot presents the Cumulative Distribution Function (CDF) of peer departure times from the network over a measurement period of one-week. The plot basically shows the percentage of nodes online at a point in time (t=0) that will have disconnected after 1 hour, 2 hours, 3 hours, .. up to 24 hours after t=0.

  • X-Axis (Time in Hours): Represents the elapsed time since the reference point (t=0), measured in hours.
  • Y-Axis (Percentage of Offline Peers): Indicates the cumulative percentage of peers that have disconnected from the network by the corresponding time interval. Specifically, it shows the proportion of peers that were online at t=0 and have since gone offline.

This visualization aids in understanding peer churn dynamics, which is crucial for optimizing network stability, resource allocation, and improving overall decentralized network performance.

Note that the sum of the CDF is NOT 100%, as it only includes peers that were online for up to 24h.

Geolocation #

Geographical data is sourced from a leading IP Geolocation provider, which maps IP addresses to corresponding countries.

This bar plot illustrates the distribution of observed nodes across different countries.

This plot displays the weekly geographical distribution of nodes, categorized by country.

Cloud Providers #

Cloud providers data is sourced from Udger, which maps IP addresses to known hosting providers.

Cloud Hosting Rate #

This line chart displays the count of nodes within the Filecoin network that are hosted on known commercial cloud providers, compared to those that are not. It tracks the distribution over a specified period, offering insights into the infrastructure preferences for node hosting.

Regular analysis of this chart can reveal trends in the adoption of cloud services for nodes. Such information is crucial for understanding the network’s resilience and the potential reliance on cloud infrastructure.

This bar chart presents the weekly distribution of Filecoin nodes among various cloud providers, including nodes not hosted within data centers (grouped under Non-Datacenter).

The line chart illustrates the trends in the distribution of all Filecoin nodes across cloud providers over the given time period. Note that nodes hosted outside of data centers are not included in this representation.

Crawls #

Protocols #

This plot illustrates the evolving count of nodes supporting each of the listed protocols over time. It exclusively presents data gathered from nodes accessible through a libp2p connection via our crawler. The identification of supported protocols relies on the libp2p identify protocol, hence necessitating a libp2p connection for discovery.

Errors #

The next plot showcases the percentage of errors encountered when connecting to peers during crawling activities, relative to the total number of connection attempts. By tracking various error types over time, it provides insights into crawling reliability and highlights trends in connection issues.

This plot displays the percentage of errors encountered when requesting peers from a remote node’s routing table after establishing a connection. It offers insights into the reliability of DHT requests within active libp2p connections.

Stale Peer Records #

This stacked plot depicts the count of peer records stored within each node’s routing table and made accessible through the DHT. These peer records are used to discover new remote peers within the network, enabling efficient and secure routing towards the target peer or content

Ensuring the reachability of referenced peers shared within the network holds paramount importance. The plot delineates the occurrences of reachable and non-reachable (stale) peer records. Note that nodes running behind a NAT are counted as unreachable even though they may be online.

For instance, if a peer’s record is present in the routing tables of 100 other nodes and the peer is reachable, the plot will reflect an increase of 100 in the online category.

Keyspace Density Monitoring #

💡 The latest keyspace density data is available here. Due to a change in the plot format on 2024-12-14, traces between 2024-12-09 and 2024-12-14 are inverted, which makes the plots hard to read.

In Kademlia, every object indexed by the DHT requires a binary identifier. In the libp2p DHT implementation, peers are identified by the digest of sha256(peer_id) and CIDs are identified by the digest of sha256(cid). This Kademlia identifier determines the location of an object within the Kademlia XOR keyspace.

The following plots examine the peer distribution within the keyspace, aiding in the identification of potential Sybil and eclipse attacks.

Keyspace population distribution #

Description: The plot illustrates the number of peers whose Kademlia identifier matches each prefix for all prefixes of a given size, for a given network crawl. Since the density of keyspace regions follows a Poisson distribution, it is expected to observe some regions that are significantly more populated than others.

How to read the plot: The selected depth indicates the prefix size. There are 2^i distinct prefixes at depth i. The slider at the bottom of the plot enables visualization of the population evolution over time across multiple crawls.

What to look out for: The red dashed line represents the expected density per region, corresponding to the number of peers matching a prefix. A bar significantly exceeding the expected density suggests that a region of the keyspace might be under an eclipse attack, especially if the value is above the risk threshold.

Keyspace density distribution #

Description: As previously mentioned, the keyspace population follows a Poisson distribution, which can make identifying outliers challenging. The plot below counts the number of regions for each population size and facilitates the identification and analysis of outliers. While it is normal for some regions to have populations above the average, the plot enables us to quantify these deviations.

How to read the plot: The red dashed line represents the expected number of regions for each population size. Note that the Poisson distribution is more evident at greater depths (longer prefix size), while analyzing data at lower depths provides limited insights. It is recommended to read the plot for depths between 6 and 8.

What to look out for: If an isolated bar appears on the far right beyond the risk threshold line, it may indicate a potential eclipse attack, warranting further investigation.