бумаг пользователя. Есть ендпоинт который возвращает текущие бумаги пользователя по его id.
Важно: у пользователя может меняться список ценных бумаг. То есть он может их продать или купить новые.
Задача:
Я хочу сделать кеширование данных, но так, чтобы актуальная информация была не позднее чем 5 минут
То есть задача сводится к тому, чтобы каждые 5 минут запускать асинхронную очередь задач - делаем запрос в бд и обновляем кеш. В пайтон это можно реализовать с помощью celery, есть ли что-то подобное в го? Пока что больше всего подходит gocron, но не уверен, что это лучшее решение
https://dev.to/vearutop/implementing-robust-in-memory-cache-with-go-196e#background-updates можно привязать фоновое обновление к самому кэшу так что оно будет вызываться при обращении к значению незадолго до экспирейшена, https://github.com/bool64/cache/blob/master/failover.go#L44 // "github.com/bool64/cache" f := cache.NewFailoverOf[TickerValues](func(cfg *cache.FailoverConfigOf[TickerValues]) { // Using last 30 seconds of 5m TTL for background update. cfg.MaxStaleness = 30 * time.Second cfg.BackendConfig.TimeToLive = 5*time.Minute - cfg.MaxStaleness }) // Get value from cache or the function. v, err := f.Get(ctx, []byte("my-key"), func(ctx context.Context) (TickerValues, error) { // Build value or return error on failure. var tv TickerValues // Load from DB. return tv, nil })
Обсуждают сегодня