Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Caching strategy #10

Open
joshwcomeau opened this issue Oct 19, 2017 · 1 comment
Open

Caching strategy #10

joshwcomeau opened this issue Oct 19, 2017 · 1 comment

Comments

@joshwcomeau
Copy link
Owner

Right now, I'm accessing episode info straight from the TV Maze API. This means if you have 50 shows, on page-load I make 50 requests to TV Maze.

This is clearly not ideal, and it will likely upset the TV Maze folks if Tello continues to see actual usage.

My idea is fairly straightforward. I should add a new Mongo collection of show info, with episodes. This would be global, not connected to a specific user.

When a show is added, I check to see if the show exists. If it doesn't, I fetch it from TV Maze, and store the results in my database.

I'll need a cron job to run every night at midnight, and delete the entire collection. So the first request for a given show fetches it from TV Maze, but subsequent requests that day use the Mongo "cache".

But yeah, this is a lot of work, so I'm hesitant to do it until I need to.

@morajabi
Copy link
Contributor

I'm doing this at subdl.com to minimize the API calls to tmdbapi.com. Yea, the mongo schema and mapping API JSON to that is a headache on its own :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants