2020-06-23 00:09:42 +05:30
---
type: reference, howto
stage: Manage
group: Import
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-09-04 01:27:46 +05:30
# Migrate projects to a GitLab instance **(FREE)**
2021-06-08 01:23:25 +05:30
See these documents to migrate to GitLab:
- [From Bitbucket Cloud ](bitbucket.md )
- [From Bitbucket Server (also known as Stash) ](bitbucket_server.md )
- [From ClearCase ](clearcase.md )
- [From CVS ](cvs.md )
- [From FogBugz ](fogbugz.md )
- [From GitHub.com or GitHub Enterprise ](github.md )
- [From GitLab.com ](gitlab_com.md )
- [From Gitea ](gitea.md )
- [From Perforce ](perforce.md )
- [From SVN ](svn.md )
- [From TFVC ](tfvc.md )
- [From repository by URL ](repo_by_url.md )
- [By uploading a manifest file (AOSP) ](manifest.md )
- [From Phabricator ](phabricator.md )
- [From Jira (issues only) ](jira.md )
You can also import any Git repository through HTTP from the **New Project** page. Note that if the
repository is too large, the import can timeout.
You can also [connect your external repository to get CI/CD benefits ](../../../ci/ci_cd_for_external_repos/index.md ). ** (PREMIUM)**
2019-07-31 22:56:46 +05:30
2021-01-29 00:20:46 +05:30
## LFS authentication
When importing a project that contains LFS objects, if the project has an [`.lfsconfig` ](https://github.com/git-lfs/git-lfs/blob/master/docs/man/git-lfs-config.5.ronn )
file with a URL host (`lfs.url`) different from the repository URL host, LFS files are not downloaded.
2021-06-08 01:23:25 +05:30
## Migrate from self-managed GitLab to GitLab.com
2018-03-17 18:26:18 +05:30
2021-06-08 01:23:25 +05:30
If you only need to migrate Git repositories, you can [import each project by URL ](repo_by_url.md ).
However, you can't import issues and merge requests this way. To retain all metadata like issues and
merge requests, use the [import/export feature ](../settings/import_export.md )
to export projects from self-managed GitLab and import those projects into GitLab.com. All GitLab
user associations (such as comment author) are changed to the user importing the project. For more
information, see [the import notes ](../settings/import_export.md#important-notes ).
2019-07-31 22:56:46 +05:30
2021-02-22 17:27:13 +05:30
NOTE:
2021-06-08 01:23:25 +05:30
When migrating to GitLab.com, you must create users manually unless [SCIM ](../../../user/group/saml_sso/scim_setup.md )
will be used. Creating users with the API is limited to self-managed instances as it requires
2021-11-18 22:05:49 +05:30
the Administrator role.
2021-06-08 01:23:25 +05:30
2021-09-30 23:02:18 +05:30
To migrate all data from self-managed to GitLab.com, you can leverage the [API ](../../../api/index.md ).
2021-06-08 01:23:25 +05:30
Migrate the assets in this order:
2019-07-31 22:56:46 +05:30
1. [Groups ](../../../api/groups.md )
1. [Projects ](../../../api/projects.md )
1. [Project variables ](../../../api/project_level_variables.md )
Keep in mind the limitations of the [import/export feature ](../settings/import_export.md#exported-contents ).
2021-06-08 01:23:25 +05:30
You must still migrate your [Container Registry ](../../packages/container_registry/ )
over a series of Docker pulls and pushes. Re-run any CI pipelines to retrieve any build artifacts.
2019-03-02 22:35:43 +05:30
2021-06-08 01:23:25 +05:30
## Migrate from GitLab.com to self-managed GitLab
2020-06-23 00:09:42 +05:30
2021-06-08 01:23:25 +05:30
The process is essentially the same as [migrating from self-managed GitLab to GitLab.com ](#migrate-from-self-managed-gitlab-to-gitlabcom ).
The main difference is that an administrator can create users on the self-managed GitLab instance
through the UI or the [users API ](../../../api/users.md#user-creation ).
2020-06-23 00:09:42 +05:30
2021-06-08 01:23:25 +05:30
## Migrate between two self-managed GitLab instances
2019-03-02 22:35:43 +05:30
2021-06-08 01:23:25 +05:30
To migrate from an existing self-managed GitLab instance to a new self-managed GitLab instance, it's
best to [back up ](../../../raketasks/backup_restore.md )
the existing instance and restore it on the new instance. For example, this is useful when migrating
a self-managed instance from an old server to a new server.
2019-07-31 22:56:46 +05:30
2021-09-30 23:02:18 +05:30
The backups produced don't depend on the operating system running GitLab. You can therefore use
the restore method to switch between different operating system distributions or versions, as long
2021-11-11 11:23:49 +05:30
as the same GitLab version [is available for installation ](../../../administration/package_information/deprecated_os.md ).
2021-09-30 23:02:18 +05:30
2021-06-08 01:23:25 +05:30
To instead merge two self-managed GitLab instances together, use the instructions in
[Migrate from self-managed GitLab to GitLab.com ](#migrate-from-self-managed-gitlab-to-gitlabcom ).
This method is useful when both self-managed instances have existing data that must be preserved.
2020-04-08 14:13:33 +05:30
2021-06-08 01:23:25 +05:30
Also note that administrators can use the [Users API ](../../../api/users.md )
to migrate users.
2021-03-11 19:13:27 +05:30
## Project aliases **(PREMIUM SELF)**
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/3264) in GitLab Premium 12.1.
2021-06-08 01:23:25 +05:30
GitLab repositories are usually accessed with a namespace and a project name. When migrating
frequently accessed repositories to GitLab, however, you can use project aliases to access those
repositories with the original name. Accessing repositories through a project alias reduces the risk
associated with migrating such repositories.
2021-03-11 19:13:27 +05:30
2021-06-08 01:23:25 +05:30
This feature is only available on Git over SSH. Also, only GitLab administrators can create project
aliases, and they can only do so through the API. For more information, see the
[Project Aliases API documentation ](../../../api/project_aliases.md ).
2021-03-11 19:13:27 +05:30
2021-06-08 01:23:25 +05:30
After an administrator creates an alias for a project, you can use the alias to clone the
repository. For example, if an administrator creates the alias `gitlab` for the project
`https://gitlab.com/gitlab-org/gitlab` , you can clone the project with
`git clone git@gitlab.com:gitlab.git` instead of `git clone git@gitlab.com:gitlab-org/gitlab.git` .
2021-12-11 22:18:48 +05:30
## Automate group and project import **(PREMIUM)**
The GitLab Professional Services team uses [Congregate ](https://gitlab.com/gitlab-org/professional-services-automation/tools/migration/congregate )
to orchestrate user, group, and project import API calls. With Congregate, you can migrate data to
GitLab from:
- Other GitLab instances
- GitHub Enterprise
- GitHub.com
- Bitbucket Server
- Bitbucket Data Center
See the [Quick Start Guide ](https://gitlab.com/gitlab-org/professional-services-automation/tools/migration/congregate/-/blob/master/docs/using-congregate.md#quick-start )
to learn how to use this approach for migrating users, groups, and projects at scale.