mempool/production
2021-02-04 15:53:08 +09:00
..
electrs-start-liquid Add production site setup guide and related install scripts 2020-05-25 20:58:46 +09:00
electrs-start-mainnet Set production electrs scripts to store db in /electrs 2021-02-04 15:53:08 +09:00
electrs-start-testnet Set production electrs scripts to store db in /electrs 2021-02-04 15:53:08 +09:00
mempool-config.bisq.json Replacing localhost with 127.0.0.1 2021-01-30 18:43:58 +07:00
mempool-config.liquid.json Fix production nginx.conf and backend config to always use unique ports 2021-01-31 01:16:32 +09:00
mempool-config.mainnet.json Fix production nginx.conf and backend config to always use unique ports 2021-01-31 01:16:32 +09:00
mempool-config.testnet.json Fix production nginx.conf and backend config to always use unique ports 2021-01-31 01:16:32 +09:00
mempool-frontend-config.json Add missing production/mempool-frontend-config.json 2021-01-11 23:14:08 +09:00
mempool-install-all Don't create empty cache.json on startup anymore 2021-01-18 12:20:55 +09:00
mempool-kill-all Fix upgrade script not restarting node due to new command line args 2020-09-18 18:08:59 +09:00
mempool-logger Update production syslog scripts 2021-01-30 20:09:47 +09:00
mempool-restart-all Add production script to update local copy of assets registry JSON 2020-09-24 18:42:13 +09:00
mempool-start-all Update production scripts to install/load NodeJS/npm using nvm 2020-09-18 21:53:58 +09:00
mempool-update-assets Add production script to update local copy of assets registry JSON 2020-09-24 18:42:13 +09:00
mempool-upgrade-all Rename production syslog notifications channel 2021-01-30 23:40:46 +09:00
newsyslog.conf Add newsyslog.conf to rotate mempool logfiles regularly 2020-10-13 19:56:10 +09:00
nginx-mempool-ssr.conf Rewrite server.ts to fix i18n and implement proper HTTP 404 responses 2020-12-23 13:26:11 +09:00
nginx-mempool.conf Enable 'ka' locale for Georgian 2020-12-07 00:20:05 +09:00
nginx.conf Fix production nginx.conf and backend config to always use unique ports 2021-01-31 01:16:32 +09:00
README.md Change nginx.conf Tor HS port from 81 to 80 to fix i18n bug 2020-12-03 09:56:29 +09:00
sitemap-update Update misc files used for mempool.space production website 2020-05-25 18:42:00 +09:00
syslog.conf Rename production syslog notifications channel 2021-01-30 23:40:46 +09:00
test-nginx Implement i18n support in frontend using Angular + Transifex + NGINX 2020-12-02 04:19:33 +09:00

mempool.space v2 production website hosting

These instructions are for setting up a serious production mempool website for Mainnet, Testnet, and Liquid. For home users, follow the main instructions instead.

Server Hardware

Mempool V2 is powered by electrs, which is a beast. I recommend a beefy server:

  • 16C CPU (more is better)
  • 64G RAM (more is better)
  • 2TB SSD (NVMe is better)

HDD vs SSD vs NVMe

If you don't have a fast SSD or NVMe backed disk, that's fine. What you do is, go online and buy some fast new NVMe drives and wait for them to arrive. After you install them, throw away your old HDDs and then proceed with the rest of this guide.

FreeBSD 12

The mempool.space site is powered by FreeBSD with ZFS root and ARC cache for maximum performance. Linux probably works fine too, but why settle?

Filesystem

For maximum performance, I use 2x 1TB NVMe SSDs in a RAID 0 using ZFS with lots of RAM for the ARC L2 cache.

# zpool list -v nvmraid
NAME         SIZE  ALLOC   FREE  CKPOINT  EXPANDSZ   FRAG    CAP  DEDUP  HEALTH  ALTROOT
nvmraid     1.81T  1.04T   787G        -         -     0%    57%  1.00x  ONLINE  -
  nvd0       928G   535G   393G        -         -     0%    57%
  nvd1       928G   534G   394G        -         -     0%    57%

For maximum flexibility of configuration, I configure the partitions separately for each data folder:

Filesystem                             Size    Used   Avail Capacity  Mounted on
nvmraid/mempool                        732G    3.0G    729G     0%    /mempool
nvmraid/mysql                          730G    618M    729G     0%    /mysql
nvmraid/bisq                           729G     88K    729G     0%    /bisq
nvmraid/elements                       731G    1.8G    729G     0%    /elements
nvmraid/elements/liquidv1              737G    7.2G    729G     1%    /elements/liquidv1
nvmraid/elements/electrs               730G    434M    729G     0%    /elements/electrs
nvmraid/bitcoin                        730G    694M    729G     0%    /bitcoin
nvmraid/bitcoin/chainstate             733G    3.9G    729G     1%    /bitcoin/chainstate
nvmraid/bitcoin/indexes                757G     27G    729G     4%    /bitcoin/indexes
nvmraid/bitcoin/electrs                730G    853M    729G     0%    /bitcoin/electrs
nvmraid/bitcoin/blocks                 1.0T    306G    729G    30%    /bitcoin/blocks
nvmraid/bitcoin/testnet3               729G     13M    729G     0%    /bitcoin/testnet3
nvmraid/bitcoin/testnet3/blocks        756G     26G    729G     3%    /bitcoin/testnet3/blocks
nvmraid/bitcoin/testnet3/chainstate    731G    1.3G    729G     0%    /bitcoin/testnet3/chainstate
nvmraid/bitcoin/testnet3/indexes       733G    3.8G    729G     1%    /bitcoin/testnet3/indexes
nvmraid/electrs/liquid/cache           729G     39M    729G     0%    /electrs/liquid/newindex/cache
nvmraid/electrs/liquid/history         730G    737M    729G     0%    /electrs/liquid/newindex/history
nvmraid/electrs/liquid/txstore         736G    6.2G    729G     1%    /electrs/liquid/newindex/txstore
nvmraid/electrs/mainnet/cache          729G     44M    729G     0%    /electrs/mainnet/newindex/cache
nvmraid/electrs/mainnet/history        964G    234G    729G    24%    /electrs/mainnet/newindex/history
nvmraid/electrs/mainnet/txstore        1.1T    392G    729G    35%    /electrs/mainnet/newindex/txstore
nvmraid/electrs/testnet/cache          729G     40M    729G     0%    /electrs/testnet/newindex/cache
nvmraid/electrs/testnet/history        747G     18G    729G     2%    /electrs/testnet/newindex/history
nvmraid/electrs/testnet/txstore        764G     34G    729G     4%    /electrs/testnet/newindex/txstore

Build Dependencies

You'll probably need these:

pkg install -y zsh sudo git screen vim-console curl wget neovim rsync
pkg install -y openssl openssh-portable open-vm-tools-nox11 py37-pip
pkg install -y boost-libs autoconf automake gmake gcc libevent libtool pkgconf
pkg install -y mariadb55-server mariadb55-client nginx py37-certbot-nginx npm

NodeJS / npm

I recommend to build nodejs / npm from source using nvm:

curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.35.3/install.sh | zsh
source $HOME/.zshrc
nvm install node
nvm alias default node

Rust

I recommend to build rust from latest source:

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh

Tor

Install tor, add Bitcoin to _tor group:

pkg install -y tor
pw user mod bitcoin -G _tor

Then configure /usr/local/etc/tor/torrc as follows:

RunAsDaemon 1
SOCKSPort 9050
ControlPort 9051
Log notice syslog

CookieAuthentication 1
CookieAuthFileGroupReadable 1
CookieAuthFile /var/db/tor/control_auth_cookie
DataDirectory /var/db/tor
DataDirectoryGroupReadable 1

HiddenServiceDir /var/db/tor/mempool
HiddenServicePort 80 127.0.0.1:80
HiddenServiceVersion 3

Bitcoin

Build Bitcoin Core from source. Alternatively, install the OS packages:

pkg install -y bitcoin-daemon bitcoin-utils

Configure your bitcoin.conf like this:

server=1
daemon=1
listen=1
discover=1
txindex=1
dbcache=3700
maxconnections=1337
onion=127.0.0.1:9050
rpcallowip=127.0.0.1
rpcuser=0cd862dce678b830bd2aa36f10b9b6b2
rpcpassword=2d89d36cac4a13c87b5d19ef8f577e37

[main]
bind=127.0.0.1:8333
rpcbind=127.0.0.1:8332

[test]
bind=127.0.0.1:18333
rpcbind=127.0.0.1:18332

Elements

Build Elements Core from source:

./autogen.sh
MAKE=gmake CC=cc CXX=c++ CPPFLAGS=-I/usr/local/include \
./configure --with-gui=no --disable-wallet
gmake -j19
gmake install

Configure your elements.conf like this:

server=1
daemon=1
listen=1
chain=liquidv1
rpcuser=liquiduser
rpcpassword=liquidpass
validatepegin=1
mainchainrpchost=127.0.0.1
mainchainrpcport=8332
mainchainrpcuser=user
mainchainrpcpassword=pass
txindex=1

Start elementsd and wait for it to sync the Liquid blockchain.

Electrs

Install Electrs from source:

git clone https://github.com/Blockstream/electrs
cd electrs
git checkout new-index

You'll need 3 instances, one for each network. Build one at a time:

./electrs-start-mainnet
./electrs-start-testnet
./electrs-start-liquid

MariaDB

Import historical mempool fee database snapshot, or the blank mariadb structure if none:

mysql -u root
create database mempool;
grant all on mempool.* to 'mempool'@'localhost' identified by 'mempool';
create database tmempool;
grant all on tmempool.* to 'tmempool'@'localhost' identified by 'tmempool';
create database lmempool;
grant all on lmempool.* to 'lmempool'@'localhost' identified by 'lmempool';

Then import

mysql -u mempool -p mempool < /mempool/mempool/mariadb-structure.sql
mysql -u tmempool -p tmempool < /mempool/mempool/mariadb-structure.sql
mysql -u lmempool -p lmempool < /mempool/mempool/mariadb-structure.sql

Mempool

After all 3 electrs instances are fully indexed, install your 3 mempool nodes:

./mempool-install-all
./mempool-upgrade-all

Finally, start your 3 mempool backends:

./mempool-start-all

Nginx

Get SSL certificate using certbot:

certbot --nginx -d mempool.space

Install nginx.conf from this repo, edit as necessary:

cp nginx.conf /usr/local/etc/nginx/nginx.conf
vi /usr/local/etc/nginx/nginx.conf

Restart nginx

service nginx restart

Done

Your site should look like https://mempool.space/ If it doesn't ask wiz on Keybase DM or Twitter for help.