Bitcoinin tekniikka
Bitcoinin tekniikka käsittelee bitcoin-kryptovaluutan tekniikkaa.
Satoshi Nakamoton whitepaper vuodelta 2008 kuvaa Bitcoin-järjestelmän periaatteet.[1] Bitcoin perustuu osittain Wei Dain b-money[2] -ehdotukseen ja Nick Szabon Bitgold-ehdotukseen.
Osoitteet
muokkaaBitcoin-verkon käyttäjä omistaa virtuaalisen lompakon, johon sisältyy mielivaltainen määrä osoitteita. Osoitteita käytetään Bitcoin-rahan vastaanottamiseen, ja osoitteet muodostetaan julkisesta salausavaimesta. Bitcoin-lähetykset tapahtuvat myös osoitteilla. Käyttäjän ei tarvitse kuitenkaan erikseen valita mistä osoitteista bitcoinit lähetetään, vaan lompakko-ohjelmat määrittävät sen automaattisesti.
Bitcoin-osoitteihin liittyy salausavainpari, eli julkinen ja yksityinen salausavain. Järjestelmän varmuus perustuu siihen, kuinka hyvin käyttäjä pystyy pitämään omat yksityisavaimensa omana tietonaan. Bitcoin-osoitteet eivät kerro mitään omistajistaan ja ovat yleisesti ottaen anonyymejä.[3] Osoitteet ovat satunnaisten merkkien ja numeroiden noin 33-merkkisiä merkkijonoja, esimerkiksi 1M8fxFJfRBptxQ2CdEpm2Se2XwPjz2kwX8
. Käyttäjällä voi olla monia eri osoitteita ja niitä voidaan luoda lähes rajaton määrä. Osoitteiden luominen yhtä ainoata käyttötarkoitusta tai käyttökertaa varten edesauttaa käyttäjän anonymiteetin säilymistä. Uuden osoitteen luominen ei vaadi yhteyttä toisiin verkon solmuihin.
QR-koodit ja Bitcoin-URI
muokkaaMobiilikäytössä bitcoinien siirtelynä suurena apuna ovat QR-koodit. Bitcoin URI-spesifikaatio mahdollistaa myös määrien ja kuvausten sisällyttämisen QR-koodiin[4]. Lähetettäessä bitcoineja mobiililaitteella skannataan QR-koodi, jolloin tietoja ei tarvitse syöttää käsin. Käytännössä kaikki mobiilikäyttöön tarkoitetut lompakot tukevat QR-koodeja. Vastaavasti lähes kaikki bitcoin-lompakko-ohjelmat osaavat muodostaa automaattisesti QR-koodeja vastaanottamiseen.
Siirrot
muokkaaBitcoinit sijaitsevat julkisessa tietokannassa, lohkoketjussa, josta on ajantasainen kopio jokaisella bitcoin-verkon ydinsolmulla. Lohkoketju sisältää muun muassa bitcoin-osoitteet ja bitcoin-määrän, johon kunkin osoitteen omistajalla on käyttöoikeus. Lohkoketju sisältää myös siirtojen aikaleimat sekä kaikki historialliset bitcoin-siirrot.
Kun käyttäjä siirtää bitcoineja toiselle käyttäjälle, hän luo yhden tai useamman sähköisen viestin tyyliin "Siirrän käyttöoikeuden X bitcoiniin osoitteesta A osoitteelle B", allekirjoittaa[5] tämän viestin osoitetta A vastaavalla yksityisellä avaimella ja kuuluttaa viestin Bitcoin-verkkoon. Verkon muut ydinsolmut varmentavat siirron allekirjoitukset ja kokonaissumman ennen viestin eteenpäin lähettämistä ja lisäämistä jonoon seuraavaa lohkoa varten.
Kun siirto sisällytetään uuteen lohkoon, sen katsotaan saaneen yhden vahvistuksen. Tämän jälkeen siirron katsotaan saaneen yhden lisävahvistuksen aina kun bitcoin-verkko löytää uuden lohkon. Vahvistusten määrä kuvastaa tarvittavaa laskentatehoa, joka olisi tarpeen, että siirtoa olisi jälkeenpäin mahdollista muokata tai perua.
Lohkoketjun siirtohistorian avulla verkko osaa hylätä sellaiset siirrot, joissa yritetään käyttää jo kerran käytettyä rahaa. Lisäksi lohkon luomiseen tarvittavan laskentatehon määrä tekee siirtojen väärentämisestä vaikeaa ja kannattamatonta verrattuna louhintaan itseensä.
Bitcoinien synty
muokkaaKeskitetysti hallituista valuutoista poiketen, ei ole olemassa mitään tahoa, joka kykenisi luomaan bitcoineja yksinoikeudella tai rajattomasti. Uudet bitcoinit syntyvät Bitcoin-verkossa louhintaprosessin sivutuotteena. Tämä luo louhijoille rahallisen kannusteen ylläpitää Bitcoin-verkon turvallisuutta laskentatehoillaan.
Bitcoinien liikkeellelaskemisessa on jäljitelty arvometallien louhintaa.[1] Uusi erä bitcoineja syntyy keskimäärin kuusi kertaa tunnissa, satunnaisesti jollekulle, joka ajaa louhintaohjelmistoa. Yksinkertaistetusti asian voi hahmottaa niin, että joka päivä on jaossa 144 pakettia uusia bitcoineja, jotka arvotaan louhijoiden kesken.[6] Arpalippuna tässä arvonnassa toimii louhijan tekemän laskennan määrä. Yksittäisen erän koko oli helmikuussa 2021 6,25 bitcoinia, ja se puolittuu 210 000 lohkon välein.[3] Ensimmäinen puolittuminen tapahtui 28. marraskuuta 2012 kello 18.[7]
Louhinta ja lohkoketju
muokkaaLouhinnan ensisijainen tehtävä on taata bitcoin-siirtojen pysyvyys ja luoda pysyvä tallenne niiden keskinäisestä järjestyksestä.[1] Tämä on toteutettu määrittelemällä kelvollisen lohkon tiivisteelle tietyt ehdot. Ainoa keino löytää kelvollinen lohko on luoda uusia lohkoja ja laskea niille tiivisteitä niin kauan, kunnes ehdot täyttävä lohko löytyy. Tämän takia louhinta vaatii paljon laskentatehoa. Ehtoja säätämällä voidaan säätää lohkon löytämiseen tarvittavan laskennan määrää. Kyseistä määrää kutsutaan myös vaikeustasoksi.
Lohkoketju muodostuu siitä, että jokainen uusi lohko sisältää sitä edeltäneen lohkon tiivisteen. Jos lohkoketju on jostain kohdasta haarautunut kahdeksi haaraksi, niin voimassa oleva haara on se, jonka lohkojen yhteenlaskettu vaikeustaso on suurempi.[1] Tästä seuraa, että jotta lohkoketjun historiaa voisi muuttaa, pitäisi ensin uudelleenluoda sekä se lohko, johon muutos tulee, että kaikki sen jälkeiset lohkot. Verkko säätää lohkoilta vaadittavaa vaikeustasoa 2 016:n lohkon välein sellaiseksi, että uusi lohko syntyy keskimäärin kymmenen minuutin välein. Louhinnan vaikeusaste siis muuttuu sen mukaan, kuinka louhijoiden yhteenlaskettujen tehojen määrä muuttuu.
Aluksi louhintaa tehtiin laskemalla suorittimien (CPU) avulla, mutta grafiikkasuoritinta (GPU) hyödyntävät louhintaohjelmistot ovat syrjäyttäneet CPU:lla louhinnan. Uusi kehityssuunta tällä hetkellä on ASIC-piirit, joiden laskentateho on moninkertainen CPU ja GPU -piireihin verrattuna. ASIC-piirien yleistyttyä on odotettavissa, että näytönohjaimilla tehtävä louhinta ei enää tuota edes käyttämänsä sähkön hintaa takaisin.
Käyttäjät voivat myös louhia bitcoineja kollektiivisesti, liittymällä niinkutsuttuun pooliin, jolloin palkkiot jaetaan osallisille poolin asetuksista riippuvalla tavalla.[8]
Siirtomaksut
muokkaaSolmuilla ei ole mitään velvoitteita sisällyttää siirtoja luomiinsa lohkoihin, mutta Bitcoineja lähettävät osapuolet voivat vapaaehtoisesti maksaa siirroista palkkiota. Siirtopalkkion maksaminen voi nopeuttaa siirron käsittelyä ja kannustaa louhijoita lisäämään louhintatehoja. Tämä tulee erityisesti olemaan tärkeätä siinä vaiheessa, kun uusien bitcoinien luonti vähenee pikkuhiljaa. Louhintasolmu voi kerätä siirtopalkkiot kaikista siirroista, jotka ovat sisällytettynä solmun löytämissä uusissa lohkoissa.[3]
Anonymiteetti
muokkaaBitcoin-verkko ei sisällä kenenkään henkilötietoja, vaikka osoitteiden väliset siirrot ovatkin täysin julkisia. Tämän takia anonymiteetti riippuukin paljon siitä, miten ja mitä lompakko-ohjelmaa tai palvelua käyttäjä käyttää. Esimerkiksi Android-lompakko BitcoinSpinner luo käyttäjälle ainoastaan yhden osoitteen ja käyttää aina sitä. Tästä seuraa, että jokainen, jolta käyttäjä on saanut siirron tai jolle hän on tehnyt siirron, voi käydä katsomassa osoitteen siirtohistoriaa ja nähdä kaikki tehdyt siirrot. Yksi sivusto, jolta näitä tietoja voi käydä katsomassa on blockchain.info.
Anonymiteetti Bitcoinia käytettäessä on siis täysin käyttäjän omalla vastuulla ja vaatii tarkkuutta ja taitoa. Anonymiteetillä viitataan tässä yhteydessä tasoon, millä tarkkuudella transaktio on yhdistettävissä tiettyyn henkilöön tai henkilöjoukkoon.
Anonymiteettiä ja yksityisyydensuojaa Bitcoin-käytön yhteydessä voi parantaa esimerkiksi käyttämällä jokaiselle transaktiolle uutta bitcoin-osoitetta sekä sekoittamalla transaktioita esimerkiksi jaetuissa lompakoissa.
Lähteet
muokkaa- ↑ a b c d Satoshi Nakamoto: Bitcoin: A Peer-to-Peer Electronic Cash System (pdf) bitcoin.org.
- ↑ Wei Dai: B-Money Proposal Wei Dai. (englanniksi)
- ↑ a b c Nathan Willis: Bitcoin: Virtual money created by CPU cycles 10.11.2010. LWN.net. (englanniksi)
- ↑ Bitcoin URI scheme en.bitcoin.it. (englanniksi)
- ↑ Bitcoin.it
- ↑ Thomas Luongo: The FED’s Real Monetary Problem lewrockwell.com. 23.7.2010. Viitattu 12.10.2010. (englanniksi)
- ↑ Henry Brade: Bitcoin tekee historiaa bittiraha.fi. 27.11.2012. Viitattu 18.2.2013.
- ↑ Bitcoin Pooled Mining