Skip to content
This repository has been archived by the owner on Jan 1, 2021. It is now read-only.

roshii/docker-cryptonodes

 
 

Repository files navigation

<<<<<<< HEAD

Docker-Cryptonode

=======

Docker-Cryptonodes

master

These sources allows one to build Docker image which provides bitcoin, bitcoin-cli and bitcoin-tx applications and which can be used to run and interact with a bitcoin server.

Images are provided for a range of current and past Bitcoin version. To see the available versions/tags, please visit the appropriate pages on Docker Hub:

<<<<<<< HEAD

master

Usage

To start a bitcoind instance running the latest version:

$ docker run r0shii/bitcoin

This docker image provides different tags so that you can specify the exact version of bitcoin you wish to run. For example, to run the latest minor version in the 0.15.x series (currently 0.15.1):

$ docker run r0shii/bitcoin:0.15.1

Or, to run the 0.15.0.1 release specifically:

$ docker run r0shii/bitcoin:0.15.0.1

To run a bitcoin container in the background, pass the -d option to docker run, and give your container a name for easy reference later:

$ docker run -d --rm --name bitcoind r0shii/bitcoin

Once you have a bitcoin service running in the background, you can show running containers:

$ docker ps

Or view the logs of a service:

$ docker logs -f bitcoind

To stop and restart a running container:

$ docker stop bitcoind
$ docker start bitcoind

Alternative Clients

Images are also provided for btc1, Bitcoin Unlimited, Bitcoin Classic, and Bitcoin XT, which are separately maintained forks of the original Bitcoin Core codebase.

To run the latest version of btc1 Core:

$ docker run r0shii/btc1

Specific versions of these alternate clients may be run using the command line options above.

Configuring Bitcoin

The best method to configure the bitcoin server is to pass arguments to the bitcoind command. For example, to run bitcoin on the testnet:

$ docker run --name bitcoind-testnet r0shii/bitcoin bitcoind -testnet

Alternatively, you can edit the bitcoin.conf file which is generated in your data directory (see below).

Data Volumes

By default, Docker will create ephemeral containers. That is, the blockchain data will not be persisted, and you will need to sync the blockchain from scratch each time you launch a container.

To keep your blockchain data between container restarts or upgrades, simply add the -v option to create a data volume:

$ docker run -d --rm --name bitcoind -v bitcoin-data:/data r0shii/bitcoin
$ docker ps
$ docker inspect bitcoin-data

Alternatively, you can map the data volume to a location on your host:

$ docker run -d --rm --name bitcoind -v "$PWD/data:/data" r0shii/bitcoin
$ ls -alh ./data

Using bitcoin-cli

By default, Docker runs all containers on a private bridge network. This means that you are unable to access the RPC port (8332) necessary to run bitcoin-cli commands.

There are several methods to run bitclin-cli against a running bitcoind container. The easiest is to simply let your bitcoin-cli container share networking with your bitcoind container:

$ docker run -d --rm --name bitcoind -v bitcoin-data:/data r0shii/bitcoin
$ docker run --rm --network container:bitcoind r0shii/bitcoin bitcoin-cli getinfo

If you plan on exposing the RPC port to multiple containers (for example, if you are developing an application which communicates with the RPC port directly), you probably want to consider creating a user-defined network. You can then use this network for both your bitcoind and bitclin-cli containers, passing -rpcconnect to specify the hostname of your bitcoind container:

$ docker network create bitcoin
$ docker run -d --rm --name bitcoind -v bitcoin-data:/data --network bitcoin r0shii/bitcoin
$ docker run --rm --network bitcoin r0shii/bitcoin bitcoin-cli -rpcconnect=bitcoind getinfo

License

Configuration files and code in this repository are distributed under the MIT license.

Contributing

All files are generated from templates in the root of this repository. Please do not edit any of the generated Dockerfiles directly.

  • To add a new Bitcoin version, update versions.yml, then run make update.
  • To make a change to the Dockerfile which affects all current and historical Bitcoin versions, edit Dockerfile.erb then run make update.

If you would like to build and test containers for all versions (similar to what happens in CI), run make. If you would like to build and test all containers for a specific Bitcoin fork, run BRANCH=core make.

About

Cryptocurrency node images for Docker

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 83.2%
  • HTML 8.0%
  • Ruby 7.6%
  • Makefile 1.2%