Skip to content
Decred daemon in Go (golang).
Go Other
  1. Go 99.9%
  2. Other 0.1%
Branch: master
Clone or download
#1841 Compare This branch is 2204 commits ahead, 624 commits behind btcsuite:master.
dajohi and davecgh chaincfg: deprecate type DNSSeed and Params.DNSSeeds
connmgr: deprecate SeedFromDNS
config: deprecate nodnsseed; add noseeders
Latest commit e3547d0 Dec 4, 2019
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.github build: golangci-lint v1.22.2 Jan 4, 2020
addrmgr multi: remove whitespace Nov 22, 2019
bech32 bech32: Add base256 conversion convenience funcs. Dec 27, 2019
blockchain multi: Update to prerel module release versions. Jan 9, 2020
certgen multi: Updates for staticcheck results. Oct 31, 2019
chaincfg chaincfg: deprecate type DNSSeed and Params.DNSSeeds Jan 12, 2020
cmd blockchain: Make checkpoints configurable. Dec 6, 2019
connmgr chaincfg: deprecate type DNSSeed and Params.DNSSeeds Jan 12, 2020
crypto multi: Address a bunch of lint issues. Dec 30, 2019
database multi: Update to prerel module release versions. Jan 9, 2020
dcrec edwards: Remove unused code. Oct 31, 2019
dcrjson multi: Updates for staticcheck results. Oct 31, 2019
dcrutil multi: Use latest base58 module. Dec 3, 2019
docs multi: Introduce regentemplate command Nov 4, 2019
fees multi: Update to prerel module release versions. Jan 9, 2020
gcs multi: Update to prerel module release versions. Jan 9, 2020
hdkeychain multi: Update to prerel module release versions. Jan 9, 2020
internal mempool: Associated tag with orphan txns. Nov 4, 2019
lru multi: Address a bunch of lint issues. Dec 30, 2019
mempool multi: Update to prerel module release versions. Jan 9, 2020
mining multi: Update to prerel module release versions. Jan 9, 2020
peer multi: Update to prerel module release versions. Jan 9, 2020
release release: Add example OpenBSD rc.d service script Jan 10, 2020
rpc/jsonrpc/types multi: remove whitespace Nov 22, 2019
rpcclient multi: Update to prerel module release versions. Jan 9, 2020
rpctest txscript: drop chainec Oct 26, 2019
sampleconfig config: Add flag to allow unsynced testnet mining. Dec 28, 2019
txscript multi: Update to prerel module release versions. Jan 9, 2020
wire multi: remove whitespace Nov 22, 2019
.dockerignore docker: Add dockerfiles for running dcrd nodes. Jul 7, 2018
.gitignore main: add address encoding magic constants test Sep 26, 2018
CHANGES multi: Use https links where available. Jun 18, 2019
Dockerfile docker: update alpine and include notes. Jul 20, 2019
Dockerfile.alpine docker: update alpine and include notes. Jul 20, 2019
LICENSE multi: Add initial committed filter (CF) support Mar 30, 2018
README.md build: Replace TravisCI with CI via Github actions. Sep 21, 2019
blocklogger.go dcrutil: Start v3 module dev cycle. Oct 25, 2019
blockmanager.go blockmanager: Remove unused diff calc code. Dec 28, 2019
cert_test.go server: Add tlscurve config parameter Oct 31, 2019
config.go chaincfg: deprecate type DNSSeed and Params.DNSSeeds Jan 12, 2020
config_test.go travis: Test go1.13 and drop go1.11. Sep 3, 2019
cpuminer.go multi: remove whitespace Nov 22, 2019
dcrd.go indexers: convert to contexts Nov 19, 2019
doc.go config: Add flag to allow unsynced testnet mining. Dec 28, 2019
go.mod multi: Update to prerel module release versions. Jan 9, 2020
go.sum dcrctl: Update dcrwallet RPC types package Dec 23, 2019
ipc.go multi: Correct typos. Aug 16, 2019
log.go server/mempool: Evict orphans on peer disconnect. Nov 4, 2019
mining.go blockchain: Explicit hash in next work diff calcs. Dec 28, 2019
mining_test.go stake: Start v3 module dev cycle. Oct 25, 2019
miningerror.go multi: Implement header commitments and vote. Oct 12, 2019
networkparams_test.go multi: Correct typos. Aug 16, 2019
params.go multi: remove global activeNetParams Nov 8, 2019
require.go bech32: Ensure HRP is lowercase when encoding. Dec 27, 2019
rpcadaptors.go mempool: Associated tag with orphan txns. Nov 4, 2019
rpcserver.go config: Add flag to allow unsynced testnet mining. Dec 28, 2019
rpcserver_test.go multi: Correct typos. Aug 16, 2019
rpcserverhelp.go multi: Introduce regentemplate command Nov 4, 2019
rpcserverhelp_test.go multi: remove whitespace Nov 22, 2019
rpcwebsocket.go rpcwebsocket: Use nonblocking messages and ntfns. Dec 27, 2019
run_tests.sh build: Add deadcode to linters for CI tests. Oct 31, 2019
server.go chaincfg: deprecate type DNSSeed and Params.DNSSeeds Jan 12, 2020
service_windows.go multi: Correct typos. Aug 22, 2019
signal.go main: Convert signal handling to use context. Apr 1, 2019
signalsigterm.go Add pipes for parent process IPC. (#311) Aug 31, 2016
upnp.go dcrd: attach shutdown context to listeners Oct 31, 2019

README.md

dcrd

Build Status ISC License GoDoc Go Report Card

Decred Overview

Decred is a blockchain-based cryptocurrency with a strong focus on community input, open governance, and sustainable funding for development. It utilizes a hybrid proof-of-work and proof-of-stake mining system to ensure that a small group cannot dominate the flow of transactions or make changes to Decred without the input of the community. A unit of the currency is called a decred (DCR).

https://decred.org

Latest Downloads

https://decred.org/downloads

What is dcrd?

dcrd is a full node implementation of Decred written in Go (golang).

It acts as a fully-validating chain daemon for the Decred cryptocurrency. dcrd maintains the entire past transactional ledger of Decred and allows relaying of transactions to other Decred nodes around the world.

This software is currently under active development. It is extremely stable and has been in production use since February 2016.

The software was originally forked from btcd, which is a bitcoin full node implementation that is still under active development. To gain the benefit of btcd's ongoing upgrades, including improved peer and connection handling, database optimization, and other blockchain related technology improvements, dcrd is continuously synced with the btcd codebase.

What is a full node?

The term 'full node' is short for 'fully-validating node' and refers to software that fully validates all transactions and blocks, as opposed to trusting a 3rd party. In addition to validating transactions and blocks, nearly all full nodes also participate in relaying transactions and blocks to other full nodes around the world, thus forming the peer-to-peer network that is the backbone of the Decred cryptocurrency.

The full node distinction is important, since full nodes are not the only type of software participating in the Decred peer network. For instance, there are 'lightweight nodes' which rely on full nodes to serve the transactions, blocks, and cryptographic proofs they require to function, as well as relay their transactions to the rest of the global network.

Why run dcrd?

As described in the previous section, the Decred cryptocurrency relies on having a peer-to-peer network of nodes that fully validate all transactions and blocks and then relay them to other full nodes.

Running a full node with dcrd contributes to the overall security of the network, increases the available paths for transactions and blocks to relay, and helps ensure there are an adequate number of nodes available to serve lightweight clients, such as Simplified Payment Verification (SPV) wallets.

Without enough full nodes, the network could be unable to expediently serve users of lightweight clients which could force them to have to rely on centralized services that significantly reduce privacy and are vulnerable to censorship.

In terms of individual benefits, since dcrd fully validates every block and transaction, it provides the highest security and privacy possible when used in conjunction with a wallet that also supports directly connecting to it in full validation mode, such as dcrwallet (CLI) and Decrediton (GUI).

Minimum Recommended Specifications (dcrd only)

  • 10 GB disk space (as of September 2018, increases over time)
  • 1GB memory (RAM)
  • ~150MB/day download, ~1.5GB/day upload
    • Plus one-time initial download of the entire block chain
  • Windows 7/8.x/10 (server preferred), macOS, Linux
  • High uptime

Getting Started

So, you've decided to help the network by running a full node. Great! Running dcrd is simple. All you need to do is install dcrd on a machine that is connected to the internet and meets the minimum recommended specifications, and launch it.

Also, make sure your firewall is configured to allow inbound connections to port 9108.

Installing and updating

Binaries (Windows/Linux/macOS)

Binary releases are provided for common operating systems and architectures:

https://decred.org/downloads

Build from source (all platforms)

Building or updating from source requires the following build dependencies:

To build and install from a checked-out repo, run go install . ./cmd/... in the repo's root directory. Some notes:

  • Set the GO111MODULE=on environment variable if building from within GOPATH.

  • The dcrd executable will be installed to $GOPATH/bin. GOPATH defaults to $HOME/go (or %USERPROFILE%\go on Windows) if unset.

Example of obtaining and building from source on Windows 10:

PS> git clone https://github.com/decred/dcrd $env:USERPROFILE\src\dcrd
PS> cd $env:USERPROFILE\src\dcrd
PS> go install . .\cmd\...
PS> & "$(go env GOPATH)\bin\dcrd" -V

Docker

Running dcrd

You can run a decred node from inside a docker container. To build the image yourself, use the following command:

docker build -t decred/dcrd .

Or you can create an alpine based image (requires Docker 17.05 or higher):

docker build -t decred/dcrd:alpine -f Dockerfile.alpine .

You can then run the image using:

docker run decred/dcrd

You may wish to use an external volume to customise your config and persist the data in an external volume:

docker run --rm -v /home/user/dcrdata:/root/.dcrd/data decred/dcrd

For a minimal image, you can use the decred/dcrd:alpine tag. This is typically a more secure option while also being a much smaller image.

You can run dcrctl from inside the image. For example, run an image (mounting your data from externally) with:

docker run --rm -ti --name=dcrd-1 -v /home/user/.dcrd:/root/.dcrd \
  decred/dcrd:alpine

And then run dcrctl commands against it. For example:

docker exec -ti dcrd-1 dcrctl getbestblock

Running Tests

All tests and linters may be run in a docker (or podman) container using the script run_tests.sh by specifying either docker or podman as the first parameter. This script defaults to using the current latest supported version of Go, but it also respects the GOVERSION environment variable set to the major version of Go to allow testing on a previous version of Go. Generally, Decred only supports the current and previous major versions of Go.

./run_tests.sh docker

To run the tests locally without docker on the latest supported version of Go:

./run_tests.sh

To run the tests locally without docker on Go 1.11:

GOVERSION=1.11 ./run_tests.sh

Contact

If you have any further questions you can find us at:

https://decred.org/community

Issue Tracker

The integrated github issue tracker is used for this project.

Documentation

The documentation for dcrd is a work-in-progress. It is located in the docs folder.

License

dcrd is licensed under the copyfree ISC License.

You can’t perform that action at this time.