Use Redis to send messages to users once a day via FCM based on their changing time preferences to avoid duplication

王林
Release: 2024-02-06 09:00:09
forward
643 people have browsed it

使用 Redis,根据用户不断变化的时间偏好,通过 FCM 每天向用户发送一次消息,避免重复

Question content

Context

I have many posts and the upvote and downvote count for each post is stored in my Postgres database. I'm running a Gin Golang server, Flutter mobile app, and sending notifications to users using FCM (Firebase Cloud Messaging).

Architectural issues

First of all, this problem is easy to solve. I just don't know how to effectively solve it.

I would like to send the top voted posts to each user approximately once a day. However, I want to send notifications to users based on the time they are most active in the app (not all at once, i.e. not just 12am every day).

So, let's say I'm tracking an entry for each user in a table called active_times, which entry has a time value that I base on their relationship with a mobile app like time# in Postgres ##) Fields updated during interaction. I am constantly updating based on user activity.

My gut tells me that I should run a cron job in my server every ~2 hours that queries for all users who have a

time field within that ~2 hour window. I then send pinned post notifications to these users. I then save a set of hashes in the Redis cache mapping user_ids to time_notification_recieveds and set the auto-expiration to about 12 hours. For each subsequent query, I first check the if user_id in Redis, don't send to that user, otherwise, send and add the id to Redis.

This would allow me to have a window where if the user suddenly logs in or interacts directly on the app after the notification is sent to them (moving their activity to

time), they will be logged in up to 12 Notifications are received later in the hour, but are usually sent approximately every 24 hours (daily) since their activity window does not change much. For example this is as opposed to their time window being 2pm and then after I send them a notification it updates to 4pm and they get hit again within 2 hours.

Remark

Is this an efficient approach? I initially considered using a Postgres database to store all these IDs, but I thought this might quickly overwhelm the database.

Also, is Redis used to do this kind of thing? Is there a completely different approach I can take to do this?

Thanks!


Correct Answer


Until you have millions of users, anything you do every few hours will be very efficient.

I would have a separate column (for example) in the user table that contains "Next Notification Time" for scheduling notifications. I guess you don't want to be in a situation where a user is using the system and then immediately gets a notification, right?

To determine when notifications are sent, you can use a table with a mini activity histogram; something like that

    User ID
  • Time of day
  • counter
Then the counter is incremented every time the user performs an "activity". Then, when calculating "Next time to send notification", you can look at this table to find the best time for that particular user. Over time you can improve the algorithm so that it becomes more complex than just activity counting. (Maybe you want to be notified an hour before the user is typically active? Or maybe a time when they sometimes use the app but aren't used to it, etc.)

The above is the detailed content of Use Redis to send messages to users once a day via FCM based on their changing time preferences to avoid duplication. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:stackoverflow.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!