2020-06-23 00:09:42 +05:30
---
stage: Enablement
group: Geo
2021-02-22 17:27:13 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
2020-06-23 00:09:42 +05:30
---
2021-04-29 21:17:54 +05:30
# Version-specific update instructions **(PREMIUM SELF)**
2019-12-04 20:38:33 +05:30
2021-03-11 19:13:27 +05:30
Review this page for update instructions for your version. These steps
2021-11-11 11:23:49 +05:30
accompany the [general steps ](updating_the_geo_sites.md#general-update-steps )
2022-04-04 11:22:00 +05:30
for updating Geo sites.
2022-05-07 20:08:51 +05:30
## Updating to 14.9
**DO NOT** update to GitLab 14.9.0.
We've discovered an issue with Geo's CI verification feature that may [cause job traces to be lost ](https://gitlab.com/gitlab-com/gl-infra/production/-/issues/6664 ). This issue will be fixed in the next patch release.
If you have already updated to GitLab 14.9.0, you can disable the feature causing the issue by [disabling the `geo_job_artifact_replication` feature flag ](../../feature_flags.md#how-to-enable-and-disable-features-behind-flags ).
2022-04-04 11:22:00 +05:30
## Updating to 14.2 through 14.7
There is [an issue in GitLab 14.2 through 14.7 ](https://gitlab.com/gitlab-org/gitlab/-/issues/299819#note_822629467 )
that affects Geo when the GitLab-managed object storage replication is used, causing blob object types to fail synchronization.
Since GitLab 14.2, verification failures result in synchronization failures and cause
a resynchronization of these objects.
As verification is not yet implemented for files stored in object storage (see
[issue 13845 ](https://gitlab.com/gitlab-org/gitlab/-/issues/13845 ) for more details), this
results in a loop that consistently fails for all objects stored in object storage.
For information on how to fix this, see
[Troubleshooting - Failed syncs with GitLab-managed object storage replication ](troubleshooting.md#failed-syncs-with-gitlab-managed-object-storage-replication ).
2019-12-04 20:38:33 +05:30
2022-01-26 12:08:38 +05:30
## Updating to 14.4
There is [an issue in GitLab 14.4.0 through 14.4.2 ](../../../update/index.md#1440 ) that can affect Geo and other features that rely on cronjobs. We recommend upgrading to GitLab 14.4.3 or later.
2021-11-11 11:23:49 +05:30
## Updating to 14.1, 14.2, 14.3
2021-11-18 22:05:49 +05:30
### Multi-arch images
2022-04-04 11:22:00 +05:30
We found an [issue ](https://gitlab.com/gitlab-org/gitlab/-/issues/336013 ) where the Container Registry replication wasn't fully working if you used multi-arch images. In case of a multi-arch image, only the primary architecture (for example `amd64` ) would be replicated to the secondary site. This has been [fixed in GitLab 14.3 ](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/67624 ) and was backported to 14.2 and 14.1, but manual steps are required to force a re-sync.
2021-11-11 11:23:49 +05:30
You can check if you are affected by running:
```shell
docker manifest inspect < SECONDARY_IMAGE_LOCATION > | jq '.mediaType'
```
2022-04-04 11:22:00 +05:30
Where `<SECONDARY_IMAGE_LOCATION>` is a container image on your secondary site.
2021-11-11 11:23:49 +05:30
If the output matches `application/vnd.docker.distribution.manifest.list.v2+json`
(there can be a `mediaType` entry at several levels, we only care about the top level entry),
then you don't need to do anything.
2022-04-04 11:22:00 +05:30
Otherwise, for each **secondary** site, on a Rails application node, open a [Rails console ](../../operations/rails_console.md ), and run the following:
2021-11-11 11:23:49 +05:30
```ruby
list_type = 'application/vnd.docker.distribution.manifest.list.v2+json'
Geo::ContainerRepositoryRegistry.synced.each do |gcr|
cr = gcr.container_repository
primary = Geo::ContainerRepositorySync.new(cr)
cr.tags.each do |tag|
primary_manifest = JSON.parse(primary.send(:client).repository_raw_manifest(cr.path, tag.name))
next unless primary_manifest['mediaType'].eql?(list_type)
cr.delete_tag_by_name(tag.name)
end
primary.execute
end
```
If you are running a version prior to 14.1 and are using Geo and multi-arch containers in your Container Registry, we recommend [upgrading ](updating_the_geo_sites.md ) to at least GitLab 14.1.
2021-11-18 22:05:49 +05:30
### Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode
2022-01-26 12:08:38 +05:30
GitLab 13.9 through GitLab 14.3 are affected by a bug in which enabling [GitLab Maintenance Mode ](../../maintenance_mode/index.md ) causes Geo secondary site statuses to appear to stop updating and become unhealthy. For more information, see [Troubleshooting - Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode ](troubleshooting.md#geo-admin-area-shows-unhealthy-after-enabling-maintenance-mode ).
2021-11-18 22:05:49 +05:30
2021-09-04 01:27:46 +05:30
## Updating to GitLab 14.0/14.1
2021-11-18 22:05:49 +05:30
### Primary sites can not be removed from the UI
2021-09-04 01:27:46 +05:30
We found an issue where [Primary sites can not be removed from the UI ](https://gitlab.com/gitlab-org/gitlab/-/issues/338231 ).
This bug only exists in the UI and does not block the removal of Primary sites using any other method.
2022-04-04 11:22:00 +05:30
If you are running an affected version and need to remove your Primary site, you can manually remove the Primary site by using the [Geo Sites API ](../../../api/geo_nodes.md#delete-a-geo-node ).
2021-09-04 01:27:46 +05:30
2021-11-18 22:05:49 +05:30
### Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode
2022-01-26 12:08:38 +05:30
GitLab 13.9 through GitLab 14.3 are affected by a bug in which enabling [GitLab Maintenance Mode ](../../maintenance_mode/index.md ) causes Geo secondary site statuses to appear to stop updating and become unhealthy. For more information, see [Troubleshooting - Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode ](troubleshooting.md#geo-admin-area-shows-unhealthy-after-enabling-maintenance-mode ).
2021-09-04 01:27:46 +05:30
## Updating to GitLab 13.12
2022-04-04 11:22:00 +05:30
### Secondary sites re-download all LFS files upon update
2021-11-18 22:05:49 +05:30
2022-04-04 11:22:00 +05:30
We found an issue where [secondary sites re-download all LFS files ](https://gitlab.com/gitlab-org/gitlab/-/issues/334550 ) upon update. This bug:
2021-09-04 01:27:46 +05:30
- Only applies to Geo secondary sites that have replicated LFS objects.
- Is _not_ a data loss risk.
- Causes churn and wasted bandwidth re-downloading all LFS objects.
- May impact performance for GitLab installations with a large number of LFS files.
If you don't have many LFS objects or can stand a bit of churn, then it is safe to let the secondary sites re-download LFS objects.
If you do have many LFS objects, or many Geo secondary sites, or limited bandwidth, or a combination of them all, then we recommend you skip GitLab 13.12.0 through 13.12.6 and update to GitLab 13.12.7 or newer.
2021-11-18 22:05:49 +05:30
#### If you have already updated to an affected version, and the re-sync is ongoing
2021-09-04 01:27:46 +05:30
You can manually migrate the legacy sync state to the new state column by running the following command in a [Rails console ](../../operations/rails_console.md ). It should take under a minute:
```ruby
Geo::LfsObjectRegistry.where(state: 0, success: true).update_all(state: 2)
```
2021-11-18 22:05:49 +05:30
### Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode
2022-01-26 12:08:38 +05:30
GitLab 13.9 through GitLab 14.3 are affected by a bug in which enabling [GitLab Maintenance Mode ](../../maintenance_mode/index.md ) causes Geo secondary site statuses to appear to stop updating and become unhealthy. For more information, see [Troubleshooting - Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode ](troubleshooting.md#geo-admin-area-shows-unhealthy-after-enabling-maintenance-mode ).
2021-11-18 22:05:49 +05:30
2021-09-04 01:27:46 +05:30
## Updating to GitLab 13.11
2021-09-30 23:02:18 +05:30
We found an [issue with Git clone/pull through HTTP(s) ](https://gitlab.com/gitlab-org/gitlab/-/issues/330787 ) on Geo secondaries and on any GitLab instance if maintenance mode is enabled. This was caused by a regression in GitLab Workhorse. This is fixed in the [GitLab 13.11.4 patch release ](https://about.gitlab.com/releases/2021/05/14/gitlab-13-11-4-released/ ). To avoid this issue, upgrade to GitLab 13.11.4 or later.
2021-09-04 01:27:46 +05:30
2021-11-18 22:05:49 +05:30
### Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode
2022-01-26 12:08:38 +05:30
GitLab 13.9 through GitLab 14.3 are affected by a bug in which enabling [GitLab Maintenance Mode ](../../maintenance_mode/index.md ) causes Geo secondary site statuses to appear to stop updating and become unhealthy. For more information, see [Troubleshooting - Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode ](troubleshooting.md#geo-admin-area-shows-unhealthy-after-enabling-maintenance-mode ).
2021-11-18 22:05:49 +05:30
## Updating to GitLab 13.10
### Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode
2022-01-26 12:08:38 +05:30
GitLab 13.9 through GitLab 14.3 are affected by a bug in which enabling [GitLab Maintenance Mode ](../../maintenance_mode/index.md ) causes Geo secondary site statuses to appear to stop updating and become unhealthy. For more information, see [Troubleshooting - Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode ](troubleshooting.md#geo-admin-area-shows-unhealthy-after-enabling-maintenance-mode ).
2021-11-18 22:05:49 +05:30
2021-04-17 20:07:23 +05:30
## Updating to GitLab 13.9
2021-11-18 22:05:49 +05:30
### Error during zero-downtime update: "cannot drop column asset_proxy_whitelist"
2021-04-17 20:07:23 +05:30
We've detected an issue [with a column rename ](https://gitlab.com/gitlab-org/gitlab/-/issues/324160 )
2022-01-26 12:08:38 +05:30
that prevents upgrades to GitLab 13.9.0, 13.9.1, 13.9.2 and 13.9.3 when following the zero-downtime steps. It is necessary
2021-11-18 22:05:49 +05:30
to perform the following additional steps for the zero-downtime update:
2021-06-08 01:23:25 +05:30
1. Before running the final `sudo gitlab-rake db:migrate` command on the deploy node,
execute the following queries using the PostgreSQL console (or `sudo gitlab-psql` )
to drop the problematic triggers:
```sql
drop trigger trigger_e40a6f1858e6 on application_settings;
drop trigger trigger_0d588df444c8 on application_settings;
drop trigger trigger_1572cbc9a15f on application_settings;
drop trigger trigger_22a39c5c25f3 on application_settings;
```
1. Run the final migrations:
```shell
sudo gitlab-rake db:migrate
```
If you have already run the final `sudo gitlab-rake db:migrate` command on the deploy node and have
2022-01-26 12:08:38 +05:30
encountered the [column rename issue ](https://gitlab.com/gitlab-org/gitlab/-/issues/324160 ), you might
2021-09-30 23:02:18 +05:30
see the following error:
```shell
-- remove_column(:application_settings, :asset_proxy_whitelist)
rake aborted!
StandardError: An error has occurred, all later migrations canceled:
PG::DependentObjectsStillExist: ERROR: cannot drop column asset_proxy_whitelist of table application_settings because other objects depend on it
DETAIL: trigger trigger_0d588df444c8 on table application_settings depends on column asset_proxy_whitelist of table application_settings
```
2021-04-17 20:07:23 +05:30
2021-09-30 23:02:18 +05:30
To work around this bug, follow the previous steps to complete the update.
2021-04-17 20:07:23 +05:30
More details are available [in this issue ](https://gitlab.com/gitlab-org/gitlab/-/issues/324160 ).
2021-11-18 22:05:49 +05:30
### Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode
2022-01-26 12:08:38 +05:30
GitLab 13.9 through GitLab 14.3 are affected by a bug in which enabling [GitLab Maintenance Mode ](../../maintenance_mode/index.md ) causes Geo secondary site statuses to appear to stop updating and become unhealthy. For more information, see [Troubleshooting - Geo Admin Area shows 'Unhealthy' after enabling Maintenance Mode ](troubleshooting.md#geo-admin-area-shows-unhealthy-after-enabling-maintenance-mode ).
2021-11-18 22:05:49 +05:30
2021-03-11 19:13:27 +05:30
## Updating to GitLab 13.7
We've detected an issue with the `FetchRemove` call used by Geo secondaries.
This causes performance issues as we execute reference transaction hooks for
each updated reference. Delay any upgrade attempts until this is in the
[13.7.5 patch release. ](https://gitlab.com/gitlab-org/gitaly/-/merge_requests/3002 ).
More details are available [in this issue ](https://gitlab.com/gitlab-org/git/-/issues/79 ).
2021-02-22 17:27:13 +05:30
## Updating to GitLab 13.5
2021-03-11 19:13:27 +05:30
GitLab 13.5 has a [regression that prevents viewing a list of container repositories and registries ](https://gitlab.com/gitlab-org/gitlab/-/issues/285475 )
on Geo secondaries. This issue is fixed in GitLab 13.6.1 and later.
2021-02-22 17:27:13 +05:30
2020-10-24 23:57:45 +05:30
## Updating to GitLab 13.3
2021-03-11 19:13:27 +05:30
In GitLab 13.3, Geo removed the PostgreSQL [Foreign Data Wrapper ](https://www.postgresql.org/docs/11/postgres-fdw.html )
dependency for the tracking database.
2020-10-24 23:57:45 +05:30
2022-01-26 12:08:38 +05:30
The FDW server, user, and the extension is removed during the upgrade
2022-04-04 11:22:00 +05:30
process on each secondary site. The GitLab settings related to the FDW in the
2021-03-11 19:13:27 +05:30
`/etc/gitlab/gitlab.rb` have been deprecated and can be safely removed.
2020-10-24 23:57:45 +05:30
2021-03-11 19:13:27 +05:30
There are some scenarios like using an external PostgreSQL instance for the
tracking database where the FDW settings must be removed manually. Enter the
PostgreSQL console of that instance and remove them:
2020-10-24 23:57:45 +05:30
```shell
DROP SERVER gitlab_secondary CASCADE;
DROP EXTENSION IF EXISTS postgres_fdw;
```
2021-02-22 17:27:13 +05:30
WARNING:
2022-04-04 11:22:00 +05:30
In GitLab 13.3, promoting a secondary site to a primary while the secondary is
2021-01-29 00:20:46 +05:30
paused fails. Do not pause replication before promoting a secondary. If the
2022-04-04 11:22:00 +05:30
site is paused, be sure to resume before promoting. To avoid this issue,
2021-01-29 00:20:46 +05:30
upgrade to GitLab 13.4 or later.
2021-09-04 01:27:46 +05:30
WARNING:
Promoting the database during a failover can fail on XFS and filesystems ordering files lexically,
when using `--force` or `--skip-preflight-checks` , due to [an issue ](https://gitlab.com/gitlab-org/omnibus-gitlab/-/issues/6076 ) fixed in 13.5.
The [troubleshooting steps ](troubleshooting.md#errors-when-using---skip-preflight-checks-or---force )
contain a workaround if you run into errors during the failover.
2021-01-29 00:20:46 +05:30
## Updating to GitLab 13.2
2022-04-04 11:22:00 +05:30
In GitLab 13.2, promoting a secondary site to a primary while the secondary is
2021-03-11 19:13:27 +05:30
paused fails. Do not pause replication before promoting a secondary. If the
2022-04-04 11:22:00 +05:30
site is paused, be sure to resume before promoting. To avoid this issue,
2021-03-11 19:13:27 +05:30
upgrade to GitLab 13.4 or later.
2021-01-29 00:20:46 +05:30
2020-10-24 23:57:45 +05:30
## Updating to GitLab 13.0
Upgrading to GitLab 13.0 requires GitLab 12.10 to already be using PostgreSQL
2021-01-29 00:20:46 +05:30
version 11. For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
## Updating to GitLab 12.10
2021-01-29 00:20:46 +05:30
GitLab 12.10 doesn't attempt to update the embedded PostgreSQL server when
using Geo, because the PostgreSQL upgrade requires downtime for secondaries
while reinitializing streaming replication. It must be upgraded manually. For
the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2020-04-22 19:07:51 +05:30
## Updating to GitLab 12.9
2021-02-22 17:27:13 +05:30
WARNING:
2020-04-22 19:07:51 +05:30
GitLab 12.9.0 through GitLab 12.9.3 are affected by [a bug that stops
repository verification](https://gitlab.com/gitlab-org/gitlab/-/issues/213523).
2021-01-29 00:20:46 +05:30
The issue is fixed in GitLab 12.9.4. Upgrade to GitLab 12.9.4 or later.
2020-04-22 19:07:51 +05:30
2021-03-11 19:13:27 +05:30
By default, GitLab 12.9 attempts to update the embedded PostgreSQL server
version from 9.6 to 10.12, which requires downtime on secondaries while
reinitializing streaming replication. For the recommended procedure, see the
2021-01-29 00:20:46 +05:30
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-03-11 19:13:27 +05:30
You can temporarily disable this behavior by running the following before
updating:
2020-10-24 23:57:45 +05:30
```shell
sudo touch /etc/gitlab/disable-postgresql-upgrade
```
## Updating to GitLab 12.8
2021-03-11 19:13:27 +05:30
By default, GitLab 12.8 attempts to update the embedded PostgreSQL server
version from 9.6 to 10.12, which requires downtime on secondaries while
reinitializing streaming replication. For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-03-11 19:13:27 +05:30
You can temporarily disable this behavior by running the following before
updating:
2020-10-24 23:57:45 +05:30
```shell
sudo touch /etc/gitlab/disable-postgresql-upgrade
```
2020-03-13 15:44:24 +05:30
## Updating to GitLab 12.7
2021-02-22 17:27:13 +05:30
WARNING:
2020-03-13 15:44:24 +05:30
Only upgrade to GitLab 12.7.5 or later. Do not upgrade to versions 12.7.0
2021-03-11 19:13:27 +05:30
through 12.7.4 because there is [an initialization order bug ](https://gitlab.com/gitlab-org/gitlab/-/issues/199672 ) that causes Geo secondaries to set the incorrect database connection pool size.
[The fix ](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/24021 ) was
2020-03-13 15:44:24 +05:30
shipped in 12.7.5.
2021-03-11 19:13:27 +05:30
By default, GitLab 12.7 attempts to update the embedded PostgreSQL server
version from 9.6 to 10.9, which requires downtime on secondaries while
reinitializing streaming replication. For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-03-11 19:13:27 +05:30
You can temporarily disable this behavior by running the following before
updating:
2020-10-24 23:57:45 +05:30
```shell
sudo touch /etc/gitlab/disable-postgresql-upgrade
```
## Updating to GitLab 12.6
2021-03-11 19:13:27 +05:30
By default, GitLab 12.6 attempts to update the embedded PostgreSQL server
version from 9.6 to 10.9, which requires downtime on secondaries while
reinitializing streaming replication. For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-03-11 19:13:27 +05:30
You can temporarily disable this behavior by running the following before
updating:
2020-10-24 23:57:45 +05:30
```shell
sudo touch /etc/gitlab/disable-postgresql-upgrade
```
## Updating to GitLab 12.5
2021-03-11 19:13:27 +05:30
By default, GitLab 12.5 attempts to update the embedded PostgreSQL server
version from 9.6 to 10.9, which requires downtime on secondaries while
reinitializing streaming replication. For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-03-11 19:13:27 +05:30
You can temporarily disable this behavior by running the following before
updating:
2020-10-24 23:57:45 +05:30
```shell
sudo touch /etc/gitlab/disable-postgresql-upgrade
```
## Updating to GitLab 12.4
2021-03-11 19:13:27 +05:30
By default, GitLab 12.4 attempts to update the embedded PostgreSQL server
version from 9.6 to 10.9, which requires downtime on secondaries while
reinitializing streaming replication. For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-03-11 19:13:27 +05:30
You can temporarily disable this behavior by running the following before
updating:
2020-10-24 23:57:45 +05:30
```shell
sudo touch /etc/gitlab/disable-postgresql-upgrade
```
## Updating to GitLab 12.3
2021-02-22 17:27:13 +05:30
WARNING:
2021-03-11 19:13:27 +05:30
If the existing PostgreSQL server version is 9.6.x, we recommend upgrading to
GitLab 12.4 or later. By default, GitLab 12.3 attempts to update the embedded
PostgreSQL server version from 9.6 to 10.9. In certain circumstances, it can
2021-01-29 00:20:46 +05:30
fail. For more information, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-01-29 00:20:46 +05:30
Additionally, if the PostgreSQL upgrade doesn't fail, a successful upgrade
requires downtime for secondaries while reinitializing streaming replication.
For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2019-12-26 22:10:19 +05:30
## Updating to GitLab 12.2
2021-02-22 17:27:13 +05:30
WARNING:
2021-03-11 19:13:27 +05:30
If the existing PostgreSQL server version is 9.6.x, we recommend upgrading to
GitLab 12.4 or later. By default, GitLab 12.2 attempts to update the embedded
PostgreSQL server version from 9.6 to 10.9. In certain circumstances, it can
2021-01-29 00:20:46 +05:30
fail. For more information, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-03-11 19:13:27 +05:30
Additionally, if the PostgreSQL upgrade doesn't fail, a successful upgrade
2021-01-29 00:20:46 +05:30
requires downtime for secondaries while reinitializing streaming replication.
For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2019-12-26 22:10:19 +05:30
GitLab 12.2 includes the following minor PostgreSQL updates:
2021-03-11 19:13:27 +05:30
- To version `9.6.14` , if you run PostgreSQL 9.6.
- To version `10.9` , if you run PostgreSQL 10.
2019-12-26 22:10:19 +05:30
2021-03-11 19:13:27 +05:30
This update occurs even if major PostgreSQL updates are disabled.
2019-12-26 22:10:19 +05:30
2021-11-11 11:23:49 +05:30
Before [refreshing Foreign Data Wrapper during a Geo upgrade ](../../../update/zero_downtime.md#step-4-run-post-deployment-migrations-and-checks ),
2019-12-26 22:10:19 +05:30
restart the Geo tracking database:
2020-03-13 15:44:24 +05:30
```shell
2019-12-26 22:10:19 +05:30
sudo gitlab-ctl restart geo-postgresql
```
2021-03-11 19:13:27 +05:30
The restart avoids a version mismatch when PostgreSQL tries to load the FDW
extension.
2019-12-26 22:10:19 +05:30
2019-12-04 20:38:33 +05:30
## Updating to GitLab 12.1
2021-02-22 17:27:13 +05:30
WARNING:
2021-03-11 19:13:27 +05:30
If the existing PostgreSQL server version is 9.6.x, we recommend upgrading to
GitLab 12.4 or later. By default, GitLab 12.1 attempts to update the embedded
PostgreSQL server version from 9.6 to 10.9. In certain circumstances, it can
2021-01-29 00:20:46 +05:30
fail. For more information, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2020-10-24 23:57:45 +05:30
2021-01-29 00:20:46 +05:30
Additionally, if the PostgreSQL upgrade doesn't fail, a successful upgrade
requires downtime for secondaries while reinitializing streaming replication.
For the recommended procedure, see the
[Omnibus GitLab documentation ](https://docs.gitlab.com/omnibus/settings/database.html#upgrading-a-geo-instance ).
2019-12-04 20:38:33 +05:30
2020-04-08 14:13:33 +05:30
## Updating to GitLab 12.0
2021-02-22 17:27:13 +05:30
WARNING:
2021-01-29 00:20:46 +05:30
This version is affected by a [bug that results in new LFS objects not being
2022-04-04 11:22:00 +05:30
replicated to Geo secondary sites](https://gitlab.com/gitlab-org/gitlab/-/issues/32696).
2021-03-11 19:13:27 +05:30
The issue is fixed in GitLab 12.1. Be sure to upgrade to GitLab 12.1 or later.