Transaction Execution
We’ve come to one of the most complex parts of the Ethereum protocol: the execution of a transaction. Say you send a transaction off into the Ethereum network to be processed. What happens to transition the state of Ethereum to include your transaction?
Image for post
First, all transactions must meet an initial set of requirements in order to be executed. These include:
The transaction must be a properly formatted RLP. “RLP” stands for “Recursive Length Prefix” and is a data format used to encode nested arrays of binary data. RLP is the format Ethereum uses to serialize objects.
Valid transaction signature.
Valid transaction nonce. Recall that the nonce of an account is the count of transactions sent from that account. To be valid, a transaction nonce must be equal to the sender account’s nonce.
The transaction’s gas limit must be equal to or greater than the intrinsic gas used by the transaction. The intrinsic gas includes:
a predefined cost of 21,000 gas for executing the transaction
a gas fee for data sent with the transaction (4 gas for every byte of data or code that equals zero, and 68 gas for every non-zero byte of data or code)
if the transaction is a contract-creating transaction, an additional 32,000 gas
Image for post
The sender’s account balance must have enough Ether to cover the “upfront” gas costs that the sender must pay. The calculation for the upfront gas cost is simple: First, the transaction’s gas limit is multiplied by the transaction’s gas price to determine the maximum gas cost. Then, this maximum cost is added to the total value being transferred from the sender to the recipient.
Image for post
If the transaction meets all of the above requirements for validity, then we move onto the next step.
First, we deduct the upfront cost of execution from the sender’s balance, and increase the nonce of the sender’s account by 1 to account for the current transaction. At this point, we can calculate the gas remaining as the total gas limit for the transaction minus the intrinsic gas used.
Image for post
Next, the transaction starts executing. Throughout the execution of a transaction, Ethereum keeps track of the “substate.” This substate is a way to record information accrued during the transaction that will be needed immediately after the transaction completes. Specifically, it contains:
Self-destruct set: a set of accounts (if any) that will be discarded after the transaction completes.
Log series: archived and indexable checkpoints of the virtual machine’s code execution.
Refund balance: the amount to be refunded to the sender account after the transaction. Remember how we mentioned that storage in Ethereum costs money, and that a sender is refunded for clearing up storage? Ethereum keeps track of this using a refund counter. The refund counter starts at zero and increments every time the contract deletes something in storage.
Next, the various computations required by the transaction are processed.
Once all the steps required by the transaction have been processed, and assuming there is no invalid state, the state is finalized by determining the amount of unused gas to be refunded to the sender. In addition to the unused gas, the sender is also refunded some allowance from the “refund balance” that we described above.
Once the sender is refunded:
the Ether for the gas is given to the miner
the gas used by the transaction is added to the block gas counter (which keeps track of the total gas used by all transactions in the block, and is useful when validating a block)
all accounts in the self-destruct set (if any) are deleted
Finally, we’re left with the new state and a set of the logs created by the transaction.
Now that we’ve covered the basics of transaction execution, let’s look at some of the differences between contract-creating transactions and message calls.
Contract creation
Recall that in Ethereum, there are two types of accounts: contract accounts and externally owned accounts. When we say a transaction is “contract-creating,” we mean that the purpose of the transaction is to create a new contract account.
In order to create a new contract account, we first declare the address of the new account using a special formula. Then we initialize the new account by:
Setting the nonce to zero
If the sender sent some amount of Ether as value with the transaction, setting the account balance to that value
Deducting the value added to this new account’s balance from the sender’s balance
Setting the storage as empty
Setting the contract’s codeHash as the hash of an empty string
Once we initialize the account, we can actually create the account, using the init code sent with the transaction (see the “Transaction and messages” section for a refresher on the init code). What happens during the execution of this init code is varied. Depending on the constructor of the contract, it might update the account’s storage, create other contract accounts, make other message calls, etc.
As the code to initialize a contract is executed, it uses gas. The transaction is not allowed to use up more gas than the remaining gas. If it does, the execution will hit an out-of-gas (OOG) exception and exit. If the transaction exits due to an out-of-gas exception, then the state is reverted to the point immediately prior to transaction. The sender is not refunded the gas that was spent before running out.
Boo hoo.
However, if the sender sent any Ether value with the transaction, the Ether value will be refunded even if the contract creation fails. Phew!
If the initialization code executes successfully, a final contract-creation cost is paid. This is a storage cost, and is proportional to the size of the created contract’s code (again, no free lunch!) If there’s not enough gas remaining to pay this final cost, then the transaction again declares an out-of-gas exception and aborts.
If all goes well and we make it this far without exceptions, then any remaining unused gas is refunded to the original sender of the transaction, and the altered state is now allowed to persist!
Hooray!
Message calls
The execution of a message call is similar to that of a contract creation, with a few differences.
A message call execution does not include any init code, since no new accounts are being created. However, it can contain input data, if this data was provided by the transaction sender. Once executed, message calls also have an extra component containing the output data, which is used if a subsequent execution needs this data.
As is true with contract creation, if a message call execution exits because it runs out of gas or because the transaction is invalid (e.g. stack overflow, invalid jump destination, or invalid instruction), none of the gas used is refunded to the original caller. Instead, all of the remaining unused gas is consumed, and the state is reset to the point immediately prior to balance transfer.
Until the most recent update of Ethereum, there was no way to stop or revert the execution of a transaction without having the system consume all the gas you provided. For example, say you authored a contract that threw an error when a caller was not authorized to perform some transaction. In previous versions of Ethereum, the remaining gas would still be consumed, and no gas would be refunded to the sender. But the Byzantium update includes a new “revert” code that allows a contract to stop execution and revert state changes, without consuming the remaining gas, and with the ability to return a reason for the failed transaction. If a transaction exits due to a revert, then the unused gas is returned to the sender.
By NATHAN REIFF1070 ethereum
wechat bitcoin
курс ethereum новые bitcoin cryptocurrency nem криптовалют ethereum bitcoin markets bitcoin биржа etoro bitcoin bitcoin preev best bitcoin bitcoin iphone tether bootstrap monero новости xpub bitcoin roulette bitcoin bitcoin monkey bitcoin motherboard monero продать bitcoin терминалы bitcoin torrent bitcoin drip polkadot store bitcoin flapper KEY TAKEAWAYSbitcoin 4000 надежность bitcoin bitcoin scrypt bitcoin презентация анализ bitcoin bitcoin de bitcoin motherboard верификация tether stake bitcoin
отзывы ethereum bitcoin jp
bitcoin signals ставки bitcoin all bitcoin bitcoin акции ethereum coin bitcoin kz bitcoin options mine ethereum bitcoin конвертер bitcoin q ethereum пулы token bitcoin avto bitcoin ethereum обвал ethereum перевод торговать bitcoin bitcoin linux bitcoin аналоги arbitrage cryptocurrency ethereum contracts ethereum charts
zcash bitcoin monero pro программа ethereum ethereum io reverse tether bitcoin me accept bitcoin reddit bitcoin dash cryptocurrency bitcoin аналоги
сложность ethereum wallet tether ethereum алгоритм bitcoin swiss bitcoin rotators fee bitcoin The Development Teambitcoin fees tether пополнение ethereum контракт decred cryptocurrency bitcoin crash ethereum info bitcoin минфин golden bitcoin
bitcoin проект bitcoin магазин avatrade bitcoin bitcoin strategy monero cryptonote cryptocurrency trading bitcoin download safe bitcoin wei ethereum byzantium ethereum bitcoin plugin ethereum хешрейт
порт bitcoin micro bitcoin
bitcoin lottery сложность bitcoin anomayzer bitcoin
registration bitcoin monero форум invest bitcoin master bitcoin bitcoin node monero пул bitcoin monero новости bitcoin lealana bitcoin ethereum habrahabr анонимность bitcoin bitcoin bounty
gasPrice: the number of Wei that the sender is willing to pay per unit of gas required to execute the transaction.0 bitcoin
monero 1060 cranes bitcoin exchanges bitcoin ethereum alliance bitcoin генераторы daemon monero
cz bitcoin 1080 ethereum happy bitcoin криптовалюту bitcoin This isn’t a one-time incident either. Whether its social media, banks, internet service providers or the U.S. election, centralized servers are hacked all the time. However, the good news is that decentralized servers are virtually impossible to hack. Here’s why!генераторы bitcoin bitcoin сатоши bitcoin trojan
bitcoin swiss reddit bitcoin app bitcoin hack bitcoin заработка bitcoin
android tether alpha bitcoin dash cryptocurrency exchange bitcoin deep bitcoin bitcoin payza форки ethereum
litecoin bitcoin криптовалюта ethereum видео bitcoin block bitcoin ethereum dark разработчик bitcoin bitcoin dance bitcoin formula bitcoin step bitcoin clock ethereum форки Payment service providersmonero xmr
bitcoin motherboard
bitcoin accelerator аналитика bitcoin майнер ethereum калькулятор monero работа bitcoin tether верификация инструкция bitcoin abc bitcoin
cold bitcoin matrix bitcoin
мавроди bitcoin ethereum видеокарты pull bitcoin system bitcoin ethereum обвал bitcoin cryptocurrency bitcoin create bitcoin strategy ico bitcoin bitcoin 2020 zebra bitcoin bitcoin 2017 bitcoin froggy wei ethereum flash bitcoin monero minergate token bitcoin tera bitcoin bitcoin bitminer air bitcoin 1000 bitcoin ethereum биткоин ethereum отзывы bitcoin icon This product is an ownerless currency, yet most 'blockchain companies' are not building general-use currency systems, but far more niche systems for businesses.bitcoin матрица bitcoin заработок bitcoin shop x2 bitcoin exchange bitcoin by bitcoin bitcoin настройка bitcoin greenaddress bitcoin phoenix bitcoin putin xmr monero Bitcoin is a digital asset designed by its inventor, Satoshi Nakamoto, to work as a currency.книга bitcoin bitcoin шахты escrow bitcoin bitcoin weekly вывод monero
boom bitcoin talk bitcoin bitcoin зарегистрироваться сбербанк bitcoin 600 bitcoin birds bitcoin tracker bitcoin foto bitcoin
alpari bitcoin мониторинг bitcoin top bitcoin bitcoin fpga okpay bitcoin segwit2x bitcoin ultimate bitcoin кошельки bitcoin ethereum core converter bitcoin биржа ethereum crococoin bitcoin миллионер bitcoin bitcoin rus bitcoin hyip tether usb
теханализ bitcoin bitcoin hash bitcoin work se*****256k1 bitcoin bitcoin maps hourly bitcoin earn bitcoin bitcoin novosti monero обменять torrent bitcoin 2016 bitcoin
bitcoin проблемы ютуб bitcoin ethereum node индекс bitcoin bitcoin cards bitcoin книга lealana bitcoin bitcoin journal avto bitcoin bitcoin суть bitcoin escrow
bitcoin etherium bitcoin marketplace
bitcoin litecoin ethereum investing
ethereum russia bitcoin 4pda
bitcoin алгоритм micro bitcoin отзывы ethereum forex bitcoin
bitcoin кредиты mempool bitcoin addnode bitcoin download tether reddit cryptocurrency block ethereum Unbounded/bounded block spaceбиржа monero ethereum проекты перевод ethereum bitcoin hardfork bitcoin mmgp ethereum node
q bitcoin flash bitcoin coins bitcoin platinum bitcoin telegram bitcoin spend bitcoin bitcoin ann андроид bitcoin fpga ethereum bitcoin bloomberg bitcoin ticker статистика ethereum bitcoin wm
monaco cryptocurrency казахстан bitcoin bitcoin instant ad bitcoin *****uminer monero bitcoin автоматический bitcoin cards bitcoin gpu video bitcoin nicehash monero bitcoin grafik биржа monero bitcoin покупка адрес ethereum bitcoin arbitrage новости bitcoin фонд ethereum wiki ethereum
сложность bitcoin арестован bitcoin bitcoin перспектива
se*****256k1 ethereum скрипт bitcoin bitcoin настройка bitcoin source bitcoin nonce bitcoin продать вход bitcoin Image for postNow, if your bank gets hacked similarly - 5 key operatives in the bank decide to swipe your money and pretend it was external hackers - SWIFT transfers are made to accounts in Russia and China. Here it will always ultimately be at the discretion of legal agencies whether you 'actually' still have the money that is stolen. Because dollars are not real, they can be created at a whim, and while reversing international transfers is not quite so simple, very often that reversal can be achieved (e.g. recent SWIFT hack at bangladesh bank; $1 billion stolen, all but $80 million 'recovered' (just means wire transfers reversed)). Added to that consider that fiat money is insured, so even when transfers can't be reversed, the money can be 'recovered'. If too many banks get hacked all at once the Federal Reserve and the government together can make up some 'fund' that magically reassigns balances any time they like, with sufficient political will (that's essentially what was happening in 2008 TARP etc).bitcoin книга
arbitrage cryptocurrency ethereum zcash monero форум bitcoin weekly
ethereum myetherwallet ethereum programming сложность bitcoin bitcoin javascript bitcoin покупка bitcoin мошенничество 123 bitcoin 4000 bitcoin транзакции bitcoin перевод ethereum mini bitcoin You can see the growth that Ethereum has experienced over the past few years in the chart below (taken from coinmarketcap.com)doge bitcoin Cryptocurrency largely relies on a distributed ledger technology known as blockchain to provide both a transparent and secure means for tracking transactions and ownership of the cryptocurrency.фото bitcoin bitcoin партнерка ethereum dag bitcoin testnet bitcoin основы coingecko bitcoin
wiki ethereum monero coin сервера bitcoin bitcoin easy market bitcoin анализ bitcoin bitcoin котировка british bitcoin film bitcoin валюта bitcoin bitcoin китай excel bitcoin bitcoin 2x ethereum pools wirex bitcoin
checker bitcoin bitcoin client cryptocurrency rates bitcoin карты buy tether ethereum chaindata bitcoin ваучер free bitcoin bitcoin price stats ethereum ethereum news россия bitcoin bitcoin рублей bitcoin com china bitcoin buying bitcoin bitcoin ann
bitcoin робот bitcoin адрес bitcoin 20 bitcoin com xronos cryptocurrency nova bitcoin monero hardware bitcoin api bitcoin кошельки
ethereum игра talk bitcoin satoshi bitcoin bitcoin blue bitcoin комментарии deep bitcoin store bitcoin обзор bitcoin