Ethereum 69: Como configurar um nó blockchain totalmente sincronizado em 10 minutos

Bem-vindo ao primeiro artigo da nossa nova série go-ethereum!

Nos próximos 10 minutos você irá:

  • Aprenda o primeiro glossário do blockchain sem nenhum conhecimento prévio do ecossistema necessário
  • Configure seu nó de teste totalmente sincronizado (“cliente / servidor”) em menos de 10 minutos
  • Crie sua conta e receba uma transação de 8ETH da fundação Ethereum GRATUITAMENTE

Nosso lema é, a prática antes da teoria - vamos pular direto para a instalação de um nó de teste Ethereum totalmente sincronizado conectado a uma rede de teste Rinkeby!

Geth

Geth é uma interface de linha de comando (CLI), um binário compilado, programa e cliente para executar um nó Ethereum completo implementado em Go.

Usaremos Geth para:

  • execute um nó Ethereum totalmente sincronizado para se conectar a uma rede de teste chamada Rinkeby
  • crie uma nova conta para poder enviar e receber transações
  • para ler o estado do EVM, por exemplo, verificar o saldo de qualquer conta (quer saber quanto saldo sua namorada, namorado, esposa, vizinho tem? Doce transparência!)

Instalando Geth

Podemos instalá-lo diretamente dos repositórios:

Mac

brew tap ethereum/ethereumbrew install ethereum

Linux

sudo apt-get install software-properties-commonsudo add-apt-repository -y ppa:ethereum/ethereumsudo apt-get updatesudo apt-get install ethereum

janelas

Good luck :)

Verifique a instalação:

which geth> /usr/local/bin/geth
geth version> Geth> Version: 1.8.20-stable

Certifique-se de que está executando a mesma versão para poder realizar uma sincronização completa de uma rede Rinkeby, conforme descrito nas próximas etapas, porque Rinkeby acionou um forcado constantinople compatível com Geth 1.8.20.

Executando um nó blockchain

Bem, o diabo está nos detalhes ... mas começar é realmente simples. Parabéns aos desenvolvedores do Ethereum.

Vamos configurar um novo Rinkeby (rede de teste Ethereum usando o protocolo Clique PoA) totalmente sincronizado .

A implementação do Rinkeby PoA é muito mais rápida, mas significativamente menos segura. É mais centralizado a partir do PoW de consenso da mainnet, o que é perfeitamente adequado para uma rede de teste. Rinkeby consegue aprovar um novo bloqueio com um monte de transações a cada 15s.

Ok, ok, ok ... O que essas palavras realmente significam?

  • Rinkeby: nome da rede de teste de Prova de Autoridade
  • Nó: basicamente um servidor tradicional executando cliente / servidor Ethereum
  • Concenso: um algoritmo que define como as transações serão validadas, anexadas e persistidas no banco de dados em cada nó
  • Bloco: um monte de transações em uma matriz complicada despachada ao redor do fio entre todos os nós da rede a cada 15s
  • Transação: não pense em uma transação bancária. Uma transação blockchain é uma mudança de estado. Renomeando o proprietário de um contrato inteligente de Alice para Bob? Alterando o saldo de sua conta de 1ETH para 5ETH? Definindo o valor da variável “foo” como “foo_value_123” em seu contrato inteligente? Isso é uma transação.

Você pode ler mais sobre a proposta Rinkeby PoA aqui: //github.com/ethereum/EIPs/issues/225

geth --rinkeby --datadir=~/.gophersland_ethereum_r1 --port=30304 --cache=2048 --rpc --rpcport=8546 --rpcapi=eth,web3,net,personal --syncmode=fast

O comando acima irá:

  • inicialize um novo diretório onde todos os dados serão armazenados ~/.gophersland_ethereum_r1. O diretório padrão seria:~/.ethereum
  • comece a baixar o histórico Ethereum necessário para se tornar um novo nó da rede totalmente válido e sincronizado
  • a comunicação acontecerá pela porta 30304
  • cache, uma espécie de buffer, será definido como 2 GB para acelerar o processo de sincronização
  • RPC API adicional será lançada para que possamos nos comunicar com nosso nó por meio de consoles, boa interface gráfica na porta 8546, mais tarde

Espere algumas horas até que o blockchain esteja totalmente sincronizado.

O número do bloco atual em 24 de setembro é: 3039786. No meu AMD Ryzen 5 2600, 3.4 Ghz, o processo de sincronização levou 3 horas. Sim, tenho um novo PC para jogos!

Enquanto isso, você pode seguir o Web3Coach no Twitter ou preparar o jantar, provavelmente o café da manhã também, ir para a academia ... digamos, o blockchain não é o banco de dados mais rápido :)

Eventualmente, a mensagem impressa será:

  • INFO [] Contagem de novos segmentos de cadeia importados = 1
  • INFO [] Contagem de novos segmentos de cadeia importados = 1
  • INFO [] Contagem de novos segmentos de cadeia importados = 1
  • INFO [] Contagem de novos segmentos de cadeia importados = 1

Parabéns, agora você faz parte da revolução do blockchain em menos de 10 minutos !!!

Criando sua primeira conta blockchain

Keystore

All the Ethereum accounts and their keys are stored in a directory called the “keystore”. The directory is empty by default as we haven’t created our own account yet!

[email protected]:~$ ls -la ~/.gophersland_ethereum_r1/
drwx------ 4 enchanter enchanter 4096 sep 24 15:26 .drwxr-xr-x 18 enchanter enchanter 4096 sep 24 11:51 ..drwx------ 4 enchanter enchanter 4096 sep 24 15:26 gethsrw------- 1 enchanter enchanter 0 sep 24 15:26 geth.ipcdrwx------ 2 enchanter enchanter 4096 sep 23 09:54 keystore
[email protected]:~$ ls -la ~/.gophersland_ethereum_r1/keystore/
drwx------ 2 enchanter enchanter 4096 sep 23 09:54 .drwx------ 4 enchanter enchanter 4096 sep 24 15:26 ..

Account

To create a new account, execute the following, already familiar, geth cmd.

geth --datadir=~/.gophersland_ethereum_r1 account new

You will be prompted to enter a passphrase (this is your SUPER SECRET PASSWORD). This is required for decrypting your newly generated private key associated with your new Ethereum address, as it allows you to use it later on for signing transactions on the blockchain. Note it down somewhere, since we will need it later. But don’t worry if you forget it, this is just a test network anyway.

[email protected]:~$ ls -la ~/.gophersland_ethereum_r1/keystore/
drwx------ 2 enchanter enchanter 4096 sep 23 09:54 .drwx------ 4 enchanter enchanter 4096 sep 24 15:26 ..
[email protected]:~$ geth --datadir=~/.gophersland_ethereum_r1 account new
INFO [09-24|15:36:33.566] Maximum peer count ETH=25 LES=0 total=25
Your new account is locked with a password. Please give a password. Do not forget this password.
Passphrase: Repeat passphrase:
Address: {ceee57f2b700c2f37d1476a7974965e149fce2d4}
[email protected]:~$ ls -la ~/.gophersland_ethereum_r1/keystore/
drwx------ 2 enchanter enchanter 4096 sep 24 15:36 .drwx------ 4 enchanter enchanter 4096 sep 24 15:26 ..-rw------- 1 enchanter enchanter 491 sep 24 15:36 
UTC--2018-09-24T13-36-43.069452577Z--ceee57f2b700c2f37d1476a7974965e149fce2d4

Woohoo! My new Ethereum address is alive: ceee57f2b700c2f37d1476a7974965e149fce2d4.

You will normally encounter this address prefixed with “0x” to indicate the address encoding, HEX.

The newest format of the keyfiles is: UTC--- encoding>. The order of accounts when listing is lexicographic, but as a consequence of the timespamp format, it is actually in order of creation.

If you are curious what is inside of the file, feel free to open it! You will see:

  • Address: your new hex address
  • Crypto: bunch of mathematical variables responsible for representing your private key in encrypted form, don’t worry about that magic for now

Interesting note: the account generation happens in offline mode and doesn’t require a synced blockchain node. Curious how is it possible to generate a unique address in an offline mode from the technical perspective? We will check out the go-ethereum source code itself in the next article.

Spoiler: it’s because the address is a hash of your public key which is based on your unique, private key.

Okay I have a new shinny Ethereum account, what’s my balance and how do I deposit some testing Ether?

Speaking of Ether… what is it actually?

Ether

Ether is the cryptocurrency powering the Ethereum network. It’s used as a unit of value and for paying miners for validating, appending, and persisting the transactions to the collective DB. But mainly its a technique for preventing SPAM because miners are rewarded 5 (since last month “just” 3) ETH for each successfully mined block. Yes, that’s $600 at the current price on 24th of September, every 15s. Not a bad business.

How to receive a transaction of 8ETH from the Ethereum foundation for FREE

Checking account balance

Let’s make sure our account balance is 0 first, unless someone already managed to send some Ether out of the goodness of their heart.

Geth provides a JavaScript console that can be attached to the executable binary for interacting with the blockchain conveniently. We can connect to it by specifying a socket file that is exposed once Geth boots up. Socket files are very useful for “inter process communication on the same machine”, aka IPC.

You can locate this file in the the default data directory while the Geth program is running:

[email protected]:~$ ls -la ~/.gophersland_ethereum_r1/
drwx------ 4 enchanter enchanter 4096 Sep 24 15:44 .drwxr-xr-x 18 enchanter enchanter 4096 Sep 24 15:47 ..drwx------ 4 enchanter enchanter 4096 Sep 24 15:44 gethsrw------- 1 enchanter enchanter 0 Sep 24 15:44 geth.ipcdrwx------ 2 enchanter enchanter 4096 Sep 24 15:47 keystore

Let’s interact with the Rinkeby network using the “geth attach” cmd in another terminal while your blockchain node is still running. Make sure to pass the absolute path to the IPC file, otherwise you will get an error.

[email protected]:~$ geth attach ipc:/home/enchanter/.gophersland_ethereum_r1/geth.ipc
Welcome to the Geth JavaScript console!
instance: Geth/v1.8.15-stable-89451f7c/linux-amd64/go1.10.1coinbase: 0xceee57f2b700c2f37d1476a7974965e149fce2d4at block: 3044891 (Mon, 24 Sep 2018 16:42:36 CEST)
datadir: /home/enchanter/.gophersland_ethereum_r1modules: admin:1.0 clique:1.0 debug:1.0 eth:1.0 miner:1.0 net:1.0 personal:1.0 rpc:1.0 txpool:1.0 web3:1.0
> eth.accounts["0xceee57f2b700c2f37d1476a7974965e149fce2d4"]
> eth.syncingfalse
> eth.getBalance("0xceee57f2b700c2f37d1476a7974965e149fce2d4")0

Query blockchain:

eth.accounts: to check your currently available accounts

eth.syncing: to make sure our state, DB is fully up to date with rest of the network to ensure the getBalance response will be based on the latest state

eth.getBalance(“ gt;”): to query the DB.

Receiving a transaction of 8ETH from the Ethereum foundation for FREE

The Ethereum foundation has a very neat program called “Faucet” available online for assigning Ether to accounts requesting it in real-time.

Requesting Ether:

  1. Publish your account address on one of the public social networks
  2. E.g, post a tweet containing your Ethereum address anywhere in the tweet like this one //twitter.com/EnchanterIO/status/1044238559224483841, make sure you tag @Web3Coach and @freeCodeCamp and let us know if you like the tutorial!
  3. Open //www.rinkeby.io/#faucet and paste the tweet URL
  4. Click on “Give me Ether”, choose between 3, 7.5 or 18.75 Ether
  5. Wait few seconds
  6. Query your account balance again

Voilà

You are rich… in a test network. Congratulation for getting so far.

You can continue expanding your blockchain skills by building one from scratch in Go!"