Next up on our data stack journey is the push notification server. I’ll be using multiple notification channels, hoping that I’ll pay attention to at least one when something critical goes down. Alerting is a key piece of analytics infrastructure for me—data should come to you, not the other way around.
So, what are doing here?
We’re bridging the gap between the data stack and the real world by setting up a notification system to deliver push notifications straight to my phone. Once my Airflow server is up and running, I’ll create a custom function to send alerts using this server.
Okay, how?
Enter Gotify: https://gotify.net/
Gotify describes itself as “a simple server for sending and receiving messages.” Perfect, because that’s exactly what we need.
Why Gotify?
It’s licesned under MIT and i can throw it onto my webserver to expose a websocket. So it’s free. It’s got a REST API So i think it will be easy to integrate it into airflow with teh requests library.
You’re going to talk about docker again aren’t you.
By now, you might’ve guessed: I love Docker. Infrastructure as code makes everything so much easier. Without it, I wouldn’t even attempt a project like this.
Well get on with it.
Here we go! Gotify has a docker-compose.yaml file in their docs:
|
|
To enhance security and tailor it to my setup, I modified the configuration. Specifically, I added an external network and restricted privilege escalation.
Here’s my updated docker-compose.yml:
|
|
Let’s fire it up:
|
|
No errors and I can I see it!
Okay now what?
While I won’t dive into every detail, here’s the roadmap I followed to finish setting up Gotify:
- DNS and Proxy Setup: Redirected traffic to Gotify. ✅
- Connect to the Web: Ensured the server was accessible externally. ✅
- Install the Android App: Play Store link ✅
- Create an Application: Generated an API key on the Gotify server. ✅
- Test Notifications: Fired off a test message to confirm delivery. ✅
Now, I’m receiving push notifications from my data stack directly to my phone. Success!