2013-09-09 11:00:46 -05:00
|
|
|
btcd
|
|
|
|
====
|
|
|
|
|
2015-01-17 00:48:13 -06:00
|
|
|
[![Build Status](https://travis-ci.org/btcsuite/btcd.png?branch=master)]
|
|
|
|
(https://travis-ci.org/btcsuite/btcd)
|
2013-12-08 20:44:06 -06:00
|
|
|
|
2013-09-09 11:00:46 -05:00
|
|
|
btcd is an alternative full node bitcoin implementation written in Go (golang).
|
|
|
|
|
2014-05-23 11:18:08 -05:00
|
|
|
This project is currently under active development and is in a Beta state. It
|
|
|
|
is extremely stable and has been in production use for over 6 months as of May
|
|
|
|
2014, however there are still a couple of major features we want to add before
|
|
|
|
we come out of beta.
|
|
|
|
|
|
|
|
It properly downloads, validates, and serves the block chain using the exact
|
|
|
|
rules (including bugs) for block acceptance as Bitcoin Core. We have taken
|
|
|
|
great care to avoid btcd causing a fork to the block chain. It passes all of
|
|
|
|
the 'official' block acceptance tests
|
|
|
|
(https://github.com/TheBlueMatt/test-scripts) as well as all of the JSON test
|
|
|
|
data in the Bitcoin Core code.
|
|
|
|
|
|
|
|
It also relays newly mined blocks, maintains a transaction pool, and relays
|
|
|
|
individual transactions that have not yet made it into a block. It ensures all
|
|
|
|
transactions admitted to the pool follow the rules required by the block chain
|
|
|
|
and also includes the same checks which filter transactions based on
|
|
|
|
miner requirements ("standard" transactions) as Bitcoin Core.
|
|
|
|
|
|
|
|
One key difference between btcd and Bitcoin Core is that btcd does *NOT* include
|
|
|
|
wallet functionality and this was a very intentional design decision. See the
|
2013-10-05 02:51:12 -05:00
|
|
|
blog entry [here](https://blog.conformal.com/btcd-not-your-moms-bitcoin-daemon)
|
|
|
|
for more details. This means you can't actually make or receive payments
|
2014-02-04 11:03:35 -06:00
|
|
|
directly with btcd. That functionality is provided by the
|
2015-01-17 00:27:28 -06:00
|
|
|
[btcwallet](https://github.com/btcsuite/btcwallet) and
|
2015-01-17 00:17:38 -06:00
|
|
|
[btcgui](https://github.com/btcsuite/btcgui) projects which are both under
|
2014-02-04 11:03:35 -06:00
|
|
|
active development.
|
2013-10-04 22:59:05 -05:00
|
|
|
|
2014-02-13 12:39:17 -05:00
|
|
|
## Requirements
|
|
|
|
|
|
|
|
[Go](http://golang.org) 1.2 or newer.
|
|
|
|
|
2013-10-04 22:59:05 -05:00
|
|
|
## Installation
|
|
|
|
|
|
|
|
#### Windows - MSI Available
|
|
|
|
|
2015-01-17 00:48:13 -06:00
|
|
|
https://github.com/btcsuite/btcd/releases
|
2013-10-04 22:59:05 -05:00
|
|
|
|
|
|
|
#### Linux/BSD/POSIX - Build from Source
|
|
|
|
|
|
|
|
- Install Go according to the installation instructions here:
|
|
|
|
http://golang.org/doc/install
|
|
|
|
|
|
|
|
- Run the following command to obtain btcd, all dependencies, and install it:
|
2015-01-17 00:48:13 -06:00
|
|
|
```$ go get github.com/btcsuite/btcd/...```
|
2013-10-04 22:59:05 -05:00
|
|
|
|
2014-03-15 22:32:45 -05:00
|
|
|
- btcd (and utilities) will now be installed in either ```$GOROOT/bin``` or
|
|
|
|
```$GOPATH/bin``` depending on your configuration. If you did not already
|
|
|
|
add the bin directory to your system path during Go installation, we
|
|
|
|
recommend you do so now.
|
2013-10-04 22:59:05 -05:00
|
|
|
|
2013-10-08 13:30:36 -05:00
|
|
|
## Updating
|
|
|
|
|
|
|
|
#### Windows
|
|
|
|
|
|
|
|
Install a newer MSI
|
|
|
|
|
|
|
|
#### Linux/BSD/POSIX - Build from Source
|
|
|
|
|
|
|
|
- Run the following command to update btcd, all dependencies, and install it:
|
2015-01-17 00:48:13 -06:00
|
|
|
```$ go get -u -v github.com/btcsuite/btcd/...```
|
2013-10-08 13:30:36 -05:00
|
|
|
|
2013-10-04 22:59:05 -05:00
|
|
|
## Getting Started
|
|
|
|
|
|
|
|
btcd has several configuration options avilable to tweak how it runs, but all
|
|
|
|
of the basic operations described in the intro section work with zero
|
|
|
|
configuration.
|
|
|
|
|
|
|
|
#### Windows (Installed from MSI)
|
|
|
|
|
|
|
|
Launch btcd from your Start menu.
|
|
|
|
|
|
|
|
#### Linux/BSD/POSIX/Source
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ ./btcd
|
|
|
|
````
|
2014-03-04 12:58:59 -05:00
|
|
|
|
|
|
|
## IRC server
|
|
|
|
|
2014-03-04 13:00:06 -05:00
|
|
|
- irc.conformal.com:6697
|
2014-03-04 12:58:59 -05:00
|
|
|
- ssl required
|
|
|
|
- channel #btcd
|
|
|
|
|
2013-10-15 12:16:17 -04:00
|
|
|
## Mailing lists
|
|
|
|
|
|
|
|
- btcd: discussion of btcd and its packages.
|
|
|
|
- btcd-commits: readonly mail-out of source code changes.
|
|
|
|
|
|
|
|
To subscribe to a given list, send email to list+subscribe@opensource.conformal.com
|
2013-09-09 11:00:46 -05:00
|
|
|
|
2014-02-04 11:03:35 -06:00
|
|
|
## Issue Tracker
|
2013-09-09 11:00:46 -05:00
|
|
|
|
2015-01-17 00:48:13 -06:00
|
|
|
The [integrated github issue tracker](https://github.com/btcsuite/btcd/issues)
|
2014-02-04 11:03:35 -06:00
|
|
|
is used for this project.
|
2013-10-04 22:59:05 -05:00
|
|
|
|
2014-02-04 11:06:39 -06:00
|
|
|
## Documentation
|
|
|
|
|
2015-01-18 11:16:43 -06:00
|
|
|
The documentation is a work-in-progress. It is located in the [docs](https://github.com/btcsuite/btcd/tree/master/docs) folder.
|
2014-02-04 11:06:39 -06:00
|
|
|
|
2013-10-04 22:59:05 -05:00
|
|
|
## GPG Verification Key
|
|
|
|
|
|
|
|
All official release tags are signed by Conformal so users can ensure the code
|
|
|
|
has not been tampered with and is coming from Conformal. To verify the
|
|
|
|
signature perform the following:
|
|
|
|
|
|
|
|
- Download the public key from the Conformal website at
|
|
|
|
https://opensource.conformal.com/GIT-GPG-KEY-conformal.txt
|
|
|
|
|
|
|
|
- Import the public key into your GPG keyring:
|
|
|
|
```bash
|
|
|
|
gpg --import GIT-GPG-KEY-conformal.txt
|
|
|
|
```
|
|
|
|
|
|
|
|
- Verify the release tag with the following command where `TAG_NAME` is a
|
|
|
|
placeholder for the specific tag:
|
|
|
|
```bash
|
|
|
|
git tag -v TAG_NAME
|
|
|
|
```
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
2014-01-15 10:19:51 -06:00
|
|
|
btcd is licensed under the [copyfree](http://copyfree.org) ISC License.
|