Mining

Uit BitcoinWiki.nl
Versie door Marnix (overleg | bijdragen) op 15 feb 2021 om 09:54 (Uitleg mining toegevoegd)

Mining is het proces van het bevestigen van transacties uit de Mempool door ze in blokken te plaatsen.

De miners vinden blokken door de juiste "hash" te vinden. Als ze deze vinden verdienen ze de bloksubsidie en ook de transactiekosten van de transacties die ze in het blok zetten.

Proces

  1. Een miner heeft een Bitcoin node. Op deze node ontvangt hij continu nieuwe transacties die mensen hebben gedaan. Die transacties zijn op het moment van verzenden onbevestigd, pas als ze in een blok komen zijn ze bevestigd. De node van de miner slaat de transacties tijdelijk op in zijn mempool.
  2. De miner bekijkt de mempool en selecteert de duurste transacties. Dit zijn dus de transcties met de hoogste kosten. aangezien de miner hier het meest mee verdient. We noemen deze selectie het "bloktemplate".
  3. De miner voegt ook een transactie naar zichzelf toe, waar hij nieuwe bitcoin creëert. Volgens de regels mag een miner (op dit moment) 6.25 bitcoin "uit het niks" claimen bij het vinden van een nieuw blok. Als de miner een grotere transactie naar zichzelf doet (en zich dus niet aan de regels houdt) zal het blok niet worden geaccepteerd.
  4. De miner voegt hash van het vorige blok toe.
  5. Nu begint het daadwerkelijke minen. De miner probeert duizenden keren per seconde om een hash te vinden die voldoet aan de regels. Dit houdt in dat hij input zal proberen (een tellertje). Als hij geluk heeft, en een bash vindt die aan de regels voldoet, zal hij het blok opsturen naar het netwerk.
  6. Het netwerk ontvangt het nieuwe blok, zal controleren of aan alle regels wordt voldaan en deze accepteren. De nodes halen de (in dit nieuwe blok) bevestigde transacties uit hun mempool.
  7. Het proces begin nu weer vanaf stap 1.

Hashing

Hashing ("verhaspelen" in het Nederlands) is een proces om een hashcode te maken: bij hashing wordt door middel van een hash algoritme een hashcode berekend van een blok gegevens ("input"). Uit deze hashcode is dan niet meer af te leiden wat de oorspronkelijke gegevens waren, maar iemand die de gegevens heeft kan wel opnieuw daarvan de hashcode berekenen en controleren of de berekende hashcode overeenkomt met een eerder verkregen hashcode.

De gegevens ("input") is een blocktemplate (zie stap 2 hierboven) en een teller. Door steeds de teller te verhogen komt er steeds een nieuwe hash uit. De regel is dat een correcte hash een bepaalde hoeveelheid nullen bevat. Op een gegeven moment vindt de miner een hash met voldoende nullen. Iedereen met dezelfde input (het blok en de juiste teller-data) kan controleren dat de hash klopt met de data.

Lege blokken

Soms worden er lege blokken gevonden. Dit kan gebeuren als de miner nog niet voldoende tijd heeft gehad, sinds het vinden van het vorige blok, om een nieuw blocktemplate (zie stap 2 hierboven) te bepalen. De miner wil zijn machines niet uitzetten, en laat zijn machines dus even lege blokken vinden, aangezien hij ook voor lege blokken een beloning (subsidie) krijgt.

Zie verder

  • Aflevering 8 van [Beginnen met Bitcoin] legt mining verder uit