Skip to content

Commit

Permalink
Merge remote-tracking branch 'origin/main' into 2d-viewer-context-dep…
Browse files Browse the repository at this point in the history
…s-spike
  • Loading branch information
rubenthoms committed Nov 14, 2024
2 parents 6bec37c + 74164ca commit 68ca037
Showing 1 changed file with 5 additions and 5 deletions.
10 changes: 5 additions & 5 deletions backend_py/primary/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,15 +23,15 @@ docker stop $CONTAINER_ID

# Cache data in memory

Sometimes large data sets must to be loaded from external sources. If the user interacts
Sometimes large data sets must be loaded from external sources. If the user interacts
with this data through a series of requests to the backend, it is inefficient to load
the same data every time. Instead the recommended pattern is to load these large data sets
using a separate job container instance bound to the user where it can then easily be cached.

Technically this is done like this:
1) The frontend makes a requests to the (primary) backend as usual.
1) The frontend makes a request to the (primary) backend as usual.
2) The "data demanding endpoints" in the primary backend proxies the request to a separate
job container runnings its own server (also using `FastAPI` as framework).
job container running its own server (also using `FastAPI` as framework).
3) If the user does not already have a job container bound to her/his user ID, the
cloud infrastructure will spin it up (takes some seconds). The job container will
have single-user scope and automatically stop when it has not seen any new requests
Expand All @@ -41,11 +41,11 @@ Technically this is done like this:

Locally during development (single user scenario) there is a single job container
continuously running, started automatically by `docker-compose`.
Except from starting at the same time as the primary backend, not stopping after user
Except for starting at the same time as the primary backend, not stopping after user
inactivity, and being limited by the developer machine resources (CPU / memory),
this job container during development behave similar to the on demand started job containers in cloud.

On route level this is implemented like the following:
At the route level this is implemented like the following:

**In `src/backend/primary`:**
```python
Expand Down

0 comments on commit 68ca037

Please sign in to comment.