Being able to select a Geo distribution for data storage and faster access is great, but only if your team is located in a single place.
We have a globally distributed team, so it would be awesome to have data mirrored across multiple distributions to make data access faster for everyone.
As an extension manager, I want to be able to select multiple geographies that align with the closest locations for my globally distributed teams so that I have mirrored data at all locations, which allows faster access for everyone.
-
Official comment
Hello Ben,
Thank you for your feedback.
Initially, when we just started working on geo distribution feature this was exactly the way we were going to use. But when we started investigating if database replication technology suits our solution and it appeared that this works better for clear reporting systems where data is loaded and isn't changed too much. But in our case, the data is being created and updated constantly - users always track time, create tacks manually, or edit them.
It means that the data should be created and changed in a single database for all world which is slow if the user is in another part of the world. And then it will be automatically mirrored to other databases and can be read from there. But the replication (mirroring) doesn't work instantly, so there might be delays between data creating and appearing in UI which is unacceptable in our product.
Another approach with creating/updating data in the closest database would inevitably lead to change conflicts if, for example, the one track was edited differently by two users from different locations (so in different databases). It would break database replication immediately.
One more point against using data mirroring is that 7pace Timetracker is not a stand-alone application. It is tightly integrated to Azure DevOps which doesn't mirror its data. Your DevOps data is stored and processed in a location chosen when you created your organization.
7pace Timetracker constantly uses DevOps APIs, makes requests to it to keep a high level of integration. It means that even if 7pace Timetracker data center is located close to a worker, it still might be slow if DevOps data center is far from there. So it doesn't make sense to keep your Timetracker data closer to users, it's much more important to keep it closer to your DevOps. This is described in our geo-distribution article.
So finally we chose the solution which works better in our case according to all the described reasons. We might review it in the future, but changing the current approach is not on our roadmap now.
Thanks for using 7pace Timeracker.
Kind regards,
Roman
Comment actions
Please sign in to leave a comment.
Comments
2 comments