Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
f22cd2df
Commit
f22cd2df
authored
Dec 19, 2017
by
James Ramsay
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add detail to disaster recovery docs
parent
51cd05e9
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
79 additions
and
12 deletions
+79
-12
doc/gitlab-geo/disaster-recovery.md
doc/gitlab-geo/disaster-recovery.md
+79
-12
No files found.
doc/gitlab-geo/disaster-recovery.md
View file @
f22cd2df
#
GitLab Geo
Disaster Recovery
# Disaster Recovery
> **Note:**
> **Note:** Disaster Recovery is in **Alpha** development. Do not use this as
GitLab Geo Disaster Recovery is in
**Alpha**
development. Please don't
> your only Disaster Recovery strategy as you may lose data.
use as your only Disaster Recovery strategy as you may lose data.
GitLab Geo replicates your database and your Git repositories. We will
GitLab Geo replicates your database and your Git repositories. We will
support and replicate more data in the future, that will enable you to
support and replicate more data in the future, that will enable you to
fail-over with minimal effort, in a disaster situation.
fail-over with minimal effort, in a disaster situation.
See
[
current limitations
](
README.md#current-limitations
)
See
[
current limitations
](
README.md#current-limitations
)
for more information.
for more information.
## Promoting a secondary node
## Promoting a secondary node
> **Warning:** Disaster Recovery does not yet support systems with multiple
> secondary nodes (3-node systems or greater).
We don't provide yet an automated way to promote a node and do fail-over,
We don't provide yet an automated way to promote a node and do fail-over,
but you can do it manually if you have
`root`
access to the machine.
but you can do it manually if you have
`root`
access to the machine.
For system with only one secondary and one primary node (2-node system):
1.
Take down your
**primary**
node.
If you have SSH access to the primary node, SSH into your **primary**
node, and stop GitLab.
```
sudo gitlab-ctl stop
```
Make sure the primary node will not come up while promoting the secondary
node to primary else you may lose data.
1.
SSH in to your
**secondary**
node and login as root:
```
sudo -i
```
1.
Edit
`/etc/gitlab/gitlab.rb`
to reflect its new status as primary node.
Remove the following line:
```
## DELETE THIS LINE, or update the value to false
geo_secondary_role['enable'] = true
```
Add the following lines, replacing the IP addresses with addresses
appropriate to your network configuration:
```
geo_primary_role['enable'] = true
##
## Primary address
## - replace '1.2.3.4' with the primary private address
##
postgresql['listen_address'] = '1.2.3.4'
postgresql['trust_auth_cidr_addresses'] = ['127.0.0.1/32','1.2.3.4/32']
##
## Disable automatic database migrations temporarily
## (until PostgreSQL is restarted and listening on the private address).
##
gitlab_rails['auto_migrate'] = false
```
A new secondary is not added at this time. You should add a new secondary
after you have verified the newly promoted primary is working correctly.
Refer to [Geo Replication database documention](
database.html#step-1-configure-the-primary-server) for more details.
1.
Take down your primary node (or make sure it will not go up during this
process or you may lose data)
1.
Log-in to your secondary node with a user with
`sudo`
permission
1.
Modify the
`gitlab.rb`
to reflect its new status
1.
Run
`sudo gitlab-ctl promote-to-primary-node`
1.
Run
`sudo gitlab-ctl promote-to-primary-node`
1.
Verify you can connect to the newly promoted primary using the URL used
previously for the secondary.
1.
Update the DNS records for the primary to reflect the public address of the
newly promoted primary.
1.
After the DNS changes have propagated, edit
`/etc/gitlab/gitlab.rb`
to
reflect it's new URL:
```
# Change the existing external_url configuration
external_url 'https://gitlab.example.com'
```
Reconfigure GitLab to apply the change:
```
gitlab-ctl reconfigure
```
1.
Success! The secondary node has now been promoted to primary node and is
accessible from the URL of the previous primary.
To bring your old primary node back into use as a working secondary, you need to
To bring your old primary node back into use as a working secondary, you need to
run
`gitlab-ctl reconfigure`
against the node and then follow the
run
`gitlab-ctl reconfigure`
against the node and then follow the
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment