Full API Node Update - 2/1/2021

in #full-nodes3 years ago

Full API node update - (2/1/2021)

2021-01-01T22:00:12 - 2021-01-02T21:00:37 (UTC)
@fullnodeupdate provides daily updates about the state of all available full API node server for HIVE.
More information about full nodes and a complete RPC node list can be fund in this post.

List of failing nodes

This table includes a list of all nodes which were not able to answer to a get_config api call within 30 seconds.

nodehours with failurepercentage

List of working nodes (At least once in the last 24h)

This table includes all nodes which were able to a get_config call in 30 seconds.The achieved mean duration values are shown. The returned version is also shown.When a node failes, its mean value is increased as it is counted as 30 seconds

Streaming blocks

In this test, it is measured how many blocks a node can stream in 30 seconds.

List of working nodes - block streaming

This table includes all nodes which were able to stream at least one block within 30 seconds.The achieved minimum, maximum and mean blocks per seconds values are shown. When a node failes, its mean value is reduced as it is counted as 0 blocks per seconds

nodeblock/smean block/s
https://api.pharesim.me35.6 - 38.237.1
https://api.deathwing.me34.1 - 38.136.2
https://hived.emre.sh22.8 - 24.923.6
https://hive.roelandp.nl20.7 - 23.723.1
https://rpc.ausbit.dev18.9 - 22.419.6
https://api.c0ff33a.uk17.0 - 19.618.8
https://rpc.ecency.com14.1 - 18.016.1
https://hive-api.arcange.eu13.0 - 15.114.2
https://hived.privex.io9.8 - 11.411.0
https://fin.hive.3speak.co7.9 - 8.48.2
https://api.hive.blog4.1 - 6.56.2
https://api.hivekings.com6.0 - 6.26.1
https://anyx.io3.5 - 6.25.2
https://techcoderx.com4.4 - 5.14.9
https://api.openhive.network4.5 - 4.84.8

Measuring irreversible block delays

In this test, the time delay of the irreversible block to the current time is measured.

List of working nodes - block delays

This table includes all nodes which were able to stream at least one block within 30 seconds.The achieved minimum, maximum and mean irreversible block delay times in seconds are shown. When a node failes, its mean value is reduced as it is counted as 120 seconds.

nodeblock delaymean delay
https://rpc.ausbit.dev45.77 - 74.5857.966
https://api.pharesim.me46.71 - 74.6958.974
https://hive-api.arcange.eu46.12 - 77.4260.798
https://api.hive.blog47.80 - 74.5560.845
https://techcoderx.com47.37 - 80.8860.908
https://rpc.ecency.com50.31 - 80.5261.270
https://hived.emre.sh48.25 - 77.8461.495
https://hive.roelandp.nl47.35 - 78.2761.885
https://hived.privex.io46.73 - 76.9562.004
https://api.openhive.network47.52 - 80.4662.064
https://api.deathwing.me49.34 - 90.7862.619
https://api.c0ff33a.uk46.78 - 84.3563.108
https://fin.hive.3speak.co51.70 - 78.4964.650
https://api.hivekings.com52.12 - 85.8065.380
https://anyx.io50.85 - 84.5166.458

Account history

In this test, it is measured how many account operation a node can stream.

List of working nodes - account history

This table includes all nodes which were able to stream at least one account history operation within 15 seconds.The achieved minimum, maximum and mean account transaction per seconds values are shown. When a node failes, its mean value is reduced as it is counted as 0 history operation per seconds

nodehist/smean hist/s
https://api.deathwing.me1587.1 - 2425.11934.8
https://hive.roelandp.nl1717.8 - 1962.81847.0
https://hived.emre.sh1688.9 - 1915.01837.3
https://api.pharesim.me1692.3 - 1823.71756.2
https://hive-api.arcange.eu1171.8 - 1329.91271.6
https://rpc.ecency.com1114.9 - 1432.41249.0
https://rpc.ausbit.dev876.0 - 1167.91048.0
https://api.c0ff33a.uk418.9 - 1296.61010.7
https://hived.privex.io939.4 - 1040.11000.1
https://fin.hive.3speak.co715.3 - 778.5751.1
https://api.hive.blog573.3 - 650.3620.9
https://api.openhive.network545.3 - 620.1560.5
https://api.hivekings.com492.1 - 539.7520.8
https://anyx.io389.6 - 462.2432.0
https://techcoderx.com338.0 - 436.9386.9

Receiving a vote, a comment, and an account

In this test, the mean duration to receive an account, a comment, and a vote is measured.

List of working nodes - api calls

This table includes all nodes which were able to answer all three api calls within 30 seconds.The achieved minimum, maximum and mean time durations are shown. When a node failes, its mean value is increased as it is counted as 30 seconds

nodetime [s]mean time [s]
https://api.deathwing.me0.04 - 0.070.055
https://api.pharesim.me0.04 - 0.070.055
https://hived.emre.sh0.06 - 0.080.070
https://hive.roelandp.nl0.06 - 0.090.075
https://rpc.ausbit.dev0.08 - 0.140.095
https://hive-api.arcange.eu0.11 - 0.130.120
https://api.c0ff33a.uk0.12 - 0.210.164
https://rpc.ecency.com0.11 - 0.250.169
https://fin.hive.3speak.co0.19 - 0.220.203
https://api.hive.blog0.19 - 0.280.226
https://api.openhive.network0.18 - 0.360.238
https://api.hivekings.com0.26 - 0.320.277
https://techcoderx.com0.33 - 0.530.408
https://hived.privex.io0.16 - 0.445.206

Summary of working nodes for HIVE

A node is working, when it could fullfil at least once in the last 24h the following conditions:

  • returned data within 30 seconds,
  • blocks could be streamed,
  • account history was possible,
  • votes, a comment, an account could successfully be fetched and were not empty.

The nodes in the following table are ranked by the mean rank of all three node tables shown above.
This table includes only nodes which were passing all three tests sucessfully.

The shown ranks are: block rank - block_diff rank - history rank - apicall rank

noderanksscore
https://api.deathwing.me2 - 11 - 8 - 274.7
https://hive.roelandp.nl4 - 8 - 6 - 572.0
https://api.pharesim.me1 - 2 - 15 - 369.3
https://api.hive.blog11 - 4 - 1 - 1168.0
https://hive-api.arcange.eu8 - 3 - 9 - 765.3
https://rpc.ausbit.dev5 - 1 - 5 - 664.0
https://hived.emre.sh3 - 7 - 11 - 458.7
https://anyx.io13 - 15 - 2 - 154.7
https://api.c0ff33a.uk6 - 12 - 7 - 854.7
https://rpc.ecency.com7 - 6 - 13 - 953.3
https://fin.hive.3speak.co10 - 13 - 10 - 1037.3
https://api.openhive.network15 - 10 - 4 - 1236.0
https://api.hivekings.com12 - 14 - 3 - 1333.3
https://hived.privex.io9 - 9 - 14 - 1530.7
https://techcoderx.com14 - 5 - 12 - 1428.0

Set fully working nodes with beempy / steempy

https://api.steemitstage.com, https://api.steemitdev.com and nodes with not working results were excluded.

beempy

beempy set nodes "['https://api.deathwing.me', 'https://hive.roelandp.nl', 'https://api.pharesim.me', 'https://api.hive.blog', 'https://hive-api.arcange.eu', 'https://rpc.ausbit.dev', 'https://hived.emre.sh', 'https://anyx.io', 'https://api.c0ff33a.uk', 'https://rpc.ecency.com', 'https://fin.hive.3speak.co', 'https://api.openhive.network', 'https://api.hivekings.com', 'https://hived.privex.io', 'https://techcoderx.com']"

steempy

steempy set nodes https://api.deathwing.me,https://hive.roelandp.nl,https://api.pharesim.me,https://api.hive.blog,https://hive-api.arcange.eu,https://rpc.ausbit.dev,https://hived.emre.sh,https://anyx.io,https://api.c0ff33a.uk,https://rpc.ecency.com,https://fin.hive.3speak.co,https://api.openhive.network,https://api.hivekings.com,https://hived.privex.io,https://techcoderx.com

Receive fully working nodes from json_metadata of the @fullnodeupdate account

The nodes are also stored in the json_metadata variable of the @fullnodeupdate account.
The nodes inside the account metadata are updated every hour.
The json_metadata includes the following data:

  • nodes - list of nodes that passed all tests.
  • failing_nodes - list of nodes that did not answer the get_config call.
  • report - test results.
  • parameter - used beem and test parameter.

Example code for python:

from beem.account import Account
import json
acc = Account("fullnodeupdate")
nodes = json.loads(acc["json_metadata"])["nodes"]
acc.steem.set_default_nodes(nodes)

If you like what I'm doing, please consider @holger80 as one of your witnesses. You can use hivesigner.com for approve your vote or go to https://peakd.com/witnesses and vote for me


This post was created with beem, my python library for steem.