123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- <!DOCTYPE html>
- <html lang="en" xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <title>Running Healthchecks - A Cron Job Monitoring Service - In Docker</title>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <meta charset="UTF-8">
- <meta name="keywords" content="Homelab,Install Guide,Linux,Ubuntu,Home Lab Ideas,Home Lab,Healthchecks Cron Monitor,Healthchecks,Healthcheck Install Guide,Debian,Cron Monitor,Cron Job Monitor,Cron Job,Cron,Docker,Docker Container,Docker How To,Docker Made Easy,Docker Simplified,Docker Tutorial,How To,Tutorial,i12bretro">
- <meta name="author" content="i12bretro">
- <meta name="description" content="Running Healthchecks - A Cron Job Monitoring Service - In Docker">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <meta name="revised" content="07/28/2024 06:48:04 AM" />
- <link rel="icon" type="image/x-icon" href="includes/favicon.ico">
- <script type="text/javascript" src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
- <script type="text/javascript" src="includes/js/steps.js"></script>
- <link href="css/steps.css" rel="stylesheet" type="text/css" />
- </head>
- <body>
- <div id="gridContainer">
- <div class="topMargin"></div>
- <div id="listName" class="topMargin">
- <h1>Running Healthchecks - A Cron Job Monitoring Service - In Docker</h1>
- </div>
- <div></div>
- <div id="content">
- <h2>What is Healthchecks?</h2>
- <blockquote>
- <p><em>Healthchecks is a cron job monitoring service. It listens for HTTP requests and email messages ("pings") from your cron jobs and scheduled tasks ("checks"). When a ping does not arrive on time, Healthchecks sends out alerts.</em></p>
- <p><em>Healthchecks comes with a web dashboard, API, 25+ integrations for delivering notifications, monthly email reports, WebAuthn 2FA support, team management features: projects, team members, read-only access.</em><em> -<a href="https://github.com/healthchecks/healthchecks" target="_blank">https://github.com/healthchecks/healthchecks</a></em></p>
- </blockquote>
- <h2>Installing Docker</h2>
- <ol>
- <li>Log into the Linux based device</li>
- <li>Run the following commands in the terminal
- <div class="codeBlock"># install prerequisites<br />
- sudo apt install apt-transport-https ca-certificates curl software-properties-common gnupg-agent -y<br />
- # add docker gpg key<br />
- curl -fsSL https://download.docker.com/linux/$(awk -F'=' '/^ID=/{ print $NF }' /etc/os-release)/gpg | sudo apt-key add -<br />
- # add docker software repository<br />
- sudo add-apt-repository "deb [arch=$(dpkg --print-architecture)] https://download.docker.com/linux/$(awk -F'=' '/^ID=/{ print $NF }' /etc/os-release) $(lsb_release -cs) stable"<br />
- # install docker<br />
- sudo apt install docker-ce docker-compose containerd.io -y<br />
- # enable and start docker service<br />
- sudo systemctl enable docker && sudo systemctl start docker<br />
- # add the current user to the docker group<br />
- sudo usermod -aG docker $USER<br />
- # reauthenticate for the new group membership to take effect<br />
- su - $USER</div>
- </li>
- </ol>
- <h2>Running the Healthchecks Container</h2>
- <ol>
- <li>Now that Docker is installed, run the following commands to setup the Healthchecks Docker container and run it
- <div class="codeBlock"># create working directories<br />
- mkdir ~/docker/postresql -p && mkdir ~/docker/healthchecks -p<br />
- # create containers network<br />
- docker network create containers<br />
- # download the base configuration<br />
- wget -O ~/docker/healthchecks/.env https://raw.githubusercontent.com/healthchecks/healthchecks/master/docker/.env.example<br />
- # generate a 32 character random string<br />
- head /dev/urandom | LC_ALL=C tr -dc 'A-Za-z0-9' | head -c 32<br />
- # copy the output string to the clipboard<br />
- # edit the .env file<br />
- nano ~/docker/healthchecks/.env</div>
- </li>
- <li>Scroll through the .env file, updating at least the key/value pairs listed below
- <p>ALLOWED_HOSTS=*<br />
- ---<br />
- DB=postgres<br />
- DB_HOST=postgres<br />
- DB_NAME=healthchecks<br />
- DB_PASSWORD=He@lt4Ch3ck$!<br />
- DB_USER=healthchecks_rw<br />
- ---<br />
- DEFAULT_FROM_EMAIL=healthchecks@i12bretro.local<br />
- ---<br />
- EMAIL_HOST=smtp.i12bretro.local<br />
- EMAIL_HOST_PASSWORD=<br />
- EMAIL_HOST_USER=<br />
- EMAIL_PORT=25<br />
- EMAIL_USE_TLS=False<br />
- EMAIL_USE_VERIFICATION=False<br />
- ---<br />
- SECRET_KEY=<% random string from clipboard %></p>
- </li>
- <li>Press CTRL+W and search for localhost</li>
- <li>Update all references to localhost with the DNS or IP address of the docker host (ie SITE_ROOT=http://localhost:8000 -> http://ubuntuserver.local:8000)</li>
- <li>Press CTRL+O, Enter, CTRL+X to write the changes to .env</li>
- <li>Continue with the following commands in terminal
- <div class="codeBlock"># set owner of working directories<br />
- sudo chown "$USER":"$USER" ~/docker -R<br />
- # run the postgresql docker container<br />
- docker run -d --name postgres -e POSTGRES_USER=healthchecks_rw -e POSTGRES_PASSWORD='He@lt4Ch3ck$!' -e POSTGRES_DB=healthchecks -v /home/$USER/docker/postresql:/var/lib/postgresql/data --network containers --restart=unless-stopped postgres<br />
- # run the healthchecks container<br />
- docker run -d --name healthchecks --env-file ~/docker/healthchecks/.env -p 8000:8000 --network containers --restart=unless-stopped healthchecks/healthchecks<br />
- # connect to healthchecks container shell<br />
- docker exec -ti healthchecks /bin/bash<br />
- # create an admin user<br />
- /opt/healthchecks/manage.py createsuperuser<br />
- # enter an email address<br />
- # enter and confirm a password<br />
- # exit the container shell<br />
- exit</div>
- </li>
- <li>Open a web browser and navigate to http://DNSorIP:8000</li>
- <li>Login with the admin account created earlier</li>
- <li>Welcome to HealthChecks</li>
- </ol>
- <p>Documentation: <a href="https://hub.docker.com/r/healthchecks/healthchecks" target="_blank">https://hub.docker.com/r/healthchecks/healthchecks</a></p> </div>
- </div>
- </body>
- </html>
-
|