mirror of
https://github.com/monero-project/monero-docs.git
synced 2025-01-27 21:16:04 +00:00
15 lines
No EOL
70 KiB
HTML
15 lines
No EOL
70 KiB
HTML
<!doctype html><html lang=en class=no-js> <head><meta charset=utf-8><meta name=viewport content="width=device-width,initial-scale=1"><meta name=description content="Unofficial Monero Documentation"><meta name=author content="Piotr 'Qertoip' Włodarek"><link href=https://monerodocs.org/interacting/monerod-reference/ rel=canonical><link rel="shortcut icon" href=../../assets/favicon.png><meta name=generator content="mkdocs-1.1.2, mkdocs-material-6.2.5"><title>monerod - Reference - Monero Documentation</title><link rel=stylesheet href=../../assets/stylesheets/main.15aa0b43.min.css><link rel=stylesheet href=../../assets/stylesheets/palette.75751829.min.css><meta name=theme-color content=#ffffff><link rel=preconnect href=https://fonts.gstatic.com crossorigin><link rel=stylesheet href="https://fonts.googleapis.com/css?family=Roboto:300,400,400i,700%7CRoboto+Mono&display=fallback"><style>body,input{font-family:"Roboto",-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif}code,kbd,pre{font-family:"Roboto Mono",SFMono-Regular,Consolas,Menlo,monospace}</style><link rel=stylesheet href=../../overrides.css></head> <body dir=ltr data-md-color-scheme data-md-color-primary=white data-md-color-accent=indigo> <input class=md-toggle data-md-toggle=drawer type=checkbox id=__drawer autocomplete=off> <input class=md-toggle data-md-toggle=search type=checkbox id=__search autocomplete=off> <label class=md-overlay for=__drawer></label> <div data-md-component=skip> <a href=#monerod-reference class=md-skip> Skip to content </a> </div> <div data-md-component=announce> </div> <header class=md-header data-md-component=header> <nav class="md-header-nav md-grid" aria-label=Header> <a href=https://monerodocs.org title="Monero Documentation" class="md-header-nav__button md-logo" aria-label="Monero Documentation"> <img src=../../images/monero.svg alt=logo> </a> <label class="md-header-nav__button md-icon" for=__drawer> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg> </label> <div class=md-header-nav__title data-md-component=header-title> <div class=md-header-nav__ellipsis> <div class=md-header-nav__topic> <span class=md-ellipsis> Monero Documentation </span> </div> <div class=md-header-nav__topic> <span class=md-ellipsis> monerod - Reference </span> </div> </div> </div> <label class="md-header-nav__button md-icon" for=__search> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0116 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 019.5 16 6.5 6.5 0 013 9.5 6.5 6.5 0 019.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg> </label> <div class=md-search data-md-component=search role=dialog> <label class=md-search__overlay for=__search></label> <div class=md-search__inner role=search> <form class=md-search__form name=search> <input type=text class=md-search__input name=query aria-label=Search placeholder=Search autocapitalize=off autocorrect=off autocomplete=off spellcheck=false data-md-component=search-query data-md-state=active required> <label class="md-search__icon md-icon" for=__search> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0116 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 019.5 16 6.5 6.5 0 013 9.5 6.5 6.5 0 019.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> </label> <button type=reset class="md-search__icon md-icon" aria-label=Clear data-md-component=search-reset tabindex=-1> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 24 24"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"/></svg> </button> </form> <div class=md-search__output> <div class=md-search__scrollwrap data-md-scrollfix> <div class=md-search-result data-md-component=search-result> <div class=md-search-result__meta> Initializing search </div> <ol class=md-search-result__list></ol> </div> </div> </div> </div> </div> <div class=md-header-nav__source> <a href=https://github.com/monerodocs/md/ title="Go to repository" class=md-source> <div class="md-source__icon md-icon"> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 448 512"><path d="M439.55 236.05L244 40.45a28.87 28.87 0 00-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 01-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 000 40.81l195.61 195.6a28.86 28.86 0 0040.8 0l194.69-194.69a28.86 28.86 0 000-40.81z"/></svg> </div> <div class=md-source__repository> monerodocs/md </div> </a> </div> </nav> </header> <div class=md-container data-md-component=container> <main class=md-main data-md-component=main> <div class="md-main__inner md-grid"> <div class="md-sidebar md-sidebar--primary" data-md-component=navigation> <div class=md-sidebar__scrollwrap> <div class=md-sidebar__inner> <nav class="md-nav md-nav--primary" aria-label=Navigation data-md-level=0> <label class=md-nav__title for=__drawer> <a href=https://monerodocs.org title="Monero Documentation" class="md-nav__button md-logo" aria-label="Monero Documentation"> <img src=../../images/monero.svg alt=logo> </a> Monero Documentation </label> <div class=md-nav__source> <a href=https://github.com/monerodocs/md/ title="Go to repository" class=md-source> <div class="md-source__icon md-icon"> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 448 512"><path d="M439.55 236.05L244 40.45a28.87 28.87 0 00-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 01-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 000 40.81l195.61 195.6a28.86 28.86 0 0040.8 0l194.69-194.69a28.86 28.86 0 000-40.81z"/></svg> </div> <div class=md-source__repository> monerodocs/md </div> </a> </div> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../.. class=md-nav__link> Home </a> </li> <li class="md-nav__item md-nav__item--active md-nav__item--nested"> <input class="md-nav__toggle md-toggle" data-md-toggle=nav-2 type=checkbox id=nav-2 checked> <label class=md-nav__link for=nav-2> Interacting <span class="md-nav__icon md-icon"></span> </label> <nav class=md-nav aria-label=Interacting data-md-level=1> <label class=md-nav__title for=nav-2> <span class="md-nav__icon md-icon"></span> Interacting </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../download-monero-binaries/ class=md-nav__link> Download </a> </li> <li class=md-nav__item> <a href=../verify-monero-binaries/ class=md-nav__link> Verify </a> </li> <li class=md-nav__item> <a href=../overview/ class=md-nav__link> Overview </a> </li> <li class=md-nav__item> <a href=../monero-config-file/ class=md-nav__link> Config file </a> </li> <li class="md-nav__item md-nav__item--active"> <input class="md-nav__toggle md-toggle" data-md-toggle=toc type=checkbox id=__toc> <label class="md-nav__link md-nav__link--active" for=__toc> monerod <span class="md-nav__icon md-icon"></span> </label> <a href=./ class="md-nav__link md-nav__link--active"> monerod </a> <nav class="md-nav md-nav--secondary" aria-label="Table of contents"> <label class=md-nav__title for=__toc> <span class="md-nav__icon md-icon"></span> Table of contents </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=#overview class=md-nav__link> Overview </a> <nav class=md-nav aria-label=Overview> <ul class=md-nav__list> <li class=md-nav__item> <a href=#connects-you-to-monero-network class=md-nav__link> Connects you to Monero network </a> </li> <li class=md-nav__item> <a href=#not-aware-of-your-private-keys class=md-nav__link> Not aware of your private keys </a> </li> </ul> </nav> </li> <li class=md-nav__item> <a href=#syntax class=md-nav__link> Syntax </a> </li> <li class=md-nav__item> <a href=#running class=md-nav__link> Running </a> </li> <li class=md-nav__item> <a href=#options class=md-nav__link> Options </a> <nav class=md-nav aria-label=Options> <ul class=md-nav__list> <li class=md-nav__item> <a href=#help-and-version class=md-nav__link> Help and version </a> </li> <li class=md-nav__item> <a href=#pick-network class=md-nav__link> Pick network </a> </li> <li class=md-nav__item> <a href=#logging class=md-nav__link> Logging </a> </li> <li class=md-nav__item> <a href=#server class=md-nav__link> Server </a> </li> <li class=md-nav__item> <a href=#p2p-network class=md-nav__link> P2P network </a> </li> <li class=md-nav__item> <a href=#tori2p class=md-nav__link> Tor/I2P </a> </li> <li class=md-nav__item> <a href=#node-rpc-api class=md-nav__link> Node RPC API </a> </li> <li class=md-nav__item> <a href=#accepting-monero class=md-nav__link> Accepting Monero </a> </li> <li class=md-nav__item> <a href=#performance class=md-nav__link> Performance </a> </li> <li class=md-nav__item> <a href=#mining class=md-nav__link> Mining </a> </li> <li class=md-nav__item> <a href=#testing-monero-itself class=md-nav__link> Testing Monero itself </a> </li> <li class=md-nav__item> <a href=#legacy class=md-nav__link> Legacy </a> </li> </ul> </nav> </li> <li class=md-nav__item> <a href=#commands class=md-nav__link> Commands </a> <nav class=md-nav aria-label=Commands> <ul class=md-nav__list> <li class=md-nav__item> <a href=#help-version-status class=md-nav__link> Help, version, status </a> </li> <li class=md-nav__item> <a href=#p2p-network_1 class=md-nav__link> P2P network </a> </li> <li class=md-nav__item> <a href=#transaction-pool class=md-nav__link> Transaction pool </a> </li> <li class=md-nav__item> <a href=#transactions class=md-nav__link> Transactions </a> </li> <li class=md-nav__item> <a href=#blockchain class=md-nav__link> Blockchain </a> </li> <li class=md-nav__item> <a href=#manage-daemon class=md-nav__link> Manage daemon </a> </li> <li class=md-nav__item> <a href=#mining_1 class=md-nav__link> Mining </a> </li> <li class=md-nav__item> <a href=#testing-monero-itself_1 class=md-nav__link> Testing Monero itself </a> </li> <li class=md-nav__item> <a href=#legacy_1 class=md-nav__link> Legacy </a> </li> </ul> </nav> </li> </ul> </nav> </li> <li class=md-nav__item> <a href=../monero-wallet-cli-reference/ class=md-nav__link> monero-wallet-cli </a> </li> <li class=md-nav__item> <a href=../monero-wallet-gui-reference/ class=md-nav__link> monero-wallet-gui </a> </li> <li class=md-nav__item> <a href=../monero-wallet-rpc-reference/ class=md-nav__link> monero-wallet-rpc </a> </li> <li class=md-nav__item> <a href=../monero-blockchain-export-reference/ class=md-nav__link> monero-blockchain-export </a> </li> <li class=md-nav__item> <a href=../monero-blockchain-import-reference/ class=md-nav__link> monero-blockchain-import </a> </li> </ul> </nav> </li> <li class=md-nav__item> <a href=../../technical-specs/ class=md-nav__link> Technical specs </a> </li> <li class="md-nav__item md-nav__item--nested"> <input class="md-nav__toggle md-toggle" data-md-toggle=nav-4 type=checkbox id=nav-4> <label class=md-nav__link for=nav-4> Cryptography <span class="md-nav__icon md-icon"></span> </label> <nav class=md-nav aria-label=Cryptography data-md-level=1> <label class=md-nav__title for=nav-4> <span class="md-nav__icon md-icon"></span> Cryptography </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../../cryptography/introduction/ class=md-nav__link> Introduction </a> </li> <li class="md-nav__item md-nav__item--nested"> <input class="md-nav__toggle md-toggle" data-md-toggle=nav-4-2 type=checkbox id=nav-4-2> <label class=md-nav__link for=nav-4-2> Asymmetric <span class="md-nav__icon md-icon"></span> </label> <nav class=md-nav aria-label=Asymmetric data-md-level=2> <label class=md-nav__title for=nav-4-2> <span class="md-nav__icon md-icon"></span> Asymmetric </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../../cryptography/asymmetric/introduction/ class=md-nav__link> Introduction </a> </li> <li class=md-nav__item> <a href=../../cryptography/asymmetric/private-key/ class=md-nav__link> Private keys </a> </li> <li class=md-nav__item> <a href=../../cryptography/asymmetric/public-key/ class=md-nav__link> Public keys </a> </li> <li class=md-nav__item> <a href=../../cryptography/asymmetric/edwards25519/ class=md-nav__link> Edwards25519 curve </a> </li> <li class=md-nav__item> <a href=../../cryptography/asymmetric/key-image/ class=md-nav__link> Key image </a> </li> </ul> </nav> </li> <li class=md-nav__item> <a href=../../cryptography/base58/ class=md-nav__link> Base58 </a> </li> <li class=md-nav__item> <a href=../../cryptography/prng/ class=md-nav__link> PRNG </a> </li> <li class=md-nav__item> <a href=../../cryptography/keccak-256/ class=md-nav__link> Keccak-256 </a> </li> </ul> </nav> </li> <li class="md-nav__item md-nav__item--nested"> <input class="md-nav__toggle md-toggle" data-md-toggle=nav-5 type=checkbox id=nav-5> <label class=md-nav__link for=nav-5> Address <span class="md-nav__icon md-icon"></span> </label> <nav class=md-nav aria-label=Address data-md-level=1> <label class=md-nav__title for=nav-5> <span class="md-nav__icon md-icon"></span> Address </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../../public-address/standard-address/ class=md-nav__link> Standard </a> </li> <li class=md-nav__item> <a href=../../public-address/subaddress/ class=md-nav__link> Subaddress </a> </li> <li class=md-nav__item> <a href=../../public-address/integrated-address/ class=md-nav__link> Integrated </a> </li> </ul> </nav> </li> <li class="md-nav__item md-nav__item--nested"> <input class="md-nav__toggle md-toggle" data-md-toggle=nav-6 type=checkbox id=nav-6> <label class=md-nav__link for=nav-6> Proof of Work <span class="md-nav__icon md-icon"></span> </label> <nav class=md-nav aria-label="Proof of Work" data-md-level=1> <label class=md-nav__title for=nav-6> <span class="md-nav__icon md-icon"></span> Proof of Work </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../../proof-of-work/what-is-pow/ class=md-nav__link> What is PoW? </a> </li> <li class=md-nav__item> <a href=../../proof-of-work/pow-in-cryptocurrencies/ class=md-nav__link> PoW in Cryptocurrencies </a> </li> <li class=md-nav__item> <a href=../../proof-of-work/cryptonight/ class=md-nav__link> CryptoNight </a> </li> <li class=md-nav__item> <a href=../../proof-of-work/random-x/ class=md-nav__link> RandomX </a> </li> </ul> </nav> </li> <li class=md-nav__item> <a href=../../multisignature/ class=md-nav__link> Multisignature </a> </li> <li class="md-nav__item md-nav__item--nested"> <input class="md-nav__toggle md-toggle" data-md-toggle=nav-8 type=checkbox id=nav-8> <label class=md-nav__link for=nav-8> Infrastructure <span class="md-nav__icon md-icon"></span> </label> <nav class=md-nav aria-label=Infrastructure data-md-level=1> <label class=md-nav__title for=nav-8> <span class="md-nav__icon md-icon"></span> Infrastructure </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../../infrastructure/networks/ class=md-nav__link> Mainnet, stagenet, testnet </a> </li> <li class=md-nav__item> <a href=../../infrastructure/tor-onion-p2p-seed-nodes/ class=md-nav__link> Tor onion seed nodes </a> </li> <li class=md-nav__item> <a href=../../infrastructure/monero-pulse/ class=md-nav__link> MoneroPulse </a> </li> </ul> </nav> </li> <li class="md-nav__item md-nav__item--nested"> <input class="md-nav__toggle md-toggle" data-md-toggle=nav-9 type=checkbox id=nav-9> <label class=md-nav__link for=nav-9> Running a Node <span class="md-nav__icon md-icon"></span> </label> <nav class=md-nav aria-label="Running a Node" data-md-level=1> <label class=md-nav__title for=nav-9> <span class="md-nav__icon md-icon"></span> Running a Node </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../../running-node/open-node-tor-onion/ class=md-nav__link> Open Node + Tor Onion </a> </li> </ul> </nav> </li> <li class="md-nav__item md-nav__item--nested"> <input class="md-nav__toggle md-toggle" data-md-toggle=nav-10 type=checkbox id=nav-10> <label class=md-nav__link for=nav-10> Accepting Monero <span class="md-nav__icon md-icon"></span> </label> <nav class=md-nav aria-label="Accepting Monero" data-md-level=1> <label class=md-nav__title for=nav-10> <span class="md-nav__icon md-icon"></span> Accepting Monero </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=../../accepting-monero/overview/ class=md-nav__link> Overview </a> </li> </ul> </nav> </li> </ul> </nav> </div> </div> </div> <div class="md-sidebar md-sidebar--secondary" data-md-component=toc> <div class=md-sidebar__scrollwrap> <div class=md-sidebar__inner> <nav class="md-nav md-nav--secondary" aria-label="Table of contents"> <label class=md-nav__title for=__toc> <span class="md-nav__icon md-icon"></span> Table of contents </label> <ul class=md-nav__list data-md-scrollfix> <li class=md-nav__item> <a href=#overview class=md-nav__link> Overview </a> <nav class=md-nav aria-label=Overview> <ul class=md-nav__list> <li class=md-nav__item> <a href=#connects-you-to-monero-network class=md-nav__link> Connects you to Monero network </a> </li> <li class=md-nav__item> <a href=#not-aware-of-your-private-keys class=md-nav__link> Not aware of your private keys </a> </li> </ul> </nav> </li> <li class=md-nav__item> <a href=#syntax class=md-nav__link> Syntax </a> </li> <li class=md-nav__item> <a href=#running class=md-nav__link> Running </a> </li> <li class=md-nav__item> <a href=#options class=md-nav__link> Options </a> <nav class=md-nav aria-label=Options> <ul class=md-nav__list> <li class=md-nav__item> <a href=#help-and-version class=md-nav__link> Help and version </a> </li> <li class=md-nav__item> <a href=#pick-network class=md-nav__link> Pick network </a> </li> <li class=md-nav__item> <a href=#logging class=md-nav__link> Logging </a> </li> <li class=md-nav__item> <a href=#server class=md-nav__link> Server </a> </li> <li class=md-nav__item> <a href=#p2p-network class=md-nav__link> P2P network </a> </li> <li class=md-nav__item> <a href=#tori2p class=md-nav__link> Tor/I2P </a> </li> <li class=md-nav__item> <a href=#node-rpc-api class=md-nav__link> Node RPC API </a> </li> <li class=md-nav__item> <a href=#accepting-monero class=md-nav__link> Accepting Monero </a> </li> <li class=md-nav__item> <a href=#performance class=md-nav__link> Performance </a> </li> <li class=md-nav__item> <a href=#mining class=md-nav__link> Mining </a> </li> <li class=md-nav__item> <a href=#testing-monero-itself class=md-nav__link> Testing Monero itself </a> </li> <li class=md-nav__item> <a href=#legacy class=md-nav__link> Legacy </a> </li> </ul> </nav> </li> <li class=md-nav__item> <a href=#commands class=md-nav__link> Commands </a> <nav class=md-nav aria-label=Commands> <ul class=md-nav__list> <li class=md-nav__item> <a href=#help-version-status class=md-nav__link> Help, version, status </a> </li> <li class=md-nav__item> <a href=#p2p-network_1 class=md-nav__link> P2P network </a> </li> <li class=md-nav__item> <a href=#transaction-pool class=md-nav__link> Transaction pool </a> </li> <li class=md-nav__item> <a href=#transactions class=md-nav__link> Transactions </a> </li> <li class=md-nav__item> <a href=#blockchain class=md-nav__link> Blockchain </a> </li> <li class=md-nav__item> <a href=#manage-daemon class=md-nav__link> Manage daemon </a> </li> <li class=md-nav__item> <a href=#mining_1 class=md-nav__link> Mining </a> </li> <li class=md-nav__item> <a href=#testing-monero-itself_1 class=md-nav__link> Testing Monero itself </a> </li> <li class=md-nav__item> <a href=#legacy_1 class=md-nav__link> Legacy </a> </li> </ul> </nav> </li> </ul> </nav> </div> </div> </div> <div class=md-content> <article class="md-content__inner md-typeset"> <a href=https://github.com/monerodocs/md/edit/master/docs/interacting/monerod-reference.md title="Edit this page" class="md-content__button md-icon"> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 24 24"><path d="M20.71 7.04c.39-.39.39-1.04 0-1.41l-2.34-2.34c-.37-.39-1.02-.39-1.41 0l-1.84 1.83 3.75 3.75M3 17.25V21h3.75L17.81 9.93l-3.75-3.75L3 17.25z"/></svg> </a> <h1 id=monerod-reference><code>monerod</code> - Reference<a class=headerlink href=#monerod-reference title="Permanent link">¶</a></h1> <h2 id=overview>Overview<a class=headerlink href=#overview title="Permanent link">¶</a></h2> <h3 id=connects-you-to-monero-network>Connects you to Monero network<a class=headerlink href=#connects-you-to-monero-network title="Permanent link">¶</a></h3> <p>The Monero daemon <code>monerod</code> keeps your computer synced up with the Monero network.</p> <p>It downloads and validates the blockchain from the p2p network.</p> <h3 id=not-aware-of-your-private-keys>Not aware of your private keys<a class=headerlink href=#not-aware-of-your-private-keys title="Permanent link">¶</a></h3> <p><code>monerod</code> is entirely decoupled from your wallet.</p> <p><code>monerod</code> does not access your private keys - it is not aware of your transactions and balance.</p> <p>This allows you to run <code>monerod</code> on a separate computer or in the cloud.</p> <p>In fact, you can connect to a remote <code>monerod</code> instance provided by a semi-trusted 3rd party. Such 3rd party will not be able to steal your funds. This is very handy for learning and experimentation.</p> <p>However, there are privacy and reliability implications to using a remote, untrusted node. For any real business <strong>you should be running your own full node</strong>.</p> <h2 id=syntax>Syntax<a class=headerlink href=#syntax title="Permanent link">¶</a></h2> <p><code>./monerod [options] [command]</code></p> <p>Options define how the daemon should be working. Their names follow the <code>--option-name</code> pattern.</p> <p>Commands give access to specific services provided by the daemon. Commands are executed against the running daemon. Their names follow the <code>command_name</code> pattern.</p> <h2 id=running>Running<a class=headerlink href=#running title="Permanent link">¶</a></h2> <p>Go to directory where you unpacked Monero.</p> <p>The <a href=/infrastructure/networks>stagenet</a> is what your should be using for learning and experimentation.</p> <div class=highlight><pre><span></span><code>./monerod --stagenet --detach # run as a daemon in background
|
||
tail -f ~/.bitmonero/stagenet/bitmonero.log # watch the logs
|
||
./monerod --stagenet exit # ask daemon to exit gracefully
|
||
</code></pre></div> <p>The <a href=/infrastructure/networks>mainnnet</a> is when you want to deal with the real XMR.</p> <div class=highlight><pre><span></span><code>./monerod --detach # run as a daemon in background
|
||
tail -f ~/.bitmonero/bitmonero.log # watch the logs
|
||
./monerod exit # ask daemon to exit gracefully
|
||
</code></pre></div> <h2 id=options>Options<a class=headerlink href=#options title="Permanent link">¶</a></h2> <p>Options define how the daemon should be working. Their names follow the <code>--option-name</code> pattern.</p> <p>The following groups are only to make reference easier to follow. The daemon itself does not group options in any way.</p> <h4 id=help-and-version>Help and version<a class=headerlink href=#help-and-version title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--help</code></td> <td>Enlist available options.</td> </tr> <tr> <td><code>--version</code></td> <td>Show <code>monerod</code> version to stdout. Example output: <br><code>Monero 'Oxygen Orion' (v0.17.1.8-release)</code></td> </tr> <tr> <td><code>--os-version</code></td> <td>Show build timestamp and target operating system. Example output:<br><code>OS: Linux #65-Ubuntu SMP Thu Dec 10 12:01:51 UTC 2020 5.4.0-59-generic</code>.</td> </tr> <tr> <td><code>--check-updates</code></td> <td>One of: <code>disabled</code> | <code>notify</code> | <code>download</code> (=<code>notify</code> by default). Check for new versions of Monero and optionally download it. You should probably prefer your OS package manager to do the update, if possible. There is also unimplemented <code>update</code> option shown by the help system.</td> </tr> </tbody> </table> <h4 id=pick-network>Pick network<a class=headerlink href=#pick-network title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>(missing)</td> <td>By default monerod assumes <a href=/infrastructure/networks>mainnet</a>.</td> </tr> <tr> <td><code>--stagenet</code></td> <td>Run on <a href=/infrastructure/networks>stagenet</a>. Remember to run your wallet with <code>--stagenet</code> as well.</td> </tr> <tr> <td><code>--testnet</code></td> <td>Run on <a href=/infrastructure/networks>testnet</a>. Remember to run your wallet with <code>--testnet</code> as well.</td> </tr> </tbody> </table> <h4 id=logging>Logging<a class=headerlink href=#logging title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--log-file</code></td> <td>Full path to the log file. Example (mind file permissions): <br><code>./monerod --log-file=/var/log/monero/mainnet/monerod.log</code></td> </tr> <tr> <td><code>--log-level</code></td> <td><code>0-4</code> with <code>0</code> being minimal logging and <code>4</code> being full tracing. Defaults to <code>0</code>. These are general presets and do not directly map to severity levels. For example, even with minimal <code>0</code>, you may see some most important <code>INFO</code> entries. Temporarily changing to <code>1</code> allows for much better understanding of how the full node operates. Example: <br><code>./monerod --log-level=1</code></td> </tr> <tr> <td><code>--max-log-file-size</code></td> <td>Soft limit in bytes for the log file (=104850000 by default, which is just under 100MB). Once log file grows past that limit, <code>monerod</code> creates the next log file with a UTC timestamp postfix <code>-YYYY-MM-DD-HH-MM-SS</code>.<br><br>In production deployments, you would probably prefer to use established solutions like logrotate instead. In that case, set <code>--max-log-file-size=0</code> to prevent monerod from managing the log files.</td> </tr> <tr> <td><code>--max-log-files</code></td> <td>Limit on the number of log files (=50 by default). The oldest log files are removed. In production deployments, you would probably prefer to use established solutions like logrotate instead.</td> </tr> </tbody> </table> <h4 id=server>Server<a class=headerlink href=#server title="Permanent link">¶</a></h4> <p><code>monerod</code> defaults are adjusted for running it occasionally on the same computer as your Monero wallet.</p> <p>The following options will be helpful if you intend to have an always running node — most likely on a remote server or your own separate PC.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--config-file</code></td> <td>Full path to the <a href=/interacting/monero-config-file>configuration file</a>. By default <code>monerod</code> looks for <code>bitmonero.conf</code> in Monero <a href=/interacting/overview/#data-directory>data directory</a>.</td> </tr> <tr> <td><code>--data-dir</code></td> <td>Full path to data directory. This is where the blockchain, log files, and p2p network memory are stored. For defaults and details see <a href=/interacting/overview/#data-directory>data directory</a>.</td> </tr> <tr> <td><code>--pidfile</code></td> <td>Full path to the PID file. Works only with <code>--detach</code>. Example: <br><code>./monerod --detach --pidfile=/run/monero/monerod.pid</code></td> </tr> <tr> <td><code>--detach</code></td> <td>Go to background (decouple from the terminal). This is useful for long-running / server scenarios. Typically, you will also want to manage <code>monerod</code> daemon with systemd or similar. By default <code>monerod</code> runs in a foreground.</td> </tr> <tr> <td><code>--non-interactive</code></td> <td>Do not require tty in a foreground mode. Helpful when running in a container. By default <code>monerod</code> runs in a foreground and opens stdin for reading. This breaks containerization because no tty gets assigned and <code>monerod</code> process crashes. You can make it run in a background with <code>--detach</code> but this is inconvenient in a containerized environment because the canonical usage is that the container waits on the main process to exist (forking makes things more complicated).</td> </tr> <tr> <td><code>--no-zmq</code></td> <td>Disable ZMQ RPC server. You <strong>should</strong> use this option to limit attack surface and number of unnecessarily open ports (the ZMQ server is unfinished thing and you are unlikely to ever use it).</td> </tr> <tr> <td><code>--no-igd</code></td> <td>Disable UPnP port mapping on the router ("Internet Gateway Device"). Add this option to improve security if you are <strong>not</strong> behind a NAT (you can bind directly to public IP or you run through Tor).</td> </tr> <tr> <td><code>--max-txpool-weight</code></td> <td>Set maximum transactions pool size in bytes. By default 648000000 (~618MB). These are transactions pending for confirmations (not included in any block).</td> </tr> <tr> <td><code>--enforce-dns-checkpointing</code></td> <td>The emergency checkpoints set by <a href=/infrastructure/monero-pulse>MoneroPulse</a> operators will be enforced. It is probably a good idea to set enforcing for unattended nodes. <br><br>If encountered block hash does not match corresponding checkpoint, the local blockchain will be rolled back a few blocks, effectively blocking following what MoneroPulse operators consider invalid fork. The log entry will be produced: <code>ERROR</code> <code>Local blockchain failed to pass a checkpoint, rolling back!</code> Eventually, the alternative ("fixed") fork will get heavier and the node will follow it, leaving the "invalid" fork behind.<br><br>By default checkpointing only notifies about discrepancy by producing the following log entry: <code>ERROR</code> <code>WARNING: local blockchain failed to pass a MoneroPulse checkpoint, and you could be on a fork. You should either sync up from scratch, OR download a fresh blockchain bootstrap, OR enable checkpoint enforcing with the --enforce-dns-checkpointing command-line option</code>.<br><br>Reference: <a href=https://github.com/monero-project/monero/blob/22a6591a70151840381e327f1b41dc27cbdb2ee6/src/cryptonote_core/blockchain.cpp#L3614>source code</a>.</td> </tr> <tr> <td><code>--disable-dns-checkpoints</code></td> <td>The <a href=/infrastructure/monero-pulse>MoneroPulse</a> checkpoints set by core developers will be discarded. The checkpoints are apparently still fetched though.</td> </tr> </tbody> </table> <h4 id=p2p-network>P2P network<a class=headerlink href=#p2p-network title="Permanent link">¶</a></h4> <p>The following options define how your node participates in Monero peer-to-peer network. This is for node-to-node communication. The following options do <strong>not</strong> affect <a href=#node-rpc-api>wallet-to-node</a> interface.</p> <p>The node and peer words are used interchangeably.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--p2p-bind-ip</code></td> <td>IPv4 network interface to bind to for p2p network protocol. Default value <code>0.0.0.0</code> binds to all network interfaces. This is typically what you want. <br><br>You must change this if you want to constrain binding, for example to force working through Tor via torsocks: <br><code>DNS_PUBLIC=tcp://1.1.1.1 TORSOCKS_ALLOW_INBOUND=1 torsocks ./monerod --p2p-bind-ip 127.0.0.1 --no-igd --hide-my-port</code></td> </tr> <tr> <td><code>--p2p-bind-port</code></td> <td>TCP port to listen for p2p network connections. Defaults to <code>18080</code> for mainnet, <code>28080</code> for testnet, and <code>38080</code> for stagenet. You normally wouldn't change that. This is helpful to run several nodes on your machine to simulate private Monero p2p network (likely using private Testnet). Example: <br><code>./monerod --p2p-bind-port=48080</code></td> </tr> <tr> <td><code>--p2p-external-port</code></td> <td>TCP port to listen for p2p network connections on your router. Relevant if you are behind a NAT and still want to accept incoming connections. You must then set this to relevant port on your router. This is to let <code>monerod</code> know what to advertise on the network. Default is <code>0</code>.</td> </tr> <tr> <td><code>--p2p-use-ipv6</code></td> <td>Enable IPv6 for p2p (disabled by default).</td> </tr> <tr> <td><code>--p2p-bind-ipv6-address</code></td> <td>IPv6 network interface to bind to for p2p network protocol. Default value <code>::</code> binds to all network interfaces.</td> </tr> <tr> <td><code>--p2p-ignore-ipv4</code></td> <td>Ignore unsuccessful IPv4 bind for p2p. Useful if you only want to use IPv6.</td> </tr> <tr> <td><code>--igd</code></td> <td>Set UPnP port mapping on the router ("Internet Gateway Device"). One of: <code>disabled</code> | <code>enabled</code> | <code>delayed</code> (=<code>delayed</code> by default). Relevant if you are behind NAT and want to accept incoming P2P network connections. The <code>delayed</code> value means it will wait for incoming connections in hope UPnP may not be necessary. After a while w/o incoming connections found it will attempt to map ports with UPnP. If you know you need UPnP change it to <code>enabled</code> to fast track the process.</td> </tr> <tr> <td><code>--hide-my-port</code></td> <td><code>monerod</code> will still open and listen on the p2p port. However, it will not announce itself as a peer list candidate. Technically, it will return port <code>0</code> in a response to p2p handshake (<code>node_data.my_port = 0</code> in <code>get_local_node_data</code> function). In effect nodes you connect to won't spread your IP to other nodes. To sum up, it is not really hiding, it is more like "do not advertise".</td> </tr> <tr> <td><code>--seed-node</code></td> <td>Connect to a node to retrieve other nodes' addresses, and disconnect. If not specified, <code>monerod</code> will use hardcoded seed nodes on the first run, and peers cached on disk on subsequent runs.</td> </tr> <tr> <td><code>--add-peer</code></td> <td>Manually add node to local peer list, <code>host:port</code>. Syntax supports IP addresses, domain names, onion and i2p hosts.</td> </tr> <tr> <td><code>--add-priority-node</code></td> <td>Specify list of nodes to connect to and then attempt to keep the connection open. <br><br>To add multiple nodes use the option several times. Example: <br><code>./monerod --add-priority-node=178.128.192.138:18081 --add-priority-node=144.76.202.167:18081</code></td> </tr> <tr> <td><code>--add-exclusive-node</code></td> <td>Specify list of nodes to connect to only. If this option is given the options <code>--add-priority-node</code> and <code>--seed-node</code> are ignored. <br><br>To add multiple nodes use the option several times. Example: <br><code>./monerod --add-exclusive-node=178.128.192.138:18081 --add-exclusive-node=144.76.202.167:18081</code></td> </tr> <tr> <td><code>--out-peers</code></td> <td>Set max number of outgoing connections to other nodes. By default 12. Value <code>-1</code> represents the code default.</td> </tr> <tr> <td><code>--in-peers</code></td> <td>Set max number of incoming connections (nodes actively connecting to you). By default unlimited. Value <code>-1</code> represents the code default.</td> </tr> <tr> <td><code>--limit-rate-up</code></td> <td>Set outgoing data transfer limit [kB/s]. By default 2048 kB/s. Value <code>-1</code> represents the code default.</td> </tr> <tr> <td><code>--limit-rate-down</code></td> <td>Set incoming data transfer limit [kB/s]. By default 8192 kB/s. Value <code>-1</code> represents the code default.</td> </tr> <tr> <td><code>--limit-rate</code></td> <td>Set the same limit value for incoming and outgoing data transfer. By default (<code>-1</code>) the individual up/down default limits will be used. It is better to use <code>--limit-rate-up</code> and <code>--limit-rate-down</code> instead to avoid confusion.</td> </tr> <tr> <td><code>--offline</code></td> <td>Do not listen for peers, nor connect to any. Useful for working with a local, archival blockchain.</td> </tr> <tr> <td><code>--allow-local-ip</code></td> <td>Allow adding local IP to peer list. Useful mostly for debug purposes when you may want to have multiple nodes on a single machine.</td> </tr> </tbody> </table> <h4 id=tori2p>Tor/I2P<a class=headerlink href=#tori2p title="Permanent link">¶</a></h4> <p>This is experimental. It may be best to start with this <a href=https://github.com/monero-project/monero/blob/master/docs/ANONYMITY_NETWORKS.md#p2p-commands>guide</a>.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--tx-proxy</code></td> <td>Send out your local transactions through SOCKS5 proxy (Tor or I2P). Format:<br><code><network-type>,<socks-ip:port>[,max_connections][,disable_noise]</code> <br><br>Example:<br><code>./monerod --tx-proxy "tx-proxy=tor,127.0.0.1:9050,16"</code><br><br>This was introduced to make publishing transactions over Tor easier (no need for torsocks) while allowing clearnet for blocks at the same time (while torsocks affected everything).<br><br>Adding <code>,disable_noise</code> disables Dandelion++ (will speed up tx broadcast but is otherwise not recommended). <br><br>Note that forwarded transactions (those not originating from connected wallet) will still be relayed over clearnet.<br><br><strong>Requires multiple <code>--add-peer</code></strong> to manually add onion-enabled p2p seed nodes - see <a href=/infrastructure/tor-onion-p2p-seed-nodes>Tor onion seed nodes for Monero P2P network</a>. See this <a href=https://github.com/monero-project/monero/blob/master/ANONYMITY_NETWORKS.md#p2p-commands>guide</a> and <a href=https://github.com/monero-project/monero/pull/6021>commit</a>.</td> </tr> <tr> <td><code>--anonymous-inbound</code></td> <td>Allow anonymous incoming connections to your onionized P2P interface. Format: <br><code><hidden-service-address>,<[bind-ip:]port>[,max_connections]</code><br><br>Example:<br><code>./monerod --anonymous-inbound "rveahdfho7wo4b2m.onion:18083,127.0.0.1:18083,100"</code>.<br><br>Obviously, you first need to setup the hidden service in your Tor config. See the <a href=https://github.com/monero-project/monero/blob/master/ANONYMITY_NETWORKS.md#p2p-commands>guide</a>.</td> </tr> <tr> <td><code>--pad-transactions</code></td> <td>Pad relayed transactions to next 1024 bytes to help defend against traffic volume analysis. This only makes sense if you are behind Tor or I2P. See <a href=https://github.com/monero-project/monero/pull/4787>commit</a>.</td> </tr> </tbody> </table> <h4 id=node-rpc-api>Node RPC API<a class=headerlink href=#node-rpc-api title="Permanent link">¶</a></h4> <p><code>monerod</code> node offers powerful API. It serves 3 purposes:</p> <ul> <li>provides network data (stats, blocks, transactions, ...)</li> <li>provides local node information (peer list, hash rate if mining, ...)</li> <li>provides interface for wallets (send transactions, ...)</li> </ul> <p>This API is typically referred to as "RPC" because it is mostly based on JSON/RPC standard.</p> <p>The following options define how the API behaves.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--public-node</code></td> <td>Advertise to other users they can use this node as a remote one for connecting their wallets. Requires <code>--restricted-rpc</code>, <code>--rpc-bind-ip</code> and <code>--confirm-external-bind</code>. Without <code>--public-node</code> the node can still be public (assuming other relevant options are set) but won't be advertised as such on the P2P network. This option will allow wallets to auto-discover public nodes (instead of requiring user to manually find one).</td> </tr> <tr> <td><code>--rpc-bind-ip</code></td> <td>IP to listen on. By default <code>127.0.0.1</code> because API gives full administrative capabilities over the node. Set it to <code>0.0.0.0</code> to listen on all interfaces - but only in connection with one of <code>*-restricted-*</code> options <strong>and</strong> <code>--confirm-external-bind</code>.</td> </tr> <tr> <td><code>--rpc-bind-port</code></td> <td>TCP port to listen on. By default <code>18081</code> (mainnet), <code>28081</code> (testnet), <code>38081</code> (stagenet).</td> </tr> <tr> <td><code>--rpc-bind-ipv6-address</code></td> <td>IPv6 to listen on. By default <code>::1</code> (localhost). All remarks for <code>--rpc-bind-ip</code> are applicable here as well.</td> </tr> <tr> <td><code>--rpc-use-ipv6</code></td> <td>Enable IPv6 for RPC server (disabled by default).</td> </tr> <tr> <td><code>--rpc-ignore-ipv4</code></td> <td>Ignore unsuccessful IPv4 bind for RPC. Useful if you only want to use IPv6.</td> </tr> <tr> <td><code>--rpc-restricted-bind-ip</code></td> <td>IP to listen on with the limited version of API. The limited API can be made public to create an Open Node.</td> </tr> <tr> <td><code>--rpc-restricted-bind-port</code></td> <td>TCP port to listen on with the limited version of API. To be used in combination with <code>`--rpc-restricted-bind-port</code>.</td> </tr> <tr> <td><code>--confirm-external-bind</code></td> <td>Confirm you consciously set <code>--rpc-bind-ip</code> to non-localhost IP and you understand the consequences.</td> </tr> <tr> <td><code>--restricted-rpc</code></td> <td>Restrict API to view only commands and do not return privacy sensitive data. Note this does not make sense with <code>--rpc-restricted-bind-port</code> because you would end up with two restricted APIs.</td> </tr> <tr> <td><code>--rpc-ssl</code></td> <td>Enable TLS on RPC connections. One of: <code>enabled</code> | <code>disabled</code> | <code>autodetect</code> (<code>=autodetect</code> by default). You <strong>should</strong> enable this if you connect a remote wallet.</td> </tr> <tr> <td><code>--rpc-ssl-private-key</code></td> <td>Path to server's private key in PEM format. Generate it with <code>monero-gen-ssl-cert</code> tool. This is to facilitate server authentication to client.</td> </tr> <tr> <td><code>--rpc-ssl-certificate</code></td> <td>Path to server's certificate in PEM format. Generate it with <code>monero-gen-ssl-cert</code> tool. This is to facilitate server authentication to client.</td> </tr> <tr> <td><code>--rpc-ssl-allowed-fingerprints</code></td> <td>List of certificate fingerprints to accept. This is a way to authenticate clients.</td> </tr> <tr> <td><code>--rpc-ssl-allow-any-cert</code></td> <td>Allow any certificate of connecting client.</td> </tr> <tr> <td><code>--rpc-ssl-ca-certificates</code></td> <td>Path to file containing concatenated PEM format certificate(s) to replace system CA(s).</td> </tr> <tr> <td><code>--rpc-ssl-allow-chained</code></td> <td>Allow user chained certificates. This is only applicable if user has a "real" CA issued certificate.</td> </tr> <tr> <td><code>--rpc-login</code></td> <td>Specify <code>username[:password]</code> required to connect to API.</td> </tr> <tr> <td><code>--rpc-access-control-origins</code></td> <td>Specify a comma separated list of origins to allow cross origin resource sharing. This is useful if you want to use <code>monerod</code> API directly from a web browser via JavaScript (say in a pure-fronted web appp scenario). With this option <code>monerod</code> will put proper HTTP CORS headers to its responses. You will also need to set <code>--rpc-login</code> if you use this option. Normally though, the API is used by backend app and this option isn't necessary.</td> </tr> </tbody> </table> <h4 id=accepting-monero>Accepting Monero<a class=headerlink href=#accepting-monero title="Permanent link">¶</a></h4> <p>These are network notifications offered by <code>monerod</code>. There are also wallet notifications like <code>--tx-notify</code> offered by <code>monero-wallet-rpc</code> <a href=https://github.com/monero-project/monero/pull/4333>here</a>.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--block-notify <arg></code></td> <td>Run a program for each new block. The <code><arg></code> must be a <strong>full path</strong>. If the <code><arg></code> contains <code>%s</code> it will be replaced by the block hash. Example: <br><code>./monerod --block-notify="/usr/bin/echo %s"</code><br><br>Block notifications are good for immediate reaction. However, you should always assume you will miss some block notifications and you should independently poll the API to cover this up. <br><br>Mind blockchain reorganizations. Block notifications can revert to same and past heights. Small reorganizations are natural and happen every day.</td> </tr> <tr> <td><code>--block-rate-notify <arg></code></td> <td>Run a program when the number of blocks received in the recent past deviates significantly from the expectation. The <code><arg></code> must be a <strong>full path</strong>. The <code><arg</code>> can contain any of <code>%t</code>, <code>%b</code>, <code>%e</code> symbols to interpolate: <br><br><code>%t</code>: the number of minutes in the observation window<br><br><code>%b</code>: the number of blocks observed in that window<br><br><code>%e</code>: the ideal number of blocks expected in that window<br><br> The option will let you know if the network hash rate drops by a lot. This may be indicative of a large section of the network miners moving off to mine a private chain, to be later released to the network. Note that if this event triggers, it is not incontrovertible proof that this is happening. It might just be chance. The longer the window (the %t parameter), and the larger the distance between actual and expected number of blocks, the more indicative it is of a possible chain reorg double-spend attack being prepared.<br><br><strong>Recommendation:</strong> unless you run economically significant Monero exchange or operation, do <strong>not</strong> act on this data. It is hard to calibrate and easy to misinterpret. If this is a real attack, it will target high-liquidity entities and not small merchants.</td> </tr> <tr> <td><code>--reorg-notify <arg></code></td> <td>Run a program when reorganization happens (ie, at least one block is removed from the top of the blockchain). The <code><arg></code> must be a <strong>full path</strong>. The <code><arg</code>> can contain any of <code>%s</code>, <code>%h</code>, <code>%n</code> symbols to interpolate: <br><br><code>%s</code>: the height at which the split occurs <br><br><code>%h</code>: the height of the new blockchain<br><br><code>%d</code>: the number of blocks discarded from the old chain <br><br><code>%n</code>: the number of blocks being added <br><br> The option will let you know when a block is removed from the chain to be replaced by other blocks. This happens when a 51% attack occurs, but small reorgs also happen in the normal course of things. The <code>%d</code> parameter will be set to the number of blocks discarded from the old chain (so if this is higher than the number of confirmations you wait to act upon an incoming payment, that payment might have been cancelled). The <code>%n</code> parameter wil be set to the number of blocks in the new chain (so if this is higher than the number of confirmations you wait to act upon an incoming payment, any incoming payment in the first block will be automatically acted upon by your platform). <br><br><strong>Recommendation</strong>: unless you run economically significant Monero exchange or operation, you do <strong>not</strong> need to bother with this option. Simply account for reorganizations by requiring at least 10 confirmations before shipping valuable goods.</td> </tr> </tbody> </table> <h4 id=performance>Performance<a class=headerlink href=#performance title="Permanent link">¶</a></h4> <p>These are advanced options that allow you to optimize performance of your <code>monerod</code> node, sometimes at the expense of reliability.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--prune-blockchain</code></td> <td>Pruning saves 2/3 of disk space w/o degrading functionality. For maximum effect this should be used already <strong>on the first sync</strong>. If you add this option later the past data will only be pruned logically w/o shrinking the file size and the gain will be delayed. <br><br>If you already have unpruned blockchain, see the <code>monero-blockchain-prune</code> tool. <br><br>The drawback is that you will contribute less to Monero P2P network in terms of helping new nodes to sync up (up to 1/8 of normal contribution). You will still be useful regarding relaying new transactions and blocks though.</td> </tr> <tr> <td><code>--sync-pruned-blocks</code></td> <td>Accept pruned blocks instead of pruning yourself. It should save network transfer when used with <code>--prune-blockchain</code>. See the <a href=https://github.com/monero-project/monero/commit/8330e772f1ed680a54833d25c4d17d09a99ab8d6>commit</a> and <a href=https://web.getmonero.org/2019/09/08/logs-for-the-dev-meeting-held-on-2019-09-08.html>comments</a>.</td> </tr> <tr> <td><code>--db-sync-mode</code></td> <td>Specify sync option, using format:<br><code>[safe|fast|fastest]:[sync|async]:[<nblocks_per_sync>[blocks]|<nbytes_per_sync>[bytes]]</code><br><br>The default is <code>fast:async:250000000bytes</code>.<br><br>The <code>fast:async:*</code> can corrupt blockchain database in case of a system crash. It should not corrupt if just <code>monerod</code> crashes. If you are concerned with system crashes use <code>safe:sync</code>.</td> </tr> <tr> <td><code>--max-concurrency</code></td> <td>Max number of threads to use for parallel jobs. The default value <code>0</code> uses the number of CPU threads.</td> </tr> <tr> <td><code>--prep-blocks-threads</code></td> <td>Max number of threads to use when computing block hashes (PoW) in groups. Defaults to 4. Decrease this if you don't want <code>monerod</code> hog your computer when syncing.</td> </tr> <tr> <td><code>--fast-block-sync</code></td> <td>Sync up most of the way by using embedded, "known" block hashes. Pass <code>1</code> to turn on and <code>0</code> to turn off. This is on (<code>1</code>) by default. Normally, for every block the full node must calculate the block hash to verify miner's proof of work. Because the CryptoNight PoW used in Monero is very expensive (even for verification), <code>monerod</code> offers skipping these calculations for old blocks. In other words, it's a mechanism to trust <code>monerod</code> binary regarding old blocks' PoW validity, to sync up faster.</td> </tr> <tr> <td><code>--block-sync-size</code></td> <td>How many blocks are processed in a single batch during chain synchronization. By default this is 20 blocks for newer history and 100 blocks for older history ("pre v4"). Default behavior is represented by value <code>0</code>. Intuitively, the more resources you have, the bigger batch size you may want to try out. Example:<br><code>./monerod --block-sync-size=500</code></td> </tr> <tr> <td><code>--bootstrap-daemon-address</code></td> <td>The host:port of a "bootstrap" remote open node that the connected wallets can use while this node is still not fully synced. Example:<br><code>./monerod --bootstrap-daemon-address=opennode.xmr-tw.org:18089</code>. The node will forward selected RPC calls to the bootstrap node. The wallet will handle this automatically and transparently. Obviously, such bootstraping phase has privacy implications similar to directly using a remote node.</td> </tr> <tr> <td><code>--bootstrap-daemon-login</code></td> <td>Specify username:password for the bootstrap daemon login (if required). This considers the RPC interface used by the wallet. Normally, open nodes do not require any credentials.</td> </tr> <tr> <td><code>--no-sync</code></td> <td>Do not sync up. Continue using bootstrap daemon instead (if set). See <a href=https://github.com/monero-project/monero/pull/5195>commit</a>.</td> </tr> </tbody> </table> <h4 id=mining>Mining<a class=headerlink href=#mining title="Permanent link">¶</a></h4> <p>The following options configure <strong>solo mining</strong> using <strong>CPU</strong> with the standard software stack <code>monerod</code>. This is mostly useful for:</p> <ul> <li>generating your <a href=/infrastructure/networks#stagenet>stagenet</a> or <a href=/infrastructure/networks#testnet>testnet</a> coins</li> <li>experimentation and learning</li> <li>if you have super cheap access to vast CPU resources</li> </ul> <p>Be advised though that real mining happens <strong>in pools</strong> and with high-end <strong>GPU-s</strong> instead of CPU-s.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--start-mining</code></td> <td>Specify wallet address to mining for. <strong>This must be a <a href=/public-address/standard-address>standard address</a>!</strong> It can be neither a subaddres nor integrated address.</td> </tr> <tr> <td><code>--mining-threads</code></td> <td>Specify mining threads count. By default ony one thread will be used. For best results, set it to number of your physical cores.</td> </tr> <tr> <td><code>--extra-messages-file</code></td> <td>Specify file for extra messages to include into coinbase transactions.</td> </tr> <tr> <td><code>--bg-mining-enable</code></td> <td>Enable unobtrusive mining. In this mode mining will use a small percentage of your system resources to never noticeably slow down your computer. This is intended to encourage people to mine to improve decentralization. That being said chances of finding a block are diminishingly small with solo CPU mining, and even lesser with its unobtrusive version. You can tweak the unobtrusivness / power trade-offs with the further <code>--bg-*</code> options below.</td> </tr> <tr> <td><code>--bg-mining-ignore-battery</code></td> <td>If true, assumes plugged in when unable to query system power status.</td> </tr> <tr> <td><code>--bg-mining-min-idle-interval</code></td> <td>Specify min lookback interval in seconds for determining idle state.</td> </tr> <tr> <td><code>--bg-mining-idle-threshold</code></td> <td>Specify minimum avg idle percentage over lookback interval.</td> </tr> <tr> <td><code>--bg-mining-miner-target</code></td> <td>Specify maximum percentage cpu use by miner(s).</td> </tr> </tbody> </table> <h4 id=testing-monero-itself>Testing Monero itself<a class=headerlink href=#testing-monero-itself title="Permanent link">¶</a></h4> <p>These options are useful for Monero project developers and testers. Normal users shouldn't be concerned with these.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--keep-alt-blocks</code></td> <td>Keep alternative blocks on restart. May help with researching reorgs etc. <a href=https://github.com/monero-project/monero/pull/5524>Commit</a>. Research project by <a href=https://noncesense-research-lab.github.io/ >noncesense research lab</a>.</td> </tr> <tr> <td><code>--test-drop-download</code></td> <td>For net tests: in download, discard ALL blocks instead checking/saving them (very fast).</td> </tr> <tr> <td><code>--test-drop-download-height</code></td> <td>Like test-drop-download but discards only after around certain height. By default <code>0</code>.</td> </tr> <tr> <td><code>--regtest</code></td> <td>Run in a regression testing mode.</td> </tr> <tr> <td><code>--keep-fakechain</code></td> <td>Don't delete any existing database when in fakechain mode.</td> </tr> <tr> <td><code>--fixed-difficulty</code></td> <td>Fixed difficulty used for testing. By default <code>0</code>.</td> </tr> <tr> <td><code>--test-dbg-lock-sleep</code></td> <td>Sleep time in ms, defaults to 0 (off), used to debug before/after locking mutex. Values 100 to 1000 are good for tests.</td> </tr> <tr> <td><code>--save-graph</code></td> <td>Save data for dr Monero.</td> </tr> </tbody> </table> <h4 id=legacy>Legacy<a class=headerlink href=#legacy title="Permanent link">¶</a></h4> <p>These options should no longer be necessary. They are still present in <code>monerod</code> for backwards compatibility.</p> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>--ban-list</code></td> <td>Specify ban list file, one IP address per line. This was introduced as an emergency measure to deal with large DDoS attacks on Monero p2p network in Dec 2020 / Jan 2021. Example: <br><code>./monerod --ban-list=block_tor.txt</code>. Here is the popular <a href=https://gui.xmr.pm/files/block_tor.txt>block_tor.txt</a> file.<br><br>It is <strong>not recommended</strong> to statically ban any IP addresses unless you absolutely need to. Banning IPs often excludes the most vulnerable users who are forced to operate entirely behind Tor or other anonymity networks.</td> </tr> <tr> <td><code>--enable-dns-blocklist</code></td> <td>Similar to <code>--ban-list</code> but instead of a static file uses dynamic IP blocklist available as DNS TXT entries. The DNS blocklist is centrally managed by Monero contributors. It is <strong>not recommended</strong> unless in emergency situations.</td> </tr> <tr> <td><code>--fluffy-blocks</code></td> <td>Relay compact blocks. Default. Compact block is just a header and a list of transaction IDs.</td> </tr> <tr> <td><code>--no-fluffy-blocks</code></td> <td>Relay classic full blocks. Classic block contains all transactions.</td> </tr> <tr> <td><code>--show-time-stats</code></td> <td>Official docs say "Show time-stats when processing blocks/txs and disk synchronization" but it does not seem to produce any output during usual blockchain synchronization.</td> </tr> <tr> <td><code>--zmq-rpc-bind-ip</code></td> <td>IP for ZMQ RPC server to listen on. By default <code>127.0.0.1</code>. This is not yet widely used as ZMQ interface currently does not provide meaningful advantage over classic JSON-RPC interface.</td> </tr> <tr> <td><code>--zmq-rpc-bind-port</code></td> <td>Port for ZMQ RPC server to listen on. By default <code>18082</code> for mainnet, <code>38082</code> for stagenet, and <code>28082</code> for testnet.</td> </tr> <tr> <td><code>--zmq-pub</code></td> <td>Address for ZMQ pub - <code>tcp://ip:port</code> or <code>ipc://path</code></td> </tr> <tr> <td><code>--db-type</code></td> <td>Specify database type. The default and only available: <code>lmdb</code>.</td> </tr> </tbody> </table> <h2 id=commands>Commands<a class=headerlink href=#commands title="Permanent link">¶</a></h2> <p>Commands give access to specific services provided by the daemon. Commands are executed against the running daemon. Their names follow the <code>command_name</code> pattern.</p> <p>The following groups are only to make reference easier to follow. The daemon itself does not group commands in any way.</p> <p>See <a href=#running>running</a> for example usage. You can also type commands directly in the console of the running <code>monerod</code> (if not detached).</p> <h4 id=help-version-status>Help, version, status<a class=headerlink href=#help-version-status title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>help [<command>]</code></td> <td>Show help for <code><command></code>.</td> </tr> <tr> <td><code>version</code></td> <td>Show version information. Example output:<br><code>Monero 'Boron Butterfly' (v0.14.0.0-release)</code></td> </tr> <tr> <td><code>status</code></td> <td>Show status. Example output:<br><code>Height: 186754/186754 (100.0%) on stagenet, not mining, net hash 317 H/s, v9, up to date, 8(out)+0(in) connections, uptime 0d 3h 48m 47s</code></td> </tr> </tbody> </table> <h4 id=p2p-network_1>P2P network<a class=headerlink href=#p2p-network_1 title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>print_pl</code></td> <td>Show the full peer list.</td> </tr> <tr> <td><code>print_pl_stats</code></td> <td>Show the full peer list statistics (white vs gray peers). White peers are online and reachable. Grey peers are offline but your <code>monerod</code> remembers them from past sessions.</td> </tr> <tr> <td><code>print_cn</code></td> <td>Show connected peers with connection initiative (incoming/outgoing) and other stats.</td> </tr> <tr> <td><code>ban <IP> [<seconds>]</code></td> <td>Ban a given <code><IP></code> for a given amount of <code><seconds></code>. By default the ban is for 24h. Example:<br><code>./monerod ban 187.63.135.161</code>.</td> </tr> <tr> <td><code>unban <IP></code></td> <td>Unban a given <code><IP></code>.</td> </tr> <tr> <td><code>bans</code></td> <td>Show the currently banned IPs. Example output:<br><code>187.63.135.161 banned for 86397 seconds</code>.</td> </tr> <tr> <td><code>in_peers <max_number></code></td> <td>Set the <max_number> of incoming connections from other peers.</td> </tr> <tr> <td><code>out_peers <max_number></code></td> <td>Set the <max_number> of outgoing connections to other peers.</td> </tr> <tr> <td><code>limit [<kB/s>]</code></td> <td>Get or set the download and upload limit.</td> </tr> <tr> <td><code>limit_down [<kB/s>]</code></td> <td>Get or set the download limit.</td> </tr> <tr> <td><code>limit_up [<kB/s>]</code></td> <td>Get or set the upload limit.</td> </tr> </tbody> </table> <h4 id=transaction-pool>Transaction pool<a class=headerlink href=#transaction-pool title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>flush_txpool [<txid>]</code></td> <td>Flush specified transaction from transactions pool, or flush the whole transactions pool if <txid> was not provided.</td> </tr> <tr> <td><code>print_pool</code></td> <td>Print the transaction pool using a verbose format.</td> </tr> <tr> <td><code>print_pool_sh</code></td> <td>Print the transaction pool using a short format.</td> </tr> <tr> <td><code>print_pool_stats</code></td> <td>Print the transaction pool's statistics (number of transactions, memory size, fees, double spend attempts etc).</td> </tr> </tbody> </table> <h4 id=transactions>Transactions<a class=headerlink href=#transactions title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>print_coinbase_tx_sum <start_height> [<block_count>]</code></td> <td>Show a sum of all emitted coins and paid fees within specified range. Example:<br><code>./monerod print_coinbase_tx_sum 0 1000000000000</code></td> </tr> <tr> <td><code>print_tx <transaction_hash> [+hex] [+json]</code></td> <td>Show specified transaction as JSON and/or HEX.</td> </tr> <tr> <td><code>relay_tx <txid></code></td> <td>Force relaying the transaction. Useful if you want to rebroadcast the transaction for any reason or if transaction was previously created with "do_not_relay":true.</td> </tr> </tbody> </table> <h4 id=blockchain>Blockchain<a class=headerlink href=#blockchain title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>print_height</code></td> <td>Show local blockchain height.</td> </tr> <tr> <td><code>sync_info</code></td> <td>Show blockchain sync progress and connected peers along with download / upload stats.</td> </tr> <tr> <td><code>print_bc <begin_height> [<end_height>]</code></td> <td>Show blocks in range <code><begin_height></code>..<code><end_height></code>. The information will include block id, height, timestamp, version, size, weight, number of non-coinbase transactions, difficulty, nonce, and reward.</td> </tr> <tr> <td><code>print_block <block_hash> | <block_height></code></td> <td>Show detailed data of specified block.</td> </tr> <tr> <td><code>hard_fork_info</code></td> <td>Show current consensus version and future hard fork block height, if any.</td> </tr> <tr> <td><code>is_key_image_spent <key_image></code></td> <td>Check if specified <a href=/cryptography/asymmetric/key-image/ >key image</a> is spent. Key image is a hash.</td> </tr> </tbody> </table> <h4 id=manage-daemon>Manage daemon<a class=headerlink href=#manage-daemon title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>exit</code>, <code>stop_daemon</code></td> <td>Ask daemon to exit gracefully. The <code>exit</code> and <code>stop_daemon</code> are identical (one is alias of the other).</td> </tr> <tr> <td><code>set_log <level>|<{+,-,}categories></code></td> <td>Set the current log level/categories where <code><level></code> is a number 0-4.</td> </tr> <tr> <td><code>print_status</code></td> <td>Show if daemon is running.</td> </tr> <tr> <td><code>update (check|download)</code></td> <td>Check if update is available and optionally download it. The hash is SHA-256. On linux use <code>sha256sum</code> to verify. Example output:<br><code>Update available: v0.13.0.4: https://downloads.getmonero.org/cli/monero-linux-x64-v0.13.0.4.tar.bz2, hash 693e1a0210201f65138ace679d1ab1928aca06bb6e679c20d8b4d2d8717e50d6</code><br><code>Update downloaded to: /opt/monero-v0.13.0.2/monero-linux-x64-v0.13.0.4.tar.bz2</code></td> </tr> </tbody> </table> <h4 id=mining_1>Mining<a class=headerlink href=#mining_1 title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>show_hr</code></td> <td>Ask <code>monerod</code> daemon to print current hash rate. Relevant only if <code>monerod</code> is mining.</td> </tr> <tr> <td><code>hide_hr</code></td> <td>Ask <code>monerod</code> daemon to stop printing current hash rate. Relevant only if <code>monerod</code> is mining.</td> </tr> <tr> <td><code>start_mining <addr> [<threads>] [do_background_mining] [ignore_battery]</code></td> <td>Ask <code>monerod</code>daemon to start mining. Block reward will go to <code><addr></code>.</td> </tr> <tr> <td><code>stop_mining</code></td> <td>Ask <code>monerod</code> daemon to stop mining.</td> </tr> </tbody> </table> <h4 id=testing-monero-itself_1>Testing Monero itself<a class=headerlink href=#testing-monero-itself_1 title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>start_save_graph</code></td> <td>Start saving data for dr Monero.</td> </tr> <tr> <td><code>stop_save_graph</code></td> <td>Stop saving data for dr Monero.</td> </tr> </tbody> </table> <h4 id=legacy_1>Legacy<a class=headerlink href=#legacy_1 title="Permanent link">¶</a></h4> <table> <thead> <tr> <th>Option</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td><code>save</code></td> <td>Flush blockchain data to disk. This is normally no longer necessary as <code>monerod</code> saves the blockchain automatically on exit.</td> </tr> <tr> <td><code>output_histogram [@<amount>] <min_count> [<max_count>]</code></td> <td>Show number of outputs for each amount denomination. This was only relevant in the pre-RingCT era. The old wallet used this to determine which outputs can be used for the requested mixin. With RingCT denominations are irrelevant as amounts are hidden. More info in <a href="https://monero.stackexchange.com/search?q=%22output_histogram%22">these SA answers</a>.</td> </tr> </tbody> </table> </article> </div> </div> </main> <footer class=md-footer> <div class=md-footer-nav> <nav class="md-footer-nav__inner md-grid" aria-label=Footer> <a href=../monero-config-file/ class="md-footer-nav__link md-footer-nav__link--prev" rel=prev> <div class="md-footer-nav__button md-icon"> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> </div> <div class=md-footer-nav__title> <div class=md-ellipsis> <span class=md-footer-nav__direction> Previous </span> Config file </div> </div> </a> <a href=../monero-wallet-cli-reference/ class="md-footer-nav__link md-footer-nav__link--next" rel=next> <div class=md-footer-nav__title> <div class=md-ellipsis> <span class=md-footer-nav__direction> Next </span> monero-wallet-cli </div> </div> <div class="md-footer-nav__button md-icon"> <svg xmlns=http://www.w3.org/2000/svg viewbox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11H4z"/></svg> </div> </a> </nav> </div> <div class="md-footer-meta md-typeset"> <div class="md-footer-meta__inner md-grid"> <div class=md-footer-copyright style="margin: auto;"> <a href=http://bumz4sduzxzlobbgzy5fiufdflg3mo2jyecdwdx5rphrqldms7wlmiid.onion/ >Tor onion version</a> | <a href=https://qertoip.com/ >contact</a> | © 2021 MoneroDocs under <a href=https://opensource.org/licenses/MIT>MIT</a> | built w/ <a href=https://www.mkdocs.org/ >mkdocs</a> and <a href=https://squidfunk.github.io/mkdocs-material/ >squidfunk/material</a> </div> </div> </div> </footer> </div> <script src=../../assets/javascripts/vendor.93c04032.min.js></script> <script src=../../assets/javascripts/bundle.83e5331e.min.js></script><script id=__lang type=application/json>{"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.term.missing": "Missing"}</script> <script>
|
||
app = initialize({
|
||
base: "../..",
|
||
features: [],
|
||
search: Object.assign({
|
||
worker: "../../assets/javascripts/worker/search.8c7e0a7e.min.js"
|
||
}, typeof search !== "undefined" && search)
|
||
})
|
||
</script> </body> </html> |