/uptime-monitor

A self-hosted web monitoring tool, built with laravel

Primary LanguagePHPMIT LicenseMIT

Uptime Monitor

Uptime Monitor is a self-hosted web monitoring tool, built with laravel.

Features

  • Monitor your web uptime per minutes (or any time interval)
  • Record response time on each web
  • Show uptime badges in 3 colors: green for up, yellow for warning, red for down, based on response time
  • Send telegram notification when you site down for 5 minutes (based on check periode)

Why I need this?

  • Open-source, modify as you need
  • Self-hosted, deploy on your own server
  • Store and control your monitoring logs yourself
  • Let you know when your websites are down
  • For freelancer/agency, increase your client's trust because you monitor their website

How to Install

Server Requirements

This application can be installed on local server and online server with these specifications:

  1. PHP 8.1 (and meet Laravel 10.x requirements).
  2. MySQL or MariaDB Database.
  3. SQLite (for automated testing).

Installation Steps

  1. Clone repository: git clone https://github.com/nafiesl/uptime-monitor.git
  2. $ cd uptime-monitor
  3. Install PHP dependencies: $ composer install
  4. Install javscript dependencies: $ npm install
  5. Copy .env.example to .env: $ cp .env.example .env
  6. Generate application key: $ php artisan key:generate
  7. Create a MySQL or MariaDB database.
  8. Configure database and environment variables .env.
    APP_URL=http://localhost:8000
    APP_TIMEZOME="Asia/Jakarta"
    
    DB_DATABASE=homestead
    DB_USERNAME=homestead
    DB_PASSWORD=secret
    
    TELEGRAM_NOTIFER_TOKEN=
    
  9. Run database migration: $ php artisan migrate --seed
  10. Build assets: $ npm run build
  11. Run task scheduler: $ php artisan schedule:work
  12. Start server in a separeted terminal tab: $ php artisan serve
  13. Open the web app: http://localhost:8000.
  14. Login using default user credential:
    • Email: admin@example.net
    • Password: password
  15. Go to Customer Site menu.
  16. Add some new customer sites (name and URL).
  17. After adding customer sites, go to Dashboard
  18. Click Start Monitoring to update the uptime badge per minute.

Telegram Notifier Setup

In order to get notified in Telegram when the customer sites are down, we need to use a Telegram Bot and a Chat ID

  1. Create a Telegram Bot (how to)
  2. Get a Chat ID of the Telegram Bot (how to)
  3. Update .env file, set TELEGRAM_NOTIFER_TOKEN=your_telegram_bot_token
  4. Set our Chat ID in the Profile Page.
    • Go to User Profile Menu
    • Click Edit Profile
    • Fill the Telegram Chat ID field with your_chat_id
    • Click Update Profile
    • Click Test Telegram Chat to test the telegram configuration
  5. By default, we will have 5 minutes inteval when the customer sites are down. But we can change the interval per customer sites.
    • Go to Customer Site menu
    • Select one of the customer site and click Edit link
    • Set the Notify User Interval field, between 0 to 60.
    • Set the Notify User Interval field to 0 if you don't want to get notified.

Screenshot

Dashboard

screen_2023-12-20_004

Dashboard in mobile device

screen_2023-12-20_009

Monitoring graph on customer site detail

screen_2023-12-20_005

Monitoring log tab on customer site detail

screen_2023-12-20_006

User profile menu

screen_2023-12-20_007

Telegram notification sample

screen_2023-12-20_008

Lisensi

Uptime Monitor project is an open-sourced software licensed under the Lisensi MIT.