Docs cleanup (#16964)
* Run lint:fix on docs * Update dependencies * Run prettier * Run lint
This commit is contained in:
parent
3d98321b38
commit
545e037e38
|
@ -0,0 +1,8 @@
|
|||
node_modules
|
||||
build
|
||||
static
|
||||
html
|
||||
|
||||
# FIXME
|
||||
src/pages/index.js
|
||||
src/theme/Footer/index.js
|
|
@ -0,0 +1,7 @@
|
|||
.docusaurus
|
||||
build
|
||||
html
|
||||
static
|
||||
|
||||
# prettier interferes with the json response too much
|
||||
src/developing/clients/jsonrpc-api.md
|
|
@ -29,6 +29,7 @@ $ docs/build.sh
|
|||
```
|
||||
|
||||
### CI Build Flow
|
||||
|
||||
The docs are built and published in Travis CI with the `docs/build.sh` script.
|
||||
On each PR, the docs are built, but not published.
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
const math = require('remark-math');
|
||||
const katex = require('rehype-katex');
|
||||
const math = require("remark-math");
|
||||
const katex = require("rehype-katex");
|
||||
module.exports = {
|
||||
title: "Solana Docs",
|
||||
tagline:
|
||||
|
@ -9,14 +9,14 @@ module.exports = {
|
|||
favicon: "img/favicon.ico",
|
||||
organizationName: "solana-labs", // Usually your GitHub org/user name.
|
||||
projectName: "solana", // Usually your repo name.
|
||||
onBrokenLinks: 'throw',
|
||||
onBrokenLinks: "throw",
|
||||
stylesheets: [
|
||||
{
|
||||
href: '/katex/katex.min.css',
|
||||
type: 'text/css',
|
||||
href: "/katex/katex.min.css",
|
||||
type: "text/css",
|
||||
integrity:
|
||||
'sha384-AfEj0r4/OFrOo5t7NnNe46zW/tFgW6x/bCJG8FqQCEo3+Aro6EYUG4+cU+KJWu/X',
|
||||
crossorigin: 'anonymous',
|
||||
"sha384-AfEj0r4/OFrOo5t7NnNe46zW/tFgW6x/bCJG8FqQCEo3+Aro6EYUG4+cU+KJWu/X",
|
||||
crossorigin: "anonymous",
|
||||
},
|
||||
],
|
||||
themeConfig: {
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -15,13 +15,15 @@
|
|||
"lint:fix": "npm run lint -- --fix"
|
||||
},
|
||||
"dependencies": {
|
||||
"@docusaurus/core": "^2.0.0-alpha.65",
|
||||
"@docusaurus/preset-classic": "^2.0.0-alpha.65",
|
||||
"@docusaurus/theme-search-algolia": "^2.0.0-alpha.32",
|
||||
"@docusaurus/core": "^2.0.0-alpha.74",
|
||||
"@docusaurus/preset-classic": "^2.0.0-alpha.74",
|
||||
"@docusaurus/theme-search-algolia": "^2.0.0-alpha.74",
|
||||
"babel-eslint": "^10.1.0",
|
||||
"clsx": "^1.1.1",
|
||||
"eslint": "^7.3.1",
|
||||
"eslint-plugin-react": "^7.20.0",
|
||||
"postcss": "^8.2.13",
|
||||
"postcss-loader": "^4.2.0",
|
||||
"prettier": "^2.0.5",
|
||||
"react": "^16.8.4",
|
||||
"react-dom": "^16.8.4",
|
||||
|
|
|
@ -1,27 +1,18 @@
|
|||
module.exports = {
|
||||
docs: {
|
||||
"About": [
|
||||
"introduction",
|
||||
"terminology",
|
||||
"history",
|
||||
],
|
||||
"Wallets": [
|
||||
About: ["introduction", "terminology", "history"],
|
||||
Wallets: [
|
||||
"wallet-guide",
|
||||
"wallet-guide/apps",
|
||||
{
|
||||
type: "category",
|
||||
label: "Web Wallets",
|
||||
items: [
|
||||
"wallet-guide/web-wallets",
|
||||
"wallet-guide/solflare",
|
||||
],
|
||||
items: ["wallet-guide/web-wallets", "wallet-guide/solflare"],
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
label: "Hardware Wallets",
|
||||
items: [
|
||||
"wallet-guide/ledger-live",
|
||||
],
|
||||
items: ["wallet-guide/ledger-live"],
|
||||
},
|
||||
{
|
||||
type: "category",
|
||||
|
@ -42,10 +33,7 @@ module.exports = {
|
|||
},
|
||||
"wallet-guide/support",
|
||||
],
|
||||
"Staking": [
|
||||
"staking",
|
||||
"staking/stake-accounts",
|
||||
],
|
||||
Staking: ["staking", "staking/stake-accounts"],
|
||||
"Command Line": [
|
||||
"cli",
|
||||
"cli/install-solana-cli-tools",
|
||||
|
@ -59,7 +47,7 @@ module.exports = {
|
|||
"offline-signing/durable-nonce",
|
||||
"cli/usage",
|
||||
],
|
||||
"Developing": [
|
||||
Developing: [
|
||||
{
|
||||
type: "category",
|
||||
label: "Programming Model",
|
||||
|
@ -103,8 +91,8 @@ module.exports = {
|
|||
},
|
||||
"developing/backwards-compatibility",
|
||||
],
|
||||
"Integrating": ["integrations/exchange"],
|
||||
"Validating": [
|
||||
Integrating: ["integrations/exchange"],
|
||||
Validating: [
|
||||
"running-validator",
|
||||
"running-validator/validator-reqs",
|
||||
"running-validator/validator-start",
|
||||
|
@ -143,13 +131,13 @@ module.exports = {
|
|||
},
|
||||
"running-validator/validator-troubleshoot",
|
||||
],
|
||||
"Clusters": [
|
||||
Clusters: [
|
||||
"clusters",
|
||||
"cluster/rpc-endpoints",
|
||||
"cluster/bench-tps",
|
||||
"cluster/performance-metrics"
|
||||
"cluster/performance-metrics",
|
||||
],
|
||||
"Architecture": [
|
||||
Architecture: [
|
||||
{
|
||||
type: "category",
|
||||
label: "Cluster",
|
||||
|
@ -177,7 +165,7 @@ module.exports = {
|
|||
],
|
||||
},
|
||||
],
|
||||
"Economics": [
|
||||
Economics: [
|
||||
"economics_overview",
|
||||
{
|
||||
type: "category",
|
||||
|
@ -189,7 +177,7 @@ module.exports = {
|
|||
],
|
||||
},
|
||||
"transaction_fees",
|
||||
"storage_rent_economics"
|
||||
"storage_rent_economics",
|
||||
],
|
||||
"Design Proposals": [
|
||||
{
|
||||
|
@ -240,7 +228,7 @@ module.exports = {
|
|||
"proposals/optimistic_confirmation",
|
||||
"proposals/embedding-move",
|
||||
"proposals/rip-curl",
|
||||
]
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
|
|
@ -25,9 +25,11 @@ Explorers:
|
|||
- Devnet typically runs a newer software version than Mainnet Beta
|
||||
- Gossip entrypoint for Devnet: `entrypoint.devnet.solana.com:8001`
|
||||
- Metrics environment variable for Devnet:
|
||||
|
||||
```bash
|
||||
export SOLANA_METRICS_CONFIG="host=https://metrics.solana.com:8086,db=devnet,u=scratch_writer,p=topsecret"
|
||||
```
|
||||
|
||||
- RPC URL for Devnet: `https://devnet.solana.com`
|
||||
|
||||
##### Example `solana` command-line configuration
|
||||
|
@ -70,9 +72,11 @@ The `--trusted-validator`s is operated by Solana
|
|||
Mainnet Beta
|
||||
- Gossip entrypoint for Testnet: `entrypoint.testnet.solana.com:8001`
|
||||
- Metrics environment variable for Testnet:
|
||||
|
||||
```bash
|
||||
export SOLANA_METRICS_CONFIG="host=https://metrics.solana.com:8086,db=tds,u=testnet_write,p=c4fa841aa918bf8274e3e2a44d77568d9861b3ea"
|
||||
```
|
||||
|
||||
- RPC URL for Testnet: `https://testnet.solana.com`
|
||||
|
||||
##### Example `solana` command-line configuration
|
||||
|
@ -121,9 +125,11 @@ Currently, rewards and inflation are disabled.
|
|||
the wallet will always be connecting to Mainnet Beta.
|
||||
- Gossip entrypoint for Mainnet Beta: `entrypoint.mainnet-beta.solana.com:8001`
|
||||
- Metrics environment variable for Mainnet Beta:
|
||||
|
||||
```bash
|
||||
export SOLANA_METRICS_CONFIG="host=https://metrics.solana.com:8086,db=mainnet-beta,u=mainnet-beta_write,p=password"
|
||||
```
|
||||
|
||||
- RPC URL for Mainnet Beta: `https://api.mainnet-beta.solana.com`
|
||||
|
||||
##### Example `solana` command-line configuration
|
||||
|
|
|
@ -57,46 +57,55 @@ release channels.
|
|||
### RPC API
|
||||
|
||||
Patch releases:
|
||||
|
||||
- Bug fixes
|
||||
- Security fixes
|
||||
- Endpoint / feature deprecation
|
||||
|
||||
Minor releases:
|
||||
|
||||
- New RPC endpoints and features
|
||||
|
||||
Major releases:
|
||||
|
||||
- Removal of deprecated features
|
||||
|
||||
### Rust Crates
|
||||
|
||||
* [`solana-sdk`](https://docs.rs/solana-sdk/) - Rust SDK for creating transactions and parsing account state
|
||||
* [`solana-program`](https://docs.rs/solana-program/) - Rust SDK for writing programs
|
||||
* [`solana-client`](https://docs.rs/solana-client/) - Rust client for connecting to RPC API
|
||||
* [`solana-cli-config`](https://docs.rs/solana-cli-config/) - Rust client for managing Solana CLI config files
|
||||
- [`solana-sdk`](https://docs.rs/solana-sdk/) - Rust SDK for creating transactions and parsing account state
|
||||
- [`solana-program`](https://docs.rs/solana-program/) - Rust SDK for writing programs
|
||||
- [`solana-client`](https://docs.rs/solana-client/) - Rust client for connecting to RPC API
|
||||
- [`solana-cli-config`](https://docs.rs/solana-cli-config/) - Rust client for managing Solana CLI config files
|
||||
|
||||
Patch releases:
|
||||
|
||||
- Bug fixes
|
||||
- Security fixes
|
||||
- Performance improvements
|
||||
|
||||
Minor releases:
|
||||
|
||||
- New APIs
|
||||
|
||||
Major releases
|
||||
|
||||
- Removal of deprecated APIs
|
||||
- Backwards incompatible behavior changes
|
||||
|
||||
### CLI Tools
|
||||
|
||||
Patch releases:
|
||||
|
||||
- Bug and security fixes
|
||||
- Performance improvements
|
||||
- Subcommand / argument deprecation
|
||||
|
||||
Minor releases:
|
||||
|
||||
- New subcommands
|
||||
|
||||
Major releases:
|
||||
|
||||
- Switch to new RPC API endpoints / configuration introduced in the previous major version.
|
||||
- Removal of deprecated features
|
||||
|
||||
|
|
|
@ -19,6 +19,7 @@ messages.
|
|||
|
||||
For information about how to log from a program see the language specific
|
||||
documentation:
|
||||
|
||||
- [Logging from a Rust program](developing-rust.md#logging)
|
||||
- [Logging from a C program](developing-c.md#logging)
|
||||
|
||||
|
@ -28,8 +29,7 @@ development it is helpful to focus on just the runtime and program logs and not
|
|||
the rest of the cluster logs. To focus in on program specific information the
|
||||
following log mask is recommended:
|
||||
|
||||
`export
|
||||
RUST_LOG=solana_runtime::system_instruction_processor=trace,solana_runtime::message_processor=info,solana_bpf_loader=debug,solana_rbpf=debug`
|
||||
`export RUST_LOG=solana_runtime::system_instruction_processor=trace,solana_runtime::message_processor=info,solana_bpf_loader=debug,solana_rbpf=debug`
|
||||
|
||||
Log messages coming directly from the program (not the runtime) will be
|
||||
displayed in the form:
|
||||
|
@ -42,6 +42,7 @@ The amount of information that can be communicated via a transaction error is
|
|||
limited but there are many points of possible failures. The following are
|
||||
possible failure points and information about what errors to expect and where to
|
||||
get more information:
|
||||
|
||||
- The BPF loader may fail to parse the program, this should not happen since the
|
||||
loader has already _finalized_ the program's account data.
|
||||
- `InstructionError::InvalidAccountData` will be returned as part of the
|
||||
|
@ -70,8 +71,7 @@ logs](debugging.md#logging).
|
|||
For example, an access violation involving the stack will look something like
|
||||
this:
|
||||
|
||||
`BPF program 4uQeVj5tqViQh7yWWGStvkEG1Zmhx6uasJtWCJziofM failed: out of bounds
|
||||
memory store (insn #615), addr 0x200001e38/8 `
|
||||
`BPF program 4uQeVj5tqViQh7yWWGStvkEG1Zmhx6uasJtWCJziofM failed: out of bounds memory store (insn #615), addr 0x200001e38/8`
|
||||
|
||||
## Monitoring Compute Budget Consumption
|
||||
|
||||
|
|
|
@ -31,11 +31,13 @@ for an example of a C program.
|
|||
## How to Build
|
||||
|
||||
First setup the environment:
|
||||
|
||||
- Install the latest Rust stable from https://rustup.rs
|
||||
- Install the latest Solana command-line tools from
|
||||
https://docs.solana.com/cli/install-solana-cli-tools
|
||||
|
||||
Then build using make:
|
||||
|
||||
```bash
|
||||
make -C <program directory>
|
||||
```
|
||||
|
@ -46,8 +48,7 @@ Solana uses the [Criterion](https://github.com/Snaipe/Criterion) test framework
|
|||
and tests are executed each time the program is built [How to
|
||||
Build](#how-to-build)].
|
||||
|
||||
To add tests, create a new file next to your source file named `test_<program
|
||||
name>.c` and populate it with criterion test cases. For an example see the
|
||||
To add tests, create a new file next to your source file named `test_<program name>.c` and populate it with criterion test cases. For an example see the
|
||||
[helloworld C
|
||||
tests](https://github.com/solana-labs/example-helloworld/blob/master/src/program-c/src/helloworld/test_helloworld.c)
|
||||
or the [Criterion docs](https://criterion.readthedocs.io/en/master) for
|
||||
|
@ -88,6 +89,7 @@ function](https://github.com/solana-labs/example-helloworld/blob/bc0b25c0ccebeff
|
|||
|
||||
Each loader provides a helper function that deserializes the program's input
|
||||
parameters into C types:
|
||||
|
||||
- [BPF Loader
|
||||
deserialization](https://github.com/solana-labs/solana/blob/d2ee9db2143859fa5dc26b15ee6da9c25cc0429c/sdk/bpf/c/inc/solana_sdk.h#L304)
|
||||
- [BPF Loader deprecated
|
||||
|
@ -162,10 +164,8 @@ implements their own heap it should not also call `calloc`.
|
|||
The runtime provides two system calls that take data and log it to the program
|
||||
logs.
|
||||
|
||||
- [`sol_log(const
|
||||
char*)`](https://github.com/solana-labs/solana/blob/d2ee9db2143859fa5dc26b15ee6da9c25cc0429c/sdk/bpf/c/inc/solana_sdk.h#L128)
|
||||
- [`sol_log_64(uint64_t, uint64_t, uint64_t, uint64_t,
|
||||
uint64_t)`](https://github.com/solana-labs/solana/blob/d2ee9db2143859fa5dc26b15ee6da9c25cc0429c/sdk/bpf/c/inc/solana_sdk.h#L134)
|
||||
- [`sol_log(const char*)`](https://github.com/solana-labs/solana/blob/d2ee9db2143859fa5dc26b15ee6da9c25cc0429c/sdk/bpf/c/inc/solana_sdk.h#L128)
|
||||
- [`sol_log_64(uint64_t, uint64_t, uint64_t, uint64_t, uint64_t)`](https://github.com/solana-labs/solana/blob/d2ee9db2143859fa5dc26b15ee6da9c25cc0429c/sdk/bpf/c/inc/solana_sdk.h#L134)
|
||||
|
||||
The [debugging](debugging.md#logging) section has more information about working
|
||||
with program logs.
|
||||
|
|
|
@ -17,10 +17,13 @@ layout](https://doc.rust-lang.org/cargo/guide/project-layout.html):
|
|||
```
|
||||
|
||||
But must also include:
|
||||
|
||||
```
|
||||
/Xargo.toml
|
||||
```
|
||||
|
||||
Which must contain:
|
||||
|
||||
```
|
||||
[target.bpfel-unknown-unknown.dependencies.std]
|
||||
features = []
|
||||
|
@ -41,6 +44,7 @@ to exclude the entrypoint.
|
|||
|
||||
Then when other programs include this program as a dependency, they should do so
|
||||
using the `exclude_entrypoint` feature.
|
||||
|
||||
- [Include without
|
||||
entrypoint](https://github.com/solana-labs/solana-program-library/blob/a5babd6cbea0d3f29d8c57d2ecbbd2a2bd59c8a9/token-swap/program/Cargo.toml#L19)
|
||||
|
||||
|
@ -53,6 +57,7 @@ Solana BPF programs have some [restrictions](#restrictions) that may prevent the
|
|||
inclusion of some crates as dependencies or require special handling.
|
||||
|
||||
For example:
|
||||
|
||||
- Crates that require the architecture be a subset of the ones supported by the
|
||||
official toolchain. There is no workaround for this unless that crate is
|
||||
forked and BPF added to that those architecture checks.
|
||||
|
@ -66,6 +71,7 @@ For example:
|
|||
## How to Build
|
||||
|
||||
First setup the environment:
|
||||
|
||||
- Install the latest Rust stable from https://rustup.rs/
|
||||
- Install the latest Solana command-line tools from
|
||||
https://docs.solana.com/cli/install-solana-cli-tools
|
||||
|
@ -129,6 +135,7 @@ entrypoint, deserializes the parameters, calls a user defined instruction
|
|||
processing function, and returns the results.
|
||||
|
||||
You can find the entrypoint macros here:
|
||||
|
||||
- [BPF Loader's entrypoint
|
||||
macro](https://github.com/solana-labs/solana/blob/7ddf10e602d2ed87a9e3737aa8c32f1db9f909d8/sdk/program/src/entrypoint.rs#L46)
|
||||
- [BPF Loader deprecated's entrypoint
|
||||
|
@ -151,6 +158,7 @@ as an example of how things fit together.
|
|||
Each loader provides a helper function that deserializes the program's input
|
||||
parameters into Rust types. The entrypoint macros automatically calls the
|
||||
deserialization helper:
|
||||
|
||||
- [BPF Loader
|
||||
deserialization](https://github.com/solana-labs/solana/blob/7ddf10e602d2ed87a9e3737aa8c32f1db9f909d8/sdk/program/src/entrypoint.rs#L104)
|
||||
- [BPF Loader deprecated
|
||||
|
@ -284,7 +292,9 @@ is provided.
|
|||
```rust
|
||||
msg!("A string");
|
||||
```
|
||||
|
||||
or
|
||||
|
||||
```rust
|
||||
msg!(0_64, 1_64, 2_64, 3_64, 4_64);
|
||||
```
|
||||
|
|
|
@ -2,7 +2,6 @@
|
|||
title: "Examples"
|
||||
---
|
||||
|
||||
|
||||
## Helloworld
|
||||
|
||||
Hello World is a project that demonstrates how to use the Solana Javascript API
|
||||
|
@ -10,6 +9,7 @@ and both Rust and C programs to build, deploy, and interact with programs on the
|
|||
Solana blockchain.
|
||||
|
||||
The project comprises of:
|
||||
|
||||
- An on-chain hello world program
|
||||
- A client that can send a "hello" to an account and get back the number of
|
||||
times "hello" has been sent
|
||||
|
@ -26,7 +26,6 @@ $ cd example-helloworld
|
|||
Next, follow the steps in the git repository's
|
||||
[README](https://github.com/solana-labs/example-helloworld/blob/master/README.md).
|
||||
|
||||
|
||||
## Break
|
||||
|
||||
[Break](https://break.solana.com/) is a React app that gives users a visceral
|
||||
|
|
|
@ -48,10 +48,7 @@ BPF uses stack frames instead of a variable stack pointer. Each stack frame is
|
|||
If a program violates that stack frame size, the compiler will report the
|
||||
overrun as a warning.
|
||||
|
||||
For example: `Error: Function
|
||||
_ZN16curve25519_dalek7edwards21EdwardsBasepointTable6create17h178b3d2411f7f082E
|
||||
Stack offset of -30728 exceeded max offset of -4096 by 26632 bytes, please
|
||||
minimize large stack variables`
|
||||
For example: `Error: Function _ZN16curve25519_dalek7edwards21EdwardsBasepointTable6create17h178b3d2411f7f082E Stack offset of -30728 exceeded max offset of -4096 by 26632 bytes, please minimize large stack variables`
|
||||
|
||||
The message identifies which symbol is exceeding its stack frame but the name
|
||||
might be mangled if it is a Rust or C++ symbol. To demangle a Rust symbol use
|
||||
|
@ -153,6 +150,7 @@ and the javascript APIs.
|
|||
|
||||
For language specific information about implementing a program for a particular
|
||||
loader see:
|
||||
|
||||
- [Rust program entrypoints](developing-rust.md#program-entrypoint)
|
||||
- [C program entrypoints](developing-c.md#program-entrypoint)
|
||||
|
||||
|
@ -187,6 +185,7 @@ array. This allows deserialization implementations to directly reference the
|
|||
byte array and provide aligned pointers to the program.
|
||||
|
||||
For language specific information about serialization see:
|
||||
|
||||
- [Rust program parameter
|
||||
deserialization](developing-rust.md#parameter-deserialization)
|
||||
- [C program parameter
|
||||
|
|
|
@ -169,7 +169,6 @@ For example, an account is created with the initial transfer of 10,000 lamports
|
|||
and no additional data. Rent is immediately debited from it on creation,
|
||||
resulting in a balance of 7,561 lamports:
|
||||
|
||||
|
||||
```text
|
||||
Rent: 2,439 = 19.055441478439427 (rent rate) * 128 bytes (minimum account size) * 1 (epoch)
|
||||
Account Balance: 7,561 = 10,000 (transfered lamports) - 2,439 (this account's rent fee for an epoch)
|
||||
|
|
|
@ -28,6 +28,7 @@ program only performed operations it was permitted to, and that the results
|
|||
adhere to the runtime policy.
|
||||
|
||||
The policy is as follows:
|
||||
|
||||
- Only the owner of the account may change owner.
|
||||
- And only if the account is writable.
|
||||
- And only if the account is not executable
|
||||
|
@ -51,6 +52,7 @@ program may not exceed. When the program consumes its entire budget or exceeds
|
|||
a bound then the runtime halts the program and returns an error.
|
||||
|
||||
The following operations incur a compute cost:
|
||||
|
||||
- Executing BPF instructions
|
||||
- Calling system calls
|
||||
- logging
|
||||
|
@ -81,6 +83,7 @@ log_pubkey_units: 100,
|
|||
```
|
||||
|
||||
Then the program
|
||||
|
||||
- Could execute 200,000 BPF instructions if it does nothing else
|
||||
- Could log 2,000 log messages
|
||||
- Can not exceed 4k of stack usage
|
||||
|
|
|
@ -139,7 +139,6 @@ accounts are permanently marked as executable by the loader once they are
|
|||
successfully deployed. The runtime will reject transactions that specify programs
|
||||
that are not executable.
|
||||
|
||||
|
||||
Unlike on-chain programs, [Native Programs](/developing/runtime-facilities/programs)
|
||||
are handled differently in that they are built directly into the Solana runtime.
|
||||
|
||||
|
@ -201,7 +200,6 @@ authorization to permit debiting the account or modifying its data. More
|
|||
information about how the authorization is communicated to a program can be
|
||||
found in [Accounts](accounts.md#signers)
|
||||
|
||||
|
||||
## Recent Blockhash
|
||||
|
||||
A transaction includes a recent [blockhash](terminology.md#blockhash) to prevent
|
||||
|
|
|
@ -88,6 +88,7 @@ struct Secp256k1SignatureOffsets {
|
|||
```
|
||||
|
||||
Pseudo code of the operation:
|
||||
|
||||
```
|
||||
process_instruction() {
|
||||
for i in 0..count {
|
||||
|
|
|
@ -12,7 +12,7 @@ and outlined below.
|
|||
To include sysvar data in program operations, pass the sysvar account address in
|
||||
the list of accounts in a transaction. The account can be read in your
|
||||
instruction processor like any other account. Access to sysvars accounts ßis
|
||||
always *readonly*.
|
||||
always _readonly_.
|
||||
|
||||
## Clock
|
||||
|
||||
|
@ -22,6 +22,7 @@ epoch, and estimated wall-clock Unix timestamp. It is updated every slot.
|
|||
- Address: `SysvarC1ock11111111111111111111111111111111`
|
||||
- Layout: [Clock](https://docs.rs/solana-program/VERSION_FOR_DOCS_RS/solana_program/clock/struct.Clock.html)
|
||||
- Fields:
|
||||
|
||||
- `slot`: the current slot
|
||||
- `epoch_start_timestamp`: the Unix timestamp of the first slot in this epoch. In the first slot of an epoch, this timestamp is identical to the `unix_timestamp` (below).
|
||||
- `epoch`: the current epoch
|
||||
|
@ -48,8 +49,7 @@ epoch, and estimated wall-clock Unix timestamp. It is updated every slot.
|
|||
|
||||
The EpochSchedule sysvar contains epoch scheduling constants that are set in
|
||||
genesis, and enables calculating the number of slots in a given epoch, the epoch
|
||||
for a given slot, etc. (Note: the epoch schedule is distinct from the [`leader
|
||||
schedule`](terminology.md#leader-schedule))
|
||||
for a given slot, etc. (Note: the epoch schedule is distinct from the [`leader schedule`](terminology.md#leader-schedule))
|
||||
|
||||
- Address: `SysvarEpochSchedu1e111111111111111111111111`
|
||||
- Layout:
|
||||
|
|
|
@ -20,45 +20,43 @@ The effective protocol-based annual staking yield \(%\) per epoch received by va
|
|||
|
||||
The first factor is a function of protocol parameters only \(i.e. independent of validator behavior in a given epoch\) and results in an inflation schedule designed to incentivize early participation, provide clear monetary stability and provide optimal security in the network.
|
||||
|
||||
As a first step to understanding the impact of the *Inflation Schedule* on the Solana economy, we’ve simulated the upper and lower ranges of what token issuance over time might look like given the current ranges of Inflation Schedule parameters under study.
|
||||
As a first step to understanding the impact of the _Inflation Schedule_ on the Solana economy, we’ve simulated the upper and lower ranges of what token issuance over time might look like given the current ranges of Inflation Schedule parameters under study.
|
||||
|
||||
Specifically:
|
||||
|
||||
- *Initial Inflation Rate*: 7-9%
|
||||
- *Dis-inflation Rate*: -14-16%
|
||||
- *Long-term Inflation Rate*: 1-2%
|
||||
- _Initial Inflation Rate_: 7-9%
|
||||
- _Dis-inflation Rate_: -14-16%
|
||||
- _Long-term Inflation Rate_: 1-2%
|
||||
|
||||
Using these ranges to simulate a number of possible Inflation Schedules, we can explore inflation over time:
|
||||
|
||||
![](/img/p_inflation_schedule_ranges_w_comments.png)
|
||||
|
||||
In the above graph, the average values of the range are identified to illustrate the contribution of each parameter.
|
||||
From these simulated *Inflation Schedules*, we can also project ranges for token issuance over time.
|
||||
From these simulated _Inflation Schedules_, we can also project ranges for token issuance over time.
|
||||
|
||||
![](/img/p_total_supply_ranges.png)
|
||||
|
||||
Finally we can estimate the *Staked Yield* on staked SOL, if we introduce an additional parameter, previously discussed, *% of Staked SOL*:
|
||||
|
||||
Finally we can estimate the _Staked Yield_ on staked SOL, if we introduce an additional parameter, previously discussed, _% of Staked SOL_:
|
||||
|
||||
%~\text{SOL Staked} = \frac{\text{Total SOL Staked}}{\text{Total Current Supply}}
|
||||
|
||||
In this case, because _% of Staked SOL_ is a parameter that must be estimated (unlike the _Inflation Schedule_ parameters), it is easier to use specific _Inflation Schedule_ parameters and explore a range of _% of Staked SOL_. For the below example, we’ve chosen the middle of the parameter ranges explored above:
|
||||
|
||||
In this case, because *% of Staked SOL* is a parameter that must be estimated (unlike the *Inflation Schedule* parameters), it is easier to use specific *Inflation Schedule* parameters and explore a range of *% of Staked SOL*. For the below example, we’ve chosen the middle of the parameter ranges explored above:
|
||||
- _Initial Inflation Rate_: 8%
|
||||
- _Dis-inflation Rate_: -15%
|
||||
- _Long-term Inflation Rate_: 1.5%
|
||||
|
||||
- *Initial Inflation Rate*: 8%
|
||||
- *Dis-inflation Rate*: -15%
|
||||
- *Long-term Inflation Rate*: 1.5%
|
||||
|
||||
The values of *% of Staked SOL* range from 60% - 90%, which we feel covers the likely range we expect to observe, based on feedback from the investor and validator communities as well as what is observed on comparable Proof-of-Stake protocols.
|
||||
The values of _% of Staked SOL_ range from 60% - 90%, which we feel covers the likely range we expect to observe, based on feedback from the investor and validator communities as well as what is observed on comparable Proof-of-Stake protocols.
|
||||
|
||||
![](/img/p_ex_staked_yields.png)
|
||||
|
||||
Again, the above shows an example *Staked Yield* that a staker might expect over time on the Solana network with the *Inflation Schedule* as specified. This is an idealized *Staked Yield* as it neglects validator uptime impact on rewards, validator commissions, potential yield throttling and potential slashing incidents. It additionally ignores that *% of Staked SOL* is dynamic by design - the economic incentives set up by this *Inflation Schedule*.
|
||||
Again, the above shows an example _Staked Yield_ that a staker might expect over time on the Solana network with the _Inflation Schedule_ as specified. This is an idealized _Staked Yield_ as it neglects validator uptime impact on rewards, validator commissions, potential yield throttling and potential slashing incidents. It additionally ignores that _% of Staked SOL_ is dynamic by design - the economic incentives set up by this _Inflation Schedule_.
|
||||
|
||||
### Adjusted Staking Yield
|
||||
|
||||
A complete appraisal of earning potential from staking tokens should take into account staked *Token Dilution* and its impact on staking yield. For this, we define *adjusted staking yield* as the change in fractional token supply ownership of staked tokens due to the distribution of inflation issuance. I.e. the positive dilutive effects of inflation.
|
||||
A complete appraisal of earning potential from staking tokens should take into account staked _Token Dilution_ and its impact on staking yield. For this, we define _adjusted staking yield_ as the change in fractional token supply ownership of staked tokens due to the distribution of inflation issuance. I.e. the positive dilutive effects of inflation.
|
||||
|
||||
We can examine the *adjusted staking yield* as a function of the inflation rate and the percent of staked tokens on the network. We can see this plotted for various staking fractions here:
|
||||
We can examine the _adjusted staking yield_ as a function of the inflation rate and the percent of staked tokens on the network. We can see this plotted for various staking fractions here:
|
||||
|
||||
![](/img/p_ex_staked_dilution.png)
|
||||
|
|
|
@ -6,7 +6,7 @@ title: instruction introspection
|
|||
|
||||
Some smart contract programs may want to verify that another Instruction is present in a
|
||||
given Message since that Instruction could be be performing a verification of certain data,
|
||||
in a precompiled function. (See secp256k1\_instruction for an example).
|
||||
in a precompiled function. (See secp256k1_instruction for an example).
|
||||
|
||||
## Solution
|
||||
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
# Long term RPC Transaction History
|
||||
|
||||
There's a need for RPC to serve at least 6 months of transaction history. The
|
||||
current history, on the order of days, is insufficient for downstream users.
|
||||
|
||||
|
@ -8,34 +9,37 @@ rocksdb ledger will continue to serve as the primary data source, and then will
|
|||
fall back to the external data store.
|
||||
|
||||
The affected RPC endpoints are:
|
||||
* [getFirstAvailableBlock](developing/clients/jsonrpc-api.md#getfirstavailableblock)
|
||||
* [getConfirmedBlock](developing/clients/jsonrpc-api.md#getconfirmedblock)
|
||||
* [getConfirmedBlocks](developing/clients/jsonrpc-api.md#getconfirmedblocks)
|
||||
* [getConfirmedSignaturesForAddress](developing/clients/jsonrpc-api.md#getconfirmedsignaturesforaddress)
|
||||
* [getConfirmedTransaction](developing/clients/jsonrpc-api.md#getconfirmedtransaction)
|
||||
* [getSignatureStatuses](developing/clients/jsonrpc-api.md#getsignaturestatuses)
|
||||
|
||||
- [getFirstAvailableBlock](developing/clients/jsonrpc-api.md#getfirstavailableblock)
|
||||
- [getConfirmedBlock](developing/clients/jsonrpc-api.md#getconfirmedblock)
|
||||
- [getConfirmedBlocks](developing/clients/jsonrpc-api.md#getconfirmedblocks)
|
||||
- [getConfirmedSignaturesForAddress](developing/clients/jsonrpc-api.md#getconfirmedsignaturesforaddress)
|
||||
- [getConfirmedTransaction](developing/clients/jsonrpc-api.md#getconfirmedtransaction)
|
||||
- [getSignatureStatuses](developing/clients/jsonrpc-api.md#getsignaturestatuses)
|
||||
|
||||
Note that [getBlockTime](developing/clients/jsonrpc-api.md#getblocktime)
|
||||
is not supported, as once https://github.com/solana-labs/solana/issues/10089 is
|
||||
fixed then `getBlockTime` can be removed.
|
||||
|
||||
Some system design constraints:
|
||||
* The volume of data to store and search can quickly jump into the terabytes,
|
||||
|
||||
- The volume of data to store and search can quickly jump into the terabytes,
|
||||
and is immutable.
|
||||
* The system should be as light as possible for SREs. For example an SQL
|
||||
- The system should be as light as possible for SREs. For example an SQL
|
||||
database cluster that requires an SRE to continually monitor and rebalance
|
||||
nodes is undesirable.
|
||||
* Data must be searchable in real time - batched queries that take minutes or
|
||||
- Data must be searchable in real time - batched queries that take minutes or
|
||||
hours to run are unacceptable.
|
||||
* Easy to replicate the data worldwide to co-locate it with the RPC endpoints
|
||||
- Easy to replicate the data worldwide to co-locate it with the RPC endpoints
|
||||
that will utilize it.
|
||||
* Interfacing with the external data store should be easy and not require
|
||||
- Interfacing with the external data store should be easy and not require
|
||||
depending on risky lightly-used community-supported code libraries
|
||||
|
||||
Based on these constraints, Google's BigTable product is selected as the data
|
||||
store.
|
||||
|
||||
## Table Schema
|
||||
|
||||
A BigTable instance is used to hold all transaction data, broken up into
|
||||
different tables for quick searching.
|
||||
|
||||
|
@ -58,12 +62,14 @@ in the future may require additions to the schema and potentially iterating over
|
|||
all transactions to build up the necessary metadata.
|
||||
|
||||
## Accessing BigTable
|
||||
|
||||
BigTable has a gRPC endpoint that can be accessed using the
|
||||
[tonic](https://crates.io/crates/crate)] and the raw protobuf API, as currently no
|
||||
higher-level Rust crate for BigTable exists. Practically this makes parsing the
|
||||
results of BigTable queries more complicated but is not a significant issue.
|
||||
|
||||
## Data Population
|
||||
|
||||
The ongoing population of instance data will occur on an epoch cadence through the
|
||||
use of a new `solana-ledger-tool` command that will convert rocksdb data for a
|
||||
given slot range into the instance schema.
|
||||
|
@ -82,13 +88,11 @@ block will always be first when the rows are listed. eg, The row key for slot
|
|||
|
||||
The row data is a compressed `StoredConfirmedBlock` struct.
|
||||
|
||||
|
||||
### Account Address Transaction Signature Lookup Table: `tx-by-addr`
|
||||
|
||||
This table contains the transactions that affect a given address.
|
||||
|
||||
The row key is `<base58
|
||||
address>/<slot-id-one's-compliment-hex-slot-0-prefixed-to-16-digits>`. The row
|
||||
The row key is `<base58 address>/<slot-id-one's-compliment-hex-slot-0-prefixed-to-16-digits>`. The row
|
||||
data is a compressed `TransactionByAddrInfo` struct.
|
||||
|
||||
Taking the one's compliment of the slot allows for listing of slots ensures that
|
||||
|
|
|
@ -2,20 +2,19 @@
|
|||
title: Adjusted Staking Yield
|
||||
---
|
||||
|
||||
|
||||
### Token Dilution
|
||||
|
||||
Similarly we can look at the expected *Staked Dilution* (i.e. *Adjusted Staking Yield*) and *Un-staked Dilution* as previously defined. Again, *dilution* in this context is defined as the change in fractional representation (i.e. ownership) of a set of tokens within a larger set. In this sense, dilution can be a positive value: an increase in fractional ownership (staked dilution / *Adjusted Staking Yield*), or a negative value: a decrease in fractional ownership (un-staked dilution).
|
||||
Similarly we can look at the expected _Staked Dilution_ (i.e. _Adjusted Staking Yield_) and _Un-staked Dilution_ as previously defined. Again, _dilution_ in this context is defined as the change in fractional representation (i.e. ownership) of a set of tokens within a larger set. In this sense, dilution can be a positive value: an increase in fractional ownership (staked dilution / _Adjusted Staking Yield_), or a negative value: a decrease in fractional ownership (un-staked dilution).
|
||||
|
||||
We are interested in the relative change in ownership of staked vs un-staked tokens as the overall token pool increases with inflation issuance. As discussed, this issuance is distributed only to staked token holders, increasing the staked token fractional representation of the *Total Current Supply*.
|
||||
We are interested in the relative change in ownership of staked vs un-staked tokens as the overall token pool increases with inflation issuance. As discussed, this issuance is distributed only to staked token holders, increasing the staked token fractional representation of the _Total Current Supply_.
|
||||
|
||||
Continuing with the same *Inflation Schedule* parameters as above, we see the fraction of staked supply grow as shown below.
|
||||
Continuing with the same _Inflation Schedule_ parameters as above, we see the fraction of staked supply grow as shown below.
|
||||
|
||||
![](/img/p_ex_staked_supply_w_range_initial_stake.png)
|
||||
|
||||
Due to this relative change in representation, the proportion of stake of any token holder will also change as a function of the *Inflation Schedule* and the proportion of all tokens that are staked.
|
||||
Due to this relative change in representation, the proportion of stake of any token holder will also change as a function of the _Inflation Schedule_ and the proportion of all tokens that are staked.
|
||||
|
||||
Of initial interest, however, is the *dilution of **un-staked** tokens*, or $D_{us}$. In the case of un-staked tokens, token dilution is only a function of the *Inflation Schedule* because the amount of un-staked tokens doesn't change over time.
|
||||
Of initial interest, however, is the _dilution of **un-staked** tokens_, or $D_{us}$. In the case of un-staked tokens, token dilution is only a function of the _Inflation Schedule_ because the amount of un-staked tokens doesn't change over time.
|
||||
|
||||
This can be seen by explicitly calculating un-staked dilution as $D_{us}$. The un-staked proportion of the token pool at time $t$ is $P_{us}(t_{N})$ and $I_{t}$ is the incremental inflation rate applied between any two consecutive time points. $SOL_{us}(t)$ and $SOL_{total}(t)$ is the amount of un-staked and total SOL on the network, respectively, at time $t$. Therefore $P_{us}(t) = SOL_{us}(t)/SOL_{total}(t)$.
|
||||
|
||||
|
@ -34,7 +33,6 @@ $$
|
|||
SOL_{us}(t_2) &= SOL_{us}(t_1)\\
|
||||
SOL_{total}(t_2) &= SOL_{total}(t_1)\times (1 + I_{t_1})\\
|
||||
\end{aligned}
|
||||
|
||||
$$
|
||||
|
||||
So $D_{us}$ becomes:
|
||||
|
@ -52,17 +50,15 @@ $$
|
|||
D_{us} = -\frac{I}{I + 1} \\
|
||||
$$
|
||||
|
||||
So as guessed, this dilution is independent of the total proportion of staked tokens and only depends on inflation rate. This can be seen with our example *Inflation Schedule* here:
|
||||
|
||||
So as guessed, this dilution is independent of the total proportion of staked tokens and only depends on inflation rate. This can be seen with our example _Inflation Schedule_ here:
|
||||
|
||||
![p_ex_unstaked_dilution](/img/p_ex_unstaked_dilution.png)
|
||||
|
||||
|
||||
### Estimated Adjusted Staked Yield
|
||||
|
||||
We can do a similar calculation to determine the *dilution* of staked token holders, or as we've defined here as the ***Adjusted Staked Yield***, keeping in mind that dilution in this context is an *increase* in proportional ownership over time. We'll use the terminology *Adjusted Staked Yield* to avoid confusion going forward.
|
||||
We can do a similar calculation to determine the _dilution_ of staked token holders, or as we've defined here as the **_Adjusted Staked Yield_**, keeping in mind that dilution in this context is an _increase_ in proportional ownership over time. We'll use the terminology _Adjusted Staked Yield_ to avoid confusion going forward.
|
||||
|
||||
To see the functional form, we calculate, $Y_{adj}$, or the *Adjusted Staked Yield* (to be compared to *D_{us}* the dilution of un-staked tokens above), where $P_{s}(t)$ is the staked proportion of token pool at time $t$ and $I_{t}$ is the incremental inflation rate applied between any two consecutive time points. The definition of $Y_{adj}$ is therefore:
|
||||
To see the functional form, we calculate, $Y_{adj}$, or the _Adjusted Staked Yield_ (to be compared to _D\_{us}_ the dilution of un-staked tokens above), where $P_{s}(t)$ is the staked proportion of token pool at time $t$ and $I_{t}$ is the incremental inflation rate applied between any two consecutive time points. The definition of $Y_{adj}$ is therefore:
|
||||
|
||||
$$
|
||||
Y_{adj} = \frac{P_s(t_2) - P_s(t_1)}{P_s(t_1)}\\
|
||||
|
@ -89,13 +85,11 @@ $$
|
|||
Y_{adj} = \frac{ 1 + I(t)/P_s(t) }{ 1 + I(t) } - 1\\
|
||||
$$
|
||||
|
||||
So we see that the *Adjusted Staked Yield* a function of the inflation rate and the percent of staked tokens on the network. We can see this plotted for various staking fractions here:
|
||||
|
||||
So we see that the _Adjusted Staked Yield_ a function of the inflation rate and the percent of staked tokens on the network. We can see this plotted for various staking fractions here:
|
||||
|
||||
![p_ex_adjusted_staked_yields](/img/p_ex_adjusted_staked_yields.png)
|
||||
|
||||
|
||||
It is also clear that in all cases, dilution of un-staked tokens $>$ adjusted staked yield (i.e. dilution of staked tokens). Explicitly we can look at the *relative dilution of un-staked tokens to staked tokens:* $D_{us}/Y_{adj}$. Here the relationship to inflation drops out and the relative dilution, i.e. the impact of staking tokens vs not staking tokens, is purely a function of the % of the total token supply staked. From above
|
||||
It is also clear that in all cases, dilution of un-staked tokens $>$ adjusted staked yield (i.e. dilution of staked tokens). Explicitly we can look at the _relative dilution of un-staked tokens to staked tokens:_ $D_{us}/Y_{adj}$. Here the relationship to inflation drops out and the relative dilution, i.e. the impact of staking tokens vs not staking tokens, is purely a function of the % of the total token supply staked. From above
|
||||
|
||||
$$
|
||||
\begin{aligned}
|
||||
|
@ -121,4 +115,4 @@ Where we can see a primary dependence of the relative dilution of un-staked toke
|
|||
|
||||
As might be intuitive, as the total fraction of staked tokens increases the relative dilution of un-staked tokens grows dramatically. E.g. with $80\%$ of the network tokens staked, an un-staked token holder will experience ~$400\%$ more dilution than a staked holder.
|
||||
|
||||
Again, this represents the change in fractional change in ownership of staked tokens and illustrates the built-in incentive for token holder to stake their tokens to earn *Staked Yield* and avoid *Un-staked Dilution*.
|
||||
Again, this represents the change in fractional change in ownership of staked tokens and illustrates the built-in incentive for token holder to stake their tokens to earn _Staked Yield_ and avoid _Un-staked Dilution_.
|
||||
|
|
|
@ -2,11 +2,11 @@
|
|||
title: Solana's Proposed Inflation Schedule
|
||||
---
|
||||
|
||||
As mentioned above, the network's *Inflation Schedule* is uniquely described by three parameters: *Initial Inflation Rate*, *Dis-inflation Rate* and *Long-term Inflation Rate*. When considering these numbers, there are many factors to take into account:
|
||||
As mentioned above, the network's _Inflation Schedule_ is uniquely described by three parameters: _Initial Inflation Rate_, _Dis-inflation Rate_ and _Long-term Inflation Rate_. When considering these numbers, there are many factors to take into account:
|
||||
|
||||
- A large portion of the SOL issued via inflation will be distributed to stake-holders in proportion to the SOL they have staked. We want to ensure that the *Inflation Schedule* design results in reasonable *Staking Yields* for token holders who delegate SOL and for validation service providers (via commissions taken from *Staking Yields*).
|
||||
- The primary driver of *Staked Yield* is the amount of SOL staked divided by the total amount of SOL (% of total SOL staked). Therefore the distribution and delegation of tokens across validators are important factors to understand when determining initial inflation parameters.
|
||||
- [Yield throttling](https://forums.solana.com/t/validator-yield-throttling-proposal-discussion/855/5) is a current area or research that would impact *staking-yields*. This is not taken into consideration in the discussion here or the modeling below.
|
||||
- A large portion of the SOL issued via inflation will be distributed to stake-holders in proportion to the SOL they have staked. We want to ensure that the _Inflation Schedule_ design results in reasonable _Staking Yields_ for token holders who delegate SOL and for validation service providers (via commissions taken from _Staking Yields_).
|
||||
- The primary driver of _Staked Yield_ is the amount of SOL staked divided by the total amount of SOL (% of total SOL staked). Therefore the distribution and delegation of tokens across validators are important factors to understand when determining initial inflation parameters.
|
||||
- [Yield throttling](https://forums.solana.com/t/validator-yield-throttling-proposal-discussion/855/5) is a current area or research that would impact _staking-yields_. This is not taken into consideration in the discussion here or the modeling below.
|
||||
- Overall token issuance - i.e. what do we expect the Current Total Supply to be in 10 years, or 20 years?
|
||||
- Long-term, steady-state inflation is an important consideration not only for sustainable support for the validator ecosystem and the Solana Foundation grant programs, but also should be tuned in consideration with expected token losses and burning over time.
|
||||
- The rate at which we expect network usage to grow, as a consideration to the dis-inflationary rate. Over time, we plan for inflation to drop and expect that usage will grow.
|
||||
|
@ -17,7 +17,7 @@ Based on these considerations and the community discussions following the initia
|
|||
- Dis-inflation Rate: $-15\%$
|
||||
- Long-term Inflation Rate: $1.5\%$
|
||||
|
||||
These parameters define the proposed *Inflation Schedule*. Below we show implications of these parameters. These plots only show the impact of inflation issuances given the Inflation Schedule as parameterized above. They *do not account* for other factors that may impact the Total Supply such as fee/rent burning, slashing or other unforeseen future token destruction events. Therefore, what is presented here is an **upper limit** on the amount of SOL issued via inflation.
|
||||
These parameters define the proposed _Inflation Schedule_. Below we show implications of these parameters. These plots only show the impact of inflation issuances given the Inflation Schedule as parameterized above. They _do not account_ for other factors that may impact the Total Supply such as fee/rent burning, slashing or other unforeseen future token destruction events. Therefore, what is presented here is an **upper limit** on the amount of SOL issued via inflation.
|
||||
|
||||
![](/img/p_inflation_schedule.png)
|
||||
|
||||
|
@ -25,16 +25,16 @@ In the above graph we see the annual inflation rate [$\%$] over time, given the
|
|||
|
||||
![](/img/p_total_supply.png)
|
||||
|
||||
Similarly, here we see the *Total Current Supply* of SOL [MM] over time, assuming an initial *Total Current Supply* of `488,587,349 SOL` (i.e. for this example, taking the *Total Current Supply* as of `2020-01-25` and simulating inflation starting from that day).
|
||||
Similarly, here we see the _Total Current Supply_ of SOL [MM] over time, assuming an initial _Total Current Supply_ of `488,587,349 SOL` (i.e. for this example, taking the _Total Current Supply_ as of `2020-01-25` and simulating inflation starting from that day).
|
||||
|
||||
Setting aside validator uptime and commissions, the expected Staking Yield and Adjusted Staking Yield metrics are then primarily a function of the % of total SOL staked on the network. Therefore we can we can model *Staking Yield*, if we introduce an additional parameter *% of Staked SOL*:
|
||||
Setting aside validator uptime and commissions, the expected Staking Yield and Adjusted Staking Yield metrics are then primarily a function of the % of total SOL staked on the network. Therefore we can we can model _Staking Yield_, if we introduce an additional parameter _% of Staked SOL_:
|
||||
|
||||
$$
|
||||
\%~\text{SOL Staked} = \frac{\text{Total SOL Staked}}{\text{Total Current Supply}}
|
||||
$$
|
||||
|
||||
This parameter must be estimated because it is a dynamic property of the token holders and staking incentives. The values of *% of Staked SOL* presented here range from $60\% - 90\%$, which we feel covers the likely range we expect to observe, based on feedback from the investor and validator communities as well as what is observed on comparable Proof-of-Stake protocols.
|
||||
This parameter must be estimated because it is a dynamic property of the token holders and staking incentives. The values of _% of Staked SOL_ presented here range from $60\% - 90\%$, which we feel covers the likely range we expect to observe, based on feedback from the investor and validator communities as well as what is observed on comparable Proof-of-Stake protocols.
|
||||
|
||||
![](/img/p_ex_staked_yields.png)
|
||||
|
||||
Again, the above shows an example *Staked Yield* that a staker might expect over time on the Solana network with the *Inflation Schedule* as specified. This is an idealized *Staked Yield* as it neglects validator uptime impact on rewards, validator commissions, potential yield throttling and potential slashing incidents. It additionally ignores that *% of Staked SOL* is dynamic by design - the economic incentives set up by this *Inflation Schedule* are more clearly seen when *Token Dilution* is taken into account (see the **Adjusted Staking Yield** section below).
|
||||
Again, the above shows an example _Staked Yield_ that a staker might expect over time on the Solana network with the _Inflation Schedule_ as specified. This is an idealized _Staked Yield_ as it neglects validator uptime impact on rewards, validator commissions, potential yield throttling and potential slashing incidents. It additionally ignores that _% of Staked SOL_ is dynamic by design - the economic incentives set up by this _Inflation Schedule_ are more clearly seen when _Token Dilution_ is taken into account (see the **Adjusted Staking Yield** section below).
|
||||
|
|
|
@ -2,39 +2,39 @@
|
|||
title: Terminology
|
||||
---
|
||||
|
||||
|
||||
Many terms are thrown around when discussing inflation and the related components (e.g. rewards/yield/interest), we try to define and clarify some commonly used concept here:
|
||||
|
||||
### Total Current Supply [SOL]
|
||||
The total amount of tokens (locked or unlocked) that have been generated (via genesis block or protocol inflation) minus any tokens that have been burnt (via transaction fees or other mechanism) or slashed. At network launch, 500,000,000 SOL were instantiated in the genesis block. Since then the Total Current Supply has been reduced by the burning of transaction fees and a planned token reduction event. Solana’s *Total Current Supply* can be found at https://explorer.solana.com/supply
|
||||
|
||||
The total amount of tokens (locked or unlocked) that have been generated (via genesis block or protocol inflation) minus any tokens that have been burnt (via transaction fees or other mechanism) or slashed. At network launch, 500,000,000 SOL were instantiated in the genesis block. Since then the Total Current Supply has been reduced by the burning of transaction fees and a planned token reduction event. Solana’s _Total Current Supply_ can be found at https://explorer.solana.com/supply
|
||||
|
||||
### Inflation Rate [%]
|
||||
The Solana protocol will automatically create new tokens on a predetermined inflation schedule (discussed below). The *Inflation Rate [%]* is the annualized growth rate of the *Total Current Supply* at any point in time.
|
||||
|
||||
The Solana protocol will automatically create new tokens on a predetermined inflation schedule (discussed below). The _Inflation Rate [%]_ is the annualized growth rate of the _Total Current Supply_ at any point in time.
|
||||
|
||||
### Inflation Schedule
|
||||
A deterministic description of token issuance over time. The Solana Foundation is proposing a dis-inflationary *Inflation Schedule*. I.e. Inflation starts at its highest value, the rate reduces over time until stabilizing at a predetermined long-term inflation rate (see discussion below). This schedule is completely and uniquely parameterized by three numbers:
|
||||
|
||||
- **Initial Inflation Rate [%]**: The starting *Inflation Rate* for when inflation is first enabled. Token issuance rate can only decrease from this point.
|
||||
- **Dis-inflation Rate [%]**: The rate at which the *Inflation Rate* is reduced.
|
||||
- **Long-term Inflation Rate [%]**: The stable, long-term *Inflation Rate* to be expected.
|
||||
A deterministic description of token issuance over time. The Solana Foundation is proposing a dis-inflationary _Inflation Schedule_. I.e. Inflation starts at its highest value, the rate reduces over time until stabilizing at a predetermined long-term inflation rate (see discussion below). This schedule is completely and uniquely parameterized by three numbers:
|
||||
|
||||
- **Initial Inflation Rate [%]**: The starting _Inflation Rate_ for when inflation is first enabled. Token issuance rate can only decrease from this point.
|
||||
- **Dis-inflation Rate [%]**: The rate at which the _Inflation Rate_ is reduced.
|
||||
- **Long-term Inflation Rate [%]**: The stable, long-term _Inflation Rate_ to be expected.
|
||||
|
||||
### Effective Inflation Rate [%]
|
||||
|
||||
The inflation rate actually observed on the Solana network after accounting for other factors that might decrease the *Total Current Supply*. Note that it is not possible for tokens to be created outside of what is described by the *Inflation Schedule*.
|
||||
The inflation rate actually observed on the Solana network after accounting for other factors that might decrease the _Total Current Supply_. Note that it is not possible for tokens to be created outside of what is described by the _Inflation Schedule_.
|
||||
|
||||
- While the *Inflation Schedule* determines how the protocol issues SOL, this neglects the concurrent elimination of tokens in the ecosystem due to various factors. The primary token burning mechanism is the burning of a portion of each transaction fee. While $100\%$ of each transaction fee is currently being destroyed, it is planned on reducing this burn rate to $50\%$ of each transaction fee, with the remaining fee to be retained by the validator that processes the transaction.
|
||||
- Additional factors such as loss of private keys and slashing events should also be considered in a holistic analysis of the *Effective Inflation Rate*. For example, it’s estimated that $10-20\%$ of all BTC have been lost and are unrecoverable and that networks may experience similar yearly losses at the rate of $1-2\%$.
|
||||
- While the _Inflation Schedule_ determines how the protocol issues SOL, this neglects the concurrent elimination of tokens in the ecosystem due to various factors. The primary token burning mechanism is the burning of a portion of each transaction fee. While $100\%$ of each transaction fee is currently being destroyed, it is planned on reducing this burn rate to $50\%$ of each transaction fee, with the remaining fee to be retained by the validator that processes the transaction.
|
||||
- Additional factors such as loss of private keys and slashing events should also be considered in a holistic analysis of the _Effective Inflation Rate_. For example, it’s estimated that $10-20\%$ of all BTC have been lost and are unrecoverable and that networks may experience similar yearly losses at the rate of $1-2\%$.
|
||||
|
||||
### Staking Yield [%]
|
||||
The rate of return (aka *interest*) earned on SOL staked on the network. It is often quoted as an annualized rate (e.g. "the network *staking yield* is currently $10\%$ per year").
|
||||
- *Staking yield* is of great interest to validators and token-holders holders who wish to delegate their tokens to avoid token dilution due to inflation (the extent of which is discussed below).
|
||||
|
||||
The rate of return (aka _interest_) earned on SOL staked on the network. It is often quoted as an annualized rate (e.g. "the network _staking yield_ is currently $10\%$ per year").
|
||||
|
||||
- _Staking yield_ is of great interest to validators and token-holders holders who wish to delegate their tokens to avoid token dilution due to inflation (the extent of which is discussed below).
|
||||
- $100\%$ of inflationary issuances are to be distributed to staked token-holders in proportion to their staked SOL and to validators who charge a commission on the rewards earned by their delegated SOL..
|
||||
- There may be future consideration for an additional split of inflation issuance with the introduction of *Archivers* into the economy. *Archivers* are network participants who provide a decentralized storage service and should also be incentivized with token distribution from inflation issuances for this service.
|
||||
- Similarly, early designs specified a fixed percentage of inflationary issuance to be delivered to the Foundation treasury for operational expenses and future grants. However, inflation will be launching without any portion allocated to the Foundation.
|
||||
- *Staking yield* can be calculated from the *Inflation Schedule* along with the fraction of the *Total Current Supply* that is staked at any given time. The explicit relationship is given by:
|
||||
- There may be future consideration for an additional split of inflation issuance with the introduction of _Archivers_ into the economy. _Archivers_ are network participants who provide a decentralized storage service and should also be incentivized with token distribution from inflation issuances for this service. - Similarly, early designs specified a fixed percentage of inflationary issuance to be delivered to the Foundation treasury for operational expenses and future grants. However, inflation will be launching without any portion allocated to the Foundation.
|
||||
- _Staking yield_ can be calculated from the _Inflation Schedule_ along with the fraction of the _Total Current Supply_ that is staked at any given time. The explicit relationship is given by:
|
||||
|
||||
$$
|
||||
\begin{aligned}
|
||||
|
@ -45,11 +45,10 @@ $$
|
|||
\end{aligned}
|
||||
$$
|
||||
|
||||
|
||||
### Token Dilution [%]
|
||||
|
||||
Dilution is defined here as the change in proportional representation of a set of tokens within a larger set due to the introduction of new tokens. In practical terms, we discuss the dilution of staked or un-staked tokens due to the introduction and distribution of inflation issuance across the network. As will be shown below, while dilution impacts every token holder, the *relative* dilution between staked and un-staked tokens should be the primary concern to un-staked token holders. Staking tokens, which will receive their proportional distribution of inflation issuance, should assuage any dilution concerns for staked token holders. I.e. dilution from 'inflation' is offset by the distribution of new tokens to staked token holders, nullifying the 'dilutive' effects of the inflation for that group.
|
||||
Dilution is defined here as the change in proportional representation of a set of tokens within a larger set due to the introduction of new tokens. In practical terms, we discuss the dilution of staked or un-staked tokens due to the introduction and distribution of inflation issuance across the network. As will be shown below, while dilution impacts every token holder, the _relative_ dilution between staked and un-staked tokens should be the primary concern to un-staked token holders. Staking tokens, which will receive their proportional distribution of inflation issuance, should assuage any dilution concerns for staked token holders. I.e. dilution from 'inflation' is offset by the distribution of new tokens to staked token holders, nullifying the 'dilutive' effects of the inflation for that group.
|
||||
|
||||
### Adjusted Staking Yield [%]
|
||||
|
||||
A complete appraisal of earning potential from staking tokens should take into account staked *Token Dilution* and its impact on the *Staking Yield*. For this, we define the *Adjusted Staking Yield* as the change in fractional token supply ownership of staked tokens due to the distribution of inflation issuance. I.e. the positive dilutive effects of inflation.
|
||||
A complete appraisal of earning potential from staking tokens should take into account staked _Token Dilution_ and its impact on the _Staking Yield_. For this, we define the _Adjusted Staking Yield_ as the change in fractional token supply ownership of staked tokens due to the distribution of inflation issuance. I.e. the positive dilutive effects of inflation.
|
||||
|
|
|
@ -12,6 +12,7 @@ instances, upgrading to newer versions promptly, and keeping an eye on service
|
|||
operations with a bundled monitoring tool.
|
||||
|
||||
This setup enables you:
|
||||
|
||||
- to have a trusted gateway to the Solana mainnet-beta cluster to get data and
|
||||
submit withdrawal transactions
|
||||
- to have full control over how much historical block data is retained
|
||||
|
@ -113,7 +114,6 @@ able to catch up to the network and will need to download a new snapshot from a
|
|||
trusted validator. In doing so your validators will now have a gap in its
|
||||
historical ledger data that cannot be filled.
|
||||
|
||||
|
||||
### Minimizing Validator Port Exposure
|
||||
|
||||
The validator requires that various UDP and TCP ports be open for inbound
|
||||
|
@ -125,14 +125,14 @@ First add the `--restricted-repair-only-mode` argument. This will cause the
|
|||
validator to operate in a restricted mode where it will not receive pushes from
|
||||
the rest of the validators, and instead will need to continually poll other
|
||||
validators for blocks. The validator will only transmit UDP packets to other
|
||||
validators using the *Gossip* and *ServeR* ("serve repair") ports, and only
|
||||
receive UDP packets on its *Gossip* and *Repair* ports.
|
||||
validators using the _Gossip_ and _ServeR_ ("serve repair") ports, and only
|
||||
receive UDP packets on its _Gossip_ and _Repair_ ports.
|
||||
|
||||
The *Gossip* port is bi-directional and allows your validator to remain in
|
||||
contact with the rest of the cluster. Your validator transmits on the *ServeR*
|
||||
The _Gossip_ port is bi-directional and allows your validator to remain in
|
||||
contact with the rest of the cluster. Your validator transmits on the _ServeR_
|
||||
to make repair requests to obtaining new blocks from the rest of the network,
|
||||
since Turbine is now disabled. Your validator will then receive repair
|
||||
responses on the *Repair* port from other validators.
|
||||
responses on the _Repair_ port from other validators.
|
||||
|
||||
To further restrict the validator to only requesting blocks from one or more
|
||||
validators, first determine the identity pubkey for that validator and add the
|
||||
|
@ -142,7 +142,7 @@ that you add, so please do this sparingly and only after consulting with the
|
|||
target validator.
|
||||
|
||||
Your validator should now only be communicating with the explicitly listed
|
||||
validators and only on the *Gossip*, *Repair* and *ServeR* ports.
|
||||
validators and only on the _Gossip_, _Repair_ and _ServeR_ ports.
|
||||
|
||||
## Setting up Deposit Accounts
|
||||
|
||||
|
@ -274,7 +274,7 @@ can request the block from RPC in binary format, and parse it using either our
|
|||
### Address History
|
||||
|
||||
You can also query the transaction history of a specific address. This is
|
||||
generally *not* a viable method for tracking all your deposit addresses over all
|
||||
generally _not_ a viable method for tracking all your deposit addresses over all
|
||||
slots, but may be useful for examining a few accounts for a specific period of
|
||||
time.
|
||||
|
||||
|
@ -484,9 +484,11 @@ prevent accidental loss of user funds.
|
|||
|
||||
Solana addresses a 32-byte array, encoded with the bitcoin base58 alphabet. This
|
||||
results in an ASCII text string matching the following regular expression:
|
||||
|
||||
```
|
||||
[1-9A-HJ-NP-Za-km-z]{32,44}
|
||||
```
|
||||
|
||||
This check is insufficient on its own as Solana addresses are not checksummed, so
|
||||
typos cannot be detected. To further validate the user's input, the string can be
|
||||
decoded and the resulting byte array's length confirmed to be 32. However, there
|
||||
|
@ -574,7 +576,7 @@ few differences which will be discussed in this section.
|
|||
|
||||
### Token Mints
|
||||
|
||||
Each *type* of SPL Token is declared by creating a *mint* account. This account
|
||||
Each _type_ of SPL Token is declared by creating a _mint_ account. This account
|
||||
stores metadata describing token features like the supply, number of decimals, and
|
||||
various authorities with control over the mint. Each SPL Token account references
|
||||
its associated mint and may only interact with SPL Tokens of that type.
|
||||
|
@ -621,7 +623,9 @@ native SOL tokens be deposited at account creation. For SPL Token v2 accounts,
|
|||
this amount is 0.00203928 SOL (2,039,280 lamports).
|
||||
|
||||
#### Command Line
|
||||
|
||||
To create an SPL Token account with the following properties:
|
||||
|
||||
1. Associated with the given mint
|
||||
1. Owned by the funding account's keypair
|
||||
|
||||
|
@ -630,6 +634,7 @@ spl-token create-account <TOKEN_MINT_ADDRESS>
|
|||
```
|
||||
|
||||
#### Example
|
||||
|
||||
```
|
||||
$ spl-token create-account AkUFCWTXb3w9nY2n6SFJvBV6VwvFUCe4KBMCcgLsa2ir
|
||||
Creating account 6VzWGL51jLebvnDifvcuEDec17sK6Wupi4gYhm5RzfkV
|
||||
|
@ -637,6 +642,7 @@ Signature: 4JsqZEPra2eDTHtHpB4FMWSfk3UgcCVmkKkP7zESZeMrKmFFkDkNd91pKP3vPVVZZPiu5
|
|||
```
|
||||
|
||||
Or to create an SPL Token account with a specific keypair:
|
||||
|
||||
```
|
||||
$ solana-keygen new -o token-account.json
|
||||
$ spl-token create-account AkUFCWTXb3w9nY2n6SFJvBV6VwvFUCe4KBMCcgLsa2ir token-account.json
|
||||
|
@ -647,11 +653,13 @@ Signature: 4JsqZEPra2eDTHtHpB4FMWSfk3UgcCVmkKkP7zESZeMrKmFFkDkNd91pKP3vPVVZZPiu5
|
|||
### Checking an Account's Balance
|
||||
|
||||
#### Command Line
|
||||
|
||||
```
|
||||
spl-token balance <TOKEN_ACCOUNT_ADDRESS>
|
||||
```
|
||||
|
||||
#### Example
|
||||
|
||||
```
|
||||
$ solana balance 6VzWGL51jLebvnDifvcuEDec17sK6Wupi4gYhm5RzfkV
|
||||
0
|
||||
|
@ -668,11 +676,13 @@ transfer will create it provided that the `--fund-recipient` argument as
|
|||
provided.
|
||||
|
||||
#### Command Line
|
||||
|
||||
```
|
||||
spl-token transfer <SENDER_ACCOUNT_ADDRESS> <AMOUNT> <RECIPIENT_WALLET_ADDRESS> --fund-recipient
|
||||
```
|
||||
|
||||
#### Example
|
||||
|
||||
```
|
||||
$ spl-token transfer 6B199xxzw3PkAm25hGJpjj3Wj3WNYNHzDAnt1tEqg5BN 1 6VzWGL51jLebvnDifvcuEDec17sK6Wupi4gYhm5RzfkV
|
||||
Transfer 1 tokens
|
||||
|
@ -682,6 +692,7 @@ Signature: 3R6tsog17QM8KfzbcbdP4aoMfwgo6hBggJDVy7dZPVmH2xbCWjEj31JKD53NzMrf25ChF
|
|||
```
|
||||
|
||||
### Depositing
|
||||
|
||||
Since each `(user, mint)` pair requires a separate account on chain, it is
|
||||
recommended that an exchange create batches of token accounts in advance and assign them
|
||||
to users on request. These accounts should all be owned by exchange-controlled
|
||||
|
@ -700,6 +711,7 @@ made to exend the `preBalance` and `postBalance` transaction status metadata
|
|||
fields to include SPL Token balance transfers.
|
||||
|
||||
### Withdrawing
|
||||
|
||||
The withdrawal address a user provides should be the same address used for
|
||||
regular SOL withdrawal.
|
||||
|
||||
|
@ -715,6 +727,7 @@ accounts, funding the withdrawal account will require 0.00203928 SOL (2,039,280
|
|||
lamports).
|
||||
|
||||
Template `spl-token transfer` command for a withdrawal:
|
||||
|
||||
```
|
||||
$ spl-token transfer --fund-recipient <exchange token account> <withdrawal amount> <withdrawal address>
|
||||
```
|
||||
|
@ -722,6 +735,7 @@ $ spl-token transfer --fund-recipient <exchange token account> <withdrawal amoun
|
|||
### Other Considerations
|
||||
|
||||
#### Freeze Authority
|
||||
|
||||
For regulatory compliance reasons, an SPL Token issuing entity may optionally
|
||||
choose to hold "Freeze Authority" over all accounts created in association with
|
||||
its mint. This allows them to [freeze](https://spl.solana.com/token#freezing-accounts)
|
||||
|
|
|
@ -105,7 +105,7 @@ function Home() {
|
|||
{features && features.length > 0 && (
|
||||
<section className={styles.features}>
|
||||
<div className="row cards__container">
|
||||
<div class="alert alert--primary" role="alert">
|
||||
<div className="alert alert--primary" role="alert">
|
||||
<b>Announcing the Solana Season Hackathon</b>
|
||||
<br />
|
||||
Jumpstart your next project on Solana & join the fastest growing
|
||||
|
@ -116,7 +116,7 @@ function Home() {
|
|||
rel="noopener noreferrer"
|
||||
target="_blank"
|
||||
>
|
||||
<button class="button button--outline button--secondary">
|
||||
<button className="button button--outline button--secondary">
|
||||
Register Now
|
||||
</button>
|
||||
</a>
|
||||
|
|
|
@ -56,6 +56,7 @@ pub enum TestInstruction {
|
|||
```
|
||||
|
||||
An example of the generated TestInstruction with docs:
|
||||
|
||||
```rust,ignore
|
||||
pub enum TestInstruction {
|
||||
/// Transfer lamports
|
||||
|
@ -85,6 +86,7 @@ pub enum TestInstruction {
|
|||
```
|
||||
|
||||
Generated constructors:
|
||||
|
||||
```rust,ignore
|
||||
/// Transfer lamports
|
||||
///
|
||||
|
|
|
@ -27,18 +27,18 @@ validator's ReplayStage.
|
|||
|
||||
Improved client experience:
|
||||
|
||||
* Support connections directly from WebAssembly apps.
|
||||
* Clients can be notified of confirmation progress in real-time, including votes
|
||||
- Support connections directly from WebAssembly apps.
|
||||
- Clients can be notified of confirmation progress in real-time, including votes
|
||||
and voter stake weight.
|
||||
* Clients can be notified when the heaviest fork changes, if it affects the
|
||||
- Clients can be notified when the heaviest fork changes, if it affects the
|
||||
transactions confirmation count.
|
||||
|
||||
Easier for validators to support:
|
||||
|
||||
* Each validator supports some number of concurrent connections and otherwise
|
||||
- Each validator supports some number of concurrent connections and otherwise
|
||||
has no significant resource constraints.
|
||||
* Transaction status is never stored in memory and cannot be polled for.
|
||||
* Signatures are only stored in memory until the desired commitment level or
|
||||
- Transaction status is never stored in memory and cannot be polled for.
|
||||
- Signatures are only stored in memory until the desired commitment level or
|
||||
until the blockhash expires, which ever is later.
|
||||
|
||||
How it works:
|
||||
|
|
|
@ -94,6 +94,7 @@ in the block. Ideally this Block-Merkle would be implmented, as the alternative
|
|||
is very inefficient.
|
||||
|
||||
#### Block Headers
|
||||
|
||||
In order to verify transaction inclusion proofs, light clients need to be able
|
||||
to infer the topology of the forks in the network
|
||||
|
||||
|
|
|
@ -2,7 +2,6 @@
|
|||
|
||||
### Step 1. Identify the slot that the cluster will be restarted at
|
||||
|
||||
|
||||
The highest optimistically confirmed slot is the best slot to start from, which
|
||||
can be found by looking for
|
||||
[this](https://github.com/solana-labs/solana/blob/0264147d42d506fb888f5c4c021a998e231a3e74/core/src/optimistic_confirmation_verifier.rs#L71)
|
||||
|
@ -22,7 +21,7 @@ $ solana-ledger-tool -l ledger create-snapshot SLOT_X ledger --hard-fork SLOT_X
|
|||
|
||||
The ledger directory should now contain the new snapshot.
|
||||
`solana-ledger-tool create-snapshot` will also output the new shred version, and bank hash value,
|
||||
call this NEW\_SHRED\_VERSION and NEW\_BANK\_HASH respectively.
|
||||
call this NEW_SHRED_VERSION and NEW_BANK_HASH respectively.
|
||||
|
||||
Adjust your validator's arguments:
|
||||
|
||||
|
@ -44,9 +43,9 @@ Post something like the following to #announcements (adjusting the text as appro
|
|||
> We've released v1.1.12 and are ready to get testnet back up again.
|
||||
>
|
||||
> Steps:
|
||||
>
|
||||
> 1. Install the v1.1.12 release: https://github.com/solana-labs/solana/releases/tag/v1.1.12
|
||||
> 2.
|
||||
> a. Preferred method, start from your local ledger with:
|
||||
> 2. a. Preferred method, start from your local ledger with:
|
||||
>
|
||||
> ```bash
|
||||
> solana-validator
|
||||
|
@ -61,7 +60,9 @@ Post something like the following to #announcements (adjusting the text as appro
|
|||
> --limit-ledger-size
|
||||
> ... # <-- your other --identity/--vote-account/etc arguments
|
||||
> ```
|
||||
>
|
||||
> b. If your validator doesn't have ledger up to slot SLOT_X or if you have deleted your ledger, have it instead download a snapshot with:
|
||||
>
|
||||
> ```bash
|
||||
> solana-validator
|
||||
> --wait-for-supermajority SLOT_X # <-- NEW! IMPORTANT! REMOVE AFTER THIS RESTART
|
||||
|
|
|
@ -47,12 +47,14 @@ that CUDA is enabled: `"[<timestamp> solana::validator] CUDA is enabled"`
|
|||
## System Tuning
|
||||
|
||||
### Linux
|
||||
|
||||
#### Automatic
|
||||
|
||||
The solana repo includes a daemon to adjust system settings to optimize performance
|
||||
(namely by increasing the OS UDP buffer and file mapping limits).
|
||||
|
||||
The daemon (`solana-sys-tuner`) is included in the solana binary release. Restart
|
||||
it, *before* restarting your validator, after each software upgrade to ensure that
|
||||
it, _before_ restarting your validator, after each software upgrade to ensure that
|
||||
the latest recommended settings are applied.
|
||||
|
||||
To run it:
|
||||
|
@ -62,10 +64,12 @@ sudo solana-sys-tuner --user $(whoami) > sys-tuner.log 2>&1 &
|
|||
```
|
||||
|
||||
#### Manual
|
||||
|
||||
If you would prefer to manage system settings on your own, you may do so with
|
||||
the following commands.
|
||||
|
||||
##### **Increase UDP buffers**
|
||||
|
||||
```bash
|
||||
sudo bash -c "cat >/etc/sysctl.d/20-solana-udp-buffers.conf <<EOF
|
||||
# Increase UDP buffer size
|
||||
|
@ -75,39 +79,50 @@ net.core.wmem_default = 134217728
|
|||
net.core.wmem_max = 134217728
|
||||
EOF"
|
||||
```
|
||||
|
||||
```bash
|
||||
sudo sysctl -p /etc/sysctl.d/20-solana-udp-buffers.conf
|
||||
```
|
||||
|
||||
##### **Increased memory mapped files limit**
|
||||
|
||||
```bash
|
||||
sudo bash -c "cat >/etc/sysctl.d/20-solana-mmaps.conf <<EOF
|
||||
# Increase memory mapped files limit
|
||||
vm.max_map_count = 700000
|
||||
EOF"
|
||||
```
|
||||
|
||||
```bash
|
||||
sudo sysctl -p /etc/sysctl.d/20-solana-mmaps.conf
|
||||
```
|
||||
|
||||
Add
|
||||
|
||||
```
|
||||
LimitNOFILE=700000
|
||||
```
|
||||
|
||||
to the `[Service]` section of your systemd service file, if you use one,
|
||||
otherwise add
|
||||
|
||||
```
|
||||
DefaultLimitNOFILE=700000
|
||||
```
|
||||
|
||||
to the `[Manager]` section of `/etc/systemd/system.conf`.
|
||||
|
||||
```bash
|
||||
sudo systemctl daemon-reload
|
||||
```
|
||||
|
||||
```bash
|
||||
sudo bash -c "cat >/etc/security/limits.d/90-solana-nofiles.conf <<EOF
|
||||
# Increase process file descriptor count limit
|
||||
* - nofile 700000
|
||||
EOF"
|
||||
```
|
||||
|
||||
```bash
|
||||
### Close all open sessions (log out then, in again) ###
|
||||
```
|
||||
|
@ -299,6 +314,7 @@ example, `solana-validator --dynamic-port-range 11000-11010 ...` will restrict
|
|||
the validator to ports 11000-11010.
|
||||
|
||||
### Limiting ledger size to conserve disk space
|
||||
|
||||
The `--limit-ledger-size` parameter allows you to specify how many ledger
|
||||
[shreds](../terminology.md#shred) your node retains on disk. If you do not
|
||||
include this parameter, the validator will keep the entire ledger until it runs
|
||||
|
@ -312,11 +328,13 @@ selecting a custom limit value is [available
|
|||
here](https://github.com/solana-labs/solana/blob/583cec922b6107e0f85c7e14cb5e642bc7dfb340/core/src/ledger_cleanup_service.rs#L15-L26).
|
||||
|
||||
### Systemd Unit
|
||||
|
||||
Running the validator as a systemd unit is one easy way to manage running in the
|
||||
background.
|
||||
|
||||
Assuming you have a user called `sol` on your machine, create the file `/etc/systemd/system/sol.service` with
|
||||
the following:
|
||||
|
||||
```
|
||||
[Unit]
|
||||
Description=Solana Validator
|
||||
|
@ -343,11 +361,13 @@ command-line. Ensure that running `/home/sol/bin/validator.sh` manually starts
|
|||
the validator as expected. Don't forget to mark it executable with `chmod +x /home/sol/bin/validator.sh`
|
||||
|
||||
Start the service with:
|
||||
|
||||
```bash
|
||||
$ sudo systemctl enable --now sol
|
||||
```
|
||||
|
||||
### Logging
|
||||
|
||||
#### Log output tuning
|
||||
|
||||
The messages that a validator emits to the log can be controlled by the `RUST_LOG`
|
||||
|
@ -376,6 +396,7 @@ instead of the validator's, which will kill them both.
|
|||
An example setup for the `logrotate`, which assumes that the validator is
|
||||
running as a systemd service called `sol.service` and writes a log file at
|
||||
/home/sol/solana-validator.log:
|
||||
|
||||
```bash
|
||||
# Setup log rotation
|
||||
|
||||
|
@ -394,11 +415,13 @@ systemctl restart logrotate.service
|
|||
```
|
||||
|
||||
### Disable port checks to speed up restarts
|
||||
|
||||
Once your validator is operating normally, you can reduce the time it takes to
|
||||
restart your validator by adding the `--no-port-check` flag to your
|
||||
`solana-validator` command-line.
|
||||
|
||||
### Disable snapshot compression to reduce CPU usage
|
||||
|
||||
If you are not serving snapshots to other validators, snapshot compression can
|
||||
be disabled to reduce CPU load at the expense of slightly more disk usage for
|
||||
local snapshot storage.
|
||||
|
@ -407,6 +430,7 @@ Add the `--snapshot-compression none` argument to your `solana-validator`
|
|||
command-line arguments and restart the validator.
|
||||
|
||||
### Using a ramdisk with spill-over into swap for the accounts database to reduce SSD wear
|
||||
|
||||
If your machine has plenty of RAM, a tmpfs ramdisk
|
||||
([tmpfs](https://man7.org/linux/man-pages/man5/tmpfs.5.html)) may be used to hold
|
||||
the accounts database
|
||||
|
@ -418,18 +442,20 @@ A 300GB tmpfs partition is recommended, with an accompanying 250GB swap
|
|||
partition.
|
||||
|
||||
Example configuration:
|
||||
|
||||
1. `sudo mkdir /mnt/solana-accounts`
|
||||
2. Add a 300GB tmpfs parition by adding a new line containing `tmpfs
|
||||
/mnt/solana-accounts tmpfs rw,size=300G,user=sol 0 0` to `/etc/fstab`
|
||||
2. Add a 300GB tmpfs parition by adding a new line containing `tmpfs /mnt/solana-accounts tmpfs rw,size=300G,user=sol 0 0` to `/etc/fstab`
|
||||
(assuming your validator is running under the user "sol"). **CAREFUL: If you
|
||||
incorrectly edit /etc/fstab your machine may no longer boot**
|
||||
3. Create at least 250GB of swap space
|
||||
|
||||
- Choose a device to use in place of `SWAPDEV` for the remainder of these instructions.
|
||||
Ideally select a free disk partition of 250GB or greater on a fast disk. If one is not
|
||||
available, create a swap file with `sudo dd if=/dev/zero of=/swapfile bs=1MiB count=250KiB`,
|
||||
set its permissions with `sudo chmod 0600 /swapfile` and use `/swapfile` as `SWAPDEV` for
|
||||
the remainder of these instructions
|
||||
- Format the device for usage as swap with `sudo mkswap SWAPDEV`
|
||||
|
||||
4. Add the swap file to `/etc/fstab` with a new line containing `SWAPDEV swap swap defaults 0 0`
|
||||
5. Enable swap with `sudo swapon -a` and mount the tmpfs with `sudo mount /mnt/solana-accounts/`
|
||||
6. Confirm swap is active with `free -g` and the tmpfs is mounted with `mount`
|
||||
|
|
|
@ -6,6 +6,7 @@ This page describes how to set up an on-chain _vote account_. Creating a vote
|
|||
account is needed if you plan to run a validator node on Solana.
|
||||
|
||||
## Create a Vote Account
|
||||
|
||||
A vote account can be created with the
|
||||
[create-vote-account](../cli/usage.md#solana-create-vote-account) command.
|
||||
The vote account can be configured when first created or after the validator is
|
||||
|
@ -14,6 +15,7 @@ running. All aspects of the vote account can be changed except for the
|
|||
of the account.
|
||||
|
||||
### Configure an Existing Vote Account
|
||||
|
||||
- To change the [validator identity](#validator-identity), use
|
||||
[vote-update-validator](../cli/usage.md#solana-vote-update-validator).
|
||||
- To change the [vote authority](#vote-authority), use
|
||||
|
@ -26,6 +28,7 @@ of the account.
|
|||
## Vote Account Structure
|
||||
|
||||
### Vote Account Address
|
||||
|
||||
A vote account is created at an address that is either the public key of a
|
||||
keypair file, or at a derived address based on a keypair file's public key and
|
||||
a seed string.
|
||||
|
@ -146,6 +149,7 @@ The integer represents the number of percentage points for the commission, so
|
|||
creating an account with `--commission 10` will set a 10% commission.
|
||||
|
||||
## Key Rotation
|
||||
|
||||
Rotating the vote account authority keys require special handling when dealing
|
||||
with a live validator.
|
||||
|
||||
|
@ -162,6 +166,7 @@ change the validator identity. The follow steps assume that
|
|||
4. Restart your validator with the new identity keypair for the `--identity` argument
|
||||
|
||||
### Vote Account Authorized Voter
|
||||
|
||||
The _vote authority_ keypair may only be changed at epoch boundaries and
|
||||
requires some additional arguments to `solana-validator` for a seamless
|
||||
migration.
|
||||
|
@ -170,20 +175,18 @@ migration.
|
|||
current epoch, consider waiting for the next epoch to allow your validator
|
||||
plenty of time to restart and catch up.
|
||||
2. Create the new vote authority keypair, `solana-keygen new -o ~/new-vote-authority.json`.
|
||||
3. Determine the current _vote authority_ keypair by running `solana
|
||||
vote-account ~/vote-account-keypair.json`. It may be validator's
|
||||
3. Determine the current _vote authority_ keypair by running `solana vote-account ~/vote-account-keypair.json`. It may be validator's
|
||||
identity account (the default) or some other keypair. The following steps
|
||||
assume that `~/validator-keypair.json` is that keypair.
|
||||
4. Run `solana vote-authorize-voter ~/vote-account-keypair.json ~/validator-keypair.json ~/new-vote-authority.json`.
|
||||
The new vote authority is scheduled to become active starting at the next epoch.
|
||||
5. `solana-validator` now needs to be restarted with the old and new vote
|
||||
authority keypairs, so that it can smoothly transition at the next epoch. Add
|
||||
the two arguments on restart: `--authorized-voter ~/validator-keypair.json
|
||||
--authorized-voter ~/new-vote-authority.json`
|
||||
the two arguments on restart: `--authorized-voter ~/validator-keypair.json --authorized-voter ~/new-vote-authority.json`
|
||||
6. After the cluster reaches the next epoch, remove the
|
||||
`--authorized-voter ~/validator-keypair.json` argument and restart
|
||||
`solana-validator`, as the old vote authority keypair is no longer required.
|
||||
|
||||
|
||||
### Vote Account Authorized Withdrawer
|
||||
|
||||
No special handling is required. Use the `solana vote-authorize-withdrawer` command as needed.
|
||||
|
|
|
@ -2,9 +2,9 @@
|
|||
title: Staking on Solana
|
||||
---
|
||||
|
||||
*Note before reading: All references to increases in values are in absolute
|
||||
_Note before reading: All references to increases in values are in absolute
|
||||
terms with regards to balance of SOL.
|
||||
This document makes no suggestion as to the monetary value of SOL at any time.*
|
||||
This document makes no suggestion as to the monetary value of SOL at any time._
|
||||
|
||||
Staking your SOL tokens on Solana is the best way you can help secure the world's
|
||||
highest-performing blockchain network, and
|
||||
|
@ -28,13 +28,13 @@ keep the network running as fast and as smoothly as possible.
|
|||
|
||||
Validators incur costs by running and maintaining their systems, and this is
|
||||
passed on to delegators in the form of a fee collected as a percentage of
|
||||
rewards earned. This fee is known as a *commission*. As validators earn more
|
||||
rewards earned. This fee is known as a _commission_. As validators earn more
|
||||
rewards the more stake is delegated to them, they may compete with one another
|
||||
to offer the lowest commission for their services, in order to attract more
|
||||
delegated stake.
|
||||
|
||||
There is a risk of loss of tokens when staking, through a process known as
|
||||
*slashing*. Slashing involves the removal and destruction of a portion of a
|
||||
_slashing_. Slashing involves the removal and destruction of a portion of a
|
||||
validator's delegated stake in response to intentional malicious behavior,
|
||||
such as creating invalid transactions or censoring certain types of transactions
|
||||
or network participants.
|
||||
|
@ -51,6 +51,7 @@ and token holders' financial incentives, which in turn help keeps the network
|
|||
secure, robust and performing at its best.
|
||||
|
||||
## How do I stake my SOL tokens?
|
||||
|
||||
In order to stake tokens on Solana, you first will need to transfer some SOL
|
||||
into a wallet that supports staking, then follow the steps or instructions
|
||||
provided by the wallet to create a stake account and delegate your stake.
|
||||
|
@ -58,6 +59,7 @@ Different wallets will vary slightly in their process for this but the general
|
|||
description is below.
|
||||
|
||||
#### Supported Wallets
|
||||
|
||||
Staking operations are supported by the following wallet solutions:
|
||||
|
||||
- SolFlare.com in conjunction with a keystore file or a Ledger Nano.
|
||||
|
@ -69,6 +71,7 @@ Check out our [guide to using SolFlare](wallet-guide/solflare.md) for details.
|
|||
[Staking commands using the Solana Command Line Tools](cli/delegate-stake.md).
|
||||
|
||||
#### Create a Stake Account
|
||||
|
||||
A stake account is a different type of account from a wallet address
|
||||
that is used to simply send and receive SOL tokens to other addresses. If you
|
||||
have received SOL in a wallet address you control, you can use some of
|
||||
|
@ -79,6 +82,7 @@ may vary slightly. Not all wallets support stake accounts, see
|
|||
[Supported Wallets](#supported-wallets).
|
||||
|
||||
#### Select a Validator
|
||||
|
||||
After a stake account is created, you will likely want to delegate the SOL
|
||||
to a validator node. Below are a few places where you can get information about
|
||||
the validators who are currently participating in running the network.
|
||||
|
@ -87,15 +91,18 @@ validator.
|
|||
|
||||
The Mainnet Beta validators introduce themselves and their services on this
|
||||
Solana Forum thread:
|
||||
|
||||
- https://forums.solana.com/t/validator-information-thread
|
||||
|
||||
The site solanabeach.io is built and maintained by one of our validators,
|
||||
Staking Facilities. It provides a some high-level graphical information about
|
||||
the network as a whole, as well as a list of each validator and some recent
|
||||
performance statistics about each one.
|
||||
|
||||
- https://solanabeach.io
|
||||
|
||||
To view block production statistics, use the Solana command-line tools:
|
||||
|
||||
- `solana validators`
|
||||
- `solana block-production`
|
||||
|
||||
|
@ -103,10 +110,12 @@ The Solana team does not make recommendations on how to interpret this
|
|||
information. Potential delegators should do their own due diligence.
|
||||
|
||||
#### Delegate your Stake
|
||||
|
||||
Once you have decided to which validator or validators you will delegate, use
|
||||
a supported wallet to delegate your stake account to the validator's vote
|
||||
account address.
|
||||
|
||||
## Stake Account Details
|
||||
|
||||
For more information about the operations and permissions associated with a
|
||||
stake account, please see [Stake Accounts](staking/stake-accounts.md)
|
||||
|
|
|
@ -5,7 +5,7 @@ title: Stake Account Structure
|
|||
A stake account on Solana can be used to delegate tokens to validators on
|
||||
the network to potentially earn rewards for the owner of the stake account.
|
||||
Stake accounts are created and managed differently than a traditional wallet
|
||||
address, known as a *system account*. A system account is only able to send and
|
||||
address, known as a _system account_. A system account is only able to send and
|
||||
receive SOL from other accounts on the network, whereas a stake account supports
|
||||
more complex operations needed to manage a delegation of tokens.
|
||||
|
||||
|
@ -14,6 +14,7 @@ blockchain networks that you may be familiar with. This document describes the
|
|||
high-level structure and functions of a Solana stake account.
|
||||
|
||||
#### Account Address
|
||||
|
||||
Each stake account has a unique address which can be used to look up the account
|
||||
information in the command line or in any network explorer tools. However,
|
||||
unlike a wallet address in which the holder of the address's keypair controls
|
||||
|
@ -27,7 +28,8 @@ a new keypair file is created first only to ensure that the stake account's
|
|||
address is new and unique.
|
||||
|
||||
#### Understanding Account Authorities
|
||||
Certain types of accounts may have one or more *signing authorities*
|
||||
|
||||
Certain types of accounts may have one or more _signing authorities_
|
||||
associated with a given account. An account authority is used to sign certain
|
||||
transactions for the account it controls. This is different from
|
||||
some other blockchain networks where the holder of the keypair associated with
|
||||
|
@ -36,7 +38,8 @@ the account's address controls all of the account's activity.
|
|||
Each stake account has two signing authorities specified by their respective address,
|
||||
each of which is authorized to perform certain operations on the stake account.
|
||||
|
||||
The *stake authority* is used to sign transactions for the following operations:
|
||||
The _stake authority_ is used to sign transactions for the following operations:
|
||||
|
||||
- Delegating stake
|
||||
- Deactivating the stake delegation
|
||||
- Splitting the stake account, creating a new stake account with a portion of the
|
||||
|
@ -44,7 +47,8 @@ The *stake authority* is used to sign transactions for the following operations:
|
|||
- Merging two stake accounts into one
|
||||
- Setting a new stake authority
|
||||
|
||||
The *withdraw authority* signs transactions for the following:
|
||||
The _withdraw authority_ signs transactions for the following:
|
||||
|
||||
- Withdrawing un-delegated stake into a wallet address
|
||||
- Setting a new withdraw authority
|
||||
- Setting a new stake authority
|
||||
|
@ -62,6 +66,7 @@ Securing the withdraw authority against loss or theft is of utmost importance
|
|||
when managing a stake account.
|
||||
|
||||
#### Multiple Delegations
|
||||
|
||||
Each stake account may only be used to delegate to one validator at a time.
|
||||
All of the tokens in the account are either delegated or un-delegated, or in the
|
||||
process of becoming delegated or un-delegated. To delegate a fraction of your
|
||||
|
@ -77,22 +82,24 @@ The same stake and withdraw authorities can be assigned to multiple
|
|||
stake accounts.
|
||||
|
||||
#### Merging stake accounts
|
||||
|
||||
Two stake accounts that have the same authorities and lockup can be merged into
|
||||
a single resulting stake account. A merge is possible between two stakes in the
|
||||
following states with no additional conditions:
|
||||
|
||||
* two deactivated stakes
|
||||
* an inactive stake into an activating stake during its activation epoch
|
||||
- two deactivated stakes
|
||||
- an inactive stake into an activating stake during its activation epoch
|
||||
|
||||
For the following cases, the voter pubkey and vote credits observed must match:
|
||||
|
||||
* two activated stakes
|
||||
* two activating accounts that share an activation epoch, during the activation epoch
|
||||
- two activated stakes
|
||||
- two activating accounts that share an activation epoch, during the activation epoch
|
||||
|
||||
All other combinations of stake states will fail to merge, including all "transient"
|
||||
states, where a stake is activating or deactivating with a non-zero effective stake.
|
||||
|
||||
#### Delegation Warmup and Cooldown
|
||||
|
||||
When a stake account is delegated, or a delegation is deactivated, the operation
|
||||
does not take effect immediately.
|
||||
|
||||
|
@ -109,6 +116,7 @@ Details on the warmup and cooldown timing can be found
|
|||
[here](../cluster/stake-delegation-and-rewards.md#stake-warmup-cooldown-withdrawal).
|
||||
|
||||
#### Lockups
|
||||
|
||||
Stake accounts can have a lockup which prevents the tokens they hold from being
|
||||
withdrawn before a particular date or epoch has been
|
||||
reached. While locked up, the stake account can still be delegated, un-delegated,
|
||||
|
@ -116,10 +124,11 @@ or split, and its stake and withdraw authorities can be changed as normal. Only
|
|||
withdrawal into a wallet address is not allowed.
|
||||
|
||||
A lockup can only be added when a stake account is first created, but it can be
|
||||
modified later, by the *lockup authority* or *custodian*, the address of which
|
||||
modified later, by the _lockup authority_ or _custodian_, the address of which
|
||||
is also set when the account is created.
|
||||
|
||||
#### Destroying a Stake Account
|
||||
|
||||
Like other types of accounts on the Solana network, a stake account that has a
|
||||
balance of 0 SOL is no longer tracked. If a stake account is not delegated
|
||||
and all of the tokens it contains are withdrawn to a wallet address, the account
|
||||
|
@ -127,6 +136,8 @@ at that address is effectively destroyed, and will need to be manually
|
|||
re-created for the address to be used again.
|
||||
|
||||
#### Viewing Stake Accounts
|
||||
|
||||
Stake account details can be viewed on the Solana Explorer by copying and pasting
|
||||
an account address into the search bar.
|
||||
|
||||
- http://explorer.solana.com/accounts
|
||||
|
|
|
@ -8,12 +8,14 @@ and community have developed several on-chain and off-chain programs to make
|
|||
stakes easier to manage.
|
||||
|
||||
#### Stake-o-matic aka Auto-delegation Bots
|
||||
|
||||
This off-chain program manages a large population of validators staked by a
|
||||
central authority. The Solana Foundation uses an auto-delegation bot to regularly delegate its
|
||||
stake to "non-delinquent" validators that meet specified performance requirements. More information can be found on the
|
||||
[official announcement](https://forums.solana.com/t/stake-o-matic-delegation-matching-program/790).
|
||||
|
||||
#### Stake Pools
|
||||
|
||||
This on-chain program pools together SOL to be staked by a manager, allowing SOL
|
||||
holders to stake and earn rewards without managing stakes.
|
||||
Users deposit SOL in exchange for SPL tokens (staking derivatives) that represent their ownership in the stake pool. The pool
|
||||
|
|
|
@ -3,11 +3,13 @@ title: Compensation
|
|||
---
|
||||
|
||||
## Compensation Calculation
|
||||
|
||||
Compensation will be calculated according to the compensation design described in [this forum post](https://forums.solana.com/t/tour-de-sol-updates-to-tour-de-sol-and-bug-bounty-compensation-structure/1132).
|
||||
|
||||
Please also see section “2\(f\) Tour de Sol Details” of the [TOUR DE SOL PARTICIPATION TERMS](https://drive.google.com/file/d/15ueLG6VJoQ5Hx4rnpjFeuL3pG5DbrBbE/view) for additional compensation details.
|
||||
|
||||
## Requirements to Receive Rewards
|
||||
|
||||
Participants must have signed the Tour de SOL participation agreement,
|
||||
passed KYC/AML , as well as filled out the W-8 BEN or W-9 tax form
|
||||
\(depending on your residency\) prior to participating in the Tour.
|
||||
|
@ -17,6 +19,7 @@ complete registration. The final registrations dates will be announced
|
|||
publicly on a stage-by-stage basis.
|
||||
|
||||
## Tax Implications
|
||||
|
||||
Participants are entering into a service agreement with Solana with discretionary compensation associated with the services. They are not considered to be a full-time employee of the company and therefore Solana is collecting W-9 and W-8 BEN forms in order to support tax reporting obligations, if applicable. Solana recommends participants consult with a tax accountant to understand any potential tax implications.
|
||||
|
||||
Also, as stated in Sections 2i, 2k and 10c of the [TOUR DE SOL PARTICIPATION TERMS](https://drive.google.com/file/d/15ueLG6VJoQ5Hx4rnpjFeuL3pG5DbrBbE/view):
|
||||
|
|
|
@ -14,7 +14,7 @@ Network consensus votes are sent as normal system transfers, which means that va
|
|||
|
||||
Many current blockchain economies \(e.g. Bitcoin, Ethereum\), rely on protocol-based rewards to support the economy in the short term, with the assumption that the revenue generated through transaction fees will support the economy in the long term, when the protocol derived rewards expire. In an attempt to create a sustainable economy through protocol-based rewards and transaction fees, a fixed portion (initially 50%) of each transaction fee is destroyed, with the remaining fee going to the current leader processing the transaction. A scheduled global inflation rate provides a source for rewards distributed to validation-clients, through the process described above.
|
||||
|
||||
Transaction fees are set by the network cluster based on recent historical throughput, see [Congestion Driven Fees](implemented-proposals/transaction-fees.md#congestion-driven-fees). This minimum portion of each transaction fee can be dynamically adjusted depending on historical *signatures-per-slot*. In this way, the protocol can use the minimum fee to target a desired hardware utilization. By monitoring a protocol specified *signatures-per-slot* with respect to a desired, target usage amount, the minimum fee can be raised/lowered which should, in turn, lower/raise the actual *signature-per-slot* per block until it reaches the target amount. This adjustment process can be thought of as similar to the difficulty adjustment algorithm in the Bitcoin protocol, however in this case it is adjusting the minimum transaction fee to guide the transaction processing hardware usage to a desired level.
|
||||
Transaction fees are set by the network cluster based on recent historical throughput, see [Congestion Driven Fees](implemented-proposals/transaction-fees.md#congestion-driven-fees). This minimum portion of each transaction fee can be dynamically adjusted depending on historical _signatures-per-slot_. In this way, the protocol can use the minimum fee to target a desired hardware utilization. By monitoring a protocol specified _signatures-per-slot_ with respect to a desired, target usage amount, the minimum fee can be raised/lowered which should, in turn, lower/raise the actual _signature-per-slot_ per block until it reaches the target amount. This adjustment process can be thought of as similar to the difficulty adjustment algorithm in the Bitcoin protocol, however in this case it is adjusting the minimum transaction fee to guide the transaction processing hardware usage to a desired level.
|
||||
|
||||
As mentioned, a fixed-proportion of each transaction fee is to be destroyed. The intent of this design is to retain leader incentive to include as many transactions as possible within the leader-slot time, while providing an inflation limiting mechanism that protects against "tax evasion" attacks \(i.e. side-channel fee payments\).
|
||||
|
||||
|
|
|
@ -6,6 +6,7 @@ Solana is supported by multiple third-party apps which should provide a familiar
|
|||
experience for most people who are new or experienced with using crypto wallets.
|
||||
|
||||
## Exodus
|
||||
|
||||
Send, receive & exchange cryptocurrency with ease on the world's leading Desktop, Mobile and Hardware crypto wallets.
|
||||
|
||||
Download [Exodus](https://exodus.com/) to easily and securely manage your Solana tokens.
|
||||
|
@ -13,10 +14,11 @@ Download [Exodus](https://exodus.com/) to easily and securely manage your Solana
|
|||
Exodus includes live charts, a built-in exchange, and 24/7 human support.
|
||||
|
||||
## Trust Wallet
|
||||
|
||||
[Trust Wallet](https://trustwallet.com/) is an app available for iOS and Android
|
||||
and can be used to send and receive SOL tokens.
|
||||
|
||||
*Note: Trust Wallet does not support stake accounts or staking operations*
|
||||
_Note: Trust Wallet does not support stake accounts or staking operations_
|
||||
|
||||
### Trust Wallet Security
|
||||
|
||||
|
@ -39,7 +41,8 @@ viewed at any later time in the app by following these steps:
|
|||
- Under the Options menu for a particular wallet tap "Show Recovery Phrase"
|
||||
|
||||
## Coin98
|
||||
|
||||
[Coin98](https://coin98.app/) is an app available for iOS and Android and can
|
||||
be used to send and receive SOL tokens.
|
||||
|
||||
*Note: Coin98 does not support stake accounts or staking operations*
|
||||
_Note: Coin98 does not support stake accounts or staking operations_
|
||||
|
|
|
@ -55,7 +55,7 @@ solana-keygen pubkey usb://ledger?key=1
|
|||
solana-keygen pubkey usb://ledger?key=2
|
||||
```
|
||||
|
||||
* NOTE: keypair url parameters are ignored in **zsh**
|
||||
- NOTE: keypair url parameters are ignored in **zsh**
|
||||
[see troubleshooting for more info](#troubleshooting)
|
||||
|
||||
You can use other values for the number after `key=` as well.
|
||||
|
|
|
@ -27,6 +27,7 @@ Chrome and Brave are supported when interacting with a Ledger Nano.
|
|||
### Using a Keystore File
|
||||
|
||||
#### Create a new Keystore File
|
||||
|
||||
To create a wallet with a Keystore file, click on "Create a Wallet" and select
|
||||
"Using Keystore File". Follow the prompts to create a password which will be
|
||||
used to encrypt your Keystore file, and then to download the new file to your
|
||||
|
@ -42,6 +43,7 @@ external drive separate from your main computer, and storing your password in a
|
|||
separate location.
|
||||
|
||||
#### Access your wallet with a Keystore File
|
||||
|
||||
To use SolFlare with a previously created Keystore file, click on
|
||||
"Access a Wallet" and select "Using Keystore File". If you just created a new
|
||||
Keystore file, you will be taken to the Access page directly.
|
||||
|
@ -50,23 +52,25 @@ then you will be taken to the wallet interface main page.
|
|||
|
||||
### Using a Ledger Nano hardware wallet
|
||||
|
||||
*NOTE: Please see [known issues](ledger-live.md#known-issues) for any current
|
||||
limitations in using the Nano.*
|
||||
_NOTE: Please see [known issues](ledger-live.md#known-issues) for any current
|
||||
limitations in using the Nano._
|
||||
|
||||
#### Initial Device Setup
|
||||
|
||||
To use a Ledger Nano with SolFlare, first ensure you have
|
||||
[set up your Nano](ledger-live.md) and have [installed the latest version of
|
||||
the Solana app](ledger-live.md#upgrade-to-the-latest-version-of-the-solana-app)
|
||||
on your device.
|
||||
|
||||
#### Select a Ledger address to access
|
||||
|
||||
Plug in your Nano and open the Solana app so the device screen displays
|
||||
"Application is Ready".
|
||||
|
||||
From the SolFlare home page, click "Access a Wallet" then select "Using Ledger
|
||||
Nano S | Ledger Nano X". Under "Select derivation path", select the only option:
|
||||
|
||||
```Solana - 44`/501`/```
|
||||
`` Solana - 44`/501`/ ``
|
||||
|
||||
Note: Your browser may prompt you to ask if SolFlare may communicate with your
|
||||
Ledger device. Click to allow this.
|
||||
|
@ -95,6 +99,7 @@ using.
|
|||
## Sending and Receiving SOL Tokens
|
||||
|
||||
### Receiving
|
||||
|
||||
To receive tokens into your wallet, someone must transfer some to your wallet's
|
||||
address. The address is displayed at the top-left on the screen, and you can
|
||||
click the Copy icon to copy the address and provide it to whoever is sending you
|
||||
|
@ -103,6 +108,7 @@ withdraw to this address as well. Once the transfer is made, the balance shown
|
|||
on SolFlare should update within a few seconds.
|
||||
|
||||
### Sending
|
||||
|
||||
Once you have some tokens at your wallet address, you can send them to any other
|
||||
wallet address or an exchange deposit address by clicking "Transfer SOL" in the
|
||||
upper-right corner. Enter the recipient address and the amount of SOL to
|
||||
|
@ -111,11 +117,13 @@ transaction before you [use your key to sign the transaction](#signing-a-transac
|
|||
and then it will be submitted to the network.
|
||||
|
||||
## Staking SOL Tokens
|
||||
|
||||
SolFlare supports creating and managing stake accounts and delegations. To learn
|
||||
about how staking on Solana works in general, check out our
|
||||
[Staking Guide](../staking).
|
||||
|
||||
### Create a Stake Account
|
||||
|
||||
You can use some of the SOL tokens in your wallet to create a new stake account.
|
||||
From the wallet main page click "Staking" at the top of the page. In the upper-
|
||||
right, click "Create Account". Enter the amount of SOL you want to use to
|
||||
|
@ -134,6 +142,7 @@ for your new account, which gives your wallet's key the authority to sign
|
|||
for any transactions related to the new stake account.
|
||||
|
||||
### View your Stake Accounts
|
||||
|
||||
On the main Wallet dashboard page or on the Staking dashboard page, your stake
|
||||
accounts will be visible in the "Your Staking Accounts" box. Stake accounts
|
||||
exist at a different address from your wallet.
|
||||
|
@ -147,6 +156,7 @@ can be managed as long as the wallet you logged in with is assigned as the stake
|
|||
authority.
|
||||
|
||||
### Delegate tokens in a Stake Account
|
||||
|
||||
Once you have [selected a validator](../staking#select-a-validator), you may
|
||||
delegate the tokens in one of your stake accounts to them. From the Staking
|
||||
dashboard, click "Delegate" at the right side of a displayed stake account.
|
||||
|
@ -158,6 +168,7 @@ process is similar. On the Staking page, at the right side of a delegated stake
|
|||
account, click the "Undelegate" button and follow the prompts.
|
||||
|
||||
### Split a Stake Account
|
||||
|
||||
You may split an existing stake account into two stake accounts. Click on the
|
||||
address of a stake account controlled by your wallet, and under the Actions bar,
|
||||
click "Split". Specify the amount of SOL tokens you want to split. This will be
|
||||
|
@ -168,15 +179,18 @@ of tokens. You may split a stake account as many times as you want, to create
|
|||
as many stake accounts as you want.
|
||||
|
||||
## Signing a Transaction
|
||||
|
||||
Any time you submit a transaction such as sending tokens to another wallet or
|
||||
delegating stake, you need to use your private key to sign the transaction so
|
||||
it will be accepted by the network.
|
||||
|
||||
### Using a Keystore File
|
||||
|
||||
If you accessed your wallet using a Keystore file, you will be prompted to enter
|
||||
your password any time the key is needed to sign a transaction.
|
||||
|
||||
### Using a Ledger Nano
|
||||
|
||||
If you accessed your wallet with a Ledger Nano, you will be prompted to
|
||||
confirm the pending transaction details on your device whenever the key is needed
|
||||
to sign. On the Nano, use the left and right buttons to view and confirm all of the
|
||||
|
|
|
@ -3,6 +3,7 @@ title: Web Wallets
|
|||
---
|
||||
|
||||
## SolFlare
|
||||
|
||||
[SolFlare.com](https://solflare.com/) is a community-created non-custodial
|
||||
web wallet that was built specifically for Solana. SolFlare supports the creation
|
||||
and management of stake accounts, and gives users the ability to send and receive
|
||||
|
@ -11,6 +12,7 @@ any SPL Token.
|
|||
Check out our [guide for using SolFlare](solflare.md).
|
||||
|
||||
## Sollet
|
||||
|
||||
[sollet.io](https://www.sollet.io/) is a non-custodial web wallet created by the
|
||||
[Project Serum](https://projectserum.com/) team. sollet.io can be used to send
|
||||
and receive SOL and any SPL Token.
|
||||
|
@ -21,4 +23,4 @@ and receive SOL and any SPL Token.
|
|||
addresses for sending and receiving SOL and SPL Tokens through its
|
||||
browser extension and web wallet interface.
|
||||
|
||||
*Note: The MathWallet iOS and Android app do not yet support SOL and SPL Tokens*
|
||||
_Note: The MathWallet iOS and Android app do not yet support SOL and SPL Tokens_
|
||||
|
|
Loading…
Reference in New Issue