Create and send transactions
You can send signed transactions using the eth_sendRawTransaction
JSON-RPC API method.
Signed transactions can be simple value transfers, contract creation, or contract invocation. Set the
maximum transaction fee for transactions using the --rpc-tx-feecap
CLI option.
Use client libraries to create and send a signed raw transaction to transfer Ether and create a smart contract.
To accept signed transactions from remote connections, set the API listening host
to 0.0.0.0
. Setting the listening host to 0.0.0.0
exposes the API service connection on your node to
any remote connection. In a production environment, ensure you are using a firewall to avoid exposing
your node to the internet.
Don't use the accounts from the examples on Mainnet or any public network except for testing. The private keys are displayed which means the accounts are not secure.
All accounts and private keys in the examples are from the dev.json
genesis file in the /besu/config/src/main/resources
directory.
In production environments avoid exposing your private keys by creating signed transactions offline, or use Web3Signer to isolate your private keys and sign transactions with eth_sendTransaction
.
eth_call
vs eth_sendRawTransaction
You can interact with contracts using eth_call
or eth_sendRawTransaction
. The table below compares the characteristics of both calls.
eth_call | eth_sendRawTransaction |
---|---|
Read-only | Write |
Invokes contract function locally | Broadcasts to the network |
Does not change state of blockchain | Updates the blockchain (for example, transfers ether between accounts) |
Does not consume gas | Requires gas |
Synchronous | Asynchronous |
Returns the value of a contract function available immediately | Returns transaction hash only. A block might not include all possible transactions (for example, if the gas price is too low). |
Override state values
Use eth_call
to override an account with temporary state values before
making the call. This allows you to make temporary state changes without affecting the actual
blockchain state, and provides the following benefits:
- Minimizes the amount of contract code required to be deployed onchain. Code that returns internal state or performs predefined validations can be kept offchain and provided to the node on demand.
- Extends and invokes custom methods on deployed contracts for analysis and debugging, avoiding the need to reconstruct the entire state in a sandbox, and allowing selective state or code overrides to observe execution changes.
Use wallets for key management
Besu doesn't support key management inside the client. Use:
- Web3Signer with Besu to provide access to your key store and sign transactions.
- Third-party tools (for example, MetaMask and web3j) for creating accounts.