Architecture Description
In this architecture:
- A load balancer with sticky sessions is used.
- A total of two machines are prepared for the application cluster. Each machine holds a Nuxeo server node, a Redis node, and a reverse proxy. More machines can be added later for scalability purpose.
- Since we have two Redis nodes, we take advantage from it to configure Redis in master / slave mode.
- An Elasticsearch cluster with at least 3 nodes.
- A database cluster with at least 2 nodes.
- Chronicle Queue as the default implementation for Nuxeo Stream.
data:image/s3,"s3://crabby-images/02356/0235603cdf47ea803d961fcf42773b268421d443" alt="1-basic-architecture.png"
data:image/s3,"s3://crabby-images/02356/0235603cdf47ea803d961fcf42773b268421d443" alt="1-basic-architecture.png"
This architecture can be improved by externalizing the Redis node inside a specific cluster:
data:image/s3,"s3://crabby-images/414e4/414e4bc34a3f31fc63eef058f3672e10ee49be7e" alt="1-basic-architecture-v2.png"
data:image/s3,"s3://crabby-images/414e4/414e4bc34a3f31fc63eef058f3672e10ee49be7e" alt="1-basic-architecture-v2.png"
Limitations
- As detailed in the asynchronous processing component description, Chronicle Queue doesn't provide a distributed and fault tolerant architecture: in case of failure, scheduled jobs might be lost.
- Chronicle Queue has to be deployed on the Nuxeo server and consumes JVM when a lot of work is queued, with possible impacts on the Nuxeo Server performance.
- Using Redis to manage the WorkManager implies that the job queues are in the JVM memory. Consequently, stacking a lot of jobs will consume JVM Memory. In cluster mode, each Nuxeo node maintains its own queue so when a Nuxeo server is restarted, all the queued jobs are lost.
→ Jump to the Compact architecture with Kafka to:
- Remove Redis and Chronicle Queue limitations
- Benefits from Kafka advantages