2018-11-28 14:25:07 -08:00
|
|
|
# Terminology
|
|
|
|
|
|
|
|
## Teminology Currently in Use
|
|
|
|
|
|
|
|
The following list contains words commonly used throughout the Solana
|
|
|
|
architecture.
|
|
|
|
|
|
|
|
#### account
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
A persistent file addressed by [public key](#public-key) and with
|
|
|
|
[lamports](#lamport) tracking its lifetime.
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### block
|
|
|
|
|
|
|
|
The [entries](#entry) generated within a [slot](#slot).
|
|
|
|
|
|
|
|
#### bootstrap leader
|
|
|
|
|
|
|
|
The first [fullnode](#fullnode) to take the [leader](#leader) role.
|
|
|
|
|
|
|
|
#### client
|
|
|
|
|
|
|
|
A [node](#node) that utilizes the [cluster](#cluster).
|
|
|
|
|
|
|
|
#### cluster
|
|
|
|
|
|
|
|
A set of [fullnodes](#fullnode) maintaining a single [ledger](#ledger).
|
|
|
|
|
|
|
|
#### control plane
|
|
|
|
|
|
|
|
A gossip network connecting all [nodes](#node) of a [cluster](#cluster).
|
|
|
|
|
|
|
|
#### data plane
|
|
|
|
|
|
|
|
A multicast network used to efficiently validate [entries](#entry) and gain
|
|
|
|
consensus.
|
|
|
|
|
|
|
|
#### entry
|
|
|
|
|
|
|
|
An entry on the [ledger](#ledger) either a [tick](#tick) or a [transactions
|
|
|
|
entry](#transactions-entry).
|
|
|
|
|
2018-12-04 19:52:38 -08:00
|
|
|
#### confirmation
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
The wallclock duration between a [leader](#leader) creating a [tick
|
|
|
|
entry](#tick) and recognizing a supermajority of [ledger votes](#ledger-vote)
|
|
|
|
with a ledger interpretation that matches the leader's.
|
|
|
|
|
|
|
|
#### fork
|
|
|
|
|
|
|
|
A [ledger](#ledger) derived from common entries but then diverged.
|
|
|
|
|
|
|
|
#### fullnode
|
|
|
|
|
|
|
|
A full participant in the [cluster](#cluster) either a [leader](#leader) or
|
|
|
|
[validator](#validator) node.
|
|
|
|
|
|
|
|
#### fullnode state
|
|
|
|
|
|
|
|
The result of interpreting all programs on the ledger a given [tick
|
|
|
|
height](#tick-height). It includes at least the set of all [accounts](#account)
|
|
|
|
holding nonzero [native tokens](#native-tokens).
|
|
|
|
|
|
|
|
#### genesis block
|
|
|
|
|
|
|
|
The first [block](#block) of the [ledger](#ledger).
|
|
|
|
|
|
|
|
#### hash
|
|
|
|
|
|
|
|
A digital fingerprint of a sequence of bytes.
|
|
|
|
|
|
|
|
#### instruction
|
|
|
|
|
|
|
|
The smallest unit of a [program](#program) that a [client](#client) can include
|
|
|
|
in a [transaction](#instruction).
|
|
|
|
|
|
|
|
#### keypair
|
|
|
|
|
|
|
|
A [public key](#public-key) and coesponding [secret key](#secret-key).
|
|
|
|
|
|
|
|
#### lamport
|
|
|
|
|
|
|
|
A fractional [native token](#native-token) with the value of approximately
|
|
|
|
0.0000000000582 [sol](#sol) (2^-34).
|
|
|
|
|
2018-12-04 19:45:55 -08:00
|
|
|
#### loader
|
|
|
|
|
|
|
|
A [program](#program) with the ability to interpret the binary encoding
|
|
|
|
of other on-chain programs.
|
|
|
|
|
2018-11-28 14:25:07 -08:00
|
|
|
#### leader
|
|
|
|
|
|
|
|
The role of a [fullnode](#fullnode) when it is appending [entries](#entry) to
|
|
|
|
the [ledger](#ledger).
|
|
|
|
|
|
|
|
#### leader schedule
|
|
|
|
|
|
|
|
A sequence of [fullnode](#fullnode) [public keys](#public-key). The cluster
|
2018-12-05 09:51:50 -08:00
|
|
|
uses the leader schedule to determine which fullnode is the [leader](#leader)
|
|
|
|
at any moment in time.
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### ledger
|
|
|
|
|
|
|
|
A list of [entries](#entry) containing [transactions](#transaction) signed by
|
|
|
|
[clients](#client).
|
|
|
|
|
|
|
|
#### ledger vote
|
|
|
|
|
|
|
|
A [hash](#hash) of the [fullnode's state](#fullnode-state) at a given [tick
|
|
|
|
height](#tick-height).
|
|
|
|
|
|
|
|
#### lockout
|
|
|
|
|
2018-12-05 09:51:50 -08:00
|
|
|
The duration of time for which a [fullnode](#fullnode) is unable to
|
2018-12-04 15:22:49 -08:00
|
|
|
[vote](#vote) on another [fork](#fork).
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### native token
|
|
|
|
|
|
|
|
The [token](#token) used to track work done by [nodes](#node) in a cluster.
|
|
|
|
|
|
|
|
#### node
|
|
|
|
|
|
|
|
A computer particpating in a [cluster](#cluster).
|
|
|
|
|
|
|
|
#### node count
|
|
|
|
|
|
|
|
The number of [fullnodes](#fullnode) participating in a [cluster](#cluster).
|
|
|
|
|
|
|
|
#### program
|
|
|
|
|
|
|
|
The code that interprets [instructions](#instruction).
|
|
|
|
|
2018-12-04 09:24:08 -08:00
|
|
|
#### program ID
|
|
|
|
|
|
|
|
The public key of the [account](#account) containing a [program](#program).
|
|
|
|
|
2018-11-28 14:25:07 -08:00
|
|
|
#### public key
|
|
|
|
|
|
|
|
The public key of a [keypair](#keypair).
|
|
|
|
|
|
|
|
#### replicator
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
A type of [client](#client) that stores copies of segments of the
|
|
|
|
[ledger](#ledger).
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### secret key
|
|
|
|
|
|
|
|
The private key of a [keypair](#keypair).
|
|
|
|
|
|
|
|
#### slot
|
|
|
|
|
|
|
|
The time in which a single [leader](#leader) may produce [entries](#entry).
|
|
|
|
|
|
|
|
#### sol
|
|
|
|
|
|
|
|
The [native token](#native-token) tracked by a [cluster](#cluster) recognized
|
|
|
|
by the company Solana.
|
|
|
|
|
|
|
|
#### stake
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
Tokens forfeit to the [cluster](#cluster] if malicious [fullnode](#fullnode)
|
|
|
|
behavior can be proven.
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### tick
|
|
|
|
|
|
|
|
A ledger [entry](#entry) that estimates wallclock duration.
|
|
|
|
|
|
|
|
#### tick height
|
|
|
|
|
|
|
|
The Nth [tick](#tick) in the [ledger](#ledger).
|
|
|
|
|
|
|
|
#### token
|
|
|
|
|
|
|
|
A scarce, fungible member of a set of tokens.
|
|
|
|
|
|
|
|
#### tps
|
|
|
|
|
|
|
|
[Transactions](#transaction) per second.
|
|
|
|
|
|
|
|
#### transaction
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
One or more [instructions](#instruction) signed by the [client](#client) and
|
|
|
|
executed atomically.
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### transactions entry
|
|
|
|
|
|
|
|
A set of [transactions](#transaction) that may be executed in parallel.
|
|
|
|
|
|
|
|
#### validator
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
The role of a [fullnode](#fullnode) when it is validating the
|
|
|
|
[leader's](#leader) latest [entries](#entry).
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
|
|
|
|
## Terminology Reserved for Future Use
|
2018-11-06 17:00:58 -08:00
|
|
|
|
|
|
|
The following keywords do not have any functionality but are reserved by Solana
|
|
|
|
for potential future use.
|
|
|
|
|
2018-11-28 14:25:07 -08:00
|
|
|
#### blob
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
A fraction of a [block](#block); the smallest unit sent between
|
|
|
|
[fullnodes](#fullnode).
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### curio
|
|
|
|
|
|
|
|
A scarce, non-fungible member of a set of curios.
|
|
|
|
|
|
|
|
#### epoch
|
|
|
|
|
2018-12-05 09:51:50 -08:00
|
|
|
The time for which a [leader schedule](#leader-schedule) is valid.
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### light client
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
A type of [client](#client) that can verify it's pointing to a valid
|
|
|
|
[cluster](#cluster).
|
2018-11-28 14:25:07 -08:00
|
|
|
|
|
|
|
#### mips
|
|
|
|
|
|
|
|
Millions of [instructions](#instruction) per second.
|
|
|
|
|
2018-12-04 09:24:08 -08:00
|
|
|
#### runtime
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
The component of a [fullnode](#fullnode) responsible for [program](#program)
|
|
|
|
execution.
|
2018-12-04 09:24:08 -08:00
|
|
|
|
2018-11-28 14:25:07 -08:00
|
|
|
#### thin client
|
|
|
|
|
2018-12-04 15:22:49 -08:00
|
|
|
A type of [client](#client) that trusts it is communicating with a valid
|
|
|
|
[cluster](#cluster).
|