# HG changeset patch # User Alain Mazy # Date 1590575084 -7200 # Node ID 86bf70a1f570cf5b455bcf55b896c91b824c872e # Parent 76b7279e52e6e705b9c78c8f06e184e2aea27c83 scalability: latency diff -r 76b7279e52e6 -r 86bf70a1f570 Sphinx/source/faq/scalability.rst --- a/Sphinx/source/faq/scalability.rst Tue May 26 08:21:52 2020 +0200 +++ b/Sphinx/source/faq/scalability.rst Wed May 27 12:24:44 2020 +0200 @@ -175,7 +175,7 @@ As of Orthanc 1.7.0, the internal code accessing the DB is still affected by limitations induced by the SQLite engine that was the only one originally available at the beginning of the project: inside a single Orthanc process, -there are no concurrent access to the DB. +there is no concurrent access to the DB. One solution to avoid this limitation is to have multiple Orthanc accessing the same DB (works only for MySQL and PostgreSQL) as presented in this `sample @@ -199,3 +199,25 @@ `__, `issue 151 `__. + +Latency +^^^^^^^ + +As of Orthanc 1.7.0, Orthanc still performs quite a large number of small +SQL requests. A simple request to a route like ``/studies/{id}`` can trigger +6 SQL queries. + +This is not an ideal situation and this might be addressed +in a future larger DB refactoring (the most time-consuming queries have already +been optimized). Given the large number of round-trips +between Orthanc and the DB server, it's important that the latency is reduced +as much as possible. I.e, if deploying Orthanc in a cloud infrastructure, +make sure that the DB server and Orthanc VMs are located in the same datacenter. + +Typically, a latency of 1-4 ms is expected to have correct performances. If your +latency is 20ms, a simple request to ``/studies/{id}`` might spend 120ms in +round-trip alone. + + + +