Files
solana/docs/i18n/zh/docusaurus-plugin-content-docs/current/offline-signing/durable-nonce.md

227 lines
6.4 KiB
Markdown
Raw Normal View History

---
title: 持久交易随机数Nonces
---
持久交易随机数是一个机制,它可以绕过交易典型的个短寿期 [`recent_blockhash`](developing/programming-model/transactions.md#recent-blockhash)。 这些方案是作为Solana方案实施的其机制详见 [proposal](../implemented-proposals/durable-tx-nonces.md)。
## 使用示例
持久的 nonce CLI 命令的详细使用情况可在 [CLI 引用](../cli/usage.md) 中找到。
### Nonce 授权
可以将对临时帐户的权限分配给另一个帐户。 这样,新授权机构将继承先前的授权机构(包括帐户创建者)对临时帐户的完全控制权。 通过此功能,可以创建更复杂的帐户的所有权安排以及与密钥对无关的派生帐户地址。 `--nonce-authority <AUTHORITY_KEYPAIR>` 参数用于指定此帐户,并且受以下命令:
- `create-nonce-account`
- `new-nonce`
- `withdraw-from-nonce-account`
- `authorize-nonce-account`
### Nonce 帐户创建
持久性交易随机数功能使用一个帐户来存储下一个随机数值。 持久的现时帐户必须为[免租](../implemented-proposals/rent.md#two-tiered-rent-regime),因此需要最低余额才能实现此目的。
通过首次生成一个新的密钥对,然后在链上创建该帐户来创建一个 nonce 帐户。
- 命令
```bash
solana-keygen new -o nonce-keypair.json
solana create-nonce-account nonce-keypair.json 1
```
- 输出
```text
2SymGjGV4ksPdpbaqWFiDoBz8okvtiik4KE9cnMQgRHRLySSdZ6jrEcpPifW4xUpp4z66XM9d9wM48sA7peG2XL
```
> 要保持密钥对完全离线,请使用 [纸钱包](wallet-guide/paper-wallet.md) 密钥生成 [指令](wallet-guide/paper-wallet.md#seed-phrase-generation)
> [完整使用文档](../cli/usage.md#solana-create-nonce-account)
### 查询存储Nonce值
创建持久的随机数交易需要在签名和提交时将存储的随机数值作为值传递给`--blockhash`参数。 使用以下方法获取当前存储的当前值:
- 命令
```bash
solana nonce none-non-keypair.json
```
- 输出
```text
8GRipryfxcsxN8mAGjy8zbFo9ezaUsh47TsPzmZbuytU
```
> [完整使用文档](../cli/usage.md#solana-get-nonce)
### 提升存储Nonce值
尽管通常不需要在更有用的交易之外进行存储,但存储的当前值可以通过以下方式获取:
- 命令
```bash
solana new-nonce none-non-keypair.json
```
- 输出
```text
44jYe1yPKrjuYDmoFTdgPjg8LFpYyh1PFKJqm5SC1PiSyAL8iw1bhadcAX1SL7KDmREEkmHpYvreKoNv6fZgfvUK
```
> [完整使用文档](../cli/usage.md#solana-new-nonce)
### 显示Nonce账户
以更人性化的格式检查nonce 帐户
- 命令
```bash
solana non-account non-ceypair.json
```
- 输出
```text
balance: 0.5 SOL
minimum balance required: 0.00136416 SOL
nonce: DZar6t2EaCFQTbUP4DHKwZ1wT8gCPW2aRfkVWhydkBvS
```
> [完整使用文档](../cli/usage.md#solana-nonce-account)
### 从Nonce帐号提取资产
通过以下方式从 nonce 帐户提取资产
- 命令
```bash
solana withdraw-from-nonce-account nonce-keypair.json ~/.config/solana/id.json 0.5
```
- 输出
```text
3foNy1SBqwXSsfSfTdmYKDuhnVheRnKXpoPySiUDBVeDEs6iMVokgqm7AqfTjbk7QBE8mqomvMUMNQhtdMvFLide
```
> 通过提取全部余额关闭nonce账户
> [完整使用文档](../cli/usage.md#solana-withdraw-from-nonce-account)
### 为Nonce账户分配新的授权
创建后重新分配 nonce 帐户的授权
- 命令
```bash
solana authorize-non-account non-keypair.json nonce-authority.json
```
- 输出
```text
3F9cg4zN9wHxLGx4c3cUKmqpej4oa67QbALmChsJbfxTgTffRiL3iUehVhR9wQmWgPua66jPuAYeL1K2pYYjbNoT
```
> [完整使用文档](../cli/usage.md#solana-authorize-nonce-account)
## 支持持久Nonce的其他命令
要将持久随机数与其他CLI子命令一起使用必须支持两个参数。
- `--nonce`,指定帐户存储 nonce 值
- `--nonce-authority`,指定一个可选的 [nonce authority](#nonce-authority)
到目前为止,以下子命令已接受此处理
- [`支付`](../cli/usage.md#solana-pay)
- [`委托质押`](../cli/usage.md#solana-delegate-stake)
- [`停用质押`](../cli/usage.md#solana-deactivate-stake)
### 使用持久Nonce的支付示例
在这里我们演示了Alice使用持久 nonce 向Bob 1 SOL支付的费用。 对于支持持久随机数的所有子命令,该过程相同
#### - 创建帐户
首先我们需要为Alice、Alice的none和Bob准备一些账户
```bash
$ solana-keygen new -o alice.json
$ solana-keygen new -o nonce.json
$ solana-keygen new -o bob.json
```
#### - Alice账户充值
Alice 需要一些资产来创建一个 nonce 帐户并发送给 Bob。 空投一些SOL给她
```bash
$ solana airdrop -k alice.json 10
10 SOL
```
#### - 创建 Alice 的 nonce 帐户
现在Alice需要一个nonce 帐户。 创建一个
> 这里没有单独的 [nonce authority](#nonce-authority) 被使用,所以 `alice.json` 对nonce 帐户拥有完全的权限
```bash
$ solana create-nonce-account -k alice.json nonce.json 1
3KPZr96BTsL3hqera9up82KAU462Gz31xjqJ6ehuAjF935Yf8i1kmfEbo6SVbNaACKE5z6gySrNjVRvmS8DcPuwV
```
#### - 支付给 Bob 的首次失败尝试
Alice 试图为支付给 Bob但签名需要太长时间。 指定的区块哈希已经过期,导致交易失败
```bash
$ solana pay -k alice.json --blockhash expiredDTaxfagttWjQweib42b6ZHADSx94Tw8gHx3W7 bob.json 1
[2020-01-02T18:48:28.462911000Z ERROR solana_cli::cli] Io(Custom { kind: Other, error: "Transaction \"33gQQaoPc9jWePMvDAeyJpcnSPiGUAdtVg8zREWv4GiKjkcGNufgpcbFyRKRrA25NkgjZySEeKue5rawyeH5TzsV\" failed: None" })
Error: Io(Custom { kind: Other, error: "Transaction \"33gQQaoPc9jWePMvDAeyJpcnSPiGUAdtVg8zREWv4GiKjkcGNufgpcbFyRKRrA25NkgjZySEeKue5rawyeH5TzsV\" failed: None" })
```
#### - 用 Nonce 来补救!
Alice 重试交易这次指定她的nonce账户和存储在那里的区块哈希。
> 记住,`alice.json` 是这个示例中的 [nonce 授权](#nonce-authority)
```bash
$ solana nonce-account nonce.json
balance: 1 SOL
minimum balance required: 0.00136416 SOL
nonce: F7vmkY3DTaxfagttWjQweib42b6ZHADSx94Tw8gHx3W7
```
```bash
$ solana pay -k alice.json --blockhash F7vmkY3DTaxfagtWjQweib42b6ZHADSx94Tw8gHx3W7 --nonce nonce.json bob.json 1
HR1368UKHVZyenmH7yVz5sBAijV6XAPeWbEiXEGVYQorRMcoijeNAbzZqEZiH8cDB8tk65ckeegFjK8dHwNFgQ
```
#### - 成功了!
交易成功! Bob 从 Alice 那里收到1个SOL并且Alice存储的nonce更新到了一个新的值
```bash
$ solana balance -k bob.json
1 SOL
```
```bash
$ solana nonce-account nonce.json
balance: 1 SOL
minimum balance required: 0.00136416 SOL
nonce: 6bjroqDcZgTv6Vavhqf81oBHTv3aMnX19UTB51YhAZnN
```