From ca986d3dcbe2ee8e26de2b73346086f654b32ea5 Mon Sep 17 00:00:00 2001 From: Taylor Helsper Date: Mon, 22 Feb 2021 20:39:14 -0600 Subject: [PATCH] Upgrade Mempool to v2.1.2 * Add mempool v2 * Update to v2.1.2 * Stop tor re-install on each upgrade * Add dates to changelog * Upgrade Mempool to v2 --- CHANGELOG | 8 +++ .../sites-enabled/https_mempoolspace.conf | 7 +++ .../etc/systemd/system/mempoolspace.service | 15 ++++-- .../standard/usr/bin/mynode_docker_images.sh | 51 +++++++++++-------- .../standard/usr/bin/mynode_post_mempool.sh | 37 ++++++++++++++ .../standard/usr/bin/mynode_post_upgrade.sh | 12 ++--- .../standard/usr/bin/mynode_reinstall_app.sh | 3 +- rootfs/standard/usr/bin/mynode_startup.sh | 20 ++++++++ .../usr/bin/wait_on_docker_image_install.sh | 4 +- .../share/mynode/mempool-docker-compose.yml | 47 +++++++++++++++++ rootfs/standard/usr/share/mynode/mempool.env | 3 ++ 11 files changed, 173 insertions(+), 34 deletions(-) create mode 100755 rootfs/standard/usr/bin/mynode_post_mempool.sh create mode 100644 rootfs/standard/usr/share/mynode/mempool-docker-compose.yml create mode 100644 rootfs/standard/usr/share/mynode/mempool.env diff --git a/CHANGELOG b/CHANGELOG index 4f7b1723..fd00d046 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -1,4 +1,5 @@ === v0.2.26 === +- Released: 02/13/21 - Add CKBunker v0.9 (beta) - Add Sphinx Relay v1.3.8 (beta) - Upgrade Thunderhub to v0.12.7 @@ -7,9 +8,11 @@ - Bug Fixes === v0.2.25 === +- Released: 02/05/21 - Improve drive detection for Clone Tool === v0.2.24 === +- Released: 02/04/21 - Upgrade Bitcoin to v0.21.0 - Upgrade LND to v0.12.0 - Upgrade JoinMarket to v0.8.0 @@ -19,6 +22,7 @@ - Bug fixes and minor UI improvements === v0.2.23 === +- Released: 01/25/21 - Update BTC RPC Explorer to v2.2.0 - Use SSO for securing BTC RPC Explorer access - Move all Dojo files to external drive @@ -26,6 +30,7 @@ - Bug Fixes === v0.2.22 === +- Released: 01/16/21 - Upgrade Caravan to v0.3.5 - Fix issue with Mempool on HTTPS - Upgrade Specter to v1.0.0 @@ -34,6 +39,7 @@ - Bug Fixes === v0.2.21 === +- Released: 01/02/21 - Update Loop to v0.11.2 - Upgrade RTL to v0.10.0 - Upgrade Thunderhub to v0.12.2 @@ -44,6 +50,7 @@ - Add Onion URL for Whirlpool === v0.2.20 === +- Released: 12/20/20 - Upgrade Specter to v0.10.4 - Upgrade Thunderhub to v0.11.0 - Upgrade Whirlpool CLI to v0.10.9 @@ -51,6 +58,7 @@ - Bug fixes === v0.2.19 === +- Released: 11/27/20 - Add Pool - Upgrade electrs to v0.8.6 - Upgrade Specter to v0.10.1 diff --git a/rootfs/standard/etc/nginx/sites-enabled/https_mempoolspace.conf b/rootfs/standard/etc/nginx/sites-enabled/https_mempoolspace.conf index 7d33de35..07005c40 100644 --- a/rootfs/standard/etc/nginx/sites-enabled/https_mempoolspace.conf +++ b/rootfs/standard/etc/nginx/sites-enabled/https_mempoolspace.conf @@ -20,4 +20,11 @@ server { proxy_set_header Connection "Upgrade"; proxy_set_header Host $host; } + location /api/v1/ws { + proxy_pass http://127.0.0.1:4080/api/v1/ws; + proxy_http_version 1.1; + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection "Upgrade"; + proxy_set_header Host $host; + } } \ No newline at end of file diff --git a/rootfs/standard/etc/systemd/system/mempoolspace.service b/rootfs/standard/etc/systemd/system/mempoolspace.service index 33db8aa4..a24143b2 100644 --- a/rootfs/standard/etc/systemd/system/mempoolspace.service +++ b/rootfs/standard/etc/systemd/system/mempoolspace.service @@ -7,19 +7,26 @@ Wants=www.service docker_images.service After=www.service docker_images.service [Service] +WorkingDirectory=/mnt/hdd/mynode/mempool EnvironmentFile=/mnt/hdd/mynode/settings/.btcrpc_environment ExecStartPre=/usr/bin/is_not_shutting_down.sh ExecStartPre=/usr/bin/wait_on_bitcoin.sh ExecStartPre=/usr/bin/wait_on_docker_image_install.sh -ExecStart=/usr/bin/docker run --rm --name mempoolspace -p 4080:80 -e BITCOIN_NODE_HOST=172.17.0.1 -e BITCOIN_NODE_USER=mynode -e BITCOIN_NODE_PASS=${BTC_RPC_PASSWORD} -e MEMPOOL_REFRESH_RATE_MS=10000 mempoolspace -ExecStop=/usr/bin/docker stop -t 2 mempoolspace +ExecStart=/usr/local/bin/docker-compose up +ExecStartPost=/usr/bin/mynode_post_mempool.sh + +ExecStop=/usr/local/bin/docker-compose down + +# Old v1 +#ExecStart=/usr/bin/docker run --rm --name mempoolspace -p 4080:80 -e BITCOIN_NODE_HOST=172.17.0.1 -e BITCOIN_NODE_USER=mynode -e BITCOIN_NODE_PASS=${BTC_RPC_PASSWORD} -e MEMPOOL_REFRESH_RATE_MS=10000 mempoolspace +#ExecStop=/usr/bin/docker stop -t 2 mempoolspace User=root Group=root Type=simple -TimeoutSec=240 +TimeoutSec=120 Restart=always -RestartSec=120 +RestartSec=30 StandardOutput=syslog StandardError=syslog SyslogIdentifier=mempoolspace diff --git a/rootfs/standard/usr/bin/mynode_docker_images.sh b/rootfs/standard/usr/bin/mynode_docker_images.sh index d9f97aca..fe466fe7 100755 --- a/rootfs/standard/usr/bin/mynode_docker_images.sh +++ b/rootfs/standard/usr/bin/mynode_docker_images.sh @@ -48,33 +48,41 @@ while true; do # Upgrade mempool echo "Checking for new mempool..." - MEMPOOLSPACE_UPGRADE_VERSION=v1.0.1 - MEMPOOLSPACE_UPGRADE_URL=https://github.com/mempool/mempool/archive/${MEMPOOLSPACE_UPGRADE_VERSION}.zip - MEMPOOLSPACE_UPGRADE_URL_FILE=/mnt/hdd/mynode/settings/mempoolspace_url + MEMPOOL_UPGRADE_VERSION=v2.1.2 + MEMPOOL_UPGRADE_URL=https://github.com/mempool/mempool/archive/${MEMPOOL_UPGRADE_VERSION}.tar.gz + MEMPOOL_UPGRADE_URL_FILE=/mnt/hdd/mynode/settings/mempoolspace_url CURRENT="" - if [ -f $MEMPOOLSPACE_UPGRADE_URL_FILE ]; then - CURRENT=$(cat $MEMPOOLSPACE_UPGRADE_URL_FILE) + if [ -f $MEMPOOL_UPGRADE_URL_FILE ]; then + CURRENT=$(cat $MEMPOOL_UPGRADE_URL_FILE) fi - if [ "$CURRENT" != "$MEMPOOLSPACE_UPGRADE_URL" ]; then - docker rmi mempoolspace || true + if [ "$CURRENT" != "$MEMPOOL_UPGRADE_URL" ]; then + docker rmi mempoolspace || true # Remove old v1 image - cd /opt/mynode - rm -rf mempoolspace - wget $MEMPOOLSPACE_UPGRADE_URL -O mempool.zip - unzip -o mempool.zip - rm mempool.zip - mv mempool* mempoolspace - cd mempoolspace - sync + cd /mnt/hdd/mynode/mempool + mkdir -p data mysql/data mysql/db-scripts + cp -f /usr/share/mynode/mempool-docker-compose.yml /mnt/hdd/mynode/docker-compose.yml - # myNode Hack - Force use of specific alpine image source - sed -i "s/alpine:latest/alpine:3.12.3/g" Dockerfile + rm -rf /opt/download/mempool + mkdir -p /opt/download/mempool + cd /opt/download/mempool + wget $MEMPOOL_UPGRADE_URL -O mempool.tar.gz + tar -xvf mempool.tar.gz + rm mempool.tar.gz + mv mempool-* mempool + cp -f mempool/mariadb-structure.sql /mnt/hdd/mynode/mempool/mysql/db-scripts/mariadb-structure.sql - sleep 3s - docker build -t mempoolspace . - if [ $? == 0 ]; then - echo $MEMPOOLSPACE_UPGRADE_URL > $MEMPOOLSPACE_UPGRADE_URL_FILE + # Update env variable to use latest version + sed -i "s/VERSION=.*/VERSION=$MEMPOOL_UPGRADE_VERSION/g" /mnt/hdd/mynode/mempool/.env + + docker pull mempool/frontend:${MEMPOOL_UPGRADE_VERSION} + docker pull mempool/backend:${MEMPOOL_UPGRADE_VERSION} + + enabled=$(systemctl is-enabled mempoolspace) + if [ "$enabled" = "enabled" ]; then + systemctl restart mempoolspace & fi + + echo $MEMPOOL_UPGRADE_URL > $MEMPOOL_UPGRADE_URL_FILE fi # Install Dojo @@ -145,6 +153,7 @@ while true; do fi rm -f /tmp/installing_docker_images + touch /tmp/installing_docker_images_completed_once # Wait a day sleep 1d diff --git a/rootfs/standard/usr/bin/mynode_post_mempool.sh b/rootfs/standard/usr/bin/mynode_post_mempool.sh new file mode 100755 index 00000000..b64fe5af --- /dev/null +++ b/rootfs/standard/usr/bin/mynode_post_mempool.sh @@ -0,0 +1,37 @@ +#!/bin/bash + +set -x + +source /usr/share/mynode/mynode_config.sh + +sleep 10s + +# initalize mysql db (REQUIRED TO START MYSQL) +isRunning="" + +# check on loop if mysql db is running. when running initialize +while [ 1 ]; do + # Check if mempool mysql db is running (check the db container) + isRunning=$(docker inspect --format="{{.State.Running}}" mempool_db_1) + if [ "$isRunning" == "true" ]; then + sleep 5s + blocks=$(docker exec -i mempool_db_1 mysql -uroot -padmin -D mempool -e "show tables;" | grep blocks) + if [[ "$blocks" == *"blocks"* ]]; then + echo "Mempool DB initialized!" + exit 0; + fi + if [ $IS_RASPI == 1 ]; then + echo "Initializing mempool db..." + docker exec -i mempool_db_1 bash -c "mysql -u root -padmin mempool" $MYNODE_STATUS_FILE chmod 777 $MYNODE_STATUS_FILE @@ -421,6 +422,15 @@ if [ ! -f /mnt/hdd/mynode/joinmarket/joinmarket.cfg ]; then fi chown -R joinmarket:joinmarket /mnt/hdd/mynode/joinmarket +# Setup Mempool +cp -f /usr/share/mynode/mempool-docker-compose.yml /mnt/hdd/mynode/mempool/docker-compose.yml +if [ ! -f /mnt/hdd/mynode/mempool/.env ]; then + cp -f /usr/share/mynode/mempool.env /mnt/hdd/mynode/mempool/.env +fi +if [ $IS_RASPI -eq 1 ]; then + sed -i "s|MARIA_DB_IMAGE=.*|MARIA_DB_IMAGE=hypriot/rpi-mysql:latest|g" /mnt/hdd/mynode/mempool/.env +fi + # Setup udev chown root:root /etc/udev/rules.d/* || true udevadm trigger @@ -441,6 +451,9 @@ fi if [ -f /mnt/hdd/mynode/joinmarket/joinmarket.cfg ]; then sed -i "s/rpc_password = .*/rpc_password = $BTCRPCPW/g" /mnt/hdd/mynode/joinmarket/joinmarket.cfg fi +if [ -f /mnt/hdd/mynode/mempool/.env ]; then + sed -i "s/BITCOIN_RPC_PASS=.*/BITCOIN_RPC_PASS=$BTCRPCPW/g" /mnt/hdd/mynode/mempool/.env +fi echo "BTC_RPC_PASSWORD=$BTCRPCPW" > /mnt/hdd/mynode/settings/.btcrpc_environment chown bitcoin:bitcoin /mnt/hdd/mynode/settings/.btcrpc_environment if [ -f /mnt/hdd/mynode/bitcoin/bitcoin.conf ]; then @@ -450,6 +463,13 @@ cp -f /mnt/hdd/mynode/bitcoin/bitcoin.conf /home/admin/.bitcoin/bitcoin.conf chown admin:admin /home/admin/.bitcoin/bitcoin.conf +# Append bitcoin UID and GID to btcrpc_environment +BITCOIN_UID=$(id -u bitcoin) +BITCOIN_GID=$(id -g bitcoin) +echo "BITCOIN_UID=$BITCOIN_UID" >> /mnt/hdd/mynode/settings/.btcrpc_environment +echo "BITCOIN_GID=$BITCOIN_GID" >> /mnt/hdd/mynode/settings/.btcrpc_environment + + # Reset BTCARGS echo "BTCARGS=" > /mnt/hdd/mynode/bitcoin/env diff --git a/rootfs/standard/usr/bin/wait_on_docker_image_install.sh b/rootfs/standard/usr/bin/wait_on_docker_image_install.sh index db2cc9d7..79937d9d 100755 --- a/rootfs/standard/usr/bin/wait_on_docker_image_install.sh +++ b/rootfs/standard/usr/bin/wait_on_docker_image_install.sh @@ -2,8 +2,8 @@ set -x -# Wait a few second to give marker file a change to get created -sleep 10s +# Wait a few second to give marker file a chance to get created +sleep 15s # Check if echo "Checking if docker images have been installed..." diff --git a/rootfs/standard/usr/share/mynode/mempool-docker-compose.yml b/rootfs/standard/usr/share/mynode/mempool-docker-compose.yml new file mode 100644 index 00000000..e8759706 --- /dev/null +++ b/rootfs/standard/usr/share/mynode/mempool-docker-compose.yml @@ -0,0 +1,47 @@ +version: "3.7" + +services: + web: + image: mempool/frontend:${VERSION} + restart: on-failure + stop_grace_period: 1m + command: "./wait-for db:3306 --timeout=720 -- nginx -g 'daemon off;'" + ports: + - 4080:8080 + environment: + FRONTEND_HTTP_PORT: "8080" + BACKEND_MAINNET_HTTP_HOST: "api" + api: + image: mempool/backend:${VERSION} + user: 0:0 + restart: on-failure + stop_grace_period: 1m + command: "./wait-for-it.sh db:3306 --timeout=720 --strict -- ./start.sh" + volumes: + - /mnt/hdd/mynode/mempool/data:/backend/cache + environment: + RPC_HOST: "172.17.0.1" + RPC_PORT: "8332" + RPC_USER: "mynode" + RPC_PASS: "${BITCOIN_RPC_PASS}" + ELECTRS_HOST: "172.17.0.1" + ELECTRS_PORT: "50001" + MYSQL_HOST: "db" + MYSQL_PORT: "3306" + MYSQL_DATABASE: "mempool" + MYSQL_USER: "mempool" + MYSQL_PASS: "mempool" + BACKEND_MAINNET_HTTP_PORT: "8999" + CACHE_DIR: "/backend/cache/" + db: + image: ${MARIA_DB_IMAGE} + restart: on-failure + stop_grace_period: 1m + volumes: + - /mnt/hdd/mynode/mempool/mysql/data:/var/lib/mysql + - /mnt/hdd/mynode/mempool/mysql/db-scripts:/docker-entrypoint-initdb.d + environment: + MYSQL_DATABASE: "mempool" + MYSQL_USER: "mempool" + MYSQL_PASSWORD: "mempool" + MYSQL_ROOT_PASSWORD: "admin" diff --git a/rootfs/standard/usr/share/mynode/mempool.env b/rootfs/standard/usr/share/mynode/mempool.env new file mode 100644 index 00000000..bc9f6517 --- /dev/null +++ b/rootfs/standard/usr/share/mynode/mempool.env @@ -0,0 +1,3 @@ +VERSION=FILL_IN +BITCOIN_RPC_PASS=FILL_IN +MARIA_DB_IMAGE=mariadb:10.5.8