Redis spike

This commit is contained in:
David McDonald
2022-02-09 12:27:50 +00:00
parent d567d1529d
commit d50d5b97fd
2 changed files with 27 additions and 1 deletions

View File

@@ -114,7 +114,7 @@ class Config(object):
# URL of redis instance
REDIS_URL = os.getenv('REDIS_URL')
REDIS_ENABLED = os.getenv('REDIS_ENABLED') == '1'
REDIS_ENABLED = True
EXPIRE_CACHE_TEN_MINUTES = 600
EXPIRE_CACHE_EIGHT_DAYS = 8 * 24 * 60 * 60

View File

@@ -148,6 +148,7 @@ def persist_notification(
# if simulated create a Notification model to return but do not persist the Notification to the dB
if not simulated:
dao_create_notification(notification)
if key_type != KEY_TYPE_TEST and current_app.config['REDIS_ENABLED']:
cache_key = redis.daily_limit_cache_key(service.id)
if redis_store.get(cache_key) is None:
@@ -158,12 +159,37 @@ def persist_notification(
redis_store.set(cache_key, 1, ex=86400)
else:
redis_store.incr(cache_key)
# sending may not always be true, check this
cache_key = notification_count_cache_key(
service.id, notification_created_at, notification_type, 'sending'
)
if redis_store.get(cache_key) is None:
# if cache does not exist set the cache to 1 with an expiry of 8 days,
# The cache should be set by the time we create the notification
# but in case it is this will make sure the expiry is set to 8 days,
# where if we let the incr method create the cache it will be set a ttl.
# fix this comment as it might be missing a word?
redis_store.set(cache_key, 1, ex=691200)
else:
redis_store.incr(cache_key)
current_app.logger.info(
"{} {} created at {}".format(notification_type, notification_id, notification_created_at)
)
return notification
def notification_count_cache_key(
service_id, created_at_utc, notification_type, simplified_status
):
# this is not actually turning it in to bst, will need to fix this
bst_date = created_at_utc.strftime("%Y-%m-%d")
return "service-{}-bst-date-{}-{}-{}".format(
str(service_id), bst_date, notification_type, simplified_status
)
def send_notification_to_queue_detached(
key_type, notification_type, notification_id, research_mode, queue=None
):