Skip to content
This repository has been archived by the owner on Dec 22, 2020. It is now read-only.

Latest commit

 

History

History
81 lines (52 loc) · 4.51 KB

README.md

File metadata and controls

81 lines (52 loc) · 4.51 KB

CustomerConsentEthereum

Joining the blockchain

  1. Install Docker
  2. Install Terraform
  3. cd terraform/personal
  4. (Mac only) Change volume_path to your docker persistent folder
  5. terraform get
  6. terraform apply
  7. Type a name for your node.

Setup will spin of next services:

Shorthand command: cd terraform/personal && terraform get && terraform apply && docker exec -it ethereum-node0 geth attach

Stop all containers: docker ps -aq | xargs docker stop

The default configuration will start two Docker container for the actual Ethereum nodes called ethereum-node0 and ethereum-node1, and two containers linked to Ethereum nodes called ethereum-netstats-api0 and ethereum-netstats-api1 that report statistics to the Ethereum Network Status dashboard. You can change the number of nodes by editing personal.tf.

The node name parameter is used to identify your node on. Participation in the dashboard is completely optional and does not actually influence the functionality of the blockchain itself in any way. It can take a few minutes for the nodes to discover each other.

Please note that the default configuration publishes all administrative functions through an unsecured RPC interface. It is not meant for a deployment on a server.

How to mine?

  1. docker exec -it ethereum-node0 geth attach
  2. miner.setEtherbase('public key') set to where transfer currency
  3. miner.start() to start mining

Development tools

Ethereum Wallet (Mac only)

  1. cd /Applications/Ethereum\ Wallet.app/Contents/MacOS/
  2. ./Ethereum\ Wallet --rpc http://localhost:8545

Ethereum Wallet (Windows)

  1. "ethereum wallet.exe" --rpc http://localhost:8545

Troubleshooting

Cannot connect to Docker

Default configuration assumes that you run it on Linux with Docker support built-in. On Windows and MacOS, Docker relies on a virtualization layer, and it may be necessary to communicate with the Docker engine via TCP. Edit personal.tf and change docker_host = "unix:///var/run/docker.sock" to docker_host = "tcp://localhost:2375" (or a proper IP address).

Cannot connect to Docker on Windows

  • Error starting userland proxy
  • Driver failed programming external connectivity on endpoint

If you are experiencing error messages that look anything like the one above, try restarting your Docker service. Docker on Windows relies on a virtualization layer, and the virtual network can become misconfigured or the clock on the virtual machine can get out of sync. This is usually provoked by putting the machine through several suspend/resume cycles, like is often the case when running on a laptop.

Transactions time out

Transactions will only function if there is an active miner in the blockchain. If there is no mining, the nodes may get out of sync, and will not communicate all that much with each other. You can see if there are any active miners on the Ethereum Network Status dashboard.

Miner does not mine transactions

Even with an active miner, transactions may still time out, because it will not mine them. If the miner does not receive any blocks from other nodes, it will assume it is out of sync and will not attempt to mine the transactions. What you want then is to start mining on your own node:

  1. docker exec -it ethereum-node0 geth attach
  2. miner.start() to start mining
  3. miner.stop() to stop mining

It is usually enough to run a miner for a few moments (assuming there are other active miners) just to let the other nodes know that your node is alive.

Please note that the initial startup time for a miner can be over 15 minutes during which an EtHash DAG is generated. After the initial generation is done, mining can be started and stopped at will.

Terraform fails

  • module.consent_ethereum.provider.docker: "ca_material": conflicts with cert_path ("")
  • module.consent_ethereum.provider.docker: "cert_material": conflicts with cert_path ("")
  • module.consent_ethereum.provider.docker: "key_material": conflicts with cert_path ("")

Install Terraform 0.7.12

Applies to Terraform 0.8.0 and 0.8.1. See hashicorp/terraform#10754.