すべてのブランチを持つgitリポジトリをbitbucketからgithubに移動するにはどうすればよいですか?


334

すべてのブランチと完全な履歴を含むgitリポジトリをbitbucketからgithubに移動する最良の方法は何ですか?使用する必要があるスクリプトまたはコマンドのリストはありますか?


9
:githubのは、ツールやドキュメントそのために提供help.github.com/articles/...の help.github.com/articles/...
MEMS

パーティーには少し遅れますが、移行のスクリプトは次のとおり
inblueswithu

回答:


393

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


2
この方法は私に問題を引き起こしました(それが問題かどうかはわかりません)。リポジトリをbitbucketからgithubにミラーリングすると、5つのブランチでgithubに「Compare and Pull Request」として表示されます。githubではブランチとして表示されません。それについて私は何ができますか?
Siddharth、2014

2
そして、問題とウィキはどうですか?
Vladislav Rastrusny 2014年

@FractalizeR wikiは、レプリケートできるもう1つのリポジトリです(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にも移動する場合にも機能します。
simeg

1
大きなファイル(> 100MB)が含まれているため、この方法を使用してリポジトリをコピーする必要がありました。GHはリポジトリに大きなファイルを許可しません。リポジトリをGHにプッシュする前に、大きなファイルを削除しました。ただし、別の回答で説明されているように、GHの「リポジトリのインポート」機能を使用することは、95%確率で正しい選択です。ただし、失敗した場合、有用なエラーメッセージは表示されないため、GHサポートに連絡する必要があります。ファイルサイズの制限を通知したのはGHサポートでした。
LS

411

とても簡単です。

1ºを GitHubの中に新しい空のリポジトリ(READMEやlicesneせずに、あなたが前にそれらを追加することができます)と、以下の画面が表示されます作成します。

内部でコードオプションをインポートするには、bitbucket URLのリポジトリを貼り付けてください。

インポートコードをクリック


12
受け入れられた回答は一般的なGit関連のメソッドのみを示しているため、ここで実際に質問に回答しています。あなたの答えはもっと簡単です!
Emile Bergeron、2015年

6
この答えは、あなたがリポジトリを作成している人であり、それが裸である限り、適切です。他の誰かがあなたのためにリポジトリを作成した場合(ブランチの作成を担当する管理者など)、これは機能しません。受け入れられた答えはそのような場合に行く方法です。
Master.Aurora 2015

4
この方法の使用を検討している他の人に向けて、このサービスを使用する前に以前のリポジトリホストで2要素認証を削除してください。そうしないと、GitHubで新しく作成されたリポジトリを削除しようとする無限ループに陥ってしまいます。これを回避する唯一の方法/importは、URLの末尾のをに置き換えて/settings、設定にアクセスして削除することです。
Dave

1
小さな警告-問題が発生した場合、説明的なエラーメッセージは表示されません。
RobertH 2016

GHの「リポジトリのインポート」機能を使用することは、95%確率で正しい選択です。ただし、失敗した場合、有用なエラーメッセージは表示されないため、GHサポートに連絡する必要があります。大きなファイル(> 100MB)が含まれているため、1つのリポジトリに使用できませんでした。受け入れられたCLIメソッドを使用して、リポジトリをGHにプッシュする直前に大きなファイルを削除する必要がありました 。
LS

125

githubに「コードのインポート」ボタンが見つからなかった場合、次のことができます。

  1. Github Importerを直接開き、を入力しurlます。次のようになります。githubインポーターのスクリーンショット
  2. 名前を付けます(または名前を自動的にインポートします)
  3. 選択PublicまたはPrivateリポジトリ
  4. クリック Begin Import

UPDATE: 最近、Githubには「への能力発表し、大きなファイルでのインポートリポジトリを


残念ながら、これはcodebasehqからgit-hubへの移行の試みでは機能せず、「このURLはサポートされていません」と表示されました。:(
sjmcdowall 2015

@sjmcdowall申し訳ありませんでしたが、codebasehqのURLがgitリポジトリを指しているため、問題なく動作するはずです。
ビニアム2015

URLは存在しません。
コード化されたコンテナ

@CodedContainer私がチェックしたところ、うまくいきました。今すぐスクリーンショットも更新しました。
ビニアム2016年

1
GitHubにログインしていない場合、URLは404のみを返します。ログインしている場合は、インポートツールが読み込まれます。
ジェイソンハート2016年

41

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

これにより、あるgitプロバイダーから別の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 'ヒントにプッシュできませんでしたヒント:リモートにローカルにない作業が含まれているため、更新が拒否されました。これは通常、別のリポジトリが同じ参照をプッシュしていることが原因です。あなたは再びプッシュする前に(例えばプル...)最初にリモートの変更を統合することもできます詳細については、Gitのプッシュ--helpで早送りについての注意を参照してください。。
符号化コンテナ

1
これはまだ:) 2019年3月3日に働いている唯一の答えである
王、趙-劉QM

13

既存のリポジトリをgithubからbitbucketにインポートするという逆の使用例がありました。

Bitbucketにはインポートツールも用意されています。必要な唯一の手順は、リポジトリにURLを追加することです。

それは次のようになります:

bitbucketインポートツールのスクリーンショット


5

これは古い質問だと思います。数か月前に同じことをやろうとしたときに気づき、与えられた答えに圧倒されました。これらはすべて、アラカルトコマンドまたはGitHubインポーターを介して、一度に1つのリポジトリをBitbucketからGitHubにインポートすることを扱っているようです。

私はと呼ばれるGitHubのプロジェクトからコードをgrabulated ギッター、私のニーズに合った、それを修正しました。

あなたは要点をフォークするか、ここからコードを取ることができます:

#!/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 Importerツールを使用してGitHubに自動的にインポートできます。

  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 origin git@github.com:folder / myrepo.git

現在の(開発)ブランチの内容をプッシュします。

git push --set-upstream origin開発

これで、新しいリモートにブランチの完全なコピーができました。

オプションで、このローカルフォルダーの元のgit-remoteに戻ります。

git remote set-url origin https://bitbucket.com/git/myrepo

githubの別のフォルダーに新しいgit-repositoryを取得できるという利点があります。2つのローカルフォルダーが両方とも異なるリモートを指しているため、以前の(ビットバケット)と新しいものの両方を使用できます。


2

すべてのBitbucket(ユーザー)リポジトリをプライベートリポジトリとしてGitHub に複製するために、次のbashスクリプトを作成しました。


要件:

  • jq(コマンドラインJSONプロセッサ)| マックOS:brew install jq

手順:

  1. 移動しhttps://github.com/settings/tokensとアクセストークンを作成します。「repo」スコープのみが必要です。

  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
トークンと組み合わせた興味深いスクリプト。きちんと。賛成。
VonC、

@VonCありがとうございます!
1912

1

プライベートGitリポジトリを移動する手順は次のとおりです。

ステップ1:Githubリポジトリを作成する

まず、Github.comに新しいプライベートリポジトリを作成します。リポジトリを空にしておくことが重要です。たとえば、リポジトリを作成するときに[READMEでこのリポジトリを初期化]オプションをチェックしないでください。

ステップ2:既存のコンテンツを移動する

次に、GithubリポジトリにBitbucketリポジトリのコンテンツを入力する必要があります。

  1. Bitbucketから既存のリポジトリを確認します
    $ git clone https://USER@bitbucket.org/USER/PROJECT.git
  1. Bitbucketからチェックアウトされたリポジトリの上流リモートとして、新しいGithubリポジトリを追加します。
    $ cd PROJECT
    $ git remote add upstream https://github.com:USER/PROJECT.git
  1. すべてのブランチ(以下:マスターのみ)とタグをGithubリポジトリにプッシュします。
    $ git push upstream master
    $ git push --tags upstream

ステップ3:古いリポジトリをクリーンアップする

最後に、同じプロジェクトに2つのリポジトリがあることで開発者が混乱しないようにする必要があります。Bitbucketリポジトリを削除する方法は次のとおりです。

  1. Githubリポジトリにすべてのコンテンツがあることを再確認します

  2. 古いBitbucketリポジトリのウェブインターフェースに移動します

  3. メニューオプションの「設定」>「リポジトリを削除」を選択します

  4. 新しいGithubリポジトリのURLをリダイレクトURLとして追加します

これにより、リポジトリはGithubの新しい家に完全に定着しました。すべての開発者に知らせてください!


-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
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.