forked from libbitcoin/libbitcoin-system
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
147 lines (107 loc) · 3.83 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
All files in this repository fall under the license specified in LICENSE
The project is licensed as AGPL with a lesser clause. It may be used within
a proprietary project, but the core library and any changes to it must be
published online. Source code for this library must always remain free for
everybody to access.
==========================
Debian/Ubuntu Instructions
==========================
Note that you need g++ 4.7 or higher. For this reason Ubuntu 12.04 and older are not supported.
VVVVVVVVVVV
> Start Here! <
^^^^^^^^^^^
$ sudo apt-get install build-essential autoconf automake libtool libboost-all-dev pkg-config libcurl4-openssl-dev libleveldb-dev libssl-dev
$ autoreconf -i
$ ./configure --enable-leveldb
$ make
$ sudo make install
$ sudo ldconfig
libbitcoin is now installed in /usr/local/.
* Ubuntu Precise Pangolin requires libboost1.48-all-dev instead of
libboost-all-dev above.
--------
Advanced
--------
Files Open Limit
----------------
For the blockchain database, set the max open files limit higher.
The default limit on most Linux systems is too low.
$ ulimit -n 4096
Core Dependencies
-----------------
You will need:
- GCC 4.7 or newer
- Boost 1.48 or newer
- OpenSSL 0.9 or newer
- LevelDB
Install Prefix
--------------
'./configure' accepts a --prefix switch. This is useful if you prefer to
install libbitcoin to a local directory instead.
$ ./configure --enable-leveldb --prefix /home/genjix/usr/
$ make
$ make install
Then add these environment variables to the end of your ~/.bashrc to point
software to your local installation. Otherwise software will have trouble
finding the libbitcoin install.
export LD_LIBRARY_PATH=~/usr/lib/
export PKG_CONFIG_PATH=~/usr/lib/pkgconfig/
'./configure' also accepts the following flags:
--enable-testnet (enables the alternative blockchain used for testing)
--enable-debug (verbose output)
Compile/Build Flags
-------------------
pkg-config can be invoked to get the neccessary compile and build flags
for creating software using libbitcoin.
$ pkg-config --cflags --libs libbitcoin
--------
Examples
--------
Start with the examples/ to see a few sample programs:
$ cd examples/
$ make
# Play around with private keys.
$ ./priv
# Initialize a new LevelDB blockchain database.
$ mkdir database
$ ./initchain database/
# Run the fullnode example (validates blocks and transactions).
$ ./fullnode
=======================
Arch Linux Instructions
=======================
Libbitcoin is available from the AUR: https://aur.archlinux.org/packages/libbitcoin-leveldb-git/
=======================
Gentoo Linux Instructions
=======================
Libbitcoin is available in the 'bitcoin' overlay. Use layman to fetch
the overlay then emerge as usual.
If you want to use live build, unlock the '**' keyword for net-p2p/libbitcoin
in /etc/portage/package.accept_keywords
====================
Mac OSX Instructions
====================
To build on Mac OSX, you will need to download and compile your own boost,
leveldb using gcc 4.7 before building libbitcoin. Then set the following
environment variables before running the build process.
CC=/usr/local/bin/gcc-4.7
CXX=/usr/local/bin/g++-4.7
You will need secp256k1 as a library dependency, if you don't have
it already in your system this is how you get/build/install it from source code.
$ git clone https://github.com/bitcoin/secp256k1
$ cd secp256k1
$ ./autogen.sh
$ ./configure
$ make
$ sudo make install
For Mac OSX Mountain Lion, you need to follow these brew commands:
$ brew install boost openssl leveldb
$ brew tap homebrew/versions
$ brew install gcc48
# Can be replaced back later if you prefer, but
# keeping the new g++ is a good idea.
$ sudo ln -sf /usr/local/bin/g++-4.8 /usr/bin/g++
$ autoreconf -i
$ ./configure --enable-leveldb
$ make
$ sudo make install