Skip to content

Redis Data

Addy Yeow edited this page Mar 12, 2022 · 39 revisions

crawl.py

[KEY]
crawl:master:state            value = 'starting', 'running'

node:ADDRESS-PORT-SERVICES    value = ''

height                        value = HEIGHT (most common height)

height:ADDRESS-PORT-SERVICES  value = HEIGHT (1 day TTL)

elapsed                       value = ELAPSED (seconds)

crawl:cidr:CIDR               value = NODES

version:ADDRESS-PORT          values = (VERSION, USER_AGENT, SERVICES) (1 day TTL)

[LIST]
nodes                         values = [(TIMESTAMP, REACHABLE_NODES), ..]

[SET]
pending                       values = [(ADDRESS, PORT, SERVICES), ..]

up                            values = [node:ADDRESS-PORT-SERVICES, ..]

[SORTED SET]
check                         score values
                                  score = TIMESTAMP (epoch in seconds)
                                  values = [(ADDRESS, PORT, SERVICES), ..]
                              This key is currently set by https://bitnodes.io/#join-the-network

ping.py

[KEY]
onion:PORT                    value = (ADDRESS, PORT) (mapping of local port to .onion node)

ping:cidr:CIDR                value = NODES

[LIST]
ping:ADDRESS-PORT:NONCE       values = [TIMESTAMP, ..] (epoch for ping in milliseconds, 3 hours TTL)

[SET]
reachable                     values = [(ADDRESS, PORT, SERVICES, HEIGHT), ..]

open                          values = [(ADDRESS, PORT), ..]

opendata                      values = [(ADDRESS, PORT, VERSION, USER_AGENT, TIMESTAMP, SERVICES), ..]

[CHANNEL]
snapshot                      value = TIMESTAMP (epoch in seconds)

resolve.py

[KEY]
resolve:ADDRESS               field value (1 day TTL)
                                  field = 'hostname'
                                  value = HOSTNAME
                                  This key can be updated by https://bitnodes.io/#join-the-network to allow e.g. A record to take precedence over PTR record

                                  field = 'geoip'
                                  value = (CITY, COUNTRY, LATITUDE, LONGITUDE, TIMEZONE, ASN, ORG)

[CHANNEL]
resolve                       value = TIMESTAMP (epoch in seconds)

export.py

[CHANNEL]
export                        value = TIMESTAMP (epoch in seconds)

cache_inv.py

[KEY]
rinv:TYPE:HASH                value = TIMESTAMP (epoch in milliseconds)

lastblockhash                 value = HASH

[LIST]
ping:ADDRESS-PORT:NONCE       values = [.., TIMESTAMP, ..] (epoch for pong in milliseconds, key must already exist)

rtt:ADDRESS-PORT              values = [RTT, ..] (round-trip time in milliseconds, 3 hours TTL, max. 36 values)

[SORTED SET]
inv:TYPE:HASH                 score values (3 hours TTL)
                                  score = TIMESTAMP (epoch in milliseconds)
                                  values = [(ADDRESS, PORT), ..]

cache_addr.py

[SORTED SET]
addr:NETWORK_ID               score values
                                  score = TIMESTAMP (epoch in seconds)
                                  values = [(ADDRESS, PORT), ..]
                              Scores are kept at less than 24 hours old
Clone this wiki locally