Skip to main content

Step 5: Verifications

After the delay that you calculated in Step 4: Run an Octez baking daemon, follow these instructions to verify the activity or diagnose and fix issues.

  1. Record the address of your baker account (not the consensus account) in an environment variable so you can use it for commands that cannot get addresses by their Octez client aliases:

    MY_BAKER="$(octez-client show address my_baker | head -n 1 | cut -d ' ' -f 2)"
  2. Run these commands to get the (consensus) attestation rights for the baker in the current cycle:

    1. Get the current cycle by running this command:

      octez-client rpc get /chains/main/blocks/head | jq | grep '"cycle"'
    2. Use the current cycle as the <current-cycle> parameter in this command. Beware, this command may take several minutes to finish if the list of rights is long:

      octez-client rpc get "/chains/main/blocks/head/helpers/attestation_rights?delegate=$MY_BAKER&cycle=<current-cycle>"

    When the baker has attestation rights, the command returns information about them, as in this example:

    [ { "level": 9484,
    "delegates":
    [ { "delegate": "tz1Zs6zjxtLxmff51tK2AVgvm4PNmdNhLcHE",
    "first_slot": 280, "attestation_power": 58,
    "consensus_key": "tz1Zs6zjxtLxmff51tK2AVgvm4PNmdNhLcHE" } ] }
    ...
    ]

    If the command returns an empty array ([]), the baker has no rights in the specified cycle.

    • Check to see if you will receive rights two cycles in the future, using commands similar to those above for the current cycle. You can see who will receive rights no farther than two cycles in the future. This number of cycles is set by the consensus_rights_delay network parameter.

      If this returns a list of future attestation rights for your account, you must wait for that cycle to arrive.

    • Otherwise, make sure that your node and baker are running.

    • Verify that the staked balance of your baker account is at least 6,000 tez by running the command octez-client get staked balance for my_baker. If the response is less than 6,000 tez, you have not staked enough. Ensure that you are registered as a delegate and stake more tez, retaining a small amount for transaction fees. If necessary you can get more from the faucet.

    • Check to see if you are active and re-register as a delegate if necessary:

      1. Run this command to see if your account is marked as inactive:

        octez-client rpc get /chains/main/blocks/head/context/delegates/$MY_BAKER/deactivated

        Baker accounts are deactivated when the baker is offline for a certain time.

      2. If the value for the deactivated field is true, re-register as a baker by running this command:

        octez-client register key my_baker as delegate with consensus key consensus_key

      When the next cycle starts, Tezos calculates attestation rights for two cycles in the future and includes your baker.

      You can find when the next cycle will start by running these commands:

      1. Find the last level of the current cycle by running this command:

        octez-client rpc get "/chains/main/blocks/head/helpers/levels_in_current_cycle"
      2. Pass the last level of the cycle as the <last-block> parameter in this command:

        octez-client rpc get "/chains/main/blocks/head/helpers/attestation_rights?level=<last-block>" | grep '"estimated_time"'

        The response shows the estimated time when the cycle will end.

      You can also find when the next cycle will start by going to a block explorer such as https://ghostnet.tzkt.io. For example, this drop-down shows that the next cycle starts in 29 minutes:

      The TZKT block explorer, showing information about the current cycle
  3. When your baker receives attestation rights as determined by the /chains/main/blocks/head/helpers/attestation_rights RPC call, run this command to get the shards that are assigned to your DAL node for the next block:

    octez-client rpc get "/chains/main/blocks/head/context/dal/shards?delegates=$MY_BAKER"

    The response includes your account's address and a list of shards, as in this example:

    [ { "delegate": "tz1QCVQinE8iVj1H2fckqx6oiM85CNJSK9Sx",
    "indexes": [ 25, 27, 67, 73, 158, 494 ] } ]

    These shards are pieces of data that the baker is assigned to attest.

    Note that you have to potentially execute the command above during many block levels in order to find a block where you have some shards assigned. There is currently no simple command line to get all your DAL rights for a whole cycle, but you can call it in a loop for future levels until you see some shards. First, get the current level:

    octez-client rpc get /chains/main/blocks/head | jq '.header.level'

    and pass it as the <current-level> parameter in this command:

    l=<current-level>; while true; echo $l; do octez-client rpc get "/chains/main/blocks/head/context/dal/shards?delegates=$MY_BAKER&level=$l"; l=$((l+1)); done

    If the DAL is active, you should see shards assigned for at least some levels but not necessarily every level.

  4. Verify the baker's activity on the Explorus block explorer by going to the Consensus Ops page at https://explorus.io/consensus_ops, selecting Ghostnet, and searching for your baker account address (only the first few characters).

    For example, this screenshot shows consensus operations that include DAL attestations, indicated by a number in the "DAL attestation bitset" column.

    DAL consensus operations, showing DAL consensus operations

    If there is no DAL attestation, the block explorer shows a document icon with an X in it: . This icon can appear before the bakers complete attestations and then turn into a binary number when they attest.

    If you see the rights, you will see the attestations in the baker's log when scheduled. Now you have a complete DAL baking setup. Your baker is attesting to the availability of DAL data and the DAL node is sharing it to Smart Rollups across the network.

If you don't see DAL attestation rights:

  • Verify that your DAL node is connected to the network by following the instructions in Troubleshooting in the Octez documentation.

Optional: Changing the consensus key

If you need to change the consensus key that the baker daemon uses, you can change it without changing the baker key. The new key takes effect after the same attestation delay that you had to wait for your baker to receive attestation rights when you first set it up:

(consensus_rights_delay + 2) * blocks_per_cycle * minimal_block_delay

Follow these steps to change the consensus key:

  1. Generate a new consensus key with the octez-client gen keys command or import a private key into the instance of the Octez client on the same machine as the baking daemon.

  2. Use this new key as the consensus key for your baker account by running this command, with the address or alias of the new consensus key as the <NEW CONSENSUS KEY> variable:

    octez-client set consensus key for my_baker to <NEW CONSENSUS KEY>
  3. Wait for the change to take effect. During this time you can leave the baking daemon running with the old consensus key.

  4. When the new consensus key is active, stop the baking daemon and restart it with the new consensus key.

Optional: Unstaking your tez and receiving your baking rewards

If you leave the baker running, you can see rewards accrue by running the command octez-client get staked balance for my_baker. This amount starts at the amount that you originally staked and increases with your baking rewards.

You can unstake your tez and withdraw your stake and any baking rewards with the octez-client unstake command. For example, this command unstakes 6,000 tez:

octez-client unstake 6000 for my_baker

You can substitute "everything" for the amount of tez to unstake everything.

Then, after the same delay of consensus_rights_delay + 2 cycles, run this command to retrieve the tez:

octez-client finalize unstake for my_baker

Then you can do whatever you want with the tez, including sending it back to the faucet for someone else to use. The Ghostnet faucet's address is tz1a4GT7THHaGDiTxgXoatDWcZfJ5j29z5RC, so you can send funds back with this command:

octez-client transfer 6000 from my_baker to tz1a4GT7THHaGDiTxgXoatDWcZfJ5j29z5RC

For a summary, see Conclusion.