gitlab-org--gitlab-foss/doc/user/project/import/index.md

3 KiB

Migrating projects to a GitLab instance

  1. From Bitbucket Cloud
  2. From Bitbucket Server (also known as Stash)
  3. From ClearCase
  4. From CVS
  5. From FogBugz
  6. From GitHub.com or GitHub Enterprise
  7. From GitLab.com
  8. From Gitea
  9. From Perforce
  10. From SVN
  11. From TFVC
  12. From repo by URL
  13. By uploading a manifest file (AOSP)
  14. From Gemnasium
  15. From Phabricator

In addition to the specific migration documentation above, you can import any Git repository via HTTP from the New Project page. Be aware that if the repository is too large the import can timeout.

There is also the option of connecting your external repository to get CI/CD benefits. (PREMIUM)

Migrating from self-managed GitLab to GitLab.com

If you only need to migrate Git repos, you can import each project by URL. Issues and merge requests can't be imported.

If you want to retain all metadata like issues and merge requests, you can use the import/export feature to export projects from self-managed GitLab and import those projects into GitLab.com.

All GitLab user associations (such as comment author) will be changed to the user importing the project. For more information, please see the import notes.

If you need to migrate all data over, you can leverage our API to migrate from self-managed to GitLab.com. The order of assets to migrate from a self-managed instance to GitLab.com is the following:

NOTE: Note: When migrating to GitLab.com, users would need to be manually created unless SCIM is going to be used. Creating users with the API is limited to self-managed instances as it requires administrator access.

  1. Groups
  2. Projects
  3. Project variables

Keep in mind the limitations of the import/export feature.

You will still need to migrate your Container Registry over a series of Docker pulls and pushes and re-run any CI pipelines to retrieve any build artifacts.

Migrating between two self-managed GitLab instances

The best method for migrating from one GitLab instance to another, perhaps from an old server to a new server for example, is to back up the instance, then restore it on the new server.

In the event of merging two GitLab instances together (for example, both instances have existing data on them and one can't be wiped), refer to the instructions in Migrating from self-managed GitLab to GitLab.com.

Additionally, you can migrate users using the Users API with an admin user.