backup_restore.md 16,5 КБ
Newer Older
Marin Jankovski's avatar
Marin Jankovski включено в состав коммита
1
2
# Backup restore

Sytse Sijbrandij's avatar
Sytse Sijbrandij включено в состав коммита
3
4
![backup banner](backup_hrz.png)

Ciro Santilli's avatar
Ciro Santilli включено в состав коммита
5
## Create a backup of the GitLab system
Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
6

Sytse Sijbrandij's avatar
Sytse Sijbrandij включено в состав коммита
7
8
A backup creates an archive file that contains the database, all repositories and all attachments.
This archive will be saved in backup_path (see `config/gitlab.yml`).
Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
9
The filename will be `[TIMESTAMP]_gitlab_backup.tar`. This timestamp can be used to restore an specific backup.
karen Carias's avatar
karen Carias включено в состав коммита
10
11
12
You can only restore a backup to exactly the same version of GitLab that you created it
on, for example 7.2.1. The best way to migrate your repositories from one server to
another is through backup restore.
Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
13

Sean McGivern's avatar
Sean McGivern включено в состав коммита
14
15
16
You need to keep separate copies of `/etc/gitlab/gitlab-secrets.json` and
`/etc/gitlab/gitlab.rb` (for omnibus packages) or
`/home/git/gitlab/config/secrets.yml` (for installations from source). This file
Sean McGivern's avatar
Sean McGivern включено в состав коммита
17
18
19
20
contains the database encryption keys used for two-factor authentication and CI
secret variables, among other things. If you restore a GitLab backup without
restoring the database encryption key, users who have two-factor authentication
enabled will lose access to your GitLab server.
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
21

Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
22
```
Job van der Voort's avatar
Job van der Voort включено в состав коммита
23
# use this command if you've installed GitLab with the Omnibus package
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
24
25
sudo gitlab-rake gitlab:backup:create

Achilleas Pipinellis's avatar
Achilleas Pipinellis включено в состав коммита
26
# if you've installed GitLab from source
Ben Bodenmiller's avatar
Ben Bodenmiller включено в состав коммита
27
sudo -u git -H bundle exec rake gitlab:backup:create RAILS_ENV=production
Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
28
29
```

Marin Jankovski's avatar
Marin Jankovski включено в состав коммита
30
Also you can choose what should be backed up by adding environment variable SKIP. Available options: db,
Marin Jankovski's avatar
Marin Jankovski включено в состав коммита
31
uploads (attachments), repositories, builds(CI build output logs), artifacts (CI build artifacts), lfs (LFS objects).
Kamil Trzcinski's avatar
Kamil Trzcinski включено в состав коммита
32
Use a comma to specify several options at the same time.
Valery Sizov's avatar
Valery Sizov включено в состав коммита
33
34
35
36
37

```
sudo gitlab-rake gitlab:backup:create SKIP=db,uploads
```

Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
Example output:

```
Dumping database tables:
- Dumping table events... [DONE]
- Dumping table issues... [DONE]
- Dumping table keys... [DONE]
- Dumping table merge_requests... [DONE]
- Dumping table milestones... [DONE]
- Dumping table namespaces... [DONE]
- Dumping table notes... [DONE]
- Dumping table projects... [DONE]
- Dumping table protected_branches... [DONE]
- Dumping table schema_migrations... [DONE]
- Dumping table services... [DONE]
- Dumping table snippets... [DONE]
- Dumping table taggings... [DONE]
- Dumping table tags... [DONE]
- Dumping table users... [DONE]
- Dumping table users_projects... [DONE]
- Dumping table web_hooks... [DONE]
- Dumping table wikis... [DONE]
Dumping repositories:
- Dumping repository abcd... [DONE]
Creating backup archive: $TIMESTAMP_gitlab_backup.tar [DONE]
Deleting tmp directories...[DONE]
Deleting old backups... [SKIPPING]
```

Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
67
68
## Upload backups to remote (cloud) storage

Sytse Sijbrandij's avatar
Sytse Sijbrandij включено в состав коммита
69
70
71
72
Starting with GitLab 7.4 you can let the backup script upload the '.tar' file it creates.
It uses the [Fog library](http://fog.io/) to perform the upload.
In the example below we use Amazon S3 for storage.
But Fog also lets you use [other storage providers](http://fog.io/storage/).
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
73
74
75
76
77
78

For omnibus packages:

```ruby
gitlab_rails['backup_upload_connection'] = {
  'provider' => 'AWS',
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
79
  'region' => 'eu-west-1',
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
  'aws_access_key_id' => 'AKIAKIAKI',
  'aws_secret_access_key' => 'secret123'
}
gitlab_rails['backup_upload_remote_directory'] = 'my.s3.bucket'
```

For installations from source:

```yaml
  backup:
    # snip
    upload:
      # Fog storage connection settings, see http://fog.io/storage/ .
      connection:
        provider: AWS
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
95
        region: eu-west-1
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
96
97
98
99
        aws_access_key_id: AKIAKIAKI
        aws_secret_access_key: 'secret123'
      # The remote 'directory' to store your backups. For S3, this would be the bucket name.
      remote_directory: 'my.s3.bucket'
Paul Beattie's avatar
Paul Beattie включено в состав коммита
100
101
      # Turns on AWS Server-Side Encryption with Amazon S3-Managed Keys for backups, this is optional
      # encryption: 'AES256'
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
102
103
104
105
```

If you are uploading your backups to S3 you will probably want to create a new
IAM user with restricted access rights. To give the upload user access only for
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
106
uploading backups create the following IAM profile, replacing `my.s3.bucket`
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
107
108
109
110
with the name of your bucket:

```json
{
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
111
  "Version": "2012-10-17",
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
112
113
  "Statement": [
    {
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
114
      "Sid": "Stmt1412062044000",
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
115
116
117
118
119
120
121
      "Effect": "Allow",
      "Action": [
        "s3:AbortMultipartUpload",
        "s3:GetBucketAcl",
        "s3:GetBucketLocation",
        "s3:GetObject",
        "s3:GetObjectAcl",
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
122
        "s3:ListBucketMultipartUploads",
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
123
124
125
126
127
128
        "s3:PutObject",
        "s3:PutObjectAcl"
      ],
      "Resource": [
        "arn:aws:s3:::my.s3.bucket/*"
      ]
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
129
    },
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
130
    {
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
131
      "Sid": "Stmt1412062097000",
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
132
133
      "Effect": "Allow",
      "Action": [
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
134
135
        "s3:GetBucketLocation",
        "s3:ListAllMyBuckets"
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
136
137
138
139
      ],
      "Resource": [
        "*"
      ]
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
140
    },
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
141
    {
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
142
      "Sid": "Stmt1412062128000",
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
143
144
145
146
147
148
149
150
151
152
153
154
      "Effect": "Allow",
      "Action": [
        "s3:ListBucket"
      ],
      "Resource": [
        "arn:aws:s3:::my.s3.bucket"
      ]
    }
  ]
}
```

Nathan Lowe's avatar
Nathan Lowe включено в состав коммита
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
### Uploading to locally mounted shares

You may also send backups to a mounted share (`NFS` / `CIFS` / `SMB` / etc.) by
using the [`Local`](https://github.com/fog/fog-local#usage) storage provider.
The directory pointed to by the `local_root` key **must** be owned by the `git`
user **when mounted** (mounting with the `uid=` of the `git` user for `CIFS` and
`SMB`) or the user that you are executing the backup tasks under (for omnibus
packages, this is the `git` user).

The `backup_upload_remote_directory` **must** be set in addition to the
`local_root` key. This is the sub directory inside the mounted directory that
backups will be copied to, and will be created if it does not exist. If the
directory that you want to copy the tarballs to is the root of your mounted
directory, just use `.` instead.

For omnibus packages:

```ruby
gitlab_rails['backup_upload_connection'] = {
  :provider => 'Local',
  :local_root => '/mnt/backups'
}

# The directory inside the mounted folder to copy backups to
# Use '.' to store them in the root directory
gitlab_rails['backup_upload_remote_directory'] = 'gitlab_backups'
```

For installations from source:

```yaml
  backup:
    # snip
    upload:
      # Fog storage connection settings, see http://fog.io/storage/ .
      connection:
        provider: Local
        local_root: '/mnt/backups'
      # The directory inside the mounted folder to copy backups to
      # Use '.' to store them in the root directory
      remote_directory: 'gitlab_backups'
```

Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
## Backup archive permissions

The backup archives created by GitLab (123456_gitlab_backup.tar) will have owner/group git:git and 0600 permissions by default.
This is meant to avoid other system users reading GitLab's data.
If you need the backup archives to have different permissions you can use the 'archive_permissions' setting.

```
# In /etc/gitlab/gitlab.rb, for omnibus packages
gitlab_rails['backup_archive_permissions'] = 0644 # Makes the backup archives world-readable
```

```
# In gitlab.yml, for installations from source:
  backup:
    archive_permissions: 0644 # Makes the backup archives world-readable
```

Sytse Sijbrandij's avatar
Sytse Sijbrandij включено в состав коммита
215
216
## Storing configuration files

Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
217
218
219
220
221
222
Please be informed that a backup does not store your configuration
files.  One reason for this is that your database contains encrypted
information for two-factor authentication.  Storing encrypted
information along with its key in the same place defeats the purpose
of using encryption in the first place!

Job van der Voort's avatar
Job van der Voort включено в состав коммита
223
If you use an Omnibus package please see the [instructions in the readme to backup your configuration](https://gitlab.com/gitlab-org/omnibus-gitlab/blob/master/README.md#backup-and-restore-omnibus-gitlab-configuration).
Sytse Sijbrandij's avatar
Sytse Sijbrandij включено в состав коммита
224
If you have a cookbook installation there should be a copy of your configuration in Chef.
Sean McGivern's avatar
Sean McGivern включено в состав коммита
225
If you have an installation from source, please consider backing up your `config/secrets.yml` file, `gitlab.yml` file, any SSL keys and certificates, and your [SSH host keys](https://superuser.com/questions/532040/copy-ssh-keys-from-one-server-to-another-server/532079#532079).
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
226

Sean McGivern's avatar
Sean McGivern включено в состав коммита
227
228
229
230
At the very **minimum** you should backup `/etc/gitlab/gitlab.rb` and
`/etc/gitlab/gitlab-secrets.json` (Omnibus), or
`/home/git/gitlab/config/secrets.yml` (source) to preserve your database
encryption key.
Sytse Sijbrandij's avatar
Sytse Sijbrandij включено в состав коммита
231

Ciro Santilli's avatar
Ciro Santilli включено в состав коммита
232
## Restore a previously created backup
Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
233

Sytse Sijbrandij's avatar
Sytse Sijbrandij включено в состав коммита
234
235
You can only restore a backup to exactly the same version of GitLab that you created it on, for example 7.2.1.

Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
236
237
238
239
240
241
242
243
244
### Prerequisites

You need to have a working GitLab installation before you can perform
a restore. This is mainly because the system user performing the
restore actions ('git') is usually not allowed to create or delete
the SQL database it needs to import data into ('gitlabhq_production').
All existing data will be either erased (SQL) or moved to a separate
directory (repositories, uploads).

Sean McGivern's avatar
Sean McGivern включено в состав коммита
245
If some or all of your GitLab users are using two-factor authentication (2FA)
Sean McGivern's avatar
Sean McGivern включено в состав коммита
246
247
248
249
then you must also make sure to restore `/etc/gitlab/gitlab.rb` and
`/etc/gitlab/gitlab-secrets.json` (Omnibus), or
`/home/git/gitlab/config/secrets.yml` (installations from source). Note that you
need to run `gitlab-ctl reconfigure` after changing `gitlab-secrets.json`.
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
250

Valery Sizov's avatar
Valery Sizov включено в состав коммита
251
### Installation from source
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
252

Valery Sizov's avatar
Valery Sizov включено в состав коммита
253
```
Drew Blessing's avatar
Drew Blessing включено в состав коммита
254
255
256
# Stop processes that are connected to the database
sudo service gitlab stop

Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets включено в состав коммита
257
bundle exec rake gitlab:backup:restore RAILS_ENV=production
Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
258
259
260
261
262
263
```

Options:

```
BACKUP=timestamp_of_backup (required if more than one backup exists)
Markus Köberl's avatar
Markus Köberl включено в состав коммита
264
force=yes (do not ask if the authorized_keys file should get regenerated)
Johannes Schleifenbaum's avatar
Johannes Schleifenbaum включено в состав коммита
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
```

Example output:

```
Unpacking backup... [DONE]
Restoring database tables:
-- create_table("events", {:force=>true})
   -> 0.2231s
[...]
- Loading fixture events...[DONE]
- Loading fixture issues...[DONE]
- Loading fixture keys...[SKIPPING]
- Loading fixture merge_requests...[DONE]
- Loading fixture milestones...[DONE]
- Loading fixture namespaces...[DONE]
- Loading fixture notes...[DONE]
- Loading fixture projects...[DONE]
- Loading fixture protected_branches...[SKIPPING]
- Loading fixture schema_migrations...[DONE]
- Loading fixture services...[SKIPPING]
- Loading fixture snippets...[SKIPPING]
- Loading fixture taggings...[SKIPPING]
- Loading fixture tags...[SKIPPING]
- Loading fixture users...[DONE]
- Loading fixture users_projects...[DONE]
- Loading fixture web_hooks...[SKIPPING]
- Loading fixture wikis...[SKIPPING]
Restoring repositories:
- Restoring repository abcd... [DONE]
Deleting tmp directories...[DONE]
```
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
297

Valery Sizov's avatar
Valery Sizov включено в состав коммита
298
299
### Omnibus installations

John McGehee's avatar
John McGehee включено в состав коммита
300
This procedure assumes that:
Valery Sizov's avatar
Valery Sizov включено в состав коммита
301

John McGehee's avatar
John McGehee включено в состав коммита
302
303
304
305
306
307
308
309
- You have installed the exact same version of GitLab Omnibus with which the
  backup was created
- You have run `sudo gitlab-ctl reconfigure` at least once
- GitLab is running.  If not, start it using `sudo gitlab-ctl start`.

First make sure your backup tar file is in the backup directory described in the
`gitlab.rb` configuration `gitlab_rails['backup_path']`. The default is
`/var/opt/gitlab/backups`.
Valery Sizov's avatar
Valery Sizov включено в состав коммита
310
311
312
313
314

```shell
sudo cp 1393513186_gitlab_backup.tar /var/opt/gitlab/backups/
```

John McGehee's avatar
John McGehee включено в состав коммита
315
316
Stop the processes that are connected to the database.  Leave the rest of GitLab
running:
Valery Sizov's avatar
Valery Sizov включено в состав коммита
317
318
319
320

```shell
sudo gitlab-ctl stop unicorn
sudo gitlab-ctl stop sidekiq
John McGehee's avatar
John McGehee включено в состав коммита
321
322
323
# Verify
sudo gitlab-ctl status
```
Valery Sizov's avatar
Valery Sizov включено в состав коммита
324

John McGehee's avatar
John McGehee включено в состав коммита
325
326
327
328
Next, restore the backup, specifying the timestamp of the backup you wish to
restore:

```shell
Valery Sizov's avatar
Valery Sizov включено в состав коммита
329
330
# This command will overwrite the contents of your GitLab database!
sudo gitlab-rake gitlab:backup:restore BACKUP=1393513186
John McGehee's avatar
John McGehee включено в состав коммита
331
```
Valery Sizov's avatar
Valery Sizov включено в состав коммита
332

John McGehee's avatar
John McGehee включено в состав коммита
333
Restart and check GitLab:
Valery Sizov's avatar
Valery Sizov включено в состав коммита
334

John McGehee's avatar
John McGehee включено в состав коммита
335
336
```shell
sudo gitlab-ctl start
Valery Sizov's avatar
Valery Sizov включено в состав коммита
337
338
339
340
sudo gitlab-rake gitlab:check SANITIZE=true
```

If there is a GitLab version mismatch between your backup tar file and the installed
John McGehee's avatar
John McGehee включено в состав коммита
341
342
version of GitLab, the restore command will abort with an error. Install the
[correct GitLab version](https://www.gitlab.com/downloads/archives/) and try again.
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
343

Valery Sizov's avatar
Valery Sizov включено в состав коммита
344
## Configure cron to make daily backups
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
345

Valery Sizov's avatar
Valery Sizov включено в состав коммита
346
### For installation from source:
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
347
348
349
350
351
352
353
354
355
```
cd /home/git/gitlab
sudo -u git -H editor config/gitlab.yml # Enable keep_time in the backup section to automatically delete old backups
sudo -u git crontab -e # Edit the crontab for the git user
```

Add the following lines at the bottom:

```
Job van der Voort's avatar
Job van der Voort включено в состав коммита
356
# Create a full backup of the GitLab repositories and SQL database every day at 4am
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
357
0 4 * * * cd /home/git/gitlab && PATH=/usr/local/bin:/usr/bin:/bin bundle exec rake gitlab:backup:create RAILS_ENV=production CRON=1
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
358
```
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
359
360
361

The `CRON=1` environment setting tells the backup script to suppress all progress output if there are no errors.
This is recommended to reduce cron spam.
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
362

Valery Sizov's avatar
Valery Sizov включено в состав коммита
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
### For omnibus installations

To schedule a cron job that backs up your repositories and GitLab metadata, use the root user:

```
sudo su -
crontab -e
```

There, add the following line to schedule the backup for everyday at 2 AM:

```
0 2 * * * /opt/gitlab/bin/gitlab-rake gitlab:backup:create CRON=1
```

You may also want to set a limited lifetime for backups to prevent regular
backups using all your disk space.  To do this add the following lines to
`/etc/gitlab/gitlab.rb` and reconfigure:

```
# limit backup lifetime to 7 days - 604800 seconds
gitlab_rails['backup_keep_time'] = 604800
```

Stan Hu's avatar
Stan Hu включено в состав коммита
387
388
389
390
391
392
393
Note that the `backup_keep_time` configuration option only manages local
files. GitLab does not automatically prune old files stored in a third-party
object storage (e.g. AWS S3) because the user may not have permission to list
and delete files. We recommend that you configure the appropriate retention
policy for your object storage. For example, you can configure [the S3 backup
policy here as described here](http://stackoverflow.com/questions/37553070/gitlab-omnibus-delete-backup-from-amazon-s3).

Valery Sizov's avatar
Valery Sizov включено в состав коммита
394
395
NOTE: This cron job does not [backup your omnibus-gitlab configuration](#backup-and-restore-omnibus-gitlab-configuration) or [SSH host keys](https://superuser.com/questions/532040/copy-ssh-keys-from-one-server-to-another-server/532079#532079).

Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
396
397
398
399
400
## Alternative backup strategies

If your GitLab server contains a lot of Git repository data you may find the GitLab backup script to be too slow.
In this case you can consider using filesystem snapshots as part of your backup strategy.

Ewan Edwards's avatar
Ewan Edwards включено в состав коммита
401
Example: Amazon EBS
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
402
403
404
405
406
407

> A GitLab server using omnibus-gitlab hosted on Amazon AWS.
> An EBS drive containing an ext4 filesystem is mounted at `/var/opt/gitlab`.
> In this case you could make an application backup by taking an EBS snapshot.
> The backup includes all repositories, uploads and Postgres data.

Ewan Edwards's avatar
Ewan Edwards включено в состав коммита
408
Example: LVM snapshots + rsync
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
409
410

> A GitLab server using omnibus-gitlab, with an LVM logical volume mounted at `/var/opt/gitlab`.
Ewan Edwards's avatar
Ewan Edwards включено в состав коммита
411
> Replicating the `/var/opt/gitlab` directory using rsync would not be reliable because too many files would change while rsync is running.
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
412
> Instead of rsync-ing `/var/opt/gitlab`, we create a temporary LVM snapshot, which we mount as a read-only filesystem at `/mnt/gitlab_backup`.
Ewan Edwards's avatar
Ewan Edwards включено в состав коммита
413
> Now we can have a longer running rsync job which will create a consistent replica on the remote server.
Jacob Vosmaer's avatar
Jacob Vosmaer включено в состав коммита
414
415
416
417
> The replica includes all repositories, uploads and Postgres data.

If you are running GitLab on a virtualized server you can possibly also create VM snapshots of the entire GitLab server.
It is not uncommon however for a VM snapshot to require you to power down the server, so this approach is probably of limited practical use.
Karen Carias's avatar
Karen Carias включено в состав коммита
418

Marin Jankovski's avatar
Marin Jankovski включено в состав коммита
419
420
421
422
423
424
425
## Troubleshooting

### Restoring database backup using omnibus packages outputs warnings
If you are using backup restore procedures you might encounter the following warnings:

```
psql:/var/opt/gitlab/backups/db/database.sql:22: ERROR:  must be owner of extension plpgsql
Anton Davydov's avatar
Anton Davydov включено в состав коммита
426
427
psql:/var/opt/gitlab/backups/db/database.sql:2931: WARNING:  no privileges could be revoked for "public" (two occurrences)
psql:/var/opt/gitlab/backups/db/database.sql:2933: WARNING:  no privileges were granted for "public" (two occurrences)
Marin Jankovski's avatar
Marin Jankovski включено в состав коммита
428
429
430
431
432
433
434
435
436
437
438
439
440

```

Be advised that, backup is successfully restored in spite of these warnings.

The rake task runs this as the `gitlab` user which does not have the superuser access to the database. When restore is initiated it will also run as `gitlab` user but it will also try to alter the objects it does not have access to.
Those objects have no influence on the database backup/restore but they give this annoying warning.

For more information see similar questions on postgresql issue tracker[here](http://www.postgresql.org/message-id/201110220712.30886.adrian.klaver@gmail.com) and [here](http://www.postgresql.org/message-id/2039.1177339749@sss.pgh.pa.us) as well as [stack overflow](http://stackoverflow.com/questions/4368789/error-must-be-owner-of-language-plpgsql).

## Note
This documentation is for GitLab CE.
We backup GitLab.com and make sure your data is secure, but you can't use these methods to export / backup your data yourself from GitLab.com.
karen Carias's avatar
karen Carias включено в состав коммита
441

karen Carias's avatar
karen Carias включено в состав коммита
442
Issues are stored in the database. They can't be stored in Git itself.
karen Carias's avatar
karen Carias включено в состав коммита
443

karen Carias's avatar
karen Carias включено в состав коммита
444
To migrate your repositories from one server to another with an up-to-date version of
karen Carias's avatar
karen Carias включено в состав коммита
445
446
447
GitLab, you can use the [import rake task](import.md) to do a mass import of the
repository. Note that if you do an import rake task, rather than a backup restore, you
will have all your repositories, but not any other data.