Merge pull request #1 from jmaurice/master
Add instructions and screenshots to README
This commit is contained in:
		
						commit
						12096b3e0d
					
				
							
								
								
									
										146
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										146
									
								
								README.md
									
									
									
									
									
								
							@ -1,2 +1,146 @@
 | 
			
		||||
# mempool.space
 | 
			
		||||
Mempool visualizer for the Bitcoin blockchain.
 | 
			
		||||
Mempool visualizer for the Bitcoin blockchain. Live demo: https://mempool.space/
 | 
			
		||||

 | 
			
		||||

 | 
			
		||||
 | 
			
		||||
## Prerequisites
 | 
			
		||||
 | 
			
		||||
* Bitcoin (full node required, no pruning)
 | 
			
		||||
* NodeJS (official stable LTS)
 | 
			
		||||
* MariaDB (default config)
 | 
			
		||||
 | 
			
		||||
## NodeJS setup
 | 
			
		||||
 | 
			
		||||
Install dependencies and build code:
 | 
			
		||||
```
 | 
			
		||||
cd mempool.space
 | 
			
		||||
npm install -g typescript
 | 
			
		||||
cd frontend
 | 
			
		||||
npm install
 | 
			
		||||
cd ../backend/
 | 
			
		||||
npm install
 | 
			
		||||
tsc .
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## Bitcoin Setup
 | 
			
		||||
 | 
			
		||||
Enable RPC and txindex in bitcoin.conf
 | 
			
		||||
```
 | 
			
		||||
rpcuser=mempool
 | 
			
		||||
rpcpassword=71b61986da5b03a5694d7c7d5165ece5
 | 
			
		||||
txindex=1
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
Edit mempool-config.json for your Bitcoin:
 | 
			
		||||
```
 | 
			
		||||
  "BITCOIN_NODE_HOST": "192.168.1.5",
 | 
			
		||||
  "BITCOIN_NODE_PORT": 8332,
 | 
			
		||||
  "BITCOIN_NODE_USER": "mempool",
 | 
			
		||||
  "BITCOIN_NODE_PASS": "71b61986da5b03a5694d7c7d5165ece5",
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## Database Setup
 | 
			
		||||
 | 
			
		||||
Install MariaDB:
 | 
			
		||||
```
 | 
			
		||||
apt-get install mariadb-server mariadb-client
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
Create database and grant privileges:
 | 
			
		||||
```
 | 
			
		||||
MariaDB [(none)]> drop database mempool;
 | 
			
		||||
Query OK, 0 rows affected (0.00 sec)
 | 
			
		||||
 | 
			
		||||
MariaDB [(none)]> create database mempool;
 | 
			
		||||
Query OK, 1 row affected (0.00 sec)
 | 
			
		||||
 | 
			
		||||
MariaDB [(none)]> grant all privileges on mempool.* to 'mempool' identified by 'mempool';
 | 
			
		||||
Query OK, 0 rows affected (0.00 sec)
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
Initialize database structure:
 | 
			
		||||
```
 | 
			
		||||
mysql -u mempool -p mempool < mariadb-structure.sql
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
Edit mempool-config.json for your MariaDB:
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
  "DB_HOST": "127.0.0.1",
 | 
			
		||||
  "DB_PORT": 3306,
 | 
			
		||||
  "DB_USER": "mempool",
 | 
			
		||||
  "DB_PASSWORD": "mempool",
 | 
			
		||||
  "DB_DATABASE": "mempool",
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## Start backend
 | 
			
		||||
 | 
			
		||||
Create an initial empty cache and start the app:
 | 
			
		||||
```
 | 
			
		||||
touch cache.json
 | 
			
		||||
node dist/index.js
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
After starting you should see:
 | 
			
		||||
```
 | 
			
		||||
Server started on port 8999 :)
 | 
			
		||||
New block found (#586498)! 0 of 1986 found in mempool. 1985 not found.
 | 
			
		||||
New block found (#586499)! 0 of 1094 found in mempool. 1093 not found.
 | 
			
		||||
New block found (#586500)! 0 of 2735 found in mempool. 2734 not found.
 | 
			
		||||
New block found (#586501)! 0 of 2675 found in mempool. 2674 not found.
 | 
			
		||||
New block found (#586502)! 0 of 975 found in mempool. 974 not found.
 | 
			
		||||
New block found (#586503)! 0 of 2130 found in mempool. 2129 not found.
 | 
			
		||||
New block found (#586504)! 0 of 2770 found in mempool. 2769 not found.
 | 
			
		||||
New block found (#586505)! 0 of 2759 found in mempool. 2758 not found.
 | 
			
		||||
Updating mempool
 | 
			
		||||
Calculated fee for transaction 1 / 3257
 | 
			
		||||
Calculated fee for transaction 2 / 3257
 | 
			
		||||
Calculated fee for transaction 3 / 3257
 | 
			
		||||
Calculated fee for transaction 4 / 3257
 | 
			
		||||
Calculated fee for transaction 5 / 3257
 | 
			
		||||
Calculated fee for transaction 6 / 3257
 | 
			
		||||
Calculated fee for transaction 7 / 3257
 | 
			
		||||
Calculated fee for transaction 8 / 3257
 | 
			
		||||
Calculated fee for transaction 9 / 3257
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
Now go make coffee for like 10 minutes while the backend indexes transactions, fees, etc. and builds the initial cache. When it's ready you will see output like this:
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
Mempool updated in 0.189 seconds
 | 
			
		||||
Updating mempool
 | 
			
		||||
Mempool updated in 0.096 seconds
 | 
			
		||||
Updating mempool
 | 
			
		||||
Mempool updated in 0.099 seconds
 | 
			
		||||
Updating mempool
 | 
			
		||||
Calculated fee for transaction 1 / 10
 | 
			
		||||
Calculated fee for transaction 2 / 10
 | 
			
		||||
Calculated fee for transaction 3 / 10
 | 
			
		||||
Calculated fee for transaction 4 / 10
 | 
			
		||||
Calculated fee for transaction 5 / 10
 | 
			
		||||
Calculated fee for transaction 6 / 10
 | 
			
		||||
Calculated fee for transaction 7 / 10
 | 
			
		||||
Calculated fee for transaction 8 / 10
 | 
			
		||||
Calculated fee for transaction 9 / 10
 | 
			
		||||
Calculated fee for transaction 10 / 10
 | 
			
		||||
Mempool updated in 0.243 seconds
 | 
			
		||||
Updating mempool
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## Start frontend
 | 
			
		||||
 | 
			
		||||
Then in another terminal:
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
cd ../frontend/
 | 
			
		||||
npm run start
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
## Open Browser
 | 
			
		||||
 | 
			
		||||
```
 | 
			
		||||
firefox http://127.0.0.1:4200/
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
And if everything went okay you should see beautiful mempool :grin:
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user