Prerequirements: Read substrate official documentation Read about webassembly and utilize "subwasm" Watch Alex's runtime migrations video: https://www.youtube.com/watch?v=MQgDV37JrIY Read about runtime migrations: https://github.com/apopiak/substrate-migrations
Add your changes to the code repository and make sure your pallets are included in the runtime. Increment the spec_version by adding +1.
Compile your node
Go over modifed changes made to the storage and apply storage migrations to convert the old types to the new once in the on_runtime_upgrade
function
Note: Failing to migrate important storage changes will have a negative effect on the chain Note: use logging to display what migrations kicked in
Verify that the compiled wasm file looks good with subwasm and srtool(https://github.com/paritytech/srtool).
Compile the node locally and use the current spec_version that is deployed on chain(check polkadot.js for last upgrade in chainstate) Push the runtime upgrade either with as Sudo Call or as a democracy vote on your local instance. If all is well and the pallet's interact good after the upgrade, go ahead to the next step
Prep a release page for the node with the output from srtool and the hashes of the binary files, upload the wasm file aswell to the releases page.
Push the upgrade on-chain
https://develop--substrate-docs.netlify.app/how-to-guides/v3/storage-migrations/basics/ https://docs.substrate.io/build/runtime-storage/ https://docs.substrate.io/build/upgrade-the-runtime/