mirror of
https://github.com/lalanza808/xmr.sh.git
synced 2025-05-12 16:32:11 -04:00
mvp, basic compose
This commit is contained in:
parent
f47ba0f65f
commit
03d1a727bf
3 changed files with 192 additions and 32 deletions
7
.env
Normal file
7
.env
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
DOMAIN=your-domain.xmr.example
|
||||||
|
|
||||||
|
TRAEFIK_TAG=2.7
|
||||||
|
TRAEFIK_ACME_EMAIL=your-email@xmr.example
|
||||||
|
TRAEFIK_LOGLEVEL=DEBUG
|
||||||
|
|
||||||
|
MONEROD_TAG=latest
|
62
docker-compose.yml
Normal file
62
docker-compose.yml
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
version: "3.7"
|
||||||
|
|
||||||
|
services:
|
||||||
|
traefik:
|
||||||
|
image: traefik:${TRAEFIK_TAG}
|
||||||
|
container_name: traefik
|
||||||
|
ports:
|
||||||
|
- 80:80
|
||||||
|
- 443:443
|
||||||
|
volumes:
|
||||||
|
- "./letsencrypt:/letsencrypt"
|
||||||
|
- "/var/run/docker.sock:/var/run/docker.sock:ro"
|
||||||
|
command:
|
||||||
|
- "--log.level=${TRAEFIK_LOGLEVEL}"
|
||||||
|
- "--providers.docker=true"
|
||||||
|
- "--providers.docker.exposedbydefault=false"
|
||||||
|
- "--entrypoints.web.address=:80"
|
||||||
|
- "--entrypoints.web.http.redirections.entryPoint.to=websecure"
|
||||||
|
- "--entrypoints.web.http.redirections.entryPoint.scheme=https"
|
||||||
|
- "--entrypoints.web.http.redirections.entrypoint.permanent=true"
|
||||||
|
- "--entrypoints.websecure.address=:443"
|
||||||
|
- "--certificatesresolvers.le.acme.httpchallenge=true"
|
||||||
|
- "--certificatesresolvers.le.acme.httpchallenge.entrypoint=web"
|
||||||
|
- "--certificatesresolvers.le.acme.email=${TRAEFIK_ACME_EMAIL}"
|
||||||
|
- "--certificatesresolvers.le.acme.storage=/letsencrypt/acme.json"
|
||||||
|
restart: always
|
||||||
|
monerod:
|
||||||
|
container_name: monerod
|
||||||
|
image: sethsimmons/simple-monerod:${MONEROD_TAG}
|
||||||
|
command: >-
|
||||||
|
--restricted-rpc --public-node --no-igd --no-zmq
|
||||||
|
--enable-dns-blocklist --rpc-restricted-bind-ip=0.0.0.0 --rpc-restricted-bind-port=18089 --confirm-external-bind
|
||||||
|
--prune-blockchain
|
||||||
|
ports:
|
||||||
|
- "18080:18080" # Exposes P2P port
|
||||||
|
- "18089"
|
||||||
|
volumes:
|
||||||
|
- "monerod-data:/home/monero/.bitmonero"
|
||||||
|
environment:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.routers.monerod.rule=(Host(`${DOMAIN}`))"
|
||||||
|
- "traefik.http.routers.monerod.entrypoints=websecure"
|
||||||
|
- "traefik.http.routers.monerod.tls.certresolver=le"
|
||||||
|
- "traefik.http.routers.monerod.service=monerod"
|
||||||
|
- "traefik.http.services.monerod.loadbalancer.server.port=18089"
|
||||||
|
- "traefik.http.middlewares.corsheader.headers.accessControlAllowOriginList=*"
|
||||||
|
- "traefik.http.routers.monerod.middlewares=corsheader"
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
watchtower:
|
||||||
|
image: containrrr/watchtower
|
||||||
|
volumes:
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
labels:
|
||||||
|
- com.centurylinklabs.watchtower.enable="false"
|
||||||
|
command: --interval 360 --include-stopped
|
||||||
|
volumes:
|
||||||
|
monerod-data: {}
|
||||||
|
|
||||||
|
networks:
|
||||||
|
xmrsh:
|
||||||
|
name: xmrsh
|
157
installer.sh
157
installer.sh
|
@ -49,15 +49,20 @@ On_White='\033[47m' # White
|
||||||
OkBullet="${OnBlack}${Green}:: ${White}"
|
OkBullet="${OnBlack}${Green}:: ${White}"
|
||||||
WarnBullet="${OnBlack}${Yellow}:: ${White}"
|
WarnBullet="${OnBlack}${Yellow}:: ${White}"
|
||||||
ErrBullet="${OnBlack}${Red}:: ${White}"
|
ErrBullet="${OnBlack}${Red}:: ${White}"
|
||||||
Done="${OnBlack}${White} done.${Off}"
|
Ok="${OnBlack}${Green} ok.${Off}"
|
||||||
Fail="${OnBlack}${Red} failed!${Off}"
|
Fail="${OnBlack}${Red} failed!${Off}"
|
||||||
|
Nok="${OnBlack}${Yellow} nok.${Off}"
|
||||||
|
|
||||||
################################################################
|
################################################################
|
||||||
# Constants #
|
# Vars #
|
||||||
################################################################
|
################################################################
|
||||||
VERSION="v0.1.0"
|
VERSION="v0.1.0"
|
||||||
XMRSH_DIR="/opt/xmr.sh"
|
XMRSH_DIR="/opt/xmr.sh"
|
||||||
XMRSH_LOG_FILE="/tmp/xmr.sh-$(date +%Y%m%d-%H%M%S).log"
|
XMRSH_LOG_FILE="/tmp/xmr.sh-$(date +%Y%m%d-%H%M%S).log"
|
||||||
|
DOCKER_INSTALLED=false
|
||||||
|
DOCKER_COMPOSE_INSTALLED=false
|
||||||
|
DOCKER_COMPOSE_VERSION="v2.5.0"
|
||||||
|
DEPENDENCIES="git curl"
|
||||||
|
|
||||||
################################################################
|
################################################################
|
||||||
# Functions #
|
# Functions #
|
||||||
|
@ -72,56 +77,142 @@ header() {
|
||||||
echo -e " Version ${VERSION}${Off}\n"
|
echo -e " Version ${VERSION}${Off}\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
detect_root() { (
|
detect_root() {
|
||||||
set -e
|
|
||||||
echo -ne "${OkBullet}Checking root... ${Off}"
|
echo -ne "${OkBullet}Checking root... ${Off}"
|
||||||
if [[ $EUID -ne 0 ]]; then
|
if [[ $EUID -ne 0 ]]; then
|
||||||
echo -e "${Fail}"
|
echo -e "${Fail}"
|
||||||
echo -e "${ErrBullet}You need to run this script as root (UID=0).${Off}"
|
echo -e "${ErrBullet}You need to run this script as root (UID=0).${Off}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
echo -e "${Done}"
|
echo -e "${Ok}"
|
||||||
); }
|
}
|
||||||
|
|
||||||
detect_docker() { (
|
check_deps() {
|
||||||
set -e
|
echo -ne "${OkBullet}Checking and installing dependencies... ${Off}"
|
||||||
which docker >/dev/null 2>&1
|
for pkg in ${DEPENDENCIES[@]}; do
|
||||||
if [ $? -eq 0 ]; then
|
if ! which ${pkg} >>"${XMRSH_LOG_FILE}" 2>&1; then
|
||||||
docker --version | grep "Docker version" >${XMRSH_LOG_FILE} 2>&1
|
echo "installing ${pkg}"
|
||||||
if [ $? -eq 0 ]; then
|
check_return $?
|
||||||
echo "Docker installation exists!"
|
|
||||||
else
|
|
||||||
echo "install docker"
|
|
||||||
fi
|
fi
|
||||||
else
|
done
|
||||||
echo "install docker" >&2
|
echo -e "${Ok}"
|
||||||
fi
|
}
|
||||||
); }
|
|
||||||
|
install_pkg() {
|
||||||
|
# This detects both ubuntu and debian
|
||||||
|
if grep -q "debian" /etc/os-release; then
|
||||||
|
apt-get update >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
apt-get install -y $1 >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
elif grep -q "arch" /etc/os-release; then
|
||||||
|
pacman -Sy --noconfirm $1 >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
elif grep -q "fedora" /etc/os-release; then
|
||||||
|
dnf update >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
dnf install -y $1 >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
else
|
||||||
|
echo -e "${ErrBullet}Cannot detect your distribution package manager.${Off}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
detect_curl() {
|
||||||
|
echo -ne "${OkBullet}Checking curl... ${Off}"
|
||||||
|
# docker --version >>"${XMRSH_LOG_FILE}" 2>&1 | grep -q "Docker version"
|
||||||
|
if curl --version >>"${XMRSH_LOG_FILE}" 2>&1; then
|
||||||
|
echo -e "${Ok}"
|
||||||
|
else
|
||||||
|
echo -e "${Nok}"
|
||||||
|
echo -e "${ErrBullet}Please install curl first.${Off}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
detect_docker() {
|
||||||
|
echo -ne "${OkBullet}Checking docker... ${Off}"
|
||||||
|
# docker --version >>"${XMRSH_LOG_FILE}" 2>&1 | grep -q "Docker version"
|
||||||
|
if docker --version >>"${XMRSH_LOG_FILE}" 2>&1; then
|
||||||
|
DOCKER_INSTALLED=true
|
||||||
|
echo -e "${Ok}"
|
||||||
|
else
|
||||||
|
echo -e "${Nok}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
# Detect Docker Compose
|
|
||||||
detect_docker_compose() {
|
detect_docker_compose() {
|
||||||
docker compose version >/dev/null 2>&1
|
echo -ne "${OkBullet}Checking docker compose... ${Off}"
|
||||||
if [ $? -eq 0 ]; then
|
#docker-compose --version >>"${XMRSH_LOG_FILE}" 2>&1 | grep -q "Docker Compose version"
|
||||||
docker --version | grep "Docker version" >/dev/null 2>&1
|
if docker-compose --version >>"${XMRSH_LOG_FILE}" 2>&1; then
|
||||||
if [ $? -eq 0 ]; then
|
DOCKER_COMPOSE_INSTALLED=true
|
||||||
echo "Docker installation exists!"
|
echo -e "${Ok}"
|
||||||
else
|
else
|
||||||
echo "install docker"
|
echo -e "${Nok}"
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "install docker" >&2
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
install_docker() { (
|
install_docker() { (
|
||||||
set -e
|
|
||||||
echo -ne "${OkBullet}Installing docker... ${Off}"
|
echo -ne "${OkBullet}Installing docker... ${Off}"
|
||||||
# Install docker
|
# Docker Installer as provided in
|
||||||
curl -fsSL https://get.docker.com -o - | bash 2>&1
|
curl -fsSL https://get.docker.com -o - | bash >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
echo -e "${Done}"
|
check_return $?
|
||||||
|
echo -e "${Ok}"
|
||||||
); }
|
); }
|
||||||
|
|
||||||
|
install_docker_compose() {
|
||||||
|
echo -ne "${OkBullet}Installing compose... ${Off}"
|
||||||
|
# Install docker-compose binary, even if "docker compose" exists, for consistency.
|
||||||
|
curl -SL "https://github.com/docker/compose/releases/download/${DOCKER_COMPOSE_VERSION}/docker-compose-linux-$(uname -m)" -o /usr/local/bin/docker-compose >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
check_return $?
|
||||||
|
chmod +x /usr/local/bin/docker-compose >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
check_return $?
|
||||||
|
echo -e "${Ok}"
|
||||||
|
}
|
||||||
|
|
||||||
|
install_xmrsh() {
|
||||||
|
echo -ne "${OkBullet}Installing xmr.sh... ${Off}"
|
||||||
|
if [ ! -d "$XMRSH_DIR" ]; then
|
||||||
|
git clone https://github.com/vdo/xmr.sh "${XMRSH_DIR}" >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
check_return $?
|
||||||
|
else
|
||||||
|
echo -e "${Ok}"
|
||||||
|
echo -e "${WarnBullet}Warning: xmr.sh already present in ${XMRSH_DIR}"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
echo -e "${Ok}"
|
||||||
|
}
|
||||||
|
|
||||||
|
start_xmrsh() {
|
||||||
|
pushd "${XMRSH_DIR}" >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
echo -ne "${OkBullet}Starting monero node... ${Off}"
|
||||||
|
docker-compose pull >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
check_return $?
|
||||||
|
docker-compose up -d >>"${XMRSH_LOG_FILE}" 2>&1
|
||||||
|
check_return $?
|
||||||
|
echo -e "${Ok}"
|
||||||
|
}
|
||||||
|
|
||||||
|
check_return() {
|
||||||
|
if [ $1 -ne 0 ]; then
|
||||||
|
echo -e "${Fail}"
|
||||||
|
echo -e "${ErrBullet}Installation failed. Check the logs in ${XMRSH_LOG_FILE}${Off}"
|
||||||
|
exit "$1"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
header
|
header
|
||||||
detect_root
|
detect_root
|
||||||
|
check_deps
|
||||||
detect_docker
|
detect_docker
|
||||||
|
detect_docker_compose
|
||||||
|
|
||||||
|
if [ $DOCKER_INSTALLED = false ]; then
|
||||||
|
install_docker
|
||||||
|
install_docker_compose
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $DOCKER_INSTALLED = true ] && [ $DOCKER_COMPOSE_INSTALLED = false ]; then
|
||||||
|
install_docker_compose
|
||||||
|
fi
|
||||||
|
|
||||||
|
install_xmrsh
|
||||||
|
start_xmrsh
|
||||||
|
|
||||||
exit 0
|
exit 0
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue