Skip to content

Final project for Engineering Distributed Infrastructure course.

Notifications You must be signed in to change notification settings

GaspardIV/smk_alerting_platform

Repository files navigation

DS Course Project: Alerting Platform

Final project of Distributed Systems course done together with @olearczuk and @brzezinskimarcin.

Project overview

Build a system that will send alert messages in case of system unavailability. In real life services fail more often than we’d like them to. As software engineers we are not using the service all the time but our users do. The alerting platforms help us notice the issues and attempt to fix them promptly. Real world example could be pagerduty.com.

Critical user journey

  • Alerting platform will be monitoring a predefined set of HTTP services.
  • When one of the services becomes unavailable the alerting platform will send a notification to the primary system administrator through a configured communication channel.
  • In case the administrator does not respond the alerting platform will send a notification to the secondary service administrator.
  • Alerting platform will log every contact attempt along with information about the administrators response.

Design doc

Used technologies

  • Golang
  • Firestore for persistent and highly available storage
  • Cloud Functions for executing monitoring steps
  • Cloud Scheduler, Cloud Tasks and Cloud Tasks Queue for repeating calling of cloud functions
  • Kubernetes for deploying fake service to test
  • Cloud Build for continuous deployment

Overview of the system

Screenshot 2022-06-20 at 19 59 57

Components overview

  • Cloud scheduler - a cron job that starts the whole checking process periodically (every minute or so)
  • Scheduler Function - gets awaken by Cloud Scheduler (via HTTP), retrieves sites eligible for monitoring from database and spawns tasks
  • Cloud Tasks - trigger Distributor Function with specified services to check
  • Distributor Function - splits specified sites into chunks (we don’t want to pass e.g. 100 services to a single cloud function) and triggers Site Checker Functions
  • Site Checker Function - performs a single check of given set of sites, updates database and triggers Notifier Function if site has not been available for long enough
  • Notifier Function - sends email to Service Administrator with links to Confirmation Handler and Resolve Handler (secondary administrator gets email only to Resolve Handler) and updates database
  • Confirmation Handler Function - handles confirmation of primary administrator (this way he confirms that he started working on the issue and there is no need to notify secondary administrator) and updates the database
  • Resolved Handler Function - handles confirmation that problem has been resolved by an administrator, this means that the site is eligible for being monitored again

Database scheme

Screenshot 2022-06-20 at 19 58 27

Possible states are:

  • Running - site is (or should be according to administrator that resolves the issue) working correctly
  • Unavailable - SiteChecker spotted that site is unavailable
  • Notified - primary administrator has been notified
  • Confirmed - primary administrator confirmed that he is working on the issue

Pricing

According to Google Cloud, first 2 million invocations of Cloud Functions are free and 0.40 USD per 2 million after that. Similarly for Cloud Tasks. We won’t consider Notifier and Confirmation/Resolved handlers since they are related to handling sites being unavailable, which produces negligible traffic. Assuming every site is checked every minute, a single site generates 3 (cloud task + distributor + checker) * 60 * 24 * 30 = 129600. That means that the first ~15 sites are free and every next ~15 sites cost us 0.4 USD monthly. This number in reality will be bigger than 15 because the distributor reduces the number of Checker calls.

According to Google Cloud first 3 jobs of Cloud Scheduler are free and we only need one.

According to Firestore pricing we will be charged for each document read, write, and delete that we perform with Firestore. Assuming each cloud function run results in execution up to 1 documents reads and 1 document write on average, then each site generates costs up to 0.324 USD + 0.18 per GiB of stored data.

Monitoring and alerting

Any needed monitoring/metrics for all used Cloud Services (Firestore, Scheduler, Tasks, Cloud Functions) are provided by Google Cloud in gcloud console

Auto healing

All services used (Cloud Functions, Firestore, Scheduler, Tasks) are serverless and entirely managed by Google, so auto healing is supported out of the box by all of them.

High availability (multi-node)

  • Cloud Firestore - automatically scales up and down based on demand. It requires no maintenance, and provides high availability of >= 99.999% (monthly uptime percentage) achieved through strongly consistent data replication.
  • Cloud Scheduler
  • Cloud Tasks - fully managed by Google, and have high availability of >= 99.95%, guaranteed by Google.
  • Cloud Functions - on zone-level are entirely managed by Google, so the high availability >= 99.95% (monthly uptime percentage) is guaranteed across all the zones.

High availability (multi-region)

  • Firestore - we will use multi-regional configuration, so thanks to the automatic data replication across regions Firestore database will be available in different regions.
  • Cloud Scheduler
  • Cloud Tasks are regional, which means the infrastructure managing the queue is located in a specific region, so using it from different region could result in some latency or availability problems. We could solve this issue by having multiple queues across regions.
  • Similarly, Cloud Functions are regional, and we could solve it in a similar way, by deploying all functions in multiple regions.

Various concerns

  • Ideally we would like to keep as much traffic as possible within a single region, however this might be complicated in Cloud Functions approach

Testing scenarios

  1. End-to-end tests We are going to deploy a test service and switch it on and off. This is going to allow us to perform manual tests of the entire project (testers would mimic administrators). Integration tests
  2. We can verify integration between SiteChecker and Notifier. It could be done by triggering SiteChecker to the moment when it should realise that a site is not available long enough. At this point it should trigger Notifier and we should receive an email (end state of this site should be set to Notified).
  3. Unit tests For each cloud function we will implement dedicated unit tests.
  4. Stress and load tests First way to test the system against a number of observable services. We could do it by creating a lot of sites in the database and test system behavior on a big scale. Secondly, in order to test throughput of the system (including services provided by Google Cloud) we could adjust the frequency of sites pinging.

Code build & Deployment

Thanks to the use of cloud functions, and firestore the deployment process is significantly simplified. In addition we would like to take advantage of Continuous Integration and Deployment (CI/CD) pipelines. As Cloud Functions are not updated automatically, we will configure CI/CD pipelines to automatically test and redeploy our functions from Cloud Source Repositories. To achieve that, we will use Cloud Build, triggered on each push to main branch.

Deployment steps:

  • run unit tests
  • pause cloud scheduler
  • deploy cloud functions
  • propagate config to database
  • resume cloud scheduler

Encryption of notification messages

Communication channels are encrypted out of the box, since we are using Sendgrid for sending messages. Links are obfuscated, because we are generating salted hashes which are stored in the database so they are not predictable and can’t be easily silenced.

Project structure:

main.go - used for test local env initialization.
config_propagator/ - script used to init database from config.
confirmation_handler/ - confirmation handler cloud function implementation.
distributor/ - distributor cloud function implementation.
fake_service/ - service with ability of switching it state off/on used for functional tests.
notifier/ - notifier  cloud function implementation.
resolved_handler/ -  cloud function implementation.
scheduler/ -  cloud function implementation.
site_checker/ - site checker cloud function implementation.
pkg/ - common files.
    cloud_tasks_queue.go - Local tasks queue interface implementation 
    consts.go - Constants.
    database.go - Database interface.
    firestore_database.go - Firestore database interface implementation.
    http_client.go - HttpClient interface and FakeHttpClient implementation.
    local_database.go - Local database interface implementation.
    local_tasks_queue.go - Local tasks queue interface implementation.
    tasks_queue.go - Tasks queue interface.

Database:

Main collection sites consist of documents that represents single site.

sites/siteID/

each site is a document and consist of fields:

{
  time_until_reporting_seconds: 10 // time of inactivity after which the primary administrator is notified
  allowed_response_time_seconds: 10 // time of after which the secondary administrator is notified
  confirmation_hash: "" // hash used in url confirmation link sent to administrator 
  frequency_seconds: 2 // frequency of checking
  primary_administrator_email: "[email protected]" // primary administrator mail
  resolved_hash: "" // hash used in url resolved link sent to administrator
  secondary_administrator_email: "[email protected]" // secondary administrator
  state: Running // int that represent state. State is one of four:     Running, Unavailable, Notified, Confirmed
  state_change_timestamp: 10 stycznia 2022 01:07:30 UTC+1 // timestamp of changing state
  last_change_timestamp: 10 stycznia 2022 01:07:31 UTC+1  // server timestamp of last document update - scheduler does use it. 
  url: "google.com" // page address
}

Functional tests raport:

Fake-service has been used to perform these tests.

test scenario “outage primary admin resolved”

turn on fake service 
test service is available
  site-checker:
    2022/01/26 16:23:41 site http://34.118.64.175 available
turn off fake service 
test service is unavailable
  site-checker:  
    2022/01/26 16:25:42 site http://34.118.64.175 is unavailable
test mail has been sent
  notifier: 
    2022/01/26 16:26:43 Site http://34.118.64.175 is unavailable. Notifying primary administrator [email protected]...
    2022/01/26 16:26:43 Sending email to [email protected] with the content: 
    smk-alerting-platform: Your site http://34.118.64.175 is unavailable.
    Visit the following link: https://europe-central2-smk-alerting-platform.cloudfunctions.net/confirmation-handler?hash=9fb95c4f271156279031f69b2844fe390e9c3a8f9dacbca7d60c44c1df1253ec to confirm you are working on the issue.
    Visit the following link: https://europe-central2-smk-alerting-platform.cloudfunctions.net/resolved-handler?hash=d66446b0c38b2f970981a4dad7c2987931994247b56caf3159eb54864199bc80 once you resolve the issue.
    2022/01/26 16:26:44 Email has been sent successfully.

turn service on
test resolved link
  resolved-handler:
    2022/01/26 16:27:22 resolved http://34.118.64.175
test service state is available
  site-checker:
    2022/01/26 16:27:45 site http://34.118.64.175 available

TEST PASSED

test scenario “outage primary admin does not confirm”

turn on fake service 
test service is available
  site-checker:
    2022/01/25 20:45:32 site http://34.118.64.175 available
turn off fake service 
test service is unavailable
  site-checker: 
    2022/01/26 15:50:04 site http://34.118.64.175 is unavailable
test mail has been sent
   notifier:
     2022/01/26 15:51:34 Site http://34.118.64.175 is unavailable. Notifying primary administrator [email protected]…

     2022/01/26 15:51:34 Sending email to [email protected] with the content:

     Your site http://34.118.64.175 is unavailable. Visit the following link: https://europe-central2-smk-alerting-platform.cloudfunctions.net/confirmation-handler?hash=9fb95c4f271156279031f69b2844fe390e9c3a8f9dacbca7d60c44c1df1253ec to confirm you are working on the issue.
     Visit the following link: https://europe-central2-smk-alerting-platform.cloudfunctions.net/resolved-handler?hash=d66446b0c38b2f970981a4dad7c2987931994247b56caf3159eb54864199bc80 once you resolve the issue.
     2022/01/26 15:51:35 Email has been sent successfully.
wait
test mail to secondary administrator has been sent
  notifier: 
    2022/01/26 15:56:33 Primary administrator [email protected] of site http://34.118.64.175 has already been notified. Notifying secondary administrator... [email protected]
    2022/01/26 15:56:33 Sending email to [email protected] with the content:
    smk-alerting-platform: Your site http://34.118.64.175 is unavailable.
    Visit the following link: https://europe-central2-smk-alerting-platform.cloudfunctions.net/resolved-handler?hash=d66446b0c38b2f970981a4dad7c2987931994247b56caf3159eb54864199bc80 once you resolve the issue.
    2022/01/26 15:56:34 Email has been sent successfully.

turn service on
test resolved link
  resolved-handler:
    2022/01/26 16:05:54 resolved http://34.118.64.175
test service state is available
  site-checker:
    2022/01/26 16:06:00 site http://34.118.64.175 available
TEST PASSED

test scenario “temporary outage without notification”

fake service turned on 
test service is available
  site-checker:
    2022/01/26 16:45:41 site http://34.118.64.175 available
fake service turned off
test service is unavailable
  site-checker:
    16:46:44 site http://34.118.64.175 is unavailable
within 60 seconds turn service on
test mails has not been sent
test status running
  site-checker:
    2022/01/26 16:47:15 site http://34.118.64.175 available


TEST PASSED

test scenario “outage primary admin confirm”

turn on fake service 
test service is available
 site-checker:
  16:27:45 site http://34.118.64.175 available
turn off fake service 
test service is unavailable
 site-checker:
  2022/01/26 16:28:15 site http://34.118.64.175 is unavailable
test mail has been sent
 notifier:
  2022/01/26 16:28:45 Site http://34.118.64.175 is unavailable. Notifying primary administrator [email protected]...
  2022/01/26 16:28:45 Sending email to [email protected] with the content:
  smk-alerting-platform: Your site http://34.118.64.175 is unavailable.
  Visit the following link: https://europe-central2-smk-alerting-platform.cloudfunctions.net/confirmation-handler?hash=486957e89f1d774979dc5516715ea304f096914797235efc02298bc5054a5bc7 to confirm you are working on the issue.
  Visit the following link: https://europe-central2-smk-alerting-platform.cloudfunctions.net/resolved-handler?hash=0f61b61a7162d28d08db7522f64c4e005dfe2b0520a61ee5aa304d1113d38cf6 once you resolve the issue.
  2022/01/26 16:28:46 Email has been sent successfully.
test confirmation link
 confirmation-handler:
  2022/01/26 16:30:46 confirmed http://34.118.64.175
wait 
test mail to secondary administrator has not been sent
turn service on
test resolved link
 resolved-handler: 
  2022/01/26 16:32:38 resolved http://34.118.64.175
test service state is available
 site-checker: 
  2022/01/26 16:33:01 site http://34.118.64.175 available

TEST PASSED

Running locally

# install dependencies
go get .

# run locally
./run_local.sh

Running tests

In order to run tests simply run run_tests.sh script.

About

Final project for Engineering Distributed Infrastructure course.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published