The Ethereum Project's logo, first used in 2014
|
Initial release | 30 July 2015 |
Repository | github.com/ethereum/go-ethereum |
Development status | Active |
Written in | C++, Go, Rust |
Operating system | Clients available for Linux, Windows, macOS, POSIX, Raspbian |
Platform | x86, ARM |
Type | Decentralized computing |
License | GPLv3, LGPLv3 |
Website | www.ethereum.org |
Ethereum is an open-source, public, blockchain-based distributed computing platform featuring smart contract (scripting) functionality. It provides a decentralized Turing-complete virtual machine, the Ethereum Virtual Machine (EVM), which can execute scripts using an international network of public nodes. Ethereum also provides a cryptocurrency token called "ether", which can be transferred between accounts and used to compensate participant nodes for computations performed. "Gas", an internal transaction pricing mechanism, is used to mitigate spam and allocate resources on the network.
Ethereum was proposed in late 2013 by Vitalik Buterin, a cryptocurrency researcher and programmer. Development was funded by an online crowdsale during July–August 2014. The system went live on 30 July 2015.
In 2016 Ethereum was forked into two blockchains, as a result of the collapse of The DAO project, thereby creating Ethereum Classic.. The new forked version is Ethereum (ETH), subject of this article and the one that continued its existence is Ethereum Classic (ETC).
History
Origin
Ethereum was initially described in a white paper by Vitalik Buterin, a programmer involved with Bitcoin, in late 2013 with a goal of building decentralized applications. Buterin had argued that Bitcoin needed a scripting language for application development. Failing to gain agreement, he proposed development of a new platform with a more general scripting language.
At the time of public announcement in January 2014, the core Ethereum team was Vitalik Buterin, Mihai Alisie, Anthony Di Iorio, and Charles Hoskinson. Formal development of the Ethereum software project began in early 2014 through a Swiss company, Ethereum Switzerland GmbH (EthSuisse). Subsequently, a Swiss non-profit foundation, the Ethereum Foundation (Stiftung Ethereum) was set up as well. Development was funded by an online public crowdsale during July–August 2014, with the participants buying the Ethereum value token (ether) with another digital currency, bitcoin. While there was early praise for the technical innovations of Ethereum, questions were also raised about its security and scalability.
Milestones
Several prototypes of the Ethereum platform were developed by the Foundation, as part of their Proof-of-Concept series, prior to the official launch of the Frontier network. The last of these prototypes culminated in a public beta pre-release known as "Olympic". The Olympic network provided users with a bug bounty of 25,000 ether for stress testing the limits of the Ethereum blockchain.
After Olympic, the Foundation announced the beginning of the Frontier network to mark the tentative experimental release of the Ethereum platform in July 2015. Since the initial launch, Ethereum has undergone several planned protocol upgrades called milestones, which are important changes affecting the underlying functionality and/or incentive structures of the platform.
The current milestone is named "Homestead" and is considered stable. It includes improvements to transaction processing, gas pricing, and security. There are at least two other protocol upgrades planned in the future, i.e. Metropolis and Serenity. Metropolis is intended to reduce the complexity of the EVM and provide more flexibility for smart contract developers. The move to Serenity is still uncertain, but should include a fundamental change to Ethereum's consensus algorithm to enable a basic transition from hardware mining (proof-of-work) to virtual mining (proof-of-stake). Improvements to scalability, specifically sharding, are also said to be a key objective on the development roadmap. Metropolis adds supports for zkSnarks (from Zcash), and the first zksnarks transaction occurred on testnet on September 19, 2017.
Version | Code name | Release date |
0 | Olympic | May, 2015 |
1 | Frontier | 30 July 2015 |
2 | Homestead | 14 March 2016 |
3 | Metropolis (vByzantium) | In testing as of September 2017 |
3.5 | Metropolis (vConstantinople) | TBA |
4 | Serenity | TBA |
Old version
Older version, still supported
Latest version
Future release
|
The DAO event
In 2016 a decentralized autonomous organization called The DAO, a set of smart contracts developed on the platform, raised a record US$150 million in a crowdsale to fund the project. The DAO was exploited in June when US$50 million in ether were claimed by an anonymous entity. The event sparked a debate in the crypto-community about whether Ethereum should perform a contentious "hard fork" to reappropriate the stolen funds. As a result of the dispute, the network split in two. Ethereum (the subject of this article) continued as on the forked blockchain, while Ethereum Classic continued on the original blockchain. The hard fork created a rivalry between the two networks.
Hard Forks
After the hard fork related to The DAO, Ethereum subsequently forked twice in the fourth quarter of 2016 to deal with other attacks. By the end of November 2016, Ethereum had increased its DDoS protection, de-bloated the blockchain, and thwarted further spam attacks by hackers.
Architecture
Ether
Ether |
Denominations |
Symbol | Ξ or ETH |
Demographics |
User(s) | Worldwide |
Issuance |
Currency type | Cryptocurrency |
The value token of the Ethereum blockchain is called ether. It is listed under the code ETH and traded on cryptocurrency exchanges. It is also used to pay for transaction fees and computational services on the Ethereum network.
Tokens can be volatile per circumstances, such as ether's plunge from $21.50 to $8 when The DAO was hacked on 17 June 2016. As of June 2017, the value of ether had risen to more than $400, a 5,000% rise since the beginning of the year.
Price volatility on any single exchange can exceed the volatility on Ether token prices more generally. A "flash crash" triggered by a large sell order on one exchange briefly dropped the price on that exchange to $0.10 as every offer to buy was absorbed, after which the price quickly recovered to more than $300.
Ethereum Virtual Machine
The Ethereum Virtual Machine (EVM) is the runtime environment for smart contracts in Ethereum. The formal definition of the EVM is specified in the Ethereum Yellow Paper, original version by Gavin Wood. It is sandboxed and also completely isolated from the network, filesystem or other processes of the host computer system. Every Ethereum node in the network runs an EVM implementation and executes the same instructions. Ethereum Virtual Machines have been implemented in C++, Go, Haskell, Java, Javascript, Python, Ruby, Rust, and WebAssembly (currently under development).
Smart contracts
Main article: Smart contract
Smart contracts are deterministic exchange mechanisms controlled by digital means that can carry out the direct transaction of value between untrusted agents. They can be used to facilitate, verify, and enforce the negotiation or performance of economically-laden procedural instructions and potentially circumvent censorship, collusion, and counter-party risk. In Ethereum, smart contracts are treated as autonomous scripts or stateful decentralized applications that are stored in the Ethereum blockchain for later execution by the EVM. Instructions embedded in Ethereum contracts are paid for in ether (or more technically "gas") and can be implemented in a variety of Turing complete scripting languages.
Contracts on the public blockchain
As the contracts can be public, it opens up the possibility to prove functionality, e.g. self-contained provably fair casinos.
One issue related to using smart contracts on a public blockchain is that bugs, including security holes, are visible to all but cannot be fixed quickly. One example of this is the 17 June 2016 attack on The DAO, which could not be quickly stopped or reversed.
There is ongoing research on how to use formal verification to express and prove non-trivial properties. A Microsoft Research report noted that writing solid smart contracts can be extremely difficult in practice, using The DAO hack to illustrate this problem. The report discussed tools that Microsoft had developed for verifying contracts, and noted that a large-scale analysis of published contracts is likely to uncover widespread vulnerabilities. The report also stated that it is possible to verify the equivalence of a Solidity program and the EVM code.
Programming languages
Main article: Solidity
Smart contracts are high-level programming abstractions that are compiled down to EVM bytecode and deployed to the Ethereum blockchain for execution. They can be written in Solidity (a language library with similarities to C and JavaScript), Serpent (similar to Python), LLL (a low-level Lisp-like language), and Mutan (Go-based, but deprecated). There is also a research-oriented language under development called Viper (a strongly-typed Python-derived decidable language).
Performance
In Ethereum all smart contracts are stored publicly on every node of the blockchain, which has trade-offs. The downside is that performance issues arise in that every node is calculating all the smart contracts in real time, resulting in lower speeds. Ethereum engineers have been working on sharding the calculations, but no solution had been detailed by early 2016. As of January 2016, the Ethereum protocol could process 25 transactions per second. In September 2016, Buterin presented proposals to increase scalability. Buterin and Joseph Poon (a co-author of Bitcoin's lightning network whitepaper) announced in 2017 their plan to launch a scaling solution called Plasma which creates "child" blockchains to the "main" parent blockchain. The plasma project is not without skeptics, specifically Vlad Zamfir (Ethereum's lead researcher on proof of stake) has publically questioned the plasma project's viability.
Ether supply increase rate
The supply of Ether was projected to increase by 14.75% in 2017, with an algorithm in place to gradually decline to 1.59% by 2065. However, a new implementation of Ethereum named "Casper" based on proof of stake rather than proof of work is expected to reduce the inflation rate to between 0.5% to 2%.
Proposed uses
Many uses have been proposed for Ethereum platform, including ones that are impossible or unfeasible. Use case proposals have included finance, the internet-of-things, farm-to-table produce, electricity sourcing and pricing, and sports betting. Ethereum is (as of 2017) the leading blockchain platform for initial coin offering project with over 50% market share.
Ecosystem
The projects listed in this section are not exhaustive and may be outdated.
Clients and wallets
These cryptocurrency wallets support Ethereum:
- Geth: Client implementation in Go
- Jaxx: Web wallet
- KeepKey: Hardware wallet
- Ledger Nano S: Hardware wallet
- Mist: Desktop wallet
- Parity: Client implementation in Rust
Decentralized applications
- Digital signatures that ensure authenticity and proof of existence of documents: the Luxembourg Stock Exchange has developed such a system
- Slock.It is developing smart locks
- Digital tokens pegged to fiat currencies: Decentralized Capital. Spanish bank Santander is also involved in such a project
- Digital tokens pegged to gold: Digix
- Improved digital rights management for music: Imogen Heap used the technology
- Platforms for prediction markets: Augur, Gnosis Stox
- Platforms for crowdfunding: the DAO
- Social media platforms with economic incentives: Backfeed, Akasha
- Decentralized marketplaces: FreeMyVunk, Etheropt, TransActive Grid[
- Remitance: Everex
- Online gambling: Etheroll
- Electric car charging management: RWE
- Secure identity systems for the Internet: uPort
Enterprise software
Ethereum is being tested by enterprise software companies for various applications. Interested parties include Microsoft, IBM, JPMorgan Chase, Deloitte, R3, Innovate UK (cross-border payments prototype).
Enterprise Ethereum Alliance (EEA)
In March 2017, various blockchain start-ups, research groups, and Fortune 500 companies announced the creation of the Enterprise Ethereum Alliance (EEA) with 30 founding members. By May, the nonprofit organization had 116 enterprise members—including ConsenSys, CME Group, Cornell University's research group, Toyota Research Institute, Samsung SDS, Microsoft, Intel, J.P. Morgan, Merck KGaA, DTCC, Deloitte, Accenture, Banco Santander, BNY Mellon, ING, and National Bank of Canada.
The purpose of the EEA is to coordinate the engineering of an open-source reference standard and private "permissioned" version of the Ethereum blockchain that can address the common interests of enterprises in banking, management, consulting, automotive, pharmaceutical, health, technology, mobile, entertainment, and other industries, while working with developers from the Ethereum ecosystem. Certain members of the alliance have also indicated a desire to investigate and collaborate on hybrid architectures to potentially anchor private blockchains to the public Ethereum blockchain in the future, although concerns remain over the security, compliance, and regulations involved in bridging such permissioned and "permissionless" blockchains.
By July 2017, there were over 150 members in the alliance, including recent additions MasterCard, Cisco Systems, and Scotiabank. (Mastercard wanted their name excluded from the press release.)
Permissioned ledgers
Ethereum is used and being investigated as a permissioned blockchain in various projects.
- J.P. Morgan Chase is developing a blockchain, atop Ethereum. The system, dubbed "Quorum," is designed to toe the line between private and public in the realm of shuffling derivatives and payments. The idea is to satisfy regulators who need seamless access to financial goings-on, while protecting the privacy of parties that don’t wish to reveal their identities nor the details of their transactions to the general public.
- Royal Bank of Scotland has announced that it has built a Clearing and Settlement Mechanism (CSM) based on the Ethereum distributed ledger and smart contract platform.
Criminal activity
A finance blogger on FT Alphaville has pointed out that criminals are using Ethereum to run Ponzi schemes and other forms of investment fraud. The article was based on a paper from the University of Cagliari, which placed the number of Ethereum smart contracts which facilitate Ponzi schemes at nearly 10% of 1384 smart contracts examined. However, it also estimated that only 0.05% of the transactions on the network were related to such contracts.