Commit 4e95c330 authored by Achilleas Pipinellis's avatar Achilleas Pipinellis

Merge branch 'sh-add-praefect-leader-election-strategy-docs' into 'master'

Add documentation for Praefect SQL election strategy

See merge request gitlab-org/gitlab!29426
parents 796bd5f7 4f2e50b8
...@@ -468,12 +468,16 @@ config. ...@@ -468,12 +468,16 @@ config.
Manual failover is possible by updating `praefect['virtual_storages']` and Manual failover is possible by updating `praefect['virtual_storages']` and
nominating a new primary node. nominating a new primary node.
NOTE: **Note:**: Automatic failover is not yet supported for setups with 1. By default, Praefect will nominate a primary Gitaly node for each
multiple Praefect nodes. There is currently no coordination between Praefect shard and store the state of the primary in local memory. This state
nodes, which could result in two Praefect instances thinking two different does not persist across restarts and will cause a split brain
Gitaly nodes are the primary. Follow issue if multiple Praefect nodes are used for redundancy.
[#2547](https://gitlab.com/gitlab-org/gitaly/-/issues/2547) for
updates. To avoid this limitation, enable the SQL election strategy:
```ruby
praefect['failover_election_strategy'] = 'sql'
```
1. Save the changes to `/etc/gitlab/gitlab.rb` and [reconfigure 1. Save the changes to `/etc/gitlab/gitlab.rb` and [reconfigure
Praefect](../restart_gitlab.md#omnibus-gitlab-reconfigure): Praefect](../restart_gitlab.md#omnibus-gitlab-reconfigure):
...@@ -677,8 +681,18 @@ current primary node is found to be unhealthy. ...@@ -677,8 +681,18 @@ current primary node is found to be unhealthy.
checks fail for the current primary backend Gitaly node, and new primary will checks fail for the current primary backend Gitaly node, and new primary will
be elected. **Do not use with multiple Praefect nodes!** Using with multiple be elected. **Do not use with multiple Praefect nodes!** Using with multiple
Praefect nodes is likely to result in a split brain. Praefect nodes is likely to result in a split brain.
- **PostgreSQL:** Coming soon. See isse - **PostgreSQL:** Enabled by setting
[#2547](https://gitlab.com/gitlab-org/gitaly/-/issues/2547) for updates. `praefect['failover_election_strategy'] = sql`. This configuration
option will allow multiple Praefect nodes to coordinate via the
PostgreSQL database to elect a primary Gitaly node. This configuration
will cause Praefect nodes to elect a new primary, monitor its health,
and elect a new primary if the current one has not been reachable in
10 seconds by a majority of the Praefect nodes.
NOTE: **Note:**: Praefect does not yet account for replication lag on
the secondaries during the election process, so data loss can occur
during a failover. Follow issue
[#2642](https://gitlab.com/gitlab-org/gitaly/-/issues/2642) for updates.
It is likely that we will implement support for Consul, and a cloud native It is likely that we will implement support for Consul, and a cloud native
strategy in the future. strategy in the future.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment