What is the most bandwidth efficient way to unidirectionally synchronise a list of data from one server to many clients?
I have sizeable chunk of data (perhaps 20,000, 50-byte records) which I need to periodically synchronise to a series of clients over the Internet (perhaps 10,000 clients). Records may added, removed or updated only at the server end.
Ok, so we’ve got some detail now – perhaps 10 GB of total (uncompressed) data, every 3 days, so that’s 100 GB per month.
That’s actually not really a sizeable chunk of data these days. Whose bandwidth are you trying to save – yours, or your clients’?
Does the data perhaps compress very readily? For raw binary data it’s not uncommon to achieve 50% compression, and if the data happens to have a lot of repeated patterns within it then 80%+ is possible.
That said, if you really do need a system that can just transfer the changes, my thoughts are: