mirror of
https://github.com/lalanza808/xmr.sh.git
synced 2025-05-12 03:55:03 -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
|
155
installer.sh
155
installer.sh
|
@ -49,15 +49,20 @@ On_White='\033[47m' # White
|
|||
OkBullet="${OnBlack}${Green}:: ${White}"
|
||||
WarnBullet="${OnBlack}${Yellow}:: ${White}"
|
||||
ErrBullet="${OnBlack}${Red}:: ${White}"
|
||||
Done="${OnBlack}${White} done.${Off}"
|
||||
Ok="${OnBlack}${Green} ok.${Off}"
|
||||
Fail="${OnBlack}${Red} failed!${Off}"
|
||||
Nok="${OnBlack}${Yellow} nok.${Off}"
|
||||
|
||||
################################################################
|
||||
# Constants #
|
||||
# Vars #
|
||||
################################################################
|
||||
VERSION="v0.1.0"
|
||||
XMRSH_DIR="/opt/xmr.sh"
|
||||
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 #
|
||||
|
@ -72,56 +77,142 @@ header() {
|
|||
echo -e " Version ${VERSION}${Off}\n"
|
||||
}
|
||||
|
||||
detect_root() { (
|
||||
set -e
|
||||
detect_root() {
|
||||
echo -ne "${OkBullet}Checking root... ${Off}"
|
||||
if [[ $EUID -ne 0 ]]; then
|
||||
echo -e "${Fail}"
|
||||
echo -e "${ErrBullet}You need to run this script as root (UID=0).${Off}"
|
||||
exit 1
|
||||
fi
|
||||
echo -e "${Done}"
|
||||
); }
|
||||
echo -e "${Ok}"
|
||||
}
|
||||
|
||||
detect_docker() { (
|
||||
set -e
|
||||
which docker >/dev/null 2>&1
|
||||
if [ $? -eq 0 ]; then
|
||||
docker --version | grep "Docker version" >${XMRSH_LOG_FILE} 2>&1
|
||||
if [ $? -eq 0 ]; then
|
||||
echo "Docker installation exists!"
|
||||
else
|
||||
echo "install docker"
|
||||
check_deps() {
|
||||
echo -ne "${OkBullet}Checking and installing dependencies... ${Off}"
|
||||
for pkg in ${DEPENDENCIES[@]}; do
|
||||
if ! which ${pkg} >>"${XMRSH_LOG_FILE}" 2>&1; then
|
||||
echo "installing ${pkg}"
|
||||
check_return $?
|
||||
fi
|
||||
done
|
||||
echo -e "${Ok}"
|
||||
}
|
||||
|
||||
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 "install docker" >&2
|
||||
echo -e "${ErrBullet}Cannot detect your distribution package manager.${Off}"
|
||||
exit 1
|
||||
fi
|
||||
); }
|
||||
}
|
||||
|
||||
# Detect Docker Compose
|
||||
detect_docker_compose() {
|
||||
docker compose version >/dev/null 2>&1
|
||||
if [ $? -eq 0 ]; then
|
||||
docker --version | grep "Docker version" >/dev/null 2>&1
|
||||
if [ $? -eq 0 ]; then
|
||||
echo "Docker installation exists!"
|
||||
else
|
||||
echo "install docker"
|
||||
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 "install docker" >&2
|
||||
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() {
|
||||
echo -ne "${OkBullet}Checking docker compose... ${Off}"
|
||||
#docker-compose --version >>"${XMRSH_LOG_FILE}" 2>&1 | grep -q "Docker Compose version"
|
||||
if docker-compose --version >>"${XMRSH_LOG_FILE}" 2>&1; then
|
||||
DOCKER_COMPOSE_INSTALLED=true
|
||||
echo -e "${Ok}"
|
||||
else
|
||||
echo -e "${Nok}"
|
||||
fi
|
||||
}
|
||||
|
||||
install_docker() { (
|
||||
set -e
|
||||
echo -ne "${OkBullet}Installing docker... ${Off}"
|
||||
# Install docker
|
||||
curl -fsSL https://get.docker.com -o - | bash 2>&1
|
||||
echo -e "${Done}"
|
||||
# Docker Installer as provided in
|
||||
curl -fsSL https://get.docker.com -o - | bash >>"${XMRSH_LOG_FILE}" 2>&1
|
||||
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
|
||||
detect_root
|
||||
check_deps
|
||||
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
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue