diff --git a/404.html b/404.html index c6cda670..358f7e79 100644 --- a/404.html +++ b/404.html @@ -4,7 +4,7 @@ Page Not Found | Stakeworld.io - + diff --git a/assets/js/0e0b553a.bf422001.js b/assets/js/0e0b553a.29bb0ca8.js similarity index 54% rename from assets/js/0e0b553a.bf422001.js rename to assets/js/0e0b553a.29bb0ca8.js index 410e1a40..03401973 100644 --- a/assets/js/0e0b553a.bf422001.js +++ b/assets/js/0e0b553a.29bb0ca8.js @@ -1 +1 @@ -"use strict";(self.webpackChunkstakeworld_io=self.webpackChunkstakeworld_io||[]).push([[158],{5852:(e,t,s)=>{s.r(t),s.d(t,{assets:()=>i,contentTitle:()=>r,default:()=>h,frontMatter:()=>n,metadata:()=>a,toc:()=>l});const a=JSON.parse('{"id":"snapshot","title":"Snapshot","description":"Polkadot and Kusama snapshots in paritydb and rocksdb format","source":"@site/docs/snapshot.mdx","sourceDirName":".","slug":"/snapshot","permalink":"/docs/snapshot","draft":false,"unlisted":false,"editUrl":"https://github.com/stakeworld/website/edit/master/docs/snapshot.mdx","tags":[],"version":"current","sidebarPosition":3,"frontMatter":{"id":"snapshot","title":"Snapshot","description":"Polkadot and Kusama snapshots in paritydb and rocksdb format","slug":"/snapshot","sidebar_position":3,"keywords":["snapshots","snapshot","kusama snapshot","polkadot snapshot","rocksdb","paritydb","pruning","polkadot","kusama"]},"sidebar":"tutorialSidebar","previous":{"title":"Pool","permalink":"/docs/pool"},"next":{"title":"Database sizes","permalink":"/docs/dbsize"}}');var o=s(4848),d=s(8453);const n={id:"snapshot",title:"Snapshot",description:"Polkadot and Kusama snapshots in paritydb and rocksdb format",slug:"/snapshot",sidebar_position:3,keywords:["snapshots","snapshot","kusama snapshot","polkadot snapshot","rocksdb","paritydb","pruning","polkadot","kusama"]},r=void 0,i={},l=[{value:"Automatic install",id:"automatic-install",level:2},{value:"Manual install",id:"manual-install",level:2},{value:"Setup a validator node",id:"setup-a-validator-node",level:3},{value:"Install the database",id:"install-the-database",level:3},{value:"Edit the systemctl startup script",id:"edit-the-systemctl-startup-script",level:3},{value:"Restore:",id:"restore",level:2},{value:"Generic command",id:"generic-command",level:3}];function c(e){const t={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",img:"img",p:"p",pre:"pre",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,d.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(t.p,{children:"Last update: Sun 02 Feb"}),"\n",(0,o.jsxs)(t.table,{children:[(0,o.jsx)(t.thead,{children:(0,o.jsxs)(t.tr,{children:[(0,o.jsx)(t.th,{}),(0,o.jsx)(t.th,{children:"Chain"}),(0,o.jsx)(t.th,{children:"Database"}),(0,o.jsx)(t.th,{children:"Format"}),(0,o.jsx)(t.th,{children:"Blockheight"}),(0,o.jsx)(t.th,{children:"Snapshot"}),(0,o.jsx)(t.th,{children:"Full"})]})}),(0,o.jsxs)(t.tbody,{children:[(0,o.jsxs)(t.tr,{children:[(0,o.jsx)(t.td,{children:(0,o.jsx)(t.a,{href:"http://snapshot.stakeworld.io/paritydb-polkadot.lz4",children:"direct link"})}),(0,o.jsx)(t.td,{children:"polkadot"}),(0,o.jsx)(t.td,{children:"paritydb"}),(0,o.jsx)(t.td,{children:"pruned"}),(0,o.jsx)(t.td,{children:"24549745"}),(0,o.jsx)(t.td,{children:"539G"}),(0,o.jsx)(t.td,{children:"562G"})]}),(0,o.jsxs)(t.tr,{children:[(0,o.jsx)(t.td,{children:(0,o.jsx)(t.a,{href:"http://snapshot.stakeworld.io/paritydb-paseo.lz4",children:"direct link"})}),(0,o.jsx)(t.td,{children:"paseo"}),(0,o.jsx)(t.td,{children:"paritydb"}),(0,o.jsx)(t.td,{children:"pruned"}),(0,o.jsx)(t.td,{children:"4965133"}),(0,o.jsx)(t.td,{children:"71G"}),(0,o.jsx)(t.td,{children:"76G"})]})]})]}),"\n",(0,o.jsx)(t.p,{children:(0,o.jsx)(t.img,{alt:"snapsize",src:s(3996).A+"",width:"800",height:"300"})}),"\n",(0,o.jsxs)(t.admonition,{type:"info",children:[(0,o.jsx)(t.p,{children:"Snapshots are compressed backups of the database directory of a polkadot or kusama node. If you start a node for the first time it will start building the database from scratch, which will take a few days, depending on network speed. If you download an up to date database snapshot your node will be up and running quicker; under an hour or a few hours, depending on network speed."}),(0,o.jsxs)(t.p,{children:["Recently the warp sync option is becoming more developed and popular. If you start the node with an empty database and the option ",(0,o.jsx)(t.code,{children:"--sync warp"})," the node will first download the finality proofs after which it will be ready to validate and in the background download the remaining blocks."]}),(0,o.jsx)(t.p,{children:'With the "beefy" update warp sync got temporarily disabled so for the time being the snapshot service is re-enabled.'}),(0,o.jsxs)(t.p,{children:["For now the snapshots are available for kusama ",(0,o.jsx)(t.code,{children:"--chain ksmcc3"})," and polkadot ",(0,o.jsx)(t.code,{children:"--chain polkadot"})," in the paritydb ",(0,o.jsx)(t.code,{children:"--database paritydb"})," database format and the rocksdb ",(0,o.jsx)(t.code,{children:"--database rocksdb"})," format. They are pruned with ",(0,o.jsx)(t.code,{children:"--state-pruning 256"})," (default), which is sufficient for a validator node."]})]}),"\n",(0,o.jsx)(t.h2,{id:"automatic-install",children:"Automatic install"}),"\n",(0,o.jsxs)(t.p,{children:["The following script can restore a snapshot for a quickstart. If you want you can first review it on ",(0,o.jsx)(t.a,{href:"https://github.com/stakeworld/stakeworld-scripts/blob/master/node-install.sh",children:"github"}),'. You can choose "snapinstall" for a snapshot restore or "nodeinstall" to install a complete node. The script will ask some questions and create an install or restore script which you can review before executing.']}),"\n",(0,o.jsx)(t.p,{children:"The script is for ubuntu/debian flavoured servers."}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"curl -o- -L https://raw.githubusercontent.com/stakeworld/stakeworld-scripts/master/node-install.sh | bash\n"})}),"\n",(0,o.jsx)(t.h2,{id:"manual-install",children:"Manual install"}),"\n",(0,o.jsx)(t.h3,{id:"setup-a-validator-node",children:"Setup a validator node"}),"\n",(0,o.jsxs)(t.p,{children:["Setting up a validator node is covered ",(0,o.jsx)(t.a,{href:"./validate",children:"here"}),". The default apt install creates an user polkadot with a home directory ",(0,o.jsx)(t.code,{children:"/home/polkadot"})," and a default service script ",(0,o.jsx)(t.code,{children:"/usr/lib/systemd/system/polkadot.service"}),"."]}),"\n",(0,o.jsx)(t.h3,{id:"install-the-database",children:"Install the database"}),"\n",(0,o.jsxs)(t.p,{children:["Database location: By default the polkadot binary runs as user polkadot and creates ",(0,o.jsx)(t.code,{children:".local/share/polkadot"})," in the users homedirectory. So for user polkadot (the default when installing from apt) that is ",(0,o.jsx)(t.code,{children:"/home/polkadot/.local/share/polkadot"}),"."]}),"\n",(0,o.jsxs)(t.p,{children:["This can be changed with ",(0,o.jsx)(t.code,{children:"--base-path"})," so for example ",(0,o.jsx)(t.code,{children:"--base-path /home/polkadot"})," or ",(0,o.jsx)(t.code,{children:"--base-path /home/polkadot/myvalidator"})," or whatever you prefer."]}),"\n",(0,o.jsx)(t.p,{children:"To delete the old database, restore a new kusama paritydb database snapshot for your node with a default install:"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"su - polkadot -s /bin/bash\nrm -fr /home/polkadot/.local/share/polkadot/chains/ksmcc3\nmkdir -p /home/polkadot/.local/share/polkadot/chains/ksmcc3\ncurl -o - -L http://snapshot.stakeworld.io/paritydb-ksmcc3.lz4 | lz4 -c -d - | tar -x -C /home/polkadot/.local/share/polkadot/chains/ksmcc3\n"})}),"\n",(0,o.jsx)(t.p,{children:"You can check the startup by running the binary as user polkadot and see if it accepts the database or throws any errors:"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"su - polkadot -s /bin/bash\npolkadot --chain kusama --database paritydb \n"})}),"\n",(0,o.jsx)(t.h3,{id:"edit-the-systemctl-startup-script",children:"Edit the systemctl startup script"}),"\n",(0,o.jsxs)(t.p,{children:["Edit the default service script and add for example ",(0,o.jsx)(t.code,{children:"--database paritydb --chain kusama"}),":"]}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:'su -\nvi /usr/lib/systemd/system/polkadot.service"\nsystemctl daemon-reload\nsystemctl retart polkadot\nsystemctl enable polkadot\n'})}),"\n",(0,o.jsx)(t.p,{children:"Or create a new script by copying the default service script:"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"su -\ncp /usr/lib/systemd/system/polkadot.service /etc/systemd/system/validator.service\nvi /etc/systemd/system/validator.service\n"})}),"\n",(0,o.jsx)(t.p,{children:"You can edit settings at wish, changing ports and settings at will."}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-config",children:"[Service]\nExecStart=/usr/bin/polkadot --chain kusama --name validator --validator --prometheus-external --base-path /home/polkadot --database paritydb --telemetry-url 'wss://telemetry.polkadot.io/submit/ 1' \n"})}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"systemctl daemon-reload\nsystemctl start validator\nsystemctl enable validator\n"})}),"\n",(0,o.jsx)(t.admonition,{type:"caution",children:(0,o.jsxs)(t.p,{children:['If you installed as root you will get an error "failed to create a test file: Permission denied". You can solve this by running ',(0,o.jsx)(t.code,{children:"chown -R polkadot:polkadot DBDIR"})]})}),"\n",(0,o.jsx)(t.h2,{id:"restore",children:"Restore:"}),"\n",(0,o.jsxs)(t.p,{children:["Best run the commands as user polkadot (",(0,o.jsx)(t.code,{children:"su - polkadot -s /bin/bash"}),") or when running as root do a ",(0,o.jsx)(t.code,{children:"chown polkadot:polkadot "}),"). Of course change the part after ",(0,o.jsx)(t.code,{children:"-C"})," to your location."]}),"\n",(0,o.jsx)(t.h3,{id:"generic-command",children:"Generic command"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"curl -o - -L http://snapshot.stakeworld.io/ | lz4 -c -d - | tar -x -C \n"})}),"\n",(0,o.jsx)(t.p,{children:"For example paritydb kusama"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"curl -o - -L http://snapshot.stakeworld.io/paritydb-ksmcc3.lz4 | lz4 -c -d - | tar -x -C /home/polkadot/.local/share/polkadot/chains/ksmcc3\n"})}),"\n",(0,o.jsx)(t.p,{children:"For example rocksdb polkadot"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"curl -o - -L http://snapshot.stakeworld.io/rocksdb-polkadot.lz4 | lz4 -c -d - | tar -x -C /home/polkadot/.local/share/polkadot/chains/polkadot\n"})})]})}function h(e={}){const{wrapper:t}={...(0,d.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(c,{...e})}):c(e)}},3996:(e,t,s)=>{s.d(t,{A:()=>a});const a=""},8453:(e,t,s)=>{s.d(t,{R:()=>n,x:()=>r});var a=s(6540);const o={},d=a.createContext(o);function n(e){const t=a.useContext(d);return a.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function r(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:n(e.components),a.createElement(d.Provider,{value:t},e.children)}}}]); \ No newline at end of file +"use strict";(self.webpackChunkstakeworld_io=self.webpackChunkstakeworld_io||[]).push([[158],{5852:(e,t,a)=>{a.r(t),a.d(t,{assets:()=>i,contentTitle:()=>r,default:()=>h,frontMatter:()=>n,metadata:()=>s,toc:()=>l});const s=JSON.parse('{"id":"snapshot","title":"Snapshot","description":"Polkadot and Kusama snapshots in paritydb and rocksdb format","source":"@site/docs/snapshot.mdx","sourceDirName":".","slug":"/snapshot","permalink":"/docs/snapshot","draft":false,"unlisted":false,"editUrl":"https://github.com/stakeworld/website/edit/master/docs/snapshot.mdx","tags":[],"version":"current","sidebarPosition":3,"frontMatter":{"id":"snapshot","title":"Snapshot","description":"Polkadot and Kusama snapshots in paritydb and rocksdb format","slug":"/snapshot","sidebar_position":3,"keywords":["snapshots","snapshot","kusama snapshot","polkadot snapshot","rocksdb","paritydb","pruning","polkadot","kusama"]},"sidebar":"tutorialSidebar","previous":{"title":"Pool","permalink":"/docs/pool"},"next":{"title":"Database sizes","permalink":"/docs/dbsize"}}');var o=a(4848),d=a(8453);const n={id:"snapshot",title:"Snapshot",description:"Polkadot and Kusama snapshots in paritydb and rocksdb format",slug:"/snapshot",sidebar_position:3,keywords:["snapshots","snapshot","kusama snapshot","polkadot snapshot","rocksdb","paritydb","pruning","polkadot","kusama"]},r=void 0,i={},l=[{value:"Automatic install",id:"automatic-install",level:2},{value:"Manual install",id:"manual-install",level:2},{value:"Setup a validator node",id:"setup-a-validator-node",level:3},{value:"Install the database",id:"install-the-database",level:3},{value:"Edit the systemctl startup script",id:"edit-the-systemctl-startup-script",level:3},{value:"Restore:",id:"restore",level:2},{value:"Generic command",id:"generic-command",level:3}];function c(e){const t={a:"a",admonition:"admonition",code:"code",h2:"h2",h3:"h3",img:"img",p:"p",pre:"pre",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,d.R)(),...e.components};return(0,o.jsxs)(o.Fragment,{children:[(0,o.jsx)(t.p,{children:"Last update: Mon 03 Feb"}),"\n",(0,o.jsxs)(t.table,{children:[(0,o.jsx)(t.thead,{children:(0,o.jsxs)(t.tr,{children:[(0,o.jsx)(t.th,{}),(0,o.jsx)(t.th,{children:"Chain"}),(0,o.jsx)(t.th,{children:"Database"}),(0,o.jsx)(t.th,{children:"Format"}),(0,o.jsx)(t.th,{children:"Blockheight"}),(0,o.jsx)(t.th,{children:"Snapshot"}),(0,o.jsx)(t.th,{children:"Full"})]})}),(0,o.jsxs)(t.tbody,{children:[(0,o.jsxs)(t.tr,{children:[(0,o.jsx)(t.td,{children:(0,o.jsx)(t.a,{href:"http://snapshot.stakeworld.io/paritydb-polkadot.lz4",children:"direct link"})}),(0,o.jsx)(t.td,{children:"polkadot"}),(0,o.jsx)(t.td,{children:"paritydb"}),(0,o.jsx)(t.td,{children:"pruned"}),(0,o.jsx)(t.td,{children:"24564094"}),(0,o.jsx)(t.td,{children:"539G"}),(0,o.jsx)(t.td,{children:"563G"})]}),(0,o.jsxs)(t.tr,{children:[(0,o.jsx)(t.td,{children:(0,o.jsx)(t.a,{href:"http://snapshot.stakeworld.io/paritydb-paseo.lz4",children:"direct link"})}),(0,o.jsx)(t.td,{children:"paseo"}),(0,o.jsx)(t.td,{children:"paritydb"}),(0,o.jsx)(t.td,{children:"pruned"}),(0,o.jsx)(t.td,{children:"4979531"}),(0,o.jsx)(t.td,{children:"72G"}),(0,o.jsx)(t.td,{children:"76G"})]})]})]}),"\n",(0,o.jsx)(t.p,{children:(0,o.jsx)(t.img,{alt:"snapsize",src:a(3996).A+"",width:"800",height:"300"})}),"\n",(0,o.jsxs)(t.admonition,{type:"info",children:[(0,o.jsx)(t.p,{children:"Snapshots are compressed backups of the database directory of a polkadot or kusama node. If you start a node for the first time it will start building the database from scratch, which will take a few days, depending on network speed. If you download an up to date database snapshot your node will be up and running quicker; under an hour or a few hours, depending on network speed."}),(0,o.jsxs)(t.p,{children:["Recently the warp sync option is becoming more developed and popular. If you start the node with an empty database and the option ",(0,o.jsx)(t.code,{children:"--sync warp"})," the node will first download the finality proofs after which it will be ready to validate and in the background download the remaining blocks."]}),(0,o.jsx)(t.p,{children:'With the "beefy" update warp sync got temporarily disabled so for the time being the snapshot service is re-enabled.'}),(0,o.jsxs)(t.p,{children:["For now the snapshots are available for kusama ",(0,o.jsx)(t.code,{children:"--chain ksmcc3"})," and polkadot ",(0,o.jsx)(t.code,{children:"--chain polkadot"})," in the paritydb ",(0,o.jsx)(t.code,{children:"--database paritydb"})," database format and the rocksdb ",(0,o.jsx)(t.code,{children:"--database rocksdb"})," format. They are pruned with ",(0,o.jsx)(t.code,{children:"--state-pruning 256"})," (default), which is sufficient for a validator node."]})]}),"\n",(0,o.jsx)(t.h2,{id:"automatic-install",children:"Automatic install"}),"\n",(0,o.jsxs)(t.p,{children:["The following script can restore a snapshot for a quickstart. If you want you can first review it on ",(0,o.jsx)(t.a,{href:"https://github.com/stakeworld/stakeworld-scripts/blob/master/node-install.sh",children:"github"}),'. You can choose "snapinstall" for a snapshot restore or "nodeinstall" to install a complete node. The script will ask some questions and create an install or restore script which you can review before executing.']}),"\n",(0,o.jsx)(t.p,{children:"The script is for ubuntu/debian flavoured servers."}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"curl -o- -L https://raw.githubusercontent.com/stakeworld/stakeworld-scripts/master/node-install.sh | bash\n"})}),"\n",(0,o.jsx)(t.h2,{id:"manual-install",children:"Manual install"}),"\n",(0,o.jsx)(t.h3,{id:"setup-a-validator-node",children:"Setup a validator node"}),"\n",(0,o.jsxs)(t.p,{children:["Setting up a validator node is covered ",(0,o.jsx)(t.a,{href:"./validate",children:"here"}),". The default apt install creates an user polkadot with a home directory ",(0,o.jsx)(t.code,{children:"/home/polkadot"})," and a default service script ",(0,o.jsx)(t.code,{children:"/usr/lib/systemd/system/polkadot.service"}),"."]}),"\n",(0,o.jsx)(t.h3,{id:"install-the-database",children:"Install the database"}),"\n",(0,o.jsxs)(t.p,{children:["Database location: By default the polkadot binary runs as user polkadot and creates ",(0,o.jsx)(t.code,{children:".local/share/polkadot"})," in the users homedirectory. So for user polkadot (the default when installing from apt) that is ",(0,o.jsx)(t.code,{children:"/home/polkadot/.local/share/polkadot"}),"."]}),"\n",(0,o.jsxs)(t.p,{children:["This can be changed with ",(0,o.jsx)(t.code,{children:"--base-path"})," so for example ",(0,o.jsx)(t.code,{children:"--base-path /home/polkadot"})," or ",(0,o.jsx)(t.code,{children:"--base-path /home/polkadot/myvalidator"})," or whatever you prefer."]}),"\n",(0,o.jsx)(t.p,{children:"To delete the old database, restore a new kusama paritydb database snapshot for your node with a default install:"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"su - polkadot -s /bin/bash\nrm -fr /home/polkadot/.local/share/polkadot/chains/ksmcc3\nmkdir -p /home/polkadot/.local/share/polkadot/chains/ksmcc3\ncurl -o - -L http://snapshot.stakeworld.io/paritydb-ksmcc3.lz4 | lz4 -c -d - | tar -x -C /home/polkadot/.local/share/polkadot/chains/ksmcc3\n"})}),"\n",(0,o.jsx)(t.p,{children:"You can check the startup by running the binary as user polkadot and see if it accepts the database or throws any errors:"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"su - polkadot -s /bin/bash\npolkadot --chain kusama --database paritydb \n"})}),"\n",(0,o.jsx)(t.h3,{id:"edit-the-systemctl-startup-script",children:"Edit the systemctl startup script"}),"\n",(0,o.jsxs)(t.p,{children:["Edit the default service script and add for example ",(0,o.jsx)(t.code,{children:"--database paritydb --chain kusama"}),":"]}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:'su -\nvi /usr/lib/systemd/system/polkadot.service"\nsystemctl daemon-reload\nsystemctl retart polkadot\nsystemctl enable polkadot\n'})}),"\n",(0,o.jsx)(t.p,{children:"Or create a new script by copying the default service script:"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"su -\ncp /usr/lib/systemd/system/polkadot.service /etc/systemd/system/validator.service\nvi /etc/systemd/system/validator.service\n"})}),"\n",(0,o.jsx)(t.p,{children:"You can edit settings at wish, changing ports and settings at will."}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-config",children:"[Service]\nExecStart=/usr/bin/polkadot --chain kusama --name validator --validator --prometheus-external --base-path /home/polkadot --database paritydb --telemetry-url 'wss://telemetry.polkadot.io/submit/ 1' \n"})}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"systemctl daemon-reload\nsystemctl start validator\nsystemctl enable validator\n"})}),"\n",(0,o.jsx)(t.admonition,{type:"caution",children:(0,o.jsxs)(t.p,{children:['If you installed as root you will get an error "failed to create a test file: Permission denied". You can solve this by running ',(0,o.jsx)(t.code,{children:"chown -R polkadot:polkadot DBDIR"})]})}),"\n",(0,o.jsx)(t.h2,{id:"restore",children:"Restore:"}),"\n",(0,o.jsxs)(t.p,{children:["Best run the commands as user polkadot (",(0,o.jsx)(t.code,{children:"su - polkadot -s /bin/bash"}),") or when running as root do a ",(0,o.jsx)(t.code,{children:"chown polkadot:polkadot "}),"). Of course change the part after ",(0,o.jsx)(t.code,{children:"-C"})," to your location."]}),"\n",(0,o.jsx)(t.h3,{id:"generic-command",children:"Generic command"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"curl -o - -L http://snapshot.stakeworld.io/ | lz4 -c -d - | tar -x -C \n"})}),"\n",(0,o.jsx)(t.p,{children:"For example paritydb kusama"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"curl -o - -L http://snapshot.stakeworld.io/paritydb-ksmcc3.lz4 | lz4 -c -d - | tar -x -C /home/polkadot/.local/share/polkadot/chains/ksmcc3\n"})}),"\n",(0,o.jsx)(t.p,{children:"For example rocksdb polkadot"}),"\n",(0,o.jsx)(t.pre,{children:(0,o.jsx)(t.code,{className:"language-bash",children:"curl -o - -L http://snapshot.stakeworld.io/rocksdb-polkadot.lz4 | lz4 -c -d - | tar -x -C /home/polkadot/.local/share/polkadot/chains/polkadot\n"})})]})}function h(e={}){const{wrapper:t}={...(0,d.R)(),...e.components};return t?(0,o.jsx)(t,{...e,children:(0,o.jsx)(c,{...e})}):c(e)}},3996:(e,t,a)=>{a.d(t,{A:()=>s});const s=""},8453:(e,t,a)=>{a.d(t,{R:()=>n,x:()=>r});var s=a(6540);const o={},d=s.createContext(o);function n(e){const t=s.useContext(d);return s.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function r(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(o):e.components||o:n(e.components),s.createElement(d.Provider,{value:t},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/539febe6.647b654d.js b/assets/js/539febe6.647b654d.js deleted file mode 100644 index 01dae432..00000000 --- a/assets/js/539febe6.647b654d.js +++ /dev/null @@ -1 +0,0 @@ -"use strict";(self.webpackChunkstakeworld_io=self.webpackChunkstakeworld_io||[]).push([[822],{3900:(A,d,s)=>{s.r(d),s.d(d,{assets:()=>C,contentTitle:()=>g,default:()=>n,frontMatter:()=>I,metadata:()=>e,toc:()=>c});const e=JSON.parse('{"id":"dbsize","title":"Database sizes","description":"Polkadot and Kusama Relaychain and common chains database sizes","source":"@site/docs/dbsize.mdx","sourceDirName":".","slug":"/dbsize","permalink":"/docs/dbsize","draft":false,"unlisted":false,"editUrl":"https://github.com/stakeworld/website/edit/master/docs/dbsize.mdx","tags":[],"version":"current","sidebarPosition":4,"frontMatter":{"id":"dbsize","title":"Database sizes","description":"Polkadot and Kusama Relaychain and common chains database sizes","slug":"/dbsize","sidebar_position":4,"keywords":["database","database size","substrate","polkadot","kusama","westend"]},"sidebar":"tutorialSidebar","previous":{"title":"Snapshot","permalink":"/docs/snapshot"},"next":{"title":"RPC server","permalink":"/docs/rpc"}}');var t=s(4848),i=s(8453);const I={id:"dbsize",title:"Database sizes",description:"Polkadot and Kusama Relaychain and common chains database sizes",slug:"/dbsize",sidebar_position:4,keywords:["database","database size","substrate","polkadot","kusama","westend"]},g=void 0,C={},c=[];function B(A){const d={img:"img",p:"p",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,i.R)(),...A.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(d.p,{children:"Last update: Sun 02 Feb"}),"\n",(0,t.jsxs)(d.table,{children:[(0,t.jsx)(d.thead,{children:(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.th,{children:"Chain"}),(0,t.jsx)(d.th,{children:"Database"}),(0,t.jsx)(d.th,{children:"Format"}),(0,t.jsx)(d.th,{children:"Blockheight"}),(0,t.jsx)(d.th,{children:"Full"}),(0,t.jsx)(d.th,{children:"Daily growth"})]})}),(0,t.jsxs)(d.tbody,{children:[(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"people-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"2798863"}),(0,t.jsx)(d.td,{children:"76G"}),(0,t.jsx)(d.td,{children:"380M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"encointer-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"7703153"}),(0,t.jsx)(d.td,{children:"166G"}),(0,t.jsx)(d.td,{children:"435M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"bridge-hub-polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"4438524"}),(0,t.jsx)(d.td,{children:"156G"}),(0,t.jsx)(d.td,{children:"593M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"collectives-polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"5643583"}),(0,t.jsx)(d.td,{children:"126G"}),(0,t.jsx)(d.td,{children:"206M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"24549726"}),(0,t.jsx)(d.td,{children:"2.7T"}),(0,t.jsx)(d.td,{children:"3.1G"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"ksmcc3"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"26907511"}),(0,t.jsx)(d.td,{children:"3.5T"}),(0,t.jsx)(d.td,{children:"3.0G"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"ksmcc3"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"pruned"}),(0,t.jsx)(d.td,{children:"26907512"}),(0,t.jsx)(d.td,{children:"627G"}),(0,t.jsx)(d.td,{children:"922M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"pruned"}),(0,t.jsx)(d.td,{children:"24549726"}),(0,t.jsx)(d.td,{children:"562G"}),(0,t.jsx)(d.td,{children:"844M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"asset-hub-polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"8123194"}),(0,t.jsx)(d.td,{children:"258G"}),(0,t.jsx)(d.td,{children:"415M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"paseo"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"4964568"}),(0,t.jsx)(d.td,{children:"422G"}),(0,t.jsx)(d.td,{children:"1.8G"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"coretime-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"2044607"}),(0,t.jsx)(d.td,{children:"54G"}),(0,t.jsx)(d.td,{children:"192M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"asset-hub-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"8714335"}),(0,t.jsx)(d.td,{children:"258G"}),(0,t.jsx)(d.td,{children:"286M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"bridge-hub-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"5053732"}),(0,t.jsx)(d.td,{children:"140G"}),(0,t.jsx)(d.td,{children:"406M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"asset-hub-paseo"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"1242280"}),(0,t.jsx)(d.td,{children:"32G"}),(0,t.jsx)(d.td,{children:"192M"})]})]})]}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"snapsize",src:s(7766).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"dbdiffarchive",src:s(4153).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"prunedsize",src:s(6780).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"dbdiffpruned",src:s(4868).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"commonsize",src:s(5419).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"dbdiffcommon",src:s(2323).A+"",width:"800",height:"300"})})]})}function n(A={}){const{wrapper:d}={...(0,i.R)(),...A.components};return d?(0,t.jsx)(d,{...A,children:(0,t.jsx)(B,{...A})}):B(A)}},7766:(A,d,s)=>{s.d(d,{A:()=>e});const e=""},5419:(A,d,s)=>{s.d(d,{A:()=>e});const e=""},2323:(A,d,s)=>{s.d(d,{A:()=>e});const e=""},4868:(A,d,s)=>{s.d(d,{A:()=>e});const e=""},4153:(A,d,s)=>{s.d(d,{A:()=>e});const e=""},6780:(A,d,s)=>{s.d(d,{A:()=>e});const e=""},8453:(A,d,s)=>{s.d(d,{R:()=>I,x:()=>g});var e=s(6540);const t={},i=e.createContext(t);function I(A){const d=e.useContext(i);return e.useMemo((function(){return"function"==typeof A?A(d):{...d,...A}}),[d,A])}function g(A){let d;return d=A.disableParentContext?"function"==typeof A.components?A.components(t):A.components||t:I(A.components),e.createElement(i.Provider,{value:d},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/539febe6.c3bdcd6e.js b/assets/js/539febe6.c3bdcd6e.js new file mode 100644 index 00000000..75de8715 --- /dev/null +++ b/assets/js/539febe6.c3bdcd6e.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunkstakeworld_io=self.webpackChunkstakeworld_io||[]).push([[822],{3900:(A,d,g)=>{g.r(d),g.d(d,{assets:()=>r,contentTitle:()=>e,default:()=>B,frontMatter:()=>s,metadata:()=>i,toc:()=>C});const i=JSON.parse('{"id":"dbsize","title":"Database sizes","description":"Polkadot and Kusama Relaychain and common chains database sizes","source":"@site/docs/dbsize.mdx","sourceDirName":".","slug":"/dbsize","permalink":"/docs/dbsize","draft":false,"unlisted":false,"editUrl":"https://github.com/stakeworld/website/edit/master/docs/dbsize.mdx","tags":[],"version":"current","sidebarPosition":4,"frontMatter":{"id":"dbsize","title":"Database sizes","description":"Polkadot and Kusama Relaychain and common chains database sizes","slug":"/dbsize","sidebar_position":4,"keywords":["database","database size","substrate","polkadot","kusama","westend"]},"sidebar":"tutorialSidebar","previous":{"title":"Snapshot","permalink":"/docs/snapshot"},"next":{"title":"RPC server","permalink":"/docs/rpc"}}');var t=g(4848),I=g(8453);const s={id:"dbsize",title:"Database sizes",description:"Polkadot and Kusama Relaychain and common chains database sizes",slug:"/dbsize",sidebar_position:4,keywords:["database","database size","substrate","polkadot","kusama","westend"]},e=void 0,r={},C=[];function u(A){const d={img:"img",p:"p",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",...(0,I.R)(),...A.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(d.p,{children:"Last update: Mon 03 Feb"}),"\n",(0,t.jsxs)(d.table,{children:[(0,t.jsx)(d.thead,{children:(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.th,{children:"Chain"}),(0,t.jsx)(d.th,{children:"Database"}),(0,t.jsx)(d.th,{children:"Format"}),(0,t.jsx)(d.th,{children:"Blockheight"}),(0,t.jsx)(d.th,{children:"Full"}),(0,t.jsx)(d.th,{children:"Daily growth"})]})}),(0,t.jsxs)(d.tbody,{children:[(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"people-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"2812905"}),(0,t.jsx)(d.td,{children:"77G"}),(0,t.jsx)(d.td,{children:"382M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"encointer-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"7717068"}),(0,t.jsx)(d.td,{children:"167G"}),(0,t.jsx)(d.td,{children:"441M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"bridge-hub-polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"4445672"}),(0,t.jsx)(d.td,{children:"157G"}),(0,t.jsx)(d.td,{children:"594M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"collectives-polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"5650729"}),(0,t.jsx)(d.td,{children:"126G"}),(0,t.jsx)(d.td,{children:"210M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"24564074"}),(0,t.jsx)(d.td,{children:"2.7T"}),(0,t.jsx)(d.td,{children:"3.0G"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"ksmcc3"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"26921747"}),(0,t.jsx)(d.td,{children:"3.5T"}),(0,t.jsx)(d.td,{children:"3.0G"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"ksmcc3"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"pruned"}),(0,t.jsx)(d.td,{children:"26921747"}),(0,t.jsx)(d.td,{children:"627G"}),(0,t.jsx)(d.td,{children:"886M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"pruned"}),(0,t.jsx)(d.td,{children:"24564074"}),(0,t.jsx)(d.td,{children:"563G"}),(0,t.jsx)(d.td,{children:"858M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"asset-hub-polkadot"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"8130337"}),(0,t.jsx)(d.td,{children:"258G"}),(0,t.jsx)(d.td,{children:"426M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"paseo"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"4978966"}),(0,t.jsx)(d.td,{children:"424G"}),(0,t.jsx)(d.td,{children:"1.8G"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"coretime-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"2051226"}),(0,t.jsx)(d.td,{children:"54G"}),(0,t.jsx)(d.td,{children:"174M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"asset-hub-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"8720885"}),(0,t.jsx)(d.td,{children:"259G"}),(0,t.jsx)(d.td,{children:"304M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"bridge-hub-kusama"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"5060801"}),(0,t.jsx)(d.td,{children:"141G"}),(0,t.jsx)(d.td,{children:"397M"})]}),(0,t.jsxs)(d.tr,{children:[(0,t.jsx)(d.td,{children:"asset-hub-paseo"}),(0,t.jsx)(d.td,{children:"paritydb"}),(0,t.jsx)(d.td,{children:"archive"}),(0,t.jsx)(d.td,{children:"1248932"}),(0,t.jsx)(d.td,{children:"32G"}),(0,t.jsx)(d.td,{children:"187M"})]})]})]}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"snapsize",src:g(7766).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"dbdiffarchive",src:g(4153).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"prunedsize",src:g(6780).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"dbdiffpruned",src:g(4868).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"commonsize",src:g(5419).A+"",width:"800",height:"300"})}),"\n",(0,t.jsx)(d.p,{children:(0,t.jsx)(d.img,{alt:"dbdiffcommon",src:g(2323).A+"",width:"800",height:"300"})})]})}function B(A={}){const{wrapper:d}={...(0,I.R)(),...A.components};return d?(0,t.jsx)(d,{...A,children:(0,t.jsx)(u,{...A})}):u(A)}},7766:(A,d,g)=>{g.d(d,{A:()=>i});const i=""},5419:(A,d,g)=>{g.d(d,{A:()=>i});const i=""},2323:(A,d,g)=>{g.d(d,{A:()=>i});const i=""},4868:(A,d,g)=>{g.d(d,{A:()=>i});const i=""},4153:(A,d,g)=>{g.d(d,{A:()=>i});const i=""},6780:(A,d,g)=>{g.d(d,{A:()=>i});const i=""},8453:(A,d,g)=>{g.d(d,{R:()=>s,x:()=>e});var i=g(6540);const t={},I=i.createContext(t);function s(A){const d=i.useContext(I);return i.useMemo((function(){return"function"==typeof A?A(d):{...d,...A}}),[d,A])}function e(A){let d;return d=A.disableParentContext?"function"==typeof A.components?A.components(t):A.components||t:s(A.components),i.createElement(I.Provider,{value:d},A.children)}}}]); \ No newline at end of file diff --git a/assets/js/fd15b893.30a8f4b4.js b/assets/js/fd15b893.c73c36f7.js similarity index 69% rename from assets/js/fd15b893.30a8f4b4.js rename to assets/js/fd15b893.c73c36f7.js index a9ea1122..2fc7e671 100644 --- a/assets/js/fd15b893.30a8f4b4.js +++ b/assets/js/fd15b893.c73c36f7.js @@ -1 +1 @@ -"use strict";(self.webpackChunkstakeworld_io=self.webpackChunkstakeworld_io||[]).push([[609],{9184:(e,s,n)=>{n.r(s),n.d(s,{assets:()=>a,contentTitle:()=>d,default:()=>h,frontMatter:()=>o,metadata:()=>t,toc:()=>c});const t=JSON.parse('{"id":"rpc","title":"RPC server","description":"Setting up a secure RPC server","source":"@site/docs/rpc.mdx","sourceDirName":".","slug":"/rpc","permalink":"/docs/rpc","draft":false,"unlisted":false,"editUrl":"https://github.com/stakeworld/website/edit/master/docs/rpc.mdx","tags":[],"version":"current","sidebarPosition":4,"frontMatter":{"id":"rpc","title":"RPC server","description":"Setting up a secure RPC server","slug":"/rpc","sidebar_position":4,"keywords":["rpc","rpc server","wss","ws","polkadot.js","validator","polkadot","kusama","westend"]},"sidebar":"tutorialSidebar","previous":{"title":"Database sizes","permalink":"/docs/dbsize"},"next":{"title":"Linux tips","permalink":"/docs/tools"}}');var r=n(4848),i=n(8453);const o={id:"rpc",title:"RPC server",description:"Setting up a secure RPC server",slug:"/rpc",sidebar_position:4,keywords:["rpc","rpc server","wss","ws","polkadot.js","validator","polkadot","kusama","westend"]},d=void 0,a={},c=[{value:"Stakeworld RPC data",id:"stakeworld-rpc-data",level:2},{value:"Setting up your own secure RPC server",id:"setting-up-your-own-secure-rpc-server",level:2},{value:"Archive node vs pruned node",id:"archive-node-vs-pruned-node",level:3},{value:"Secure the RPC server",id:"secure-the-rpc-server",level:3},{value:"Secure the ws port",id:"secure-the-ws-port",level:3},{value:"Using Apache2 for proxying",id:"using-apache2-for-proxying",level:3},{value:"Enabling ssl through letsencrypt",id:"enabling-ssl-through-letsencrypt",level:4},{value:"Add the proxy to the apache2 config",id:"add-the-proxy-to-the-apache2-config",level:4},{value:"Tweaking connections",id:"tweaking-connections",level:4},{value:"Rate limiting",id:"rate-limiting",level:4},{value:"Load balancing & failover",id:"load-balancing--failover",level:3},{value:"Stress testing",id:"stress-testing",level:3}];function l(e){const s={a:"a",admonition:"admonition",code:"code",em:"em",h2:"h2",h3:"h3",h4:"h4",img:"img",li:"li",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,i.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)(s.admonition,{type:"info",children:[(0,r.jsx)(s.p,{children:"RPC servers allow access into the polkadot/kusama and parachains ecosystem. Stakeworld runs multiple public archive RPC servers:"}),(0,r.jsxs)(s.ul,{children:["\n",(0,r.jsxs)(s.li,{children:["Polkadot: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://dot-rpc.stakeworld.io",children:"dot-rpc.stakeworld.io"}),"\n",(0,r.jsxs)(s.ul,{children:["\n",(0,r.jsxs)(s.li,{children:["AssetHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://dot-rpc.stakeworld.io/assethub",children:"dot-rpc.stakeworld.io/assethub"})]}),"\n",(0,r.jsxs)(s.li,{children:["BridgeHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://dot-rpc.stakeworld.io/bridgehub",children:"dot-rpc.stakeworld.io/bridgehub"})]}),"\n",(0,r.jsxs)(s.li,{children:["Collectives: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://dot-rpc.stakeworld.io/collectives",children:"dot-rpc.stakeworld.io/collectives"})]}),"\n"]}),"\n"]}),"\n",(0,r.jsxs)(s.li,{children:["Kusama: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://ksm-rpc.stakeworld.io",children:"ksm-rpc.stakeworld.io"}),"\n",(0,r.jsxs)(s.ul,{children:["\n",(0,r.jsxs)(s.li,{children:["AssetHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://ksm-rpc.stakeworld.io/assethub",children:"ksm-rpc.stakeworld.io/assethub"})]}),"\n",(0,r.jsxs)(s.li,{children:["BridgeHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://ksm-rpc.stakeworld.io/bridgehub",children:"ksm-rpc.stakeworld.io/bridgehub"})]}),"\n",(0,r.jsxs)(s.li,{children:["Encointer: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://ksm-rpc.stakeworld.io/encointer",children:"ksm-rpc.stakeworld.io/encointer"})]}),"\n"]}),"\n"]}),"\n",(0,r.jsxs)(s.li,{children:["Paseo: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://pas-rpc.stakeworld.io",children:"pas-rpc.stakeworld.io"}),"\n",(0,r.jsxs)(s.ul,{children:["\n",(0,r.jsxs)(s.li,{children:["AssetHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://pas-rpc.stakeworld.io/assethub",children:"pas-rpc.stakeworld.io/assethub"})]}),"\n"]}),"\n"]}),"\n"]})]}),"\n",(0,r.jsx)(s.h2,{id:"stakeworld-rpc-data",children:"Stakeworld RPC data"}),"\n",(0,r.jsx)(s.p,{children:"Last update: Sat 04 Jan"}),"\n",(0,r.jsx)(s.p,{children:"Requests in millions:"}),"\n",(0,r.jsxs)(s.table,{children:[(0,r.jsx)(s.thead,{children:(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.th,{children:"Chain"}),(0,r.jsx)(s.th,{children:"Requests in millions (6 months)"}),(0,r.jsx)(s.th,{children:"Requests in millions (per month)"}),(0,r.jsx)(s.th,{children:"Requests in millions (per day)"})]})}),(0,r.jsxs)(s.tbody,{children:[(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"ksmcc3"}),(0,r.jsx)(s.td,{children:"6306"}),(0,r.jsx)(s.td,{children:"1051"}),(0,r.jsx)(s.td,{children:"35"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"asset-hub-kusama"}),(0,r.jsx)(s.td,{children:"86"}),(0,r.jsx)(s.td,{children:"14"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"bridge-hub-kusama"}),(0,r.jsx)(s.td,{children:"26"}),(0,r.jsx)(s.td,{children:"4"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"coretime-kusama"}),(0,r.jsx)(s.td,{children:"11"}),(0,r.jsx)(s.td,{children:"2"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"encointer-kusama"}),(0,r.jsx)(s.td,{children:"29"}),(0,r.jsx)(s.td,{children:"5"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"people-kusama"}),(0,r.jsx)(s.td,{children:"321"}),(0,r.jsx)(s.td,{children:"54"}),(0,r.jsx)(s.td,{children:"2"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"polkadot"}),(0,r.jsx)(s.td,{children:"5192"}),(0,r.jsx)(s.td,{children:"865"}),(0,r.jsx)(s.td,{children:"29"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"asset-hub-polkadot"}),(0,r.jsx)(s.td,{children:"6628"}),(0,r.jsx)(s.td,{children:"1105"}),(0,r.jsx)(s.td,{children:"36"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"bridge-hub-polkadot"}),(0,r.jsx)(s.td,{children:"44"}),(0,r.jsx)(s.td,{children:"7"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"collectives_polkadot"}),(0,r.jsx)(s.td,{children:"2"}),(0,r.jsx)(s.td,{children:"0"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"coretime-polkadot"}),(0,r.jsx)(s.td,{children:"N/A"}),(0,r.jsx)(s.td,{children:"N/A"}),(0,r.jsx)(s.td,{children:"N/A"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"people-polkadot"}),(0,r.jsx)(s.td,{children:"N/A"}),(0,r.jsx)(s.td,{children:"N/A"}),(0,r.jsx)(s.td,{children:"N/A"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"paseo"}),(0,r.jsx)(s.td,{children:"76"}),(0,r.jsx)(s.td,{children:"13"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"asset-hub-paseo"}),(0,r.jsx)(s.td,{children:"9"}),(0,r.jsx)(s.td,{children:"2"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"westend2"}),(0,r.jsx)(s.td,{children:"49"}),(0,r.jsx)(s.td,{children:"8"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"asset-hub-westend"}),(0,r.jsx)(s.td,{children:"33"}),(0,r.jsx)(s.td,{children:"5"}),(0,r.jsx)(s.td,{children:"0"})]})]})]}),"\n",(0,r.jsx)(s.h2,{id:"setting-up-your-own-secure-rpc-server",children:"Setting up your own secure RPC server"}),"\n",(0,r.jsxs)(s.p,{children:["To access the polkadot, kusama and parachains networks we need some kind of access into the network. This can be achieved by ",(0,r.jsx)(s.a,{href:"./validate",children:"setting up a node"})," with a RPC server and allowing access to that RPC server via a secure websocket (wss) port. The default node setup already exposes a non secure ws socket on port 9944 (which can optionally be changed by the ",(0,r.jsx)(s.code,{children:"--ws-port"})," parameter), but for a more usable situation we need a secure websocket which is accesible through a public port."]}),"\n",(0,r.jsx)(s.h3,{id:"archive-node-vs-pruned-node",children:"Archive node vs pruned node"}),"\n",(0,r.jsx)(s.p,{children:"A pruned node knows only the recent information about the network and not its full history. Most frequently done actions can be done with a pruned node, for example see account balances, make transfers, setup session keys, staking, etc. An archive node has the full history (database) of the network and can be queried in all kind of ways, give information about transfers since the network started, historical balances, advanced queries about past events, etc."}),"\n",(0,r.jsxs)(s.p,{children:["An archive node requires a lot more ",(0,r.jsx)(s.a,{href:"./snapshot",children:"diskspace"}),". For an archive node you need the options ",(0,r.jsx)(s.code,{children:"--state-pruning archive --blocks-pruning archive"})," in your startup settings.\n",(0,r.jsx)(s.img,{alt:"snapsize",src:n(3996).A+"",width:"800",height:"300"})]}),"\n",(0,r.jsx)(s.admonition,{type:"tip",children:(0,r.jsx)(s.p,{children:"Inclusion in the Polkadot.js UI requires an archive node."})}),"\n",(0,r.jsx)(s.h3,{id:"secure-the-rpc-server",children:"Secure the RPC server"}),"\n",(0,r.jsxs)(s.p,{children:["Via the node startup settings you can choose ",(0,r.jsx)(s.strong,{children:"what"})," to expose with ",(0,r.jsx)(s.strong,{children:"how many"})," connections ",(0,r.jsx)(s.strong,{children:"from where"})," through your rpc server."]}),"\n",(0,r.jsxs)(s.p,{children:[(0,r.jsx)(s.em,{children:"How many"}),": You can set your maximum connections through ",(0,r.jsx)(s.code,{children:"--ws-max-connections"}),", for example ",(0,r.jsx)(s.code,{children:"--ws-max-connections 100"})]}),"\n",(0,r.jsxs)(s.p,{children:[(0,r.jsx)(s.em,{children:"From where"}),": by default localhost and the polkadot.js are allowed to access the RPC server, you can change this by setting ",(0,r.jsx)(s.code,{children:"--rpc-cors"}),", to allow access from everywhere you need ",(0,r.jsx)(s.code,{children:"--rpc-cors all"})]}),"\n",(0,r.jsxs)(s.p,{children:[(0,r.jsx)(s.em,{children:"What"}),": you can limit the methods to use with ",(0,r.jsx)(s.code,{children:"--rpc-methods"}),", an easy way to set this to a safe mode is ",(0,r.jsx)(s.code,{children:"--rpc-methods Safe"})]}),"\n",(0,r.jsx)(s.h3,{id:"secure-the-ws-port",children:"Secure the ws port"}),"\n",(0,r.jsxs)(s.p,{children:['The ws port is preferably exposed from the outside as a ssl secured wss port. The "',(0,r.jsx)(s.a,{href:"https://wiki.polkadot.network/docs/maintain-wss",children:"maintain wss"}),"\" on the wiki already covers a lot of information about this, especially in relation to setting it up in a nginx configuration. This page is focussed more on a apache2 but principles are the same. The main idea is converting the non secure ws port to a secure wss port by putting it behind a ssl enabled proxy. So from outside one see's the ssl enabled apache2/nginx/other proxy server, witch redirect the request to the internal rpc node."]}),"\n",(0,r.jsx)(s.h3,{id:"using-apache2-for-proxying",children:"Using Apache2 for proxying"}),"\n",(0,r.jsxs)(s.p,{children:["Apache2 is a little heavier then nginx but also has some more tweaking posibilities. You can run it in different modes, prefork, worker or event. We chose ",(0,r.jsx)(s.a,{href:"https://httpd.apache.org/docs/2.4/mod/event.html",children:"event"})," since this seems best suited for high load enviroments. Downside is that you can't use the default php module and need to enable it via php-fm. The proxy_wstunnel module works out of the box."]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-bash",children:"apt install apache2\na2dismod mpm_prefork\na2enmod mpm_event proxy proxy_html proxy_http proxy_wstunnel rewrite ssl\n"})}),"\n",(0,r.jsx)(s.p,{children:"If you want to enable php"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{children:"apt install php-fpm\na2enmod proxy_fcgi setenvif\n"})}),"\n",(0,r.jsx)(s.h4,{id:"enabling-ssl-through-letsencrypt",children:"Enabling ssl through letsencrypt"}),"\n",(0,r.jsxs)(s.p,{children:["There are multiple options for getting a ssl certificate, one popular (and free) being letsencrypt. Obtaining a letsencrypt certificate can be done through for example ",(0,r.jsx)(s.a,{href:"https://certbot.eff.org/",children:"certbot"})," or ",(0,r.jsx)(s.a,{href:"https://go-acme.github.io/lego/dns/",children:"lego"})," (which has more dns provider options)."]}),"\n",(0,r.jsx)(s.h4,{id:"add-the-proxy-to-the-apache2-config",children:"Add the proxy to the apache2 config"}),"\n",(0,r.jsxs)(s.p,{children:["The ",(0,r.jsx)(s.a,{href:"https://httpd.apache.org/docs/2.4/mod/mod_proxy_wstunnel.html",children:"mod_proxy_wstunnel"})," provides ",(0,r.jsx)(s.em,{children:"support for the tunnelling of web socket connections to a backend websockets server. The connection is automatically upgraded to a websocket connection"}),". In a ssl enabled virtualhost add:"]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-apacheconf",children:"SSLProxyEngine on\nProxyRequests off\n\nProxyPass / ws://localhost:9944\nProxyPassReverse / ws://localhost:9944\n"})}),"\n",(0,r.jsx)(s.p,{children:"Older versions of mod_proxy_wstunnel do not upgrade the connection automatically and will need the following config added:"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-apacheconf",children:"RewriteEngine on\nRewriteCond %{HTTP:Upgrade} websocket [NC]\nRewriteRule /(.*) ws://localhost:9944/$1 [P,L]\nRewriteRule /(.*) http://localhost:9944/$1 [P,L]\n"})}),"\n",(0,r.jsx)(s.h4,{id:"tweaking-connections",children:"Tweaking connections"}),"\n",(0,r.jsxs)(s.p,{children:["The number of connections is limited by the node itself (",(0,r.jsx)(s.code,{children:"--ws-max-connections"}),") but also by the number of threads available on the proxy server. For apache2 this can be tweaked by editing ",(0,r.jsx)(s.code,{children:"/etc/apache2/mods-enabled/mpm_event.conf"})]}),"\n",(0,r.jsx)(s.p,{children:"We are using:"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-apacheconf",children:"StartServers\t\t 4\nMinSpareThreads\t\t 25\nMaxSpareThreads\t\t 75\nThreadLimit\t\t 128\nThreadsPerChild\t\t 128\nMaxRequestWorkers \t 896\nMaxConnectionsPerChild 0\n"})}),"\n",(0,r.jsx)(s.h4,{id:"rate-limiting",children:"Rate limiting"}),"\n",(0,r.jsx)(s.p,{children:"Theoretically one client could use all connections/resources, draining the resources of the server and making it inaccessible. This can be countered by rate limiting the connections, for example by using mod_qos:"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-bash",children:"apt install libapache2-mod-qos\na2enmod qos\n"})}),"\n",(0,r.jsxs)(s.p,{children:["And edit ",(0,r.jsx)(s.code,{children:"/etc/apache2/mods-available/qos.conf"})]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{children:" # allows max 50 connections from a single ip address:\n QS_SrvMaxConnPerIP 50\n"})}),"\n",(0,r.jsx)(s.p,{children:"Be carefull when running behind a load balancer (for example cloudflare) because the load balancer will only use a few ip's and thus can trigger the rate limit, iso in this case it is better to use the rate limit options from the load balancer itself."}),"\n",(0,r.jsx)(s.h3,{id:"load-balancing--failover",children:"Load balancing & failover"}),"\n",(0,r.jsxs)(s.p,{children:["With multiple servers it is possible to build a load balancing or even a failover construction. A simple load balancing can be a ",(0,r.jsx)(s.a,{href:"https://en.wikipedia.org/wiki/Round-robin_DNS",children:"round robin-robin dns"})," up to a more advanced (dedicated) load balancer or a content delivery network (CDN) like cloudflare."]}),"\n",(0,r.jsx)(s.h3,{id:"stress-testing",children:"Stress testing"}),"\n",(0,r.jsx)(s.p,{children:"You can test basic usage by accessing your server through the polkadot.js UI as a custom endpoint. For example staking target display is RPC intensive and can give you an indication of performance."}),"\n",(0,r.jsxs)(s.p,{children:["There are also more dedicated stress testing solutions, we have forked the ",(0,r.jsx)(s.a,{href:"https://github.com/dwellir-public/artillery-engine-substrate",children:"Dwellir repository"})," for our testing."]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-bash",children:"wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.1/install.sh | bash\nnvm install --lts\nnpm install -g yarn\nyarn global add artillery\nyarn global add artillery-engine-substrate\ncd /opt\ngit clone git@github.com:stakeworld/stakeworld-rpc-artillery.git\ncd /opt/stakeworld-rpc-artillery\nyarn\n./run.sh\n"})}),"\n",(0,r.jsxs)(s.p,{children:["After the ",(0,r.jsx)(s.code,{children:"run.sh"})," you can edit some variables like how many connections per second, the wss node, etc. The following is a test run for 10 seconds with 10 connections per second and maximum 20 concurrent users."]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{children:'config:\n target: "wss://ksm-rpc.stakeworld.io"\n processor: "./functions.js"\n phases:\n - duration: 10\n arrivalRate: 10\n maxVusers: 20\n'})}),"\n",(0,r.jsx)(s.p,{children:"After this you get some info about the run and a report is created, which can be used for further diagnostics"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{children:"--------------------------------\nSummary report @ 23:38:40(+0100)\n--------------------------------\n\nvusers.completed: .............................................................. 100\nvusers.created: ................................................................ 100\nvusers.created_by_name.balance: ................................................ 35\nvusers.created_by_name.complex_call: ........................................... 33\nvusers.created_by_name.headers_blocks: ......................................... 32\nvusers.failed: ................................................................. 0\nvusers.session_length:\n min: ......................................................................... 231.7\n max: ......................................................................... 656.1\n median: ...................................................................... 361.5\n p95: ......................................................................... 518.1\n p99: ......................................................................... 645.6\nws.messages_sent: .............................................................. 163\nws.send_rate: .................................................................. 29/sec\nLog file: reports/report.json\nReport generated: reports/report.html\n"})})]})}function h(e={}){const{wrapper:s}={...(0,i.R)(),...e.components};return s?(0,r.jsx)(s,{...e,children:(0,r.jsx)(l,{...e})}):l(e)}},3996:(e,s,n)=>{n.d(s,{A:()=>t});const t=""},8453:(e,s,n)=>{n.d(s,{R:()=>o,x:()=>d});var t=n(6540);const r={},i=t.createContext(r);function o(e){const s=t.useContext(i);return t.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function d(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),t.createElement(i.Provider,{value:s},e.children)}}}]); \ No newline at end of file +"use strict";(self.webpackChunkstakeworld_io=self.webpackChunkstakeworld_io||[]).push([[609],{9184:(e,s,n)=>{n.r(s),n.d(s,{assets:()=>a,contentTitle:()=>d,default:()=>h,frontMatter:()=>o,metadata:()=>t,toc:()=>c});const t=JSON.parse('{"id":"rpc","title":"RPC server","description":"Setting up a secure RPC server","source":"@site/docs/rpc.mdx","sourceDirName":".","slug":"/rpc","permalink":"/docs/rpc","draft":false,"unlisted":false,"editUrl":"https://github.com/stakeworld/website/edit/master/docs/rpc.mdx","tags":[],"version":"current","sidebarPosition":4,"frontMatter":{"id":"rpc","title":"RPC server","description":"Setting up a secure RPC server","slug":"/rpc","sidebar_position":4,"keywords":["rpc","rpc server","wss","ws","polkadot.js","validator","polkadot","kusama","westend"]},"sidebar":"tutorialSidebar","previous":{"title":"Database sizes","permalink":"/docs/dbsize"},"next":{"title":"Linux tips","permalink":"/docs/tools"}}');var r=n(4848),i=n(8453);const o={id:"rpc",title:"RPC server",description:"Setting up a secure RPC server",slug:"/rpc",sidebar_position:4,keywords:["rpc","rpc server","wss","ws","polkadot.js","validator","polkadot","kusama","westend"]},d=void 0,a={},c=[{value:"Stakeworld RPC data",id:"stakeworld-rpc-data",level:2},{value:"Setting up your own secure RPC server",id:"setting-up-your-own-secure-rpc-server",level:2},{value:"Archive node vs pruned node",id:"archive-node-vs-pruned-node",level:3},{value:"Secure the RPC server",id:"secure-the-rpc-server",level:3},{value:"Secure the ws port",id:"secure-the-ws-port",level:3},{value:"Using Apache2 for proxying",id:"using-apache2-for-proxying",level:3},{value:"Enabling ssl through letsencrypt",id:"enabling-ssl-through-letsencrypt",level:4},{value:"Add the proxy to the apache2 config",id:"add-the-proxy-to-the-apache2-config",level:4},{value:"Tweaking connections",id:"tweaking-connections",level:4},{value:"Rate limiting",id:"rate-limiting",level:4},{value:"Load balancing & failover",id:"load-balancing--failover",level:3},{value:"Stress testing",id:"stress-testing",level:3}];function l(e){const s={a:"a",admonition:"admonition",code:"code",em:"em",h2:"h2",h3:"h3",h4:"h4",img:"img",li:"li",p:"p",pre:"pre",strong:"strong",table:"table",tbody:"tbody",td:"td",th:"th",thead:"thead",tr:"tr",ul:"ul",...(0,i.R)(),...e.components};return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)(s.admonition,{type:"info",children:[(0,r.jsx)(s.p,{children:"RPC servers allow access into the polkadot/kusama and parachains ecosystem. Stakeworld runs multiple public archive RPC servers:"}),(0,r.jsxs)(s.ul,{children:["\n",(0,r.jsxs)(s.li,{children:["Polkadot: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://dot-rpc.stakeworld.io",children:"dot-rpc.stakeworld.io"}),"\n",(0,r.jsxs)(s.ul,{children:["\n",(0,r.jsxs)(s.li,{children:["AssetHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://dot-rpc.stakeworld.io/assethub",children:"dot-rpc.stakeworld.io/assethub"})]}),"\n",(0,r.jsxs)(s.li,{children:["BridgeHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://dot-rpc.stakeworld.io/bridgehub",children:"dot-rpc.stakeworld.io/bridgehub"})]}),"\n",(0,r.jsxs)(s.li,{children:["Collectives: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://dot-rpc.stakeworld.io/collectives",children:"dot-rpc.stakeworld.io/collectives"})]}),"\n"]}),"\n"]}),"\n",(0,r.jsxs)(s.li,{children:["Kusama: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://ksm-rpc.stakeworld.io",children:"ksm-rpc.stakeworld.io"}),"\n",(0,r.jsxs)(s.ul,{children:["\n",(0,r.jsxs)(s.li,{children:["AssetHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://ksm-rpc.stakeworld.io/assethub",children:"ksm-rpc.stakeworld.io/assethub"})]}),"\n",(0,r.jsxs)(s.li,{children:["BridgeHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://ksm-rpc.stakeworld.io/bridgehub",children:"ksm-rpc.stakeworld.io/bridgehub"})]}),"\n",(0,r.jsxs)(s.li,{children:["Encointer: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://ksm-rpc.stakeworld.io/encointer",children:"ksm-rpc.stakeworld.io/encointer"})]}),"\n"]}),"\n"]}),"\n",(0,r.jsxs)(s.li,{children:["Paseo: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://pas-rpc.stakeworld.io",children:"pas-rpc.stakeworld.io"}),"\n",(0,r.jsxs)(s.ul,{children:["\n",(0,r.jsxs)(s.li,{children:["AssetHub: ",(0,r.jsx)(s.a,{href:"https://polkadot.js.org/apps/?rpc=wss://pas-rpc.stakeworld.io/assethub",children:"pas-rpc.stakeworld.io/assethub"})]}),"\n"]}),"\n"]}),"\n"]})]}),"\n",(0,r.jsx)(s.h2,{id:"stakeworld-rpc-data",children:"Stakeworld RPC data"}),"\n",(0,r.jsx)(s.p,{children:"Last update: Sat 04 Jan"}),"\n",(0,r.jsx)(s.p,{children:"Requests in millions:"}),"\n",(0,r.jsxs)(s.table,{children:[(0,r.jsx)(s.thead,{children:(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.th,{children:"Chain"}),(0,r.jsx)(s.th,{children:"Requests in millions (6 months)"}),(0,r.jsx)(s.th,{children:"Requests in millions (per month)"}),(0,r.jsx)(s.th,{children:"Requests in millions (per day)"})]})}),(0,r.jsxs)(s.tbody,{children:[(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"ksmcc3"}),(0,r.jsx)(s.td,{children:"6306"}),(0,r.jsx)(s.td,{children:"1051"}),(0,r.jsx)(s.td,{children:"35"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"asset-hub-kusama"}),(0,r.jsx)(s.td,{children:"86"}),(0,r.jsx)(s.td,{children:"14"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"bridge-hub-kusama"}),(0,r.jsx)(s.td,{children:"26"}),(0,r.jsx)(s.td,{children:"4"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"coretime-kusama"}),(0,r.jsx)(s.td,{children:"11"}),(0,r.jsx)(s.td,{children:"2"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"encointer-kusama"}),(0,r.jsx)(s.td,{children:"29"}),(0,r.jsx)(s.td,{children:"5"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"people-kusama"}),(0,r.jsx)(s.td,{children:"321"}),(0,r.jsx)(s.td,{children:"54"}),(0,r.jsx)(s.td,{children:"2"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"polkadot"}),(0,r.jsx)(s.td,{children:"5192"}),(0,r.jsx)(s.td,{children:"865"}),(0,r.jsx)(s.td,{children:"29"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"asset-hub-polkadot"}),(0,r.jsx)(s.td,{children:"6628"}),(0,r.jsx)(s.td,{children:"1105"}),(0,r.jsx)(s.td,{children:"36"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"bridge-hub-polkadot"}),(0,r.jsx)(s.td,{children:"44"}),(0,r.jsx)(s.td,{children:"7"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"collectives_polkadot"}),(0,r.jsx)(s.td,{children:"2"}),(0,r.jsx)(s.td,{children:"0"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"coretime-polkadot"}),(0,r.jsx)(s.td,{children:"N/A"}),(0,r.jsx)(s.td,{children:"N/A"}),(0,r.jsx)(s.td,{children:"N/A"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"people-polkadot"}),(0,r.jsx)(s.td,{children:"N/A"}),(0,r.jsx)(s.td,{children:"N/A"}),(0,r.jsx)(s.td,{children:"N/A"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"paseo"}),(0,r.jsx)(s.td,{children:"76"}),(0,r.jsx)(s.td,{children:"13"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"asset-hub-paseo"}),(0,r.jsx)(s.td,{children:"9"}),(0,r.jsx)(s.td,{children:"2"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"westend2"}),(0,r.jsx)(s.td,{children:"49"}),(0,r.jsx)(s.td,{children:"8"}),(0,r.jsx)(s.td,{children:"0"})]}),(0,r.jsxs)(s.tr,{children:[(0,r.jsx)(s.td,{children:"asset-hub-westend"}),(0,r.jsx)(s.td,{children:"33"}),(0,r.jsx)(s.td,{children:"5"}),(0,r.jsx)(s.td,{children:"0"})]})]})]}),"\n",(0,r.jsx)(s.h2,{id:"setting-up-your-own-secure-rpc-server",children:"Setting up your own secure RPC server"}),"\n",(0,r.jsxs)(s.p,{children:["To access the polkadot, kusama and parachains networks we need some kind of access into the network. This can be achieved by ",(0,r.jsx)(s.a,{href:"./validate",children:"setting up a node"})," with a RPC server and allowing access to that RPC server via a secure websocket (wss) port. The default node setup already exposes a non secure ws socket on port 9944 (which can optionally be changed by the ",(0,r.jsx)(s.code,{children:"--ws-port"})," parameter), but for a more usable situation we need a secure websocket which is accesible through a public port."]}),"\n",(0,r.jsx)(s.h3,{id:"archive-node-vs-pruned-node",children:"Archive node vs pruned node"}),"\n",(0,r.jsx)(s.p,{children:"A pruned node knows only the recent information about the network and not its full history. Most frequently done actions can be done with a pruned node, for example see account balances, make transfers, setup session keys, staking, etc. An archive node has the full history (database) of the network and can be queried in all kind of ways, give information about transfers since the network started, historical balances, advanced queries about past events, etc."}),"\n",(0,r.jsxs)(s.p,{children:["An archive node requires a lot more ",(0,r.jsx)(s.a,{href:"./snapshot",children:"diskspace"}),". For an archive node you need the options ",(0,r.jsx)(s.code,{children:"--state-pruning archive --blocks-pruning archive"})," in your startup settings.\n",(0,r.jsx)(s.img,{alt:"snapsize",src:n(3996).A+"",width:"800",height:"300"})]}),"\n",(0,r.jsx)(s.admonition,{type:"tip",children:(0,r.jsx)(s.p,{children:"Inclusion in the Polkadot.js UI requires an archive node."})}),"\n",(0,r.jsx)(s.h3,{id:"secure-the-rpc-server",children:"Secure the RPC server"}),"\n",(0,r.jsxs)(s.p,{children:["Via the node startup settings you can choose ",(0,r.jsx)(s.strong,{children:"what"})," to expose with ",(0,r.jsx)(s.strong,{children:"how many"})," connections ",(0,r.jsx)(s.strong,{children:"from where"})," through your rpc server."]}),"\n",(0,r.jsxs)(s.p,{children:[(0,r.jsx)(s.em,{children:"How many"}),": You can set your maximum connections through ",(0,r.jsx)(s.code,{children:"--ws-max-connections"}),", for example ",(0,r.jsx)(s.code,{children:"--ws-max-connections 100"})]}),"\n",(0,r.jsxs)(s.p,{children:[(0,r.jsx)(s.em,{children:"From where"}),": by default localhost and the polkadot.js are allowed to access the RPC server, you can change this by setting ",(0,r.jsx)(s.code,{children:"--rpc-cors"}),", to allow access from everywhere you need ",(0,r.jsx)(s.code,{children:"--rpc-cors all"})]}),"\n",(0,r.jsxs)(s.p,{children:[(0,r.jsx)(s.em,{children:"What"}),": you can limit the methods to use with ",(0,r.jsx)(s.code,{children:"--rpc-methods"}),", an easy way to set this to a safe mode is ",(0,r.jsx)(s.code,{children:"--rpc-methods Safe"})]}),"\n",(0,r.jsx)(s.h3,{id:"secure-the-ws-port",children:"Secure the ws port"}),"\n",(0,r.jsxs)(s.p,{children:['The ws port is preferably exposed from the outside as a ssl secured wss port. The "',(0,r.jsx)(s.a,{href:"https://wiki.polkadot.network/docs/maintain-wss",children:"maintain wss"}),"\" on the wiki already covers a lot of information about this, especially in relation to setting it up in a nginx configuration. This page is focussed more on a apache2 but principles are the same. The main idea is converting the non secure ws port to a secure wss port by putting it behind a ssl enabled proxy. So from outside one see's the ssl enabled apache2/nginx/other proxy server, witch redirect the request to the internal rpc node."]}),"\n",(0,r.jsx)(s.h3,{id:"using-apache2-for-proxying",children:"Using Apache2 for proxying"}),"\n",(0,r.jsxs)(s.p,{children:["Apache2 is a little heavier then nginx but also has some more tweaking posibilities. You can run it in different modes, prefork, worker or event. We chose ",(0,r.jsx)(s.a,{href:"https://httpd.apache.org/docs/2.4/mod/event.html",children:"event"})," since this seems best suited for high load enviroments. Downside is that you can't use the default php module and need to enable it via php-fm. The proxy_wstunnel module works out of the box."]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-bash",children:"apt install apache2\na2dismod mpm_prefork\na2enmod mpm_event proxy proxy_html proxy_http proxy_wstunnel rewrite ssl\n"})}),"\n",(0,r.jsx)(s.p,{children:"If you want to enable php"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{children:"apt install php-fpm\na2enmod proxy_fcgi setenvif\n"})}),"\n",(0,r.jsx)(s.h4,{id:"enabling-ssl-through-letsencrypt",children:"Enabling ssl through letsencrypt"}),"\n",(0,r.jsxs)(s.p,{children:["There are multiple options for getting a ssl certificate, one popular (and free) being letsencrypt. Obtaining a letsencrypt certificate can be done through for example ",(0,r.jsx)(s.a,{href:"https://certbot.eff.org/",children:"certbot"})," or ",(0,r.jsx)(s.a,{href:"https://go-acme.github.io/lego/dns/",children:"lego"})," (which has more dns provider options)."]}),"\n",(0,r.jsx)(s.h4,{id:"add-the-proxy-to-the-apache2-config",children:"Add the proxy to the apache2 config"}),"\n",(0,r.jsxs)(s.p,{children:["The ",(0,r.jsx)(s.a,{href:"https://httpd.apache.org/docs/2.4/mod/mod_proxy_wstunnel.html",children:"mod_proxy_wstunnel"})," provides ",(0,r.jsx)(s.em,{children:"support for the tunnelling of web socket connections to a backend websockets server. The connection is automatically upgraded to a websocket connection"}),". In a ssl enabled virtualhost add:"]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-apacheconf",children:"SSLProxyEngine on\nProxyRequests off\n\nProxyPass / ws://localhost:9944\nProxyPassReverse / ws://localhost:9944\n"})}),"\n",(0,r.jsx)(s.p,{children:"Older versions of mod_proxy_wstunnel do not upgrade the connection automatically and will need the following config added:"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-apacheconf",children:"RewriteEngine on\nRewriteCond %{HTTP:Upgrade} websocket [NC]\nRewriteRule /(.*) ws://localhost:9944/$1 [P,L]\nRewriteRule /(.*) http://localhost:9944/$1 [P,L]\n"})}),"\n",(0,r.jsx)(s.h4,{id:"tweaking-connections",children:"Tweaking connections"}),"\n",(0,r.jsxs)(s.p,{children:["The number of connections is limited by the node itself (",(0,r.jsx)(s.code,{children:"--ws-max-connections"}),") but also by the number of threads available on the proxy server. For apache2 this can be tweaked by editing ",(0,r.jsx)(s.code,{children:"/etc/apache2/mods-enabled/mpm_event.conf"})]}),"\n",(0,r.jsx)(s.p,{children:"We are using:"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-apacheconf",children:"StartServers\t\t 4\nMinSpareThreads\t\t 25\nMaxSpareThreads\t\t 75\nThreadLimit\t\t 128\nThreadsPerChild\t\t 128\nMaxRequestWorkers \t 896\nMaxConnectionsPerChild 0\n"})}),"\n",(0,r.jsx)(s.h4,{id:"rate-limiting",children:"Rate limiting"}),"\n",(0,r.jsx)(s.p,{children:"Theoretically one client could use all connections/resources, draining the resources of the server and making it inaccessible. This can be countered by rate limiting the connections, for example by using mod_qos:"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-bash",children:"apt install libapache2-mod-qos\na2enmod qos\n"})}),"\n",(0,r.jsxs)(s.p,{children:["And edit ",(0,r.jsx)(s.code,{children:"/etc/apache2/mods-available/qos.conf"})]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{children:" # allows max 50 connections from a single ip address:\n QS_SrvMaxConnPerIP 50\n"})}),"\n",(0,r.jsx)(s.p,{children:"Be carefull when running behind a load balancer (for example cloudflare) because the load balancer will only use a few ip's and thus can trigger the rate limit, iso in this case it is better to use the rate limit options from the load balancer itself."}),"\n",(0,r.jsx)(s.h3,{id:"load-balancing--failover",children:"Load balancing & failover"}),"\n",(0,r.jsxs)(s.p,{children:["With multiple servers it is possible to build a load balancing or even a failover construction. A simple load balancing can be a ",(0,r.jsx)(s.a,{href:"https://en.wikipedia.org/wiki/Round-robin_DNS",children:"round robin-robin dns"})," up to a more advanced (dedicated) load balancer or a content delivery network (CDN) like cloudflare."]}),"\n",(0,r.jsx)(s.h3,{id:"stress-testing",children:"Stress testing"}),"\n",(0,r.jsx)(s.p,{children:"You can test basic usage by accessing your server through the polkadot.js UI as a custom endpoint. For example staking target display is RPC intensive and can give you an indication of performance."}),"\n",(0,r.jsxs)(s.p,{children:["There are also more dedicated stress testing solutions, we have forked the ",(0,r.jsx)(s.a,{href:"https://github.com/dwellir-public/artillery-engine-substrate",children:"Dwellir repository"})," for our testing."]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{className:"language-bash",children:"wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.1/install.sh | bash\nnvm install --lts\nnpm install -g yarn\nyarn global add artillery\nyarn global add artillery-engine-substrate\ncd /opt\ngit clone git@github.com:stakeworld/stakeworld-rpc-artillery.git\ncd /opt/stakeworld-rpc-artillery\nyarn\n./run.sh\n"})}),"\n",(0,r.jsxs)(s.p,{children:["After the ",(0,r.jsx)(s.code,{children:"run.sh"})," you can edit some variables like how many connections per second, the wss node, etc. The following is a test run for 10 seconds with 10 connections per second and maximum 20 concurrent users."]}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{children:'config:\n target: "wss://ksm-rpc.stakeworld.io"\n processor: "./functions.js"\n phases:\n - duration: 10\n arrivalRate: 10\n maxVusers: 20\n'})}),"\n",(0,r.jsx)(s.p,{children:"After this you get some info about the run and a report is created, which can be used for further diagnostics"}),"\n",(0,r.jsx)(s.pre,{children:(0,r.jsx)(s.code,{children:"--------------------------------\nSummary report @ 23:38:40(+0100)\n--------------------------------\n\nvusers.completed: .............................................................. 100\nvusers.created: ................................................................ 100\nvusers.created_by_name.balance: ................................................ 35\nvusers.created_by_name.complex_call: ........................................... 33\nvusers.created_by_name.headers_blocks: ......................................... 32\nvusers.failed: ................................................................. 0\nvusers.session_length:\n min: ......................................................................... 231.7\n max: ......................................................................... 656.1\n median: ...................................................................... 361.5\n p95: ......................................................................... 518.1\n p99: ......................................................................... 645.6\nws.messages_sent: .............................................................. 163\nws.send_rate: .................................................................. 29/sec\nLog file: reports/report.json\nReport generated: reports/report.html\n"})})]})}function h(e={}){const{wrapper:s}={...(0,i.R)(),...e.components};return s?(0,r.jsx)(s,{...e,children:(0,r.jsx)(l,{...e})}):l(e)}},3996:(e,s,n)=>{n.d(s,{A:()=>t});const t=""},8453:(e,s,n)=>{n.d(s,{R:()=>o,x:()=>d});var t=n(6540);const r={},i=t.createContext(r);function o(e){const s=t.useContext(i);return t.useMemo((function(){return"function"==typeof e?e(s):{...s,...e}}),[s,e])}function d(e){let s;return s=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),t.createElement(i.Provider,{value:s},e.children)}}}]); \ No newline at end of file diff --git a/assets/js/runtime~main.3a821ab4.js b/assets/js/runtime~main.570cb8c2.js similarity index 51% rename from assets/js/runtime~main.3a821ab4.js rename to assets/js/runtime~main.570cb8c2.js index 2481adc4..bb645b4d 100644 --- a/assets/js/runtime~main.3a821ab4.js +++ b/assets/js/runtime~main.570cb8c2.js @@ -1 +1 @@ -(()=>{"use strict";var e,t,r,a,o,d={},n={};function f(e){var t=n[e];if(void 0!==t)return t.exports;var r=n[e]={id:e,loaded:!1,exports:{}};return d[e].call(r.exports,r,r.exports,f),r.loaded=!0,r.exports}f.m=d,f.c=n,e=[],f.O=(t,r,a,o)=>{if(!r){var d=1/0;for(i=0;i=o)&&Object.keys(f.O).every((e=>f.O[e](r[c])))?r.splice(c--,1):(n=!1,o0&&e[i-1][2]>o;i--)e[i]=e[i-1];e[i]=[r,a,o]},f.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return f.d(t,{a:t}),t},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,f.t=function(e,a){if(1&a&&(e=this(e)),8&a)return e;if("object"==typeof e&&e){if(4&a&&e.__esModule)return e;if(16&a&&"function"==typeof e.then)return e}var o=Object.create(null);f.r(o);var d={};t=t||[null,r({}),r([]),r(r)];for(var n=2&a&&e;"object"==typeof n&&!~t.indexOf(n);n=r(n))Object.getOwnPropertyNames(n).forEach((t=>d[t]=()=>e[t]));return d.default=()=>e,f.d(o,d),o},f.d=(e,t)=>{for(var r in t)f.o(t,r)&&!f.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},f.f={},f.e=e=>Promise.all(Object.keys(f.f).reduce(((t,r)=>(f.f[r](e,t),t)),[])),f.u=e=>"assets/js/"+({48:"a94703ab",57:"b29f7657",98:"a7bd4aaa",158:"0e0b553a",197:"5505b55a",212:"621db11d",235:"a7456010",285:"beb33250",333:"6880cad0",401:"17896441",420:"e35d94cf",472:"814f3328",609:"fd15b893",634:"c4f5d8e4",647:"5e95c892",705:"1d027521",742:"aba21aa0",770:"3e44a806",779:"395bcc0c",822:"539febe6",849:"0058b4c6",858:"36994c47",868:"9fbdee33",903:"acecf23e",920:"8fb24621",947:"ef8b811a",969:"14eb3368"}[e]||e)+"."+{48:"d946bb33",57:"be47b69b",98:"3bfa816c",158:"bf422001",197:"ee7d9f4d",212:"76c08d0a",230:"e22088dd",235:"d426a33b",237:"eef87f82",285:"0c43b763",333:"8c5f9f1c",401:"b64292a7",420:"d7c6d7ed",472:"a53acd42",609:"30a8f4b4",634:"f3dbc83c",647:"2428b5a0",705:"3fd7a169",742:"588fe060",770:"365c92bc",779:"95f13929",822:"647b654d",849:"2836888f",858:"8545061d",868:"50598539",903:"5ab6e46f",920:"afe76c55",947:"2db6ffa3",969:"0672b723"}[e]+".js",f.miniCssF=e=>{},f.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),f.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},o="stakeworld-io:",f.l=(e,t,r,d)=>{if(a[e])a[e].push(t);else{var n,c;if(void 0!==r)for(var b=document.getElementsByTagName("script"),i=0;i{n.onerror=n.onload=null,clearTimeout(s);var o=a[e];if(delete a[e],n.parentNode&&n.parentNode.removeChild(n),o&&o.forEach((e=>e(r))),t)return t(r)},s=setTimeout(u.bind(null,void 0,{type:"timeout",target:n}),12e4);n.onerror=u.bind(null,n.onerror),n.onload=u.bind(null,n.onload),c&&document.head.appendChild(n)}},f.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},f.nmd=e=>(e.paths=[],e.children||(e.children=[]),e),f.p="/",f.gca=function(e){return e={17896441:"401",a94703ab:"48",b29f7657:"57",a7bd4aaa:"98","0e0b553a":"158","5505b55a":"197","621db11d":"212",a7456010:"235",beb33250:"285","6880cad0":"333",e35d94cf:"420","814f3328":"472",fd15b893:"609",c4f5d8e4:"634","5e95c892":"647","1d027521":"705",aba21aa0:"742","3e44a806":"770","395bcc0c":"779","539febe6":"822","0058b4c6":"849","36994c47":"858","9fbdee33":"868",acecf23e:"903","8fb24621":"920",ef8b811a:"947","14eb3368":"969"}[e]||e,f.p+f.u(e)},(()=>{var e={354:0,869:0};f.f.j=(t,r)=>{var a=f.o(e,t)?e[t]:void 0;if(0!==a)if(a)r.push(a[2]);else if(/^(354|869)$/.test(t))e[t]=0;else{var o=new Promise(((r,o)=>a=e[t]=[r,o]));r.push(a[2]=o);var d=f.p+f.u(t),n=new Error;f.l(d,(r=>{if(f.o(e,t)&&(0!==(a=e[t])&&(e[t]=void 0),a)){var o=r&&("load"===r.type?"missing":r.type),d=r&&r.target&&r.target.src;n.message="Loading chunk "+t+" failed.\n("+o+": "+d+")",n.name="ChunkLoadError",n.type=o,n.request=d,a[1](n)}}),"chunk-"+t,t)}},f.O.j=t=>0===e[t];var t=(t,r)=>{var a,o,d=r[0],n=r[1],c=r[2],b=0;if(d.some((t=>0!==e[t]))){for(a in n)f.o(n,a)&&(f.m[a]=n[a]);if(c)var i=c(f)}for(t&&t(r);b{"use strict";var e,t,r,a,o,d={},n={};function c(e){var t=n[e];if(void 0!==t)return t.exports;var r=n[e]={id:e,loaded:!1,exports:{}};return d[e].call(r.exports,r,r.exports,c),r.loaded=!0,r.exports}c.m=d,c.c=n,e=[],c.O=(t,r,a,o)=>{if(!r){var d=1/0;for(i=0;i=o)&&Object.keys(c.O).every((e=>c.O[e](r[f])))?r.splice(f--,1):(n=!1,o0&&e[i-1][2]>o;i--)e[i]=e[i-1];e[i]=[r,a,o]},c.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return c.d(t,{a:t}),t},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,c.t=function(e,a){if(1&a&&(e=this(e)),8&a)return e;if("object"==typeof e&&e){if(4&a&&e.__esModule)return e;if(16&a&&"function"==typeof e.then)return e}var o=Object.create(null);c.r(o);var d={};t=t||[null,r({}),r([]),r(r)];for(var n=2&a&&e;"object"==typeof n&&!~t.indexOf(n);n=r(n))Object.getOwnPropertyNames(n).forEach((t=>d[t]=()=>e[t]));return d.default=()=>e,c.d(o,d),o},c.d=(e,t)=>{for(var r in t)c.o(t,r)&&!c.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},c.f={},c.e=e=>Promise.all(Object.keys(c.f).reduce(((t,r)=>(c.f[r](e,t),t)),[])),c.u=e=>"assets/js/"+({48:"a94703ab",57:"b29f7657",98:"a7bd4aaa",158:"0e0b553a",197:"5505b55a",212:"621db11d",235:"a7456010",285:"beb33250",333:"6880cad0",401:"17896441",420:"e35d94cf",472:"814f3328",609:"fd15b893",634:"c4f5d8e4",647:"5e95c892",705:"1d027521",742:"aba21aa0",770:"3e44a806",779:"395bcc0c",822:"539febe6",849:"0058b4c6",858:"36994c47",868:"9fbdee33",903:"acecf23e",920:"8fb24621",947:"ef8b811a",969:"14eb3368"}[e]||e)+"."+{48:"d946bb33",57:"be47b69b",98:"3bfa816c",158:"29bb0ca8",197:"ee7d9f4d",212:"76c08d0a",230:"e22088dd",235:"d426a33b",237:"eef87f82",285:"0c43b763",333:"8c5f9f1c",401:"b64292a7",420:"d7c6d7ed",472:"a53acd42",609:"c73c36f7",634:"f3dbc83c",647:"2428b5a0",705:"3fd7a169",742:"588fe060",770:"365c92bc",779:"95f13929",822:"c3bdcd6e",849:"2836888f",858:"8545061d",868:"50598539",903:"5ab6e46f",920:"afe76c55",947:"2db6ffa3",969:"0672b723"}[e]+".js",c.miniCssF=e=>{},c.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),c.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),a={},o="stakeworld-io:",c.l=(e,t,r,d)=>{if(a[e])a[e].push(t);else{var n,f;if(void 0!==r)for(var b=document.getElementsByTagName("script"),i=0;i{n.onerror=n.onload=null,clearTimeout(s);var o=a[e];if(delete a[e],n.parentNode&&n.parentNode.removeChild(n),o&&o.forEach((e=>e(r))),t)return t(r)},s=setTimeout(u.bind(null,void 0,{type:"timeout",target:n}),12e4);n.onerror=u.bind(null,n.onerror),n.onload=u.bind(null,n.onload),f&&document.head.appendChild(n)}},c.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},c.nmd=e=>(e.paths=[],e.children||(e.children=[]),e),c.p="/",c.gca=function(e){return e={17896441:"401",a94703ab:"48",b29f7657:"57",a7bd4aaa:"98","0e0b553a":"158","5505b55a":"197","621db11d":"212",a7456010:"235",beb33250:"285","6880cad0":"333",e35d94cf:"420","814f3328":"472",fd15b893:"609",c4f5d8e4:"634","5e95c892":"647","1d027521":"705",aba21aa0:"742","3e44a806":"770","395bcc0c":"779","539febe6":"822","0058b4c6":"849","36994c47":"858","9fbdee33":"868",acecf23e:"903","8fb24621":"920",ef8b811a:"947","14eb3368":"969"}[e]||e,c.p+c.u(e)},(()=>{var e={354:0,869:0};c.f.j=(t,r)=>{var a=c.o(e,t)?e[t]:void 0;if(0!==a)if(a)r.push(a[2]);else if(/^(354|869)$/.test(t))e[t]=0;else{var o=new Promise(((r,o)=>a=e[t]=[r,o]));r.push(a[2]=o);var d=c.p+c.u(t),n=new Error;c.l(d,(r=>{if(c.o(e,t)&&(0!==(a=e[t])&&(e[t]=void 0),a)){var o=r&&("load"===r.type?"missing":r.type),d=r&&r.target&&r.target.src;n.message="Loading chunk "+t+" failed.\n("+o+": "+d+")",n.name="ChunkLoadError",n.type=o,n.request=d,a[1](n)}}),"chunk-"+t,t)}},c.O.j=t=>0===e[t];var t=(t,r)=>{var a,o,d=r[0],n=r[1],f=r[2],b=0;if(d.some((t=>0!==e[t]))){for(a in n)c.o(n,a)&&(c.m[a]=n[a]);if(f)var i=f(c)}for(t&&t(r);b Authors | Stakeworld.io - + diff --git a/docs/1kv.html b/docs/1kv.html index 62775fe6..c97c560e 100644 --- a/docs/1kv.html +++ b/docs/1kv.html @@ -4,7 +4,7 @@ 1000 validator resources | Stakeworld.io - + diff --git a/docs/category/validate.html b/docs/category/validate.html index 675c5cc2..8d1d5615 100644 --- a/docs/category/validate.html +++ b/docs/category/validate.html @@ -4,7 +4,7 @@ Validate | Stakeworld.io - + diff --git a/docs/chain.html b/docs/chain.html index f14ca2a6..648d9ebc 100644 --- a/docs/chain.html +++ b/docs/chain.html @@ -4,7 +4,7 @@ Chain info | Stakeworld.io - + diff --git a/docs/dbsize.html b/docs/dbsize.html index a7a2709b..42a838f9 100644 --- a/docs/dbsize.html +++ b/docs/dbsize.html @@ -4,17 +4,17 @@ Database sizes | Stakeworld.io - + -

Database sizes

Last update: Sun 02 Feb

-
ChainDatabaseFormatBlockheightFullDaily growth
people-kusamaparitydbarchive279886376G380M
encointer-kusamaparitydbarchive7703153166G435M
bridge-hub-polkadotparitydbarchive4438524156G593M
collectives-polkadotparitydbarchive5643583126G206M
polkadotparitydbarchive245497262.7T3.1G
ksmcc3paritydbarchive269075113.5T3.0G
ksmcc3paritydbpruned26907512627G922M
polkadotparitydbpruned24549726562G844M
asset-hub-polkadotparitydbarchive8123194258G415M
paseoparitydbarchive4964568422G1.8G
coretime-kusamaparitydbarchive204460754G192M
asset-hub-kusamaparitydbarchive8714335258G286M
bridge-hub-kusamaparitydbarchive5053732140G406M
asset-hub-paseoparitydbarchive124228032G192M
-

snapsize

-

dbdiffarchive

-

prunedsize

-

dbdiffpruned

-

commonsize

-

dbdiffcommon

+

Database sizes

Last update: Mon 03 Feb

+
ChainDatabaseFormatBlockheightFullDaily growth
people-kusamaparitydbarchive281290577G382M
encointer-kusamaparitydbarchive7717068167G441M
bridge-hub-polkadotparitydbarchive4445672157G594M
collectives-polkadotparitydbarchive5650729126G210M
polkadotparitydbarchive245640742.7T3.0G
ksmcc3paritydbarchive269217473.5T3.0G
ksmcc3paritydbpruned26921747627G886M
polkadotparitydbpruned24564074563G858M
asset-hub-polkadotparitydbarchive8130337258G426M
paseoparitydbarchive4978966424G1.8G
coretime-kusamaparitydbarchive205122654G174M
asset-hub-kusamaparitydbarchive8720885259G304M
bridge-hub-kusamaparitydbarchive5060801141G397M
asset-hub-paseoparitydbarchive124893232G187M
+

snapsize

+

dbdiffarchive

+

prunedsize

+

dbdiffpruned

+

commonsize

+

dbdiffcommon

\ No newline at end of file diff --git a/docs/disaster.html b/docs/disaster.html index d860475b..699b209c 100644 --- a/docs/disaster.html +++ b/docs/disaster.html @@ -4,7 +4,7 @@ Disaster managment | Stakeworld.io - + diff --git a/docs/ledger.html b/docs/ledger.html index e3640f45..dc102d82 100644 --- a/docs/ledger.html +++ b/docs/ledger.html @@ -4,7 +4,7 @@ Using a Ledger Wallet | Stakeworld.io - + diff --git a/docs/monitor.html b/docs/monitor.html index c3ebeba5..6dd1408c 100644 --- a/docs/monitor.html +++ b/docs/monitor.html @@ -4,7 +4,7 @@ Monitoring a validator node | Stakeworld.io - + diff --git a/docs/nominate.html b/docs/nominate.html index f95b9f52..e1299de1 100644 --- a/docs/nominate.html +++ b/docs/nominate.html @@ -4,7 +4,7 @@ Nominate | Stakeworld.io - + diff --git a/docs/pool.html b/docs/pool.html index 2010826c..a3e720e1 100644 --- a/docs/pool.html +++ b/docs/pool.html @@ -4,7 +4,7 @@ Pool | Stakeworld.io - + diff --git a/docs/rpc.html b/docs/rpc.html index 69ffb58f..25cbb407 100644 --- a/docs/rpc.html +++ b/docs/rpc.html @@ -4,7 +4,7 @@ RPC server | Stakeworld.io - + @@ -38,7 +38,7 @@

Archive node vs pruned node

A pruned node knows only the recent information about the network and not its full history. Most frequently done actions can be done with a pruned node, for example see account balances, make transfers, setup session keys, staking, etc. An archive node has the full history (database) of the network and can be queried in all kind of ways, give information about transfers since the network started, historical balances, advanced queries about past events, etc.

An archive node requires a lot more diskspace. For an archive node you need the options --state-pruning archive --blocks-pruning archive in your startup settings. -snapsize

+snapsize

tip

Inclusion in the Polkadot.js UI requires an archive node.

Secure the RPC server

Via the node startup settings you can choose what to expose with how many connections from where through your rpc server.

diff --git a/docs/snapshot.html b/docs/snapshot.html index 70173e44..a2fe2cb1 100644 --- a/docs/snapshot.html +++ b/docs/snapshot.html @@ -4,13 +4,13 @@ Snapshot | Stakeworld.io - + -

Snapshot

Last update: Sun 02 Feb

-
ChainDatabaseFormatBlockheightSnapshotFull
direct linkpolkadotparitydbpruned24549745539G562G
direct linkpaseoparitydbpruned496513371G76G
-

snapsize

+

Snapshot

Last update: Mon 03 Feb

+
ChainDatabaseFormatBlockheightSnapshotFull
direct linkpolkadotparitydbpruned24564094539G563G
direct linkpaseoparitydbpruned497953172G76G
+

snapsize

info

Snapshots are compressed backups of the database directory of a polkadot or kusama node. If you start a node for the first time it will start building the database from scratch, which will take a few days, depending on network speed. If you download an up to date database snapshot your node will be up and running quicker; under an hour or a few hours, depending on network speed.

Recently the warp sync option is becoming more developed and popular. If you start the node with an empty database and the option --sync warp the node will first download the finality proofs after which it will be ready to validate and in the background download the remaining blocks.

With the "beefy" update warp sync got temporarily disabled so for the time being the snapshot service is re-enabled.

For now the snapshots are available for kusama --chain ksmcc3 and polkadot --chain polkadot in the paritydb --database paritydb database format and the rocksdb --database rocksdb format. They are pruned with --state-pruning 256 (default), which is sufficient for a validator node.

Automatic install

The following script can restore a snapshot for a quickstart. If you want you can first review it on github. You can choose "snapinstall" for a snapshot restore or "nodeinstall" to install a complete node. The script will ask some questions and create an install or restore script which you can review before executing.

diff --git a/docs/tools.html b/docs/tools.html index 5af29988..9c8d49ba 100644 --- a/docs/tools.html +++ b/docs/tools.html @@ -4,7 +4,7 @@ Linux tips | Stakeworld.io - + diff --git a/docs/validate.html b/docs/validate.html index 67e6be2e..cd0b016e 100644 --- a/docs/validate.html +++ b/docs/validate.html @@ -4,7 +4,7 @@ Setting up a validator node | Stakeworld.io - + diff --git a/img/archivesize.png b/img/archivesize.png index 20a02652..7ffedf23 100644 Binary files a/img/archivesize.png and b/img/archivesize.png differ diff --git a/img/commonsize.png b/img/commonsize.png index 19e31117..dfa70cf4 100644 Binary files a/img/commonsize.png and b/img/commonsize.png differ diff --git a/img/dbdiff.png b/img/dbdiff.png index 3e6fe607..cf4da723 100644 Binary files a/img/dbdiff.png and b/img/dbdiff.png differ diff --git a/img/dbdiffcommon.png b/img/dbdiffcommon.png index 6ee65702..b1e218b7 100644 Binary files a/img/dbdiffcommon.png and b/img/dbdiffcommon.png differ diff --git a/img/dbdiffpruned.png b/img/dbdiffpruned.png index 6b45b89e..f91137e4 100644 Binary files a/img/dbdiffpruned.png and b/img/dbdiffpruned.png differ diff --git a/img/dbdiffrelay.png b/img/dbdiffrelay.png index 5d86d0e9..e849b9d1 100644 Binary files a/img/dbdiffrelay.png and b/img/dbdiffrelay.png differ diff --git a/img/prunedsize.png b/img/prunedsize.png index 5414a8de..735a53a1 100644 Binary files a/img/prunedsize.png and b/img/prunedsize.png differ diff --git a/img/snapsize.png b/img/snapsize.png index 62660d2e..5915b4d6 100644 Binary files a/img/snapsize.png and b/img/snapsize.png differ diff --git a/index.html b/index.html index b7a6cad5..d62430f6 100644 --- a/index.html +++ b/index.html @@ -4,7 +4,7 @@ Home | Stakeworld.io - +