Skip to main content

Eventual consistency

Ory Network is a global, planet-spanning system with data distributed across numerous continents. To enhance query performance, Ory's APIs offer robust consistency controls. This article will delve into the consistency levels provided by Ory's APIs and how they can be utilized to balance data freshness and latency.

Consistency Levels

Ory Network offers two distinct consistency levels: full and eventual.

Full Consistency

Definition: The full consistency level ensures that you receive the freshest data available.

Characteristics:

  • Data Freshness: Full consistency guarantees that you receive the latest updates to the data.
  • Latency: However, this level introduces higher latency to your queries, as the system takes the necessary steps to synchronize and deliver the most recent information.
  • Use Cases: Use full consistency when access to the most up-to-date data is critical, even if it means longer response times.

Eventual Consistency

Definition: The eventual consistency level delivers data as fast as possible.

Characteristics:

  • Data Freshness: While eventual consistency offers faster query response times, the data can be stale, meaning it does not reflect the latest updates.
  • Latency: This level minimizes latency, enabling rapid access to data.
  • Use Cases: Choose eventual consistency when immediate data access is crucial, and you can tolerate data that is not current.

Replication Lag

It's important to note that Ory Network operates with a replication lag of approximately 4.8 seconds. This means that even under full consistency, there is still a delay in accessing the latest data due to the replication process. In some cases, replication lag can be higher.

Identity List API Support

The [Identity List API(../reference/api#tag/identity/operation/listIdentities) in Ory Network supports consistency controls. This means you can choose the consistency level when using the Identity List API.