mempool/production
2021-08-21 21:56:42 +09:00
..
electrs-start-liquid Add missing --db-dir option in electrs-start-liquid script 2021-08-08 05:18:11 +09:00
electrs-start-mainnet Patch sysconf dep for blockstream/electrs build in start scripts 2021-07-25 15:20:35 +09:00
electrs-start-signet Enable sending CORS headers from electrs backend in startup script 2021-03-03 21:29:18 +09:00
electrs-start-testnet Enable sending CORS headers from electrs backend in startup script 2021-03-03 21:29:18 +09:00
mempool-config.bisq.json Unified Bisq config 2021-04-25 02:38:46 +04:00
mempool-config.liquid.json Update nginx and mempool backend configuration for active failover HA 2021-02-22 20:22:38 +09:00
mempool-config.mainnet.json Set production backend config "CLEAR_PROTECTION_MINUTES": 5 2021-04-15 21:44:38 +09:00
mempool-config.signet.json Update nginx and mempool backend configuration for active failover HA 2021-02-22 20:22:38 +09:00
mempool-config.testnet.json Update nginx and mempool backend configuration for active failover HA 2021-02-22 20:22:38 +09:00
mempool-frontend-config.json Update production frontend/backend config to support signet 2021-02-21 03:41:52 +09:00
mempool-install-all Modify production startup scripts to support signet 2021-02-21 03:44:33 +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 Fix typo/bug in mempool-logger script 2021-08-21 15:39:15 +09:00
mempool-restart-all Tweak production syslog configuration 2021-08-21 15:19:29 +09:00
mempool-start-all Don't start production instances if backend folder doesn't exist 2021-02-25 02:38:38 +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 Fix missing fetch command in upgrade script 2021-08-21 21:56:42 +09:00
newsyslog.conf Add newsyslog.conf to rotate mempool logfiles regularly 2020-10-13 19:56:10 +09:00
nginx-bisq.conf Add production/nginx-bisq.conf for bisq.markets usage 2021-05-11 14:18:25 +09:00
nginx-mempool-ssr.conf Improve production high availability using structured failover and cache 2021-02-23 13:33:52 +09:00
nginx-mempool.conf Update production nginx-mempool.conf for donations API endpoint 2021-08-11 01:00:17 +09:00
nginx.conf Enable 'ca' locale for Catalan 2021-08-08 01:05:42 +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
sysctl.conf Add production FreeBSD tuning parameters to increase network buffers 2021-04-16 00:12:29 +09:00
syslog.conf Tweak production syslog configuration 2021-08-21 15:19:29 +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.