Commit 01333b96 authored by Tiago Botelho's avatar Tiago Botelho

updates documentation

parent 4c50e915
...@@ -27,7 +27,7 @@ class UpdateAllMirrorsWorker ...@@ -27,7 +27,7 @@ class UpdateAllMirrorsWorker
private private
def mirrors_to_sync def mirrors_to_sync
Project.mirror.where("NOW() >= mirror_last_update_at + sync_time * interval '1 minute' OR sync_time IN (?)", Gitlab::Mirror.sync_times) Project.mirror.where(sync_time: Gitlab::Mirror.sync_times)
end end
def try_obtain_lease def try_obtain_lease
......
...@@ -17,6 +17,6 @@ class UpdateAllRemoteMirrorsWorker ...@@ -17,6 +17,6 @@ class UpdateAllRemoteMirrorsWorker
private private
def remote_mirrors_to_sync def remote_mirrors_to_sync
RemoteMirror.where("NOW() >= updated_at + sync_time * interval '1 minute' OR sync_time IN (?)", Gitlab::Mirror.sync_times) RemoteMirror.where(sync_time: Gitlab::Mirror.sync_times)
end end
end end
# Cron jobs
## Adjusting synchronization times for repository mirroring
>**Notes:**
- This is an [Enterprise Edition][ee] only feature.
- For more information on the repository mirroring, see the
[user documentation](../workflow/repository_mirroring.md).
You can manually configure the repository synchronization times by setting the
following configuration values.
Please note that `update_all_mirrors_worker_cron` refers to the worker used for
pulling changes from a remote mirror while `update_all_remote_mirrors_worker_cron`
refers to the worker used for pushing changes to the remote mirror.
>**Note:**
These are cron formatted values. You can use a crontab generator to create these
values, for example http://www.crontabgenerator.com/.
**Omnibus installations**
```
gitlab_rails['update_all_mirrors_worker_cron'] = "0 * * * *"
gitlab_rails['update_all_remote_mirrors_worker_cron'] = "30 * * * *"
```
**Source installations**
```
cron_jobs:
update_all_mirrors_worker_cron:
cron: "0 * * * *"
update_all_remote_mirrors_worker_cron:
cron: "30 * * * *"
```
[ee]: https://about.gitlab.com/products
...@@ -7,7 +7,7 @@ There are two kinds of repository mirroring features supported by GitLab: ...@@ -7,7 +7,7 @@ There are two kinds of repository mirroring features supported by GitLab:
to another location, whereas the **pull** method mirrors an external repository to another location, whereas the **pull** method mirrors an external repository
in one in GitLab. in one in GitLab.
Mirror repositories are updated every hour, and all new branches, tags, and By default mirror repositories are updated every hour, and all new branches, tags, and
commits will be visible in the project's activity feed. commits will be visible in the project's activity feed.
Users with at least [developer access][perms] to the project can also force an Users with at least [developer access][perms] to the project can also force an
...@@ -51,8 +51,8 @@ whether you want to trigger builds for mirror updates. ...@@ -51,8 +51,8 @@ whether you want to trigger builds for mirror updates.
Since the repository on GitLab functions as a mirror of the upstream repository, Since the repository on GitLab functions as a mirror of the upstream repository,
you are advised not to push commits directly to the repository on GitLab. you are advised not to push commits directly to the repository on GitLab.
Instead, any commits should be pushed to the upstream repository, and will end Instead, any commits should be pushed to the upstream repository, and will end
up in the GitLab repository automatically within an hour, or when a up in the GitLab repository automatically within your project's configured
[forced update](#forcing-an-update) is initiated. synchronization time, or when a [forced update](#forcing-an-update) is initiated.
If you do manually update a branch in the GitLab repository, the branch will If you do manually update a branch in the GitLab repository, the branch will
become diverged from upstream, and GitLab will no longer automatically update become diverged from upstream, and GitLab will no longer automatically update
...@@ -72,8 +72,8 @@ repository to push to. Hit **Save changes** for the changes to take effect. ...@@ -72,8 +72,8 @@ repository to push to. Hit **Save changes** for the changes to take effect.
Similarly to the pull mirroring, since the upstream repository functions as a Similarly to the pull mirroring, since the upstream repository functions as a
mirror to the repository in GitLab, you are advised not to push commits directly mirror to the repository in GitLab, you are advised not to push commits directly
to the mirrored repository. Instead, any commits should be pushed to GitLab, to the mirrored repository. Instead, any commits should be pushed to GitLab,
and will end up in the mirrored repository automatically within an hour, or when and will end up in the mirrored repository automatically within the configured time,
a [forced update](#forcing-an-update) is initiated. or when a [forced update](#forcing-an-update) is initiated.
In case of a diverged branch, you will see an error indicated at the In case of a diverged branch, you will see an error indicated at the
**Mirror repository** settings. **Mirror repository** settings.
...@@ -82,7 +82,7 @@ In case of a diverged branch, you will see an error indicated at the ...@@ -82,7 +82,7 @@ In case of a diverged branch, you will see an error indicated at the
## Forcing an update ## Forcing an update
While mirrors update once an hour, you can force an update (either **push** or While mirrors update at a pre-configured time (hourly by default), you can always force an update (either **push** or
**pull**) by using the **Update now** button which is exposed in various places: **pull**) by using the **Update now** button which is exposed in various places:
- in the commits page - in the commits page
...@@ -92,22 +92,24 @@ While mirrors update once an hour, you can force an update (either **push** or ...@@ -92,22 +92,24 @@ While mirrors update once an hour, you can force an update (either **push** or
## Adjusting synchronization times ## Adjusting synchronization times
You can adjust the synchronization times for the repository mirroring if you Your repository's default synchronization time is hourly.
have access to the GitLab server. For more information, see However, you can adjust it by visiting the **Mirror repository** page
[the administration documentation][sync-times]. under the wheel icon in the upper right corner.
Check the Synchronization time section where you can choose to have your mirror
be updated once every fifteen minutes, hourly or daily and then hit **Save changes**
at the bottom.
## Using both mirroring methods at the same time ## Using both mirroring methods at the same time
Currently there is no bidirectional support without conflicts. That means that Currently there is no bidirectional support without conflicts. That means that
if you configure a repository to both pull and push to a second one, there is if you configure a repository to both pull and push to a second one, there is
no guarantee that it will update correctly on both remotes. You could no guarantee that it will update correctly on both remotes. You could
[adjust the synchronization times][sync-times] to a very low value and hope adjust the synchronization times on the mirror settings page
that no conflicts occur during the pull/push window time, but that is not a to a very low value and hope that no conflicts occur during
solution to consider on a production environment. Another thing you could try the pull/push window time, but that is not a solution to consider on a
is [configuring custom Git hooks][hooks] on the GitLab server. production environment. Another thing you could try is [configuring custom Git hooks][hooks] on the GitLab server.
[ee-51]: https://gitlab.com/gitlab-org/gitlab-ee/merge_requests/51 [ee-51]: https://gitlab.com/gitlab-org/gitlab-ee/merge_requests/51
[perms]: ../user/permissions.md [perms]: ../user/permissions.md
[sync-times]: ../administration/cron_jobs.md#adjusting-synchronization-times-for-repository-mirroring
[hooks]: https://docs.gitlab.com/ee/administration/custom_hooks.html [hooks]: https://docs.gitlab.com/ee/administration/custom_hooks.html
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