How to design a Notification System
A notification system has become a mandatory feature os any system that helps touch it users, collect analytics data, etc. It's more than a mobile push and there are some different types of notification formats like push, SMS, email and software badge (not covered here).
In this article, we will surf on Notification System Design for Push, SMS and email formats in near real time, average of 10 million of notifications per day triggered by a secure API Endpoint respecting an unsubscribe list control.
Notification Types
iOS Push
A provider sends notifications do Apple Push Notification Service, a remote service provided by Apple do push notifications do iOS devies.
Android Push
The android notification is similar of IOS notification flow, but, instead using de APNs we will use Firebase Cloud Messaging do tens android push notifications.
SMS Message
Same above, but, using a SMS Service provider like Twilio. Some providers like Twilio has features to send message using WhatsApp telephony and mail marketing.
Email Message
Same above, but, using a email service provider like Sendgrid.
Complete Notification System Design
Important to say, it's a high-level design and we will have a lot of not covered details in this article when we focus on each point of this picture.
- External software sends JSON message through https with message data, like address, type, message, etc.
- Rate limiter validate internal rules to protect system overload and security issues.
- Notification Service receives the message, deliver to correct message queue and writes some log to data store over a Data Cache cluster.
- Some workers consumes the messages from queue and connect with third part software to send a message to defined device type ou message format.
- Third part software calls back using Web Hooks to give status and analytics information about message.
- More workers running gets these informations and stores on data store layer.
- Status and analytics data are available for Notification Status & Analytics Service giving these data to external Service back.
Using these system design the software we gain the following benefits:
- Reliability: mechanisms to minimize the failure rate and SPOF.
- Security: running over https using AppKey/appSecret pair to ensure only authorized users can send messages.
- Tracking and Monitoring: logs, status and analytics data are stored.
- Rate Limiting: protect system overload, unexpected burst and security issues.
This design works very well and should be replicated in other regions to increase the SLA, inserting new components like Load balancers, Big IPs, firewalls, etc.
It’s only the starting way to get a Reliable Notification System.
More about balance and reliability here!
Comments and tips would be welcome!
;)
References:
- Xu A. System Design Interview — An insider’s guide. Independently Published; 2020. 324 p.
- MOHAN, HANA. A Guide to Notification System Design. [S. l.], 21 jun. 2022. Disponível em: https://www.magicbell.com/blog/notification-system-design. Acesso em: 4 jul. 2022.