Transacties
Laatst bewerkt: @tarcanhursit(opens in a new tab), 11 augustus 2024
Transacties zijn cryptografisch ondertekende instructies van accounts. Een account zal een transactie starten om de status van het Ethereum-netwerk bij te werken. De eenvoudigste transactie is het overmaken van ETH van het ene account naar het andere.
Randvoorwaarden
Om u te helpen om deze pagina beter te begrijpen, raden we u aan om eerst onze Accounts en onze inleiding tot Ethereum te lezen.
Wat is een transactie?
Een Ethereum-transactie verwijst naar een actie die gestart wordt door een account in externe eigendom, met andere woorden een account dat beheerd wordt door een mens, en niet door een contract. Als Bob bijvoorbeeld 1 ETH naar Alice stuurt, moet het account van Bob gedebiteerd worden en dat van Alice gecrediteerd. Deze actie waarbij de status wordt gewijzigd, vindt plaats binnen een transactie.
Aangepast diagram van Ethereum-EVM geïllustreerd(opens in a new tab)
Transacties die de toestand van de EVM veranderen, moeten naar het hele netwerk worden uitgezonden. Elke node kan een verzoek uitzenden om een transactie uit te voeren op de EVM; nadat dit is gebeurd, zal een validator de transactie uitvoeren en de resulterende statuswijziging verspreiden naar de rest van het netwerk.
Transacties vragen om een kost en moeten worden opgenomen in een gevalideerde block. Om dit overzicht eenvoudiger te maken, behandelen we de gaskosten en validatie ergens anders.
Een ingediende transactie bevat de volgende informatie:
from
: het adres van de afzender die de transactie zal ondertekenen. Dit is een account in externe eigendom, aangezien contractaccounts geen transacties kunnen verzenden.to
: het ontvangende adres (als het een account in externe eigendom is, zal de transactie de waarde overdragen. Als het een contractaccount is, zal de transactie de contractcode uitvoeren)signature
: de identificator van de afzender. Dit wordt gegenereerd wanneer de persoonlijke sleutel van de afzender de transactie ondertekent en bevestigt dat de afzender deze transactie heeft geautoriseerdnonce
: een sequentieel oplopende teller die het transactienummer van het account aangeeftvalue
: hoeveelheid ETH over te dragen van afzender naar ontvanger (uitgedrukt in WEI, waarbij 1ETH gelijk is aan 1e+18wei)input data
: optioneel veld om willekeurige gegevens in te plaatsengasLimit
: de maximale hoeveelheid gaseenheden die door de transactie kan worden verbruikt. De EVM specificeert de benodigde gaseenheden voor elke rekenstapmaxPriorityFeePerGas
: de maximumprijs van het verbruikte gas dat als fooi aan de validator wordt gegevenmaxFeePerGas
- de maximale kost per eenheid gas bereid te betalen voor de transactie (inclusiefbaseFeePerGas
enmaxPriorityFeePerGas
)
Gas is een verwijzing naar de berekening die nodig is om de transactie te verwerken door een validator. Gebruikers moeten een kost betalen voor deze berekening. De gasLimit
en maxPriorityFeePerGas
bepalen de maximale transactiekost die aan de validator wordt betaald. Meer over gas.
Het transactie-object zal er ongeveer zo uitzien:
1{2 from: "0xEA674fdDe714fd979de3EdF0F56AA9716B898ec8",3 to: "0xac03bb73b6a9e108530aff4df5077c2b3d481e5a",4 gasLimit: "21000",5 maxFeePerGas: "300",6 maxPriorityFeePerGas: "10",7 nonce: "0",8 value: "10000000000"9}Toon alleKopiëren
Maar een transactie-object moet worden ondertekend met de persoonlijke sleutel van de afzender. Dit bewijst dat de transactie alleen van de afzender afkomstig kan zijn en niet frauduleus is verzonden.
Een Ethereum client zoals Geth zal dit ondertekeningsproces afhandelen.
Voorbeeld JSON-RPC call:
1{2 "id": 2,3 "jsonrpc": "2.0",4 "method": "account_signTransaction",5 "params": [6 {7 "from": "0x1923f626bb8dc025849e00f99c25fe2b2f7fb0db",8 "gas": "0x55555",9 "maxFeePerGas": "0x1234",10 "maxPriorityFeePerGas": "0x1234",11 "input": "0xabcd",12 "nonce": "0x0",13 "to": "0x07a565b7ed7d7a678680a4c162885bedbb695fe0",14 "value": "0x1234"15 }16 ]17}Toon alleKopiëren
Voorbeeldreactie:
1{2 "jsonrpc": "2.0",3 "id": 2,4 "result": {5 "raw": "0xf88380018203339407a565b7ed7d7a678680a4c162885bedbb695fe080a44401a6e4000000000000000000000000000000000000000000000000000000000000001226a0223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20ea02aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663",6 "tx": {7 "nonce": "0x0",8 "maxFeePerGas": "0x1234",9 "maxPriorityFeePerGas": "0x1234",10 "gas": "0x55555",11 "to": "0x07a565b7ed7d7a678680a4c162885bedbb695fe0",12 "value": "0x1234",13 "input": "0xabcd",14 "v": "0x26",15 "r": "0x223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20e",16 "s": "0x2aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663",17 "hash": "0xeba2df809e7a612a0a0d444ccfa5c839624bdc00dd29e3340d46df3870f8a30e"18 }19 }20}Toon alleKopiëren
- de
raw
is de ondertekende transactie in Recursive Length Prefix (RLP)-gecodeerde vorm - de
tx
is de ondertekende transactie in JSON-vorm
Met de hash van de handtekening kan cryptografisch bewezen worden dat de transactie afkomstig is van de afzender en ingediend is bij het netwerk.
Het dataveld
De overgrote meerderheid van de transacties heeft toegang tot een contract vanaf een account in externe eigendom. De meeste contracten zijn geschreven in Solidity en interpreteren hun gegevensveld in overeenstemming met de .
De eerste vier bytes geven aan welke functie moet worden opgeroepen, met behulp van de hash van de naam en argumenten van de functie. Soms kunt u de functie uit de selector identificeren met behulp van deze database(opens in a new tab).
De rest van de calldata zijn de argumenten, gecodeerd zoals aangegeven in de ABI-specificaties(opens in a new tab).
Laten we bijvoorbeeld eens kijken naar deze transactie(opens in a new tab). Gebruik Klik om meer te zien om de calldata te bekijken.
De functieselector is 0xa9059cbb
. Er zijn verschillende bekende functies met deze handtekening(opens in a new tab). In dit geval is de contractbroncode(opens in a new tab) geüpload naar Etherscan, dus we weten dat de functie transfer(address,uint256)
is.
De rest van de gegevens zijn:
10000000000000000000000004f6742badb049791cd9a37ea913f2bac38d012792000000000000000000000000000000000000000000000000000000003b0559f4
Volgens de ABI-specificaties verschijnen gehele waarden (zoals adressen, die gehele getallen van 20 bytes zijn) in de ABI als woorden van 32 bytes, opgevuld met nullen vooraan. We weten dus dat het to
-adres 4f6742badb049791cd9a37ea913f2bac38d01279
(opens in a new tab) is. De value
is 0x3b0559f4 = 990206452.
Types transacties
Op Ethereum zijn er verschillende soorten transacties:
- Reguliere transacties: een transactie van het ene account naar het andere.
- Contractimplementatietransacties: een transactie zonder een 'to'-adres, waarbij het gegevensveld wordt gebruikt voor de contractcode.
- Uitvoering van een contract: een transactie die interactie heeft met een ingezet smart contract. In dit geval is het 'to'-adres het smart contract-adres.
Over gas
Zoals gezegd, kosten transacties gas om uit te voeren. Eenvoudige overschrijvingstransacties vereisen 21.000 eenheden gas.
Dus als Bob 1 ETH zou sturen naar Alice met een baseFeePerGas
van 190 gwei en een maxPriorityFeePerGas
van 10 gwei, zal Bob de volgende kosten moeten betalen:
1(190 + 10) * 21000 = 4.200.000 gwei2--of-30,0042 ETH
Bob's account zal worden gedebiteerd met -1,0042 ETH (1 ETH voor Alice + 0,0042 ETH aan gaskosten)
Alice's account zal worden gecrediteerd met +1,0 ETH
De basiskost van -0,00399 ETH wordt verbrand
Validator houdt de fooi van +0,000210 ETH zelf bij
Aangepast diagram van Ethereum-EVM geïllustreerd(opens in a new tab)
Gas dat niet wordt gebruikt in een transactie, wordt terugbetaald op het gebruikersaccount.
Smart contract-interactions
Gas is vereist voor elke transactie waar een smart contract bij betrokken is.
Smart contracts kunnen ook functies bevatten die bekend staan als view
(opens in a new tab)- of pure
(opens in a new tab) functies, die de status van het contract niet veranderen. Voor het aanroepen van deze functies vanuit een EOA is dus geen gas nodig. De onderliggende RPC-aanroep voor dit scenario is eth_call
In tegenstelling tot wanneer eth_call
wordt gebruikt, worden deze view
- of pure
-functies ook vaak intern aangeroepen (d.w.z. vanuit het contract zelf of vanuit een ander contract), wat gas kost.
Transactielevenscyclus
Zodra de transactie is ingediend, gebeurt het volgende:
- Een transactie-hash wordt cryptografisch gegenereerd:
0x97d99bc7729211111a21b12c933c949d4f31684f1d6954ff477d0477538ff017
- De transactie wordt vervolgens uitgezonden naar het netwerk en toegevoegd aan een transactiepool die bestaat uit alle andere netwerktransacties die in behandeling zijn.
- Een validator moet uw transactie kiezen en in een block opnemen om de transactie te verifiëren en als “succesvol” te beschouwen.
- Na verloop van tijd wordt de block die uw transactie bevat geüpgraded naar “gerechtvaardigd” en vervolgens naar “gefinaliseerd”. Deze upgrades maken het veel zekerder dat uw transactie succesvol was en nooit zal worden gewijzigd. Als een block eenmaal “gefinaliseerd” is, kan het alleen worden veranderd door een aanval op netwerkniveau die vele miljarden dollars zou kosten.
Een visuele demo
Austin leidt u door transacties, gas en mining.
Getypte transactie-envelop
Ethereum had oorspronkelijk één formaat voor transacties. Elke transactie bevatte een nonce, gasprijs, gaslimiet, to-adres, waarde, gegevens, v, r en s. Deze velden zijn RLP-gecodeerd, om er ongeveer zo uit te zien:
RLP([nonce, gasPrice, gasLimit, to, value, data, v, r, s])
Ethereum heeft zich ontwikkeld om meerdere soorten transacties te ondersteunen om nieuwe functies, zoals toegangslijsten en EIP-1559(opens in a new tab) te kunnen implementeren, zonder oudere transactieformaten te beïnvloeden.
EIP-2718(opens in a new tab) maakt dit gedrag mogelijk. Transacties worden geïnterpreteerd als:
TransactionType || TransactionPayload
Waar de velden worden gedefinieerd als:
TransactionType
: een getal tussen 0 en 0x7f, voor een totaal van 128 mogelijke transactietypes.TransactionPayload
: een willekeurige byte array gedefinieerd door het transactietype.
Op basis van de waarde TransactionType
kan een transactie worden geclassificeerd als
Type 0 (oudere) transacties: het oorspronkelijke transactieformaat dat sinds de lancering van Ethereum wordt gebruikt. Ze bevatten geen functies uit EIP-1559(opens in a new tab) zoals dynamische berekeningen van gaskosten of toegangslijsten voor smart contracts. Oudere transacties hebben geen specifieke prefix die hun type aangeeft in hun seriële vorm, beginnend met de byte
0xf8
bij gebruik van Recursive Length Prefix (RLP)-codering. De TransactionType-waarde voor deze transacties is0x0
.Transacties van type 1: Sinds EIP-2930(opens in a new tab) geïntroduceerd als onderdeel van de Berlin-upgrade van Ethereum, bevatten deze transacties een
accessList
-parameter. Deze lijst geeft adressen en opslagsleutels aan waartoe de transactie toegang verwacht te krijgen, wat helpt om mogelijk de gaskosten te verminderen voor complexe transacties waarbij smart contracts betrokken zijn. De marktwijzigingen voor EIP-1559-kosten zijn niet opgenomen in transacties van type 1. Transacties van type 1 bevatten ook eenyParity
-parameter, die0x0
of0x1
kan zijn, waarmee de pariteit van de y-waarde van de secp256k1-handtekening wordt aangegeven. Ze worden geïdentificeerd door te beginnen met de byte0x01
, en hun TransactionType-waarde is0x1
.Transacties van type 2, ook wel EIP-1559-transacties genoemd, zijn transacties geïntroduceerd in EIP-1559(opens in a new tab), in de London-upgrade van Ethereum. Ze zijn het standaard transactietype geworden op het Ethereum-netwerk. Deze transacties introduceren een nieuw kostenmarktmechanisme waardoor de voorspelbaarheid wordt verbeterd door de transactiekosten te splitsen in een basiskost en een prioriteitskost. Ze beginnen met de byte
0x02
en bevatten velden zoalsmaxPriorityFeePerGas
enmaxFeePerGas
. Transacties van type 2 zijn nu standaard dankzij hun flexibiliteit en efficiëntie, en zijn vooral interessant tijdens periodes van hoge netwerkcongestie omdat ze gebruikers helpen om transactiekosten voorspelbaarder te beheren. De TransactionType-waarde voor deze transacties is0x2
.
Verder lezen
Weet je van een community resource die je heeft geholpen? Bewerk deze pagina en voeg het toe!