Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8784309
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 13, 20262026-06-13T21:03:18+00:00 2026-06-13T21:03:18+00:00

Imagine there’s a web service: Runs on a cluster of servers (nginx/node.js) All data

  • 0

Imagine there’s a web service:

  • Runs on a cluster of servers (nginx/node.js)
  • All data is stored remotely
  • Must respond within 20ms

Data that must be read for a response is split like this..

BatchA

  • Millions of small objects stored in AWS DynamoDB
  • Updated randomly at random times
  • Only consistent reads, can’t be catched

BatchB

  • ~2,000 records in SQL
  • Updated rarely, records up to 1KB
  • Can be catched for up to 60-90s

We can’t read them all at once as we don’t know which records to fetch from BatchB until we read from BatchA.

Read from DynamoDB takes up to 10ms. If we read BatchB from remote location, it would leave us with no time for calculations or we would have already been timed out.

My current idea is to load all BatchB records into memory of each node (that’s only ~2MB). On startup, the system would connect to SQL server and fetch all records and then it would update them every 60 or 90 seconds. The question is what’s the best way to do this?

I could simply read them all into a variable (array) in node.js and then use SetTimeout to update the array after 60-90s. But is the the best solution?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-13T21:03:20+00:00Added an answer on June 13, 2026 at 9:03 pm

    Your solution doesn’t sound bad. It fits your needs. Go for it.

    I suggest keeping two copies of the cache while in the process of updating it from remote location. While the 2MB are being received you’ve got yourself a partial copy of the data. I would hold on to the old cache until the new data is fully received.

    Another approach would be to maintain only one cache set and update it as each record arrives. However, this is more difficult to implement and is error-prone. (For example, you should not forget to delete records from the cache if they are no longer found in the remote location.) This approach conserves memory, but I don’t suppose that 2MB is a big deal.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Good morning all. Is there any jsf control that escapes the html tags? Imagine
Imagine you have those 3 tables: And imagine there is massive data according to
Imagine there's a web (mvc) application, which home directory on the server is the
Imagine this scenario: in our company there is an employee that play around graphic,css,html
Imagine it like this. There is a field in my database called flags in
If there were such a thing I would imagine the syntax to be something
Is there a secure Python intepreter? Imagine a Python VM you can run on
Imagine you use a plugin and want to change settings on-the-fly, there are 2
I would like to ask you: Imagine that you have a site and there
Let's imagine I have instantiated generic type by Activator.CreateInstance. Is there any way to

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.