Reduce disk writes in post-compile triggers
commit4191404225e1b86534392f0fdbeb5b766bb0f45d
authorKonstantin Ryabitsev <konstantin@linuxfoundation.org>
Sat, 14 Apr 2018 15:35:18 +0000 (14 11:35 -0400)
committerSitaram Chamarty <sitaramc@gmail.com>
Mon, 16 Apr 2018 04:27:58 +0000 (16 09:57 +0530)
tree85ea805b6aff386b6454c158339890d2e0c343e0
parent69f92d6dc49fde79309d60e0978bb9402da3ac3b
Reduce disk writes in post-compile triggers

We have a system with thousands of repositories located on disks where:

1. write operations are much slower than read operations
2. IO is burstable but is throttled after a certain limit

In such conditions, writing out 10-15 git config settings per each of the
15,000 repositories resulted in around 200,000 calls to git-config and
200,000 disk writes to 15,000 files on every gitolite-admin push, even
if there were no changes to any git configs.

With this change, we call git-config once to read the entirety of the
git config for the repo, and issue writes only if there are changes to
any of the settings.

Similarly, we only touch git-daemon-export-ok if such file doesn't
already exist to avoid another few thousand unnecessary writes.

As a result, our gitolite-admin push times went from 10-12 minutes to 20
seconds.

Signed-off-by: Konstantin Ryabitsev <konstantin@linuxfoundation.org>
src/triggers/post-compile/update-git-configs
src/triggers/post-compile/update-git-daemon-access-list