Gerrit Code Review multi-site

Luca Milanesio
Luca MilanesioDirector at GerritForge Ltd
0Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 0
Gerrit goes multi-site
… and is 100% open source
Luca Milanesio
Gerrit Code Review Maintainer
GerritForge
1Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 1
About GerritForge
Founded in the
UK
HQ in London Committed to
OpenSource
2Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 2
The Journey to multi-site
3Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 3
Single master
Gerrit Master
Incoming traffic
4Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 4
Gerrit master
Replication
plugin
Incoming traffic
Gerrit master + slave
5Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 5
Gerrit Master (+DR) + Slave
Gerrit master
Replication
plugin
Gerrit DR
Incoming traffic
6Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 6
Gerrit master (HA+DR) + Slave
Gerrit master
1
Replication
plugin
Gerrit DR
Incoming traffic
Gerrit master
2
Replication
plugin
HAproxy HAproxy
HAplugin
HApluginShared NFS
7Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 7
Gerrit master (HA+DR) + Slave: components
• HAProxy
• Gerrit >= v2.14 + plugins
• https://gerrit.googlesource.com/plugins/+
• replication
• high-availability (GerritForge’s fork)
github.com/GerritForge/plugins_high_availability
• websession-flatfile
• healthcheck
8Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 8
Gerrit multi-master – two-sites
Gerrit master
(CA)
Replication
plugin
R/W Traffic
Gerrit master
(CA)
Replication
plugin
HAproxy HAproxy
Multi-site
Multi-site
Gerrit master
(GER)
Replication
plugin
Gerrit master
(GER)
Replication
plugin
HAproxy HAproxy
Multi-site
Multi-site
R Analytics Traffic
Shared NFSShared NFS
9Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 9
(CA)(CA)
Gerrit multi-master multi-site
Gerrit
masters
(USA)
Replication
Gerrit
masters
(India)
Replication
Multi-site
Multi-site
Reliable broker
ü Sync index and caches across sites
ü Reliable across failures
ü Fully async, max performance
ü Fully distributed, max availability
ü Eventually consistent across sites
10Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 10
Gerrit multi-master multi-site
Gerrit multi-site
IS
Highly Available
Partition tolerant
11Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 11
Split-brain
prevention
12Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 12
Ref-Db
Coordinator
• The Ref-Db coordinator is
used to guarantee that
two Gerrit instances do
not go into a split-brain
scenario
• Reject any push where
parent ObjectId is not
aligned with the shared
ref-db
13Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 13
Next steps: location-aware DNS
Gerrit master
(CA)
Rest of the World
Traffic (R/W)
Gerrit master
(CA)
HAproxy HAproxy
Gerrit master
(GER)
Gerrit master
(GER)
HAproxy HAproxy
EU Traffic (R/W)
Multi-site pluginMulti-site pluginMulti-site pluginMulti-site plugin
14Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 14
Poll: have you implemented multi-master/HA?
Image from: http://cypp.rutgers.edu/ru-voting/political-information/public-opinion-polls/
15Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 15
Wants to know more?
GerritForge.com/contact
1 of 16

More Related Content

What's hot(20)

Introduction to HelmIntroduction to Helm
Introduction to Helm
Harshal Shah2K views
BitBucket presentationBitBucket presentation
BitBucket presentation
Jonathan Lawerh10.3K views
Gitlab ci, cncf.skGitlab ci, cncf.sk
Gitlab ci, cncf.sk
Juraj Hantak588 views
Introduction to NginxIntroduction to Nginx
Introduction to Nginx
Knoldus Inc.6.4K views
CI-CD Jenkins, GitHub Actions, Tekton CI-CD Jenkins, GitHub Actions, Tekton
CI-CD Jenkins, GitHub Actions, Tekton
Araf Karsh Hamid1.2K views
RedHat Virtualization ManagerRedHat Virtualization Manager
RedHat Virtualization Manager
Raz Tamir1.1K views
NginxNginx
Nginx
Dhrubaji Mandal ♛1.9K views
CD using ArgoCD(KnolX).pdfCD using ArgoCD(KnolX).pdf
CD using ArgoCD(KnolX).pdf
Knoldus Inc.1.1K views
Quarkus   k8sQuarkus   k8s
Quarkus k8s
Georgios Andrianakis728 views
Docker Kubernetes IstioDocker Kubernetes Istio
Docker Kubernetes Istio
Araf Karsh Hamid3K views
ArgoCD Meetup PPT final.pdfArgoCD Meetup PPT final.pdf
ArgoCD Meetup PPT final.pdf
amanmakwana3639 views

Similar to Gerrit Code Review multi-site(20)

Gerrit Code Review multi-site

  • 1. 0Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 0 Gerrit goes multi-site … and is 100% open source Luca Milanesio Gerrit Code Review Maintainer GerritForge
  • 2. 1Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 1 About GerritForge Founded in the UK HQ in London Committed to OpenSource
  • 3. 2Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 2 The Journey to multi-site
  • 4. 3Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 3 Single master Gerrit Master Incoming traffic
  • 5. 4Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 4 Gerrit master Replication plugin Incoming traffic Gerrit master + slave
  • 6. 5Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 5 Gerrit Master (+DR) + Slave Gerrit master Replication plugin Gerrit DR Incoming traffic
  • 7. 6Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 6 Gerrit master (HA+DR) + Slave Gerrit master 1 Replication plugin Gerrit DR Incoming traffic Gerrit master 2 Replication plugin HAproxy HAproxy HAplugin HApluginShared NFS
  • 8. 7Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 7 Gerrit master (HA+DR) + Slave: components • HAProxy • Gerrit >= v2.14 + plugins • https://gerrit.googlesource.com/plugins/+ • replication • high-availability (GerritForge’s fork) github.com/GerritForge/plugins_high_availability • websession-flatfile • healthcheck
  • 9. 8Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 8 Gerrit multi-master – two-sites Gerrit master (CA) Replication plugin R/W Traffic Gerrit master (CA) Replication plugin HAproxy HAproxy Multi-site Multi-site Gerrit master (GER) Replication plugin Gerrit master (GER) Replication plugin HAproxy HAproxy Multi-site Multi-site R Analytics Traffic Shared NFSShared NFS
  • 10. 9Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 9 (CA)(CA) Gerrit multi-master multi-site Gerrit masters (USA) Replication Gerrit masters (India) Replication Multi-site Multi-site Reliable broker ü Sync index and caches across sites ü Reliable across failures ü Fully async, max performance ü Fully distributed, max availability ü Eventually consistent across sites
  • 11. 10Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 10 Gerrit multi-master multi-site Gerrit multi-site IS Highly Available Partition tolerant
  • 12. 11Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 11 Split-brain prevention
  • 13. 12Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 12 Ref-Db Coordinator • The Ref-Db coordinator is used to guarantee that two Gerrit instances do not go into a split-brain scenario • Reject any push where parent ObjectId is not aligned with the shared ref-db
  • 14. 13Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 13 Next steps: location-aware DNS Gerrit master (CA) Rest of the World Traffic (R/W) Gerrit master (CA) HAproxy HAproxy Gerrit master (GER) Gerrit master (GER) HAproxy HAproxy EU Traffic (R/W) Multi-site pluginMulti-site pluginMulti-site pluginMulti-site plugin
  • 15. 14Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 14 Poll: have you implemented multi-master/HA? Image from: http://cypp.rutgers.edu/ru-voting/political-information/public-opinion-polls/
  • 16. 15Gerrit User Summit 2019 – Volvo Cars – Gothenburg - Sweden GerritForge.com 15 Wants to know more? GerritForge.com/contact