Как переместить git-репозиторий со всеми ветками из bitbucket в github?


334

Каков наилучший способ переместить git-репозиторий со всеми ветками и полной историей из bitbucket в github? Есть ли сценарий или список команд, которые я должен использовать?


9
Github предоставлять инструменты и документацию для этого: help.github.com/articles/... help.github.com/articles/...
MEMS

Немного опоздал на вечеринку, но вот сценарий для миграции: gist.github.com/chinmaya-n/cff02f1277c811deab2e550f2aad9967
inblueswithu

Ответы:


394

Вы можете обратиться к странице GitHub « Дублирование репозитория »

Оно использует:

Это дало бы:

git clone --mirror https://bitbucket.org/exampleuser/repository-to-mirror.git
# Make a bare mirrored clone of the repository

cd repository-to-mirror.git
git remote set-url --push origin https://github.com/exampleuser/mirrored
# Set the push location to your mirror

git push --mirror

Как отмечено в комментарии s LS :

  • проще использовать Import Codeфункцию из GitHub, описанную MarMass .
    Смотрите https://github.com/new/import
  • Если ... в вашем репо нет большого файла: проблема в том, что инструмент импорта не сможет работать без четкого сообщения об ошибке. Только GitHub Support сможет диагностировать произошедшее.

2
Этот метод создал проблему для меня (не уверен, если это проблема). Когда я отразил репозиторий из bitbucket в github, то для 5 веток в github он показывался как «Запрос сравнения и извлечения». Это не показано как ветви в github. Что я могу с этим поделать?
Сиддхарт

2
А как насчет вопросов и вики?
Владислав Раструсный

@FractalizeR wiki - это просто еще один репозиторий, который вы также можете копировать ( github.com/blog/699-making-github-more-open-git-backed-wikis ). Нет простого способа воспроизвести проблемы. Вам нужно использовать Api (различные программы резервного копирования GitHub делают именно это: addyosmani.com/blog/backing-up-a-github-account )
VonC

3
Это работает, если вы хотите переместить хранилище из Github в Bitbucket.
Симег

1
Мне нужно было использовать этот метод для копирования репо, потому что он содержал большой файл (> 100 МБ). GH не допустит больших файлов в своих репозиториях. Я удалил большой файл, прежде чем отправлять репо в GH. Однако, за исключением других проблем, использование функции импорта репозитория GH является правильным выбором в 95% случаев, как описано в другом ответе . Однако, если это не удается, оно не выдает полезных сообщений об ошибках, и вы должны обратиться в службу поддержки GH. Именно поддержка GH сообщила мне об ограничении размера файла.
LS

412

Это очень просто.

Создайте новый пустой репозиторий в GitHub (без readme или licesne, вы можете добавить их раньше), и на следующем экране появится

Внутри, чтобы импортировать код, вы вставляете репозиторий вашего bitbucket URL и вуаля !!

Нажмите в коде импорта


12
Вы действительно отвечаете на вопрос здесь, так как принятый ответ показывает только общий метод, связанный с Git. Ваш ответ намного проще!
Эмиль Бержерон

6
Этот ответ хорош до тех пор, пока вы создаете хранилище, и он пуст. Если кто-то еще создал хранилище для вас (например, администратор отвечает за создание ветки), то это не сработает. Принятый ответ - путь в таком случае.
Master.Aurora

4
Обращайтесь к любому, кто задумывается об использовании этого метода, удалите двухфакторную аутентификацию на своем предыдущем хосте репозитория, прежде чем использовать эту службу, иначе вы застрянете в бесконечном цикле попыток удалить вновь созданный репозиторий в GitHub, и единственный способ выйти из этого - заменить /importконец URL-адреса на, /settingsчтобы получить доступ к настройкам и удалить его.
Дейв

1
Небольшое предупреждение - если вы столкнетесь с проблемой, вы не получите описательное сообщение об ошибке.
RobertH

Использование функции импорта репозитория GH является правильным выбором в 95% случаев. Однако, если это не удается, оно не выдает полезных сообщений об ошибках, и вы должны обратиться в службу поддержки GH. Я не мог использовать его для одного репо, потому что он содержал большой файл (> 100 МБ). Мне нужно было использовать принятый метод CLI , удаляя большой файл непосредственно перед отправкой репо в GH.
LS

125

Если вы не можете найти кнопку «Импорт кода» на github, вы можете:

  1. откройте Github Importer и введитеurl . Это будет выглядеть так:Снимок экрана: импортер github
  2. дать ему имя (или оно будет импортировано автоматически)
  3. выберите PublicилиPrivate репо
  4. щелчок Begin Import

ОБНОВЛЕНИЕ: Недавно Github объявил о возможности « Импортировать репозитории с большими файлами »


К сожалению, это не сработало из-за моей попытки перейти от codebasehq к git-hub, из-за чего «Этот URL не поддерживается». :(
sjmcdowall

@sjmcdowall К сожалению это не так, но я думаю, что это должно было сработать, поскольку URL codebasehq указывает на репозиторий git.
Бинам

URL больше не существует.
Кодированный контейнер

@CodedContainer Я только что проверил, и это работает. Я даже обновил снимок экрана только сейчас.
biniam

1
URL вернет 404, только если вы не вошли в GitHub. Если вы вошли в систему, загрузится инструмент импорта.
Джейсон Херт

41

http://www.blackdogfoundry.com/blog/moving-repository-from-bitbucket-to-github/

Это помогло мне перейти от одного git-провайдера к другому. В конце все коммиты были в git назначения. Просто и прямо.

git remote rename origin bitbucket
git remote add origin https://github.com/edwardaux/Pipelines.git
git push origin master

Как только я был рад, что загрузка прошла успешно на GitHub, я мог удалить старый пульт, выполнив:

git remote rm bitbucket

2
Пожалуйста, включите соответствующие части ссылки в ваш ответ, так как она должна быть в состоянии стоять самостоятельно.
k0pernikus

Я получаю сообщение об ошибке: «Ошибка: не удалось отправить som-ссылки на« url.gi »подсказка: обновления были отклонены, поскольку удаленный сервер содержит работу, которой у вас нет локально. Обычно это происходит из-за того, что другой репозиторий нажимает на ту же ссылку. Возможно, вы захотите сначала интегрировать удаленные изменения (например, pull ...) перед повторным нажатием. Для получения дополнительной информации см. Примечание о быстрой перемотке в git push --help.
Кодированный контейнер

1
это единственный ответ, который все еще работает в 3/3/2019 :)
Ван-Чжао-Лю QM

13

У меня был обратный вариант использования импорта существующего репозитория из github в bitbucket.

Bitbucket также предлагает инструмент для импорта . Единственный необходимый шаг - добавить URL в репозиторий.

Это выглядит как:

Снимок экрана инструмента импорта битбакета


5

Я понимаю, что это старый вопрос. Я нашел это несколько месяцев назад, когда пытался сделать то же самое, и был не в восторге от полученных ответов. Казалось, что все они имели дело с импортом из Bitbucket в GitHub по одному репозиторию за раз, либо с помощью команд, выданных по меню, либо с помощью импортера GitHub.

Я взял код из проекта GitHub под названием gitter и изменил его в соответствии со своими потребностями.

Вы можете раскошелиться , или взять код отсюда:

#!/usr/bin/env ruby
require 'fileutils'

# Originally  -- Dave Deriso        -- deriso@gmail.com
# Contributor -- G. Richard Bellamy -- rbellamy@terradatum.com
# If you contribute, put your name here!
# To get your team ID:
# 1. Go to your GitHub profile, select 'Personal Access Tokens', and create an Access token
# 2. curl -H "Authorization: token <very-long-access-token>" https://api.github.com/orgs/<org-name>/teams
# 3. Find the team name, and grabulate the Team ID
# 4. PROFIT!

#----------------------------------------------------------------------
#your particulars
@access_token = ''
@team_id = ''
@org = ''


#----------------------------------------------------------------------
#the verison of this app
@version = "0.2"

#----------------------------------------------------------------------
#some global params
@create = false
@add = false
@migrate = false
@debug = false
@done = false
@error = false

#----------------------------------------------------------------------
#fancy schmancy color scheme

class String; def c(cc); "\e[#{cc}m#{self}\e[0m" end end
#200.to_i.times{ |i| print i.to_s.c(i) + " " }; puts
@sep = "-".c(90)*95
@sep_pref = ".".c(90)*95
@sep_thick = "+".c(90)*95

#----------------------------------------------------------------------
# greetings

def hello
  puts @sep
  puts "BitBucket to GitHub migrator -- v.#{@version}".c(95)
  #puts @sep_thick
end

def goodbye
  puts @sep
  puts "done!".c(95)
  puts @sep
  exit
end

def puts_title(text)
   puts  @sep, "#{text}".c(36), @sep
end

#----------------------------------------------------------------------
# helper methods

def get_options
  require 'optparse'

  n_options = 0
  show_options = false

  OptionParser.new do |opts|
    opts.banner = @sep +"\nUsage: gitter [options]\n".c(36)
    opts.version = @version
    opts.on('-n', '--name [name]', String, 'Set the name of the new repo') { |value| @repo_name = value; n_options+=1 }
    opts.on('-c', '--create', String, 'Create new repo') { @create = true; n_options+=1 }
    opts.on('-m', '--migrate', String, 'Migrate the repo') { @migrate = true; n_options+=1 }
    opts.on('-a', '--add', String, 'Add repo to team') { @add = true; n_options+=1 }
    opts.on('-l', '--language [language]', String, 'Set language of the new repo') { |value| @language = value.strip.downcase; n_options+=1 }
    opts.on('-d', '--debug', 'Print commands for inspection, doesn\'t actually run them') { @debug = true; n_options+=1 }
    opts.on_tail('-h', '--help', 'Prints this little guide') { show_options = true; n_options+=1 }
    @opts = opts
  end.parse!

  if show_options || n_options == 0
    puts @opts
    puts "\nExamples:".c(36)
    puts 'create new repo: ' + "\t\tgitter -c -l javascript -n node_app".c(93)
    puts 'migrate existing to GitHub: ' + "\tgitter -m -n node_app".c(93)
    puts 'create repo and migrate to it: ' + "\tgitter -c -m -l javascript -n node_app".c(93)
    puts 'create repo, migrate to it, and add it to a team: ' + "\tgitter -c -m -a -l javascript -n node_app".c(93)
    puts "\nNotes:".c(36)
    puts "Access Token for repo is #{@access_token} - change this on line 13"
    puts "Team ID for repo is #{@team_id} - change this on line 14"
    puts "Organization for repo is #{@org} - change this on line 15"
    puts 'The assumption is that the person running the script has SSH access to BitBucket,'
    puts 'and GitHub, and that if the current directory contains a directory with the same'
    puts 'name as the repo to migrated, it will deleted and recreated, or created if it'
    puts 'doesn\'t exist - the repo to migrate is mirrored locally, and then created on'
    puts 'GitHub and pushed from that local clone.'
    puts 'New repos are private by default'
    puts "Doesn\'t like symbols for language (ex. use \'c\' instead of \'c++\')"
    puts @sep
    exit
  end
end

#----------------------------------------------------------------------
# git helper methods

def gitter_create(repo)
  if @language
    %q[curl https://api.github.com/orgs/] + @org + %q[/repos -H "Authorization: token ] + @access_token + %q[" -d '{"name":"] + repo + %q[","private":true,"language":"] + @language + %q["}']
  else
    %q[curl https://api.github.com/orgs/] + @org + %q[/repos -H "Authorization: token ] + @access_token + %q[" -d '{"name":"] + repo + %q[","private":true}']
  end
end

def gitter_add(repo)
  if @language
    %q[curl https://api.github.com/teams/] + @team_id + %q[/repos/] + @org + %q[/] + repo + %q[ -H "Accept: application/vnd.github.v3+json" -H "Authorization: token ] + @access_token + %q[" -d '{"permission":"pull","language":"] + @language + %q["}']
  else
    %q[curl https://api.github.com/teams/] + @team_id + %q[/repos/] + @org + %q[/] + repo + %q[ -H "Accept: application/vnd.github.v3+json" -H "Authorization: token ] + @access_token + %q[" -d '{"permission":"pull"}']
  end
end

def git_clone_mirror(bitbucket_origin, path)
  "git clone --mirror #{bitbucket_origin}"
end

def git_push_mirror(github_origin, path)
  "(cd './#{path}' && git push --mirror #{github_origin} && cd ..)"
end

def show_pwd
  if @debug
    Dir.getwd()
  end
end

def git_list_origin(path)
  "(cd './#{path}' && git config remote.origin.url && cd ..)"
end

# error checks

def has_repo
  File.exist?('.git')
end

def has_repo_or_error(show_error)
  @repo_exists = has_repo
  if !@repo_exists
    puts 'Error: no .git folder in current directory'.c(91) if show_error
    @error = true
  end
  "has repo: #{@repo_exists}"
end

def has_repo_name_or_error(show_error)
  @repo_name_exists = !(defined?(@repo_name)).nil?
  if !@repo_name_exists
    puts 'Error: repo name missing (-n your_name_here)'.c(91) if show_error
    @error = true
  end
end

#----------------------------------------------------------------------
# main methods
def run(commands)
  if @debug
    commands.each { |x| puts(x) }
  else
    commands.each { |x| system(x) }
  end
end

def set_globals

  puts_title 'Parameters'

  @git_bitbucket_origin =   "git@bitbucket.org:#{@org}/#{@repo_name}.git"
  @git_github_origin = "git@github.com:#{@org}/#{@repo_name}.git"

  puts 'debug: ' + @debug.to_s.c(93)
  puts 'working in: ' + Dir.pwd.c(93)
  puts 'create: ' + @create.to_s.c(93)
  puts 'migrate: ' + @migrate.to_s.c(93)
  puts 'add: ' + @add.to_s.c(93)
  puts 'language: ' + @language.to_s.c(93)
  puts 'repo name: '+ @repo_name.to_s.c(93)
  puts 'bitbucket: ' + @git_bitbucket_origin.to_s.c(93)
  puts 'github: ' + @git_github_origin.to_s.c(93)
  puts 'team_id: ' + @team_id.to_s.c(93)
  puts 'org: ' + @org.to_s.c(93)
end

def create_repo
  puts_title 'Creating'

  #error checks
  has_repo_name_or_error(true)
  goodbye if @error

  puts @sep

  commands = [
      gitter_create(@repo_name)
  ]

  run commands
end


def add_repo
  puts_title 'Adding repo to team'

  #error checks
  has_repo_name_or_error(true)
  goodbye if @error

  puts @sep

  commands = [
      gitter_add(@repo_name)
  ]

  run commands
end

def migrate_repo

  puts_title "Migrating Repo to #{@repo_provider}"

  #error checks
  has_repo_name_or_error(true)
  goodbye if @error

  if Dir.exists?("#{@repo_name}.git")
    puts "#{@repo_name} already exists... recursively deleting."
    FileUtils.rm_r("#{@repo_name}.git")
  end

  path = "#{@repo_name}.git"
  commands = [
    git_clone_mirror(@git_bitbucket_origin, path),
    git_list_origin(path),
    git_push_mirror(@git_github_origin, path)
  ]

  run commands
end

#----------------------------------------------------------------------
#sequence control
hello
get_options

#do stuff
set_globals
create_repo if @create
migrate_repo if @migrate
add_repo if @add

#peace out
goodbye

Затем, чтобы использовать скрипт:

# create a list of repos
foo
bar
baz

# execute the script, iterating over your list
while read p; do ./bitbucket-to-github.rb -a -n $p; done<repos

# good nuff

5

Есть Импорт репозитория с GitHub Importer

Если у вас есть проект, размещенный в другой системе управления версиями, например Mercurial, вы можете автоматически импортировать его в GitHub с помощью инструмента GitHub Importer.

  1. В правом верхнем углу любой страницы нажмите, а затем нажмите Импорт репозитория.
  2. В поле «URL-адрес вашего старого репозитория» введите URL-адрес проекта, который вы хотите импортировать.
  3. Выберите свою учетную запись пользователя или организацию, которой принадлежит хранилище, затем введите имя хранилища на GitHub.
  4. Укажите, должен ли новый репозиторий быть публичным или закрытым.
    • Публичные репозитории видны любому пользователю GitHub, поэтому вы можете воспользоваться преимуществами сообщества GitHub.
    • Переключатели общедоступных или частных репозиториевЧастные репозитории доступны только владельцу репозитория, а также любым соавторам, с которыми вы хотите поделиться.
  5. Просмотрите введенную информацию и нажмите «Начать импорт».

Вы получите электронное письмо, когда репозиторий будет полностью импортирован.

  1. https://help.github.com/categories/importing-your-projects-to-github
  2. https://help.github.com/articles/importing-a-repository-with-github-importer/

2

Если вы хотите переместить свой локальный репозиторий git в другой апстрим, вы также можете сделать это:

чтобы получить текущий удаленный URL:

git remote get-url origin

покажет что-то вроде: https://bitbucket.com/git/myrepo

установить новый удаленный репозиторий:

Git Remote Set-URL происхождения Git@github.com: папка / myrepo.git

Теперь нажмите на содержимое текущей (развернутой) ветки:

git push - set-upstream origin разработать

Теперь у вас есть полная копия ветки в новом пульте.

по желанию вернитесь к исходному git-remote для этой локальной папки:

Git Remote Set-URL происхождения https://bitbucket.com/git/myrepo

Теперь вы можете получить новый git-репозиторий из github в другой папке, так что у вас есть две локальные папки, указывающие на разные пульты: предыдущая (bitbucket) и новая.


2

Я сделал следующий скрипт bash, чтобы клонировать ВСЕ мои репозитории Bitbucket (пользователя) в GitHub в качестве частных репозиториев.


Требования:

  • JQ (процессор JSON командной строки) | MacOS:brew install jq

шаги:

  1. Перейдите на https://github.com/settings/tokens и создайте токен доступа. Нам нужен только объем "репо".

  2. Сохраните move_me.shскрипт в рабочей папке и отредактируйте файл по мере необходимости.

  3. Не забудь CHMOD 755

  4. Бегать! ./move_me.sh

  5. Наслаждайтесь временем, которое вы сэкономили.


Ноты:

  • Он будет клонировать репозитории BitBucket внутри каталога, в котором находится скрипт (ваш рабочий каталог).

  • Этот скрипт не удаляет ваши репозитории BitBucket.


Нужно перейти в публичные репозитории на GitHub?

Найти и изменить , "private": trueчтобы "private": falseниже.

Перемещение хранилищ организации?

Изучите руководство разработчика , это несколько изменений.


Счастливого переезда.

#!/bin/bash

BB_USERNAME=your_bitbucket_username 
BB_PASSWORD=your_bitbucket_password

GH_USERNAME=your_github_username
GH_ACCESS_TOKEN=your_github_access_token

###########################

pagelen=$(curl -s -u $BB_USERNAME:$BB_PASSWORD https://api.bitbucket.org/2.0/repositories/$BB_USERNAME | jq -r '.pagelen')

echo "Total number of pages: $pagelen"

hr () {
  printf '%*s\n' "${COLUMNS:-$(tput cols)}" '' | tr ' ' -  
}

i=1

while [ $i -le $pagelen ]
do
  echo
  echo "* Processing Page: $i..."
  hr  
  pageval=$(curl -s -u $BB_USERNAME:$BB_PASSWORD https://api.bitbucket.org/2.0/repositories/$BB_USERNAME?page=$i)
  
  next=$(echo $pageval | jq -r '.next')
  slugs=($(echo $pageval | jq -r '.values[] | .slug'))
  repos=($(echo $pageval | jq -r '.values[] | .links.clone[1].href'))
  
  j=0
  for repo in ${repos[@]}
  do
    echo "$(($j + 1)) = ${repos[$j]}"
    slug=${slugs[$j]}
  git clone --bare $repo 
  cd "$slug.git"
  echo
  echo "* $repo cloned, now creating $slug on github..."  
  echo  

  read -r -d '' PAYLOAD <<EOP
  {
    "name": "$slug",
    "description": "$slug - moved from bitbucket",
    "homepage": "https://github.com/$slug",
    "private": true
  }
  EOP

  curl -H "Authorization: token $GH_ACCESS_TOKEN" --data "$PAYLOAD" \
      https://api.github.com/user/repos
  echo
  echo "* mirroring $repo to github..."  
  echo
  git push --mirror "git@github.com:$GH_USERNAME/$slug.git"
  j=$(( $j + 1 ))
  hr    
  cd ..
  done  
  i=$(( $i + 1 ))
done

1
Интересный сценарий в сочетании с токеном. Ухоженная. Upvoted.
VonC

@VonC Спасибо!
сент

1

Вот шаги для перемещения частного репозитория Git:

Шаг 1: Создать репозиторий Github

Сначала создайте новый частный репозиторий на Github.com. Важно сохранять хранилище пустым, например, не проверять опцию. При создании хранилища инициализируйте этот репозиторий с помощью README.

Шаг 2. Переместите существующий контент

Далее нам нужно заполнить репозиторий Github содержимым нашего репозитория Bitbucket:

  1. Проверьте существующий репозиторий из Bitbucket:
    $ git clone https://USER@bitbucket.org/USER/PROJECT.git
  1. Добавьте новый репозиторий Github как удаленный по потоку поток от репозитория, извлеченного из Bitbucket:
    $ cd PROJECT
    $ git remote add upstream https://github.com:USER/PROJECT.git
  1. Вставьте все ветви (ниже: просто master) и теги в репозиторий Github:
    $ git push upstream master
    $ git push --tags upstream

Шаг 3: Очистить старый репозиторий

Наконец, нам нужно убедиться, что разработчики не запутаются, имея два репозитория для одного проекта. Вот как удалить хранилище Bitbucket:

  1. Дважды проверьте, что репозиторий Github имеет все содержимое

  2. Перейти к веб-интерфейсу старого хранилища Bitbucket

  3. Выберите пункт меню Настройка> Удалить репозиторий

  4. Добавьте URL нового репозитория Github в качестве URL перенаправления

После этого хранилище полностью обосновалось в своем новом доме в Гитхубе. Пусть все разработчики знают!


-1

Самый простой способ сделать это:

git remote rename origin repo_bitbucket

git remote add origin https://github.com/abc/repo.git

git push origin master

После успешного перехода на GitHub удалите старый пульт, выполнив:

git remote rm repo_bitbucket
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.