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
05353538
Commit
05353538
authored
Jan 22, 2018
by
Nick Thomas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update the Geo documentation to replicate all secrets to the secondary
parent
1003c04e
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
103 additions
and
31 deletions
+103
-31
changelogs/unreleased-ee/4253-dr-compliant-secrets.yml
changelogs/unreleased-ee/4253-dr-compliant-secrets.yml
+5
-0
doc/gitlab-geo/configuration.md
doc/gitlab-geo/configuration.md
+30
-13
doc/gitlab-geo/configuration_source.md
doc/gitlab-geo/configuration_source.md
+33
-13
doc/gitlab-geo/faq.md
doc/gitlab-geo/faq.md
+13
-0
doc/gitlab-geo/updating_the_geo_nodes.md
doc/gitlab-geo/updating_the_geo_nodes.md
+22
-0
ee/lib/tasks/geo.rake
ee/lib/tasks/geo.rake
+0
-5
No files found.
changelogs/unreleased-ee/4253-dr-compliant-secrets.yml
0 → 100644
View file @
05353538
---
title
:
Update the Geo documentation to replicate all secrets to the secondary
merge_request
:
4188
author
:
type
:
fixed
doc/gitlab-geo/configuration.md
View file @
05353538
...
@@ -25,32 +25,49 @@ in your testing/production environment.
...
@@ -25,32 +25,49 @@ in your testing/production environment.
-
**Do not**
add anything in the secondaries Geo nodes admin area
-
**Do not**
add anything in the secondaries Geo nodes admin area
(
**Admin Area ➔ Geo Nodes**
). This is handled solely by the primary node.
(
**Admin Area ➔ Geo Nodes**
). This is handled solely by the primary node.
### Step 1.
Copying the database encryption key
### Step 1.
Manually replicate secret GitLab values
GitLab stores a unique encryption key on disk that is used to encrypt
GitLab stores a number of secret values in the
`/etc/gitlab/gitlab-secrets.json`
sensitive data stored in the database. All secondary nodes must have the
file which
*must*
match between the primary and secondary nodes. Until there is
**exact same value**
for
`db_key_base`
as defined on the primary node.
a means of automatically replicating these between nodes (see
[
issue #3789
](
https://gitlab.com/gitlab-org/gitlab-ee/issues/3789
)
), they must
be manually replicated to the secondary.
1.
SSH into the
**primary**
node, and execute the command below
1.
SSH into the
**primary**
node, and execute the command below:
to display the current encryption key:
```bash
```bash
sudo
gitlab-rake geo:db:show_encryption_key
sudo
cat /etc/gitlab/gitlab-secrets.json
```
```
Copy the encryption key to bring it to the secondary node in the following steps
.
This will display the secrets that need to be replicated, in JSON format
.
1.
SSH into the
**secondary**
node and login as
root
:
1.
SSH into the
**secondary**
node and login as
the
`root`
user
:
```
```
sudo -i
sudo -i
```
```
1.
Add the following to
`/etc/gitlab/gitlab.rb`
, replacing
`encryption-key`
with the output
1.
Make a backup of any existing secrets:
of the previous command:
```ruby
```bash
gitlab_rails['db_key_base'] = 'encryption-key'
mv /etc/gitlab/gitlab-secrets.json /etc/gitlab/gitlab-secrets.json.`date +%F`
```
1.
Copy
`/etc/gitlab/gitlab-secrets.json`
from the primary to the secondary, or
copy-and-paste the file contents between nodes:
```bash
sudo editor /etc/gitlab/gitlab-secrets.json
# paste the output of the `cat` command you ran on the primary
# save and exit
```
1.
Ensure the file permissions are correct:
```bash
chown root:root /etc/gitlab/gitlab-secrets.json
chmod 0600 /etc/gitlab/gitlab-secrets.json
```
```
1.
Reconfigure the secondary node for the change to take effect:
1.
Reconfigure the secondary node for the change to take effect:
...
...
doc/gitlab-geo/configuration_source.md
View file @
05353538
...
@@ -26,30 +26,50 @@ in your testing/production environment.
...
@@ -26,30 +26,50 @@ in your testing/production environment.
-
**Do not**
add anything in the secondaries Geo nodes admin area
-
**Do not**
add anything in the secondaries Geo nodes admin area
(
**Admin Area ➔ Geo Nodes**
). This is handled solely by the primary node.
(
**Admin Area ➔ Geo Nodes**
). This is handled solely by the primary node.
### Step 1.
Copying the database encryption key
### Step 1.
Manually replicate secret GitLab values
GitLab stores a unique encryption key on disk that is used to encrypt
GitLab stores a number of secret values in the
`/home/git/gitlab/config/secrets.yml`
sensitive data stored in the database. All secondary nodes must have the
file which
*must*
match between the primary and secondary nodes. Until there is
**exact same value**
for
`db_key_base`
as defined on the primary node.
a means of automatically replicating these between nodes (see
[
issue #3789
](
https://gitlab.com/gitlab-org/gitlab-ee/issues/3789
)
), they must
be manually replicated to the secondary.
1.
SSH into the
**primary**
node, and execute the command below to display the
1.
SSH into the
**primary**
node, and execute the command below:
current encryption key:
```bash
```bash
sudo
-u git -H bundle exec rake geo:db:show_encryption_key RAILS_ENV=production
sudo
cat /home/git/gitlab/config/secrets.yml
```
```
Copy the encryption key to bring it to the secondary node in the following steps
.
This will display the secrets that need to be replicated, in YAML format
.
1.
SSH into the
**secondary**
, and execute the command below to open the
1.
SSH into the
**secondary**
node and login as the
`git`
user:
`secrets.yml`
file:
```bash
```bash
sudo -
u git -H editor config/secrets.yml
sudo -
i -u git
```
```
1.
Change the value of
`db_key_base`
to the output from the primary node.
1.
Make a backup of any existing secrets:
Then save and close the file.
```bash
mv /home/git/gitlab/config/secrets.yml /home/git/gitlab/config/secrets.yml.`date +%F`
```
1.
Copy
`/home/git/gitlab/config/secrets.yml`
from the primary to the secondary, or
copy-and-paste the file contents between nodes:
```bash
sudo editor /home/git/gitlab/config/secrets.yml
# paste the output of the `cat` command you ran on the primary
# save and exit
```
1.
Ensure the file permissions are correct:
```bash
chown git:git /home/git/gitlab/config/secrets.yml
chmod 0600 /home/git/gitlab/config/secrets.yml
```
1.
Restart GitLab for the changes to take effect:
1.
Restart GitLab for the changes to take effect:
...
...
doc/gitlab-geo/faq.md
View file @
05353538
...
@@ -10,6 +10,19 @@ primary, but this is not officially supported yet.
...
@@ -10,6 +10,19 @@ primary, but this is not officially supported yet.
If you still want to proceed, see our step-by-step instructions on how to
If you still want to proceed, see our step-by-step instructions on how to
manually
[
promote a secondary node
](
disaster-recovery.md
)
into primary.
manually
[
promote a secondary node
](
disaster-recovery.md
)
into primary.
## I followed the disaster recovery instructions and now two-factor auth is broken!
The setup instructions for GitLab Geo prior to 10.5 failed to replicate the
`otp_key_base`
secret, which used to encrypt the two-factor authentication
secrets stored in the database. If it differs between primary and secondary
nodes, users with two-factor authentication enabled won't be able to log in
after a DR failover.
If you still have access to the old primary node, you can follow the
instructions in the
[
Upgrading to GitLab 10.5
](
updating_the_geo_nodes.md#upgrading-to-gitlab-105
)
section to resolve the error. Otherwise, the secret is lost and you'll need to
[
reset two-factor authentication for all users
](
../security/two_factor_authentication.md#disabling-2fa-for-everyone
)
.
## What data is replicated to a secondary node?
## What data is replicated to a secondary node?
We currently replicate project repositories, LFS objects, generated
We currently replicate project repositories, LFS objects, generated
...
...
doc/gitlab-geo/updating_the_geo_nodes.md
View file @
05353538
...
@@ -14,6 +14,28 @@ all you need to do is update GitLab itself:
...
@@ -14,6 +14,28 @@ all you need to do is update GitLab itself:
the tracking database is enabled.
the tracking database is enabled.
1.
[
Test
](
#check-status-after-updating
)
primary and secondary nodes, and check version in each.
1.
[
Test
](
#check-status-after-updating
)
primary and secondary nodes, and check version in each.
## Upgrading to GitLab 10.5
For Geo Disaster Recovery to work with minimum downtime, your Geo secondary
should use the same set of secrets as the primary. However, setup instructions
prior to the 10.5 release only synchronized the
`db_key_base`
secret.
To rectify this error on existing installations, you should
**overwrite**
the
contents of
`/etc/gitlab/gitlab-secrets.json`
on the secondary node with the
contents of
`/etc/gitlab/gitlab-secrets.json`
on the primary node, then run the
following command on the secondary node:
```
bash
sudo
gitlab-ctl reconfigure
```
If you do not perform this step, you may find that two-factor authentication
[
is broken following DR
](
faq.md#i-followed-the-disaster-recovery-instructions-and-now-two-factor-auth-is-broken
)
.
## Upgrading to GitLab 10.4
There are no Geo-specific steps to take!
## Upgrading to GitLab 10.3
## Upgrading to GitLab 10.3
### Support for SSH repository synchronization removed
### Support for SSH repository synchronization removed
...
...
ee/lib/tasks/geo.rake
View file @
05353538
...
@@ -55,11 +55,6 @@ namespace :geo do
...
@@ -55,11 +55,6 @@ namespace :geo do
Gitlab
::
Geo
::
DatabaseTasks
.
load_seed
Gitlab
::
Geo
::
DatabaseTasks
.
load_seed
end
end
desc
'Display database encryption key'
task
show_encryption_key: :environment
do
puts
Rails
.
application
.
secrets
.
db_key_base
end
desc
'Refresh Foreign Tables definition in Geo Secondary node'
desc
'Refresh Foreign Tables definition in Geo Secondary node'
task
refresh_foreign_tables:
[
:environment
]
do
task
refresh_foreign_tables:
[
:environment
]
do
if
Gitlab
::
Geo
::
GeoTasks
.
foreign_server_configured?
if
Gitlab
::
Geo
::
GeoTasks
.
foreign_server_configured?
...
...
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