Git 如何迁移仓库并保留 commit 记录?

Posted dongfangzhaoyue

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Git 如何迁移仓库并保留 commit 记录?相关的知识,希望对你有一定的参考价值。

Git 如何迁移仓库并保留 commit 记录

一、作用

把在 A 托管平台的仓库完全的迁移到 B 托管平台,保留 commit 历史记录。

二、场景

将 Gitlab 上的仓库迁移到 GitHub
将 Coding 上的仓库迁移到 GitHub
将 Gitee 上的仓库迁移到 GitHub
……
迁移前后,保留 commit 历史记录,即在迁移后的新仓库中能查询历史提交信息,同时也能保留小绿点。

三、步骤

建立新仓库
克隆旧仓库
推送新仓库
下面,以 Coding 迁移到 GitHub 为例。

A. Git Bash操作

1. 在 GitHub 建立新仓库

在 GitHub 中新建一个同名项目(不同名也可以),不要添加 README.md,以及任何 License 和 .gitignore 文件,只需要新建一个空的仓库。

2. 克隆 Coding 上的项目

将 Coding 上想要迁移的项目完整克隆到本地。
本地执行 bash

git clone https://git.coding.net/wenyuan/blog.git  --bare

3. 将克隆下来的仓库推送到GitHub

克隆完成后,将仓库推送到 GitHub。
使用新仓库页面提供的仓库地址(web URL),推送所有的分支和对象
bash

cd blog.git
git push https://github.com/wenyuan/blog.git --all

4. 完成后,再执行推送所有的Tags

bash

git push https://github.com/wenyuan/blog.git --tags

这样,整个仓库就全部迁移到 GitHub 了,如果这些commit中的邮箱在GitHub配置中,可以看到小绿点也一起迁移过来了。

B. TortoiseGit 操作

这种简单的操作我不是很喜欢用可视化工具,不过这里也介绍下怎么用「小乌龟」来完成仓库的迁移。

1. 在 GitHub 建立新仓库

同上,不赘述了。

2. 克隆 Coding 上的项目

同上,不赘述了。

3. 将克隆下来的仓库推送到 GitHub

进入项目文件夹,鼠标右键 -> Git Sync…

 

点击 Manage。

 

填写 GitHub 远程仓库的信息,并 Add New/Save,应用,确认。
Remote URL 选则刚刚添加的 gitHub,然后 Push。

 

最后再提交 Tags.

四、git命令区别

上面在推送代码至 GitHub(新仓库)时,我们用到了下面这个命令:
git push https://github.com/wenyuan/blog.git --all

其实还有另外一个命令:
git push https://github.com/wenyuan/blog.git --mirror

五 参考(reference)

1.Git 如何迁移仓库并保留 commit 记录

转载至:(57条消息) Git 如何迁移仓库并保留 commit 记录_git迁移仓库保持记录_静思心远的博客-CSDN博客

Git远程仓库 复制到另一个远程仓库 并保留commit信息。关于Git代码提交到远程仓库怎么撤回。.gitignore。git pull 时提示为何需要merge操作如何退出

一、Git远程仓库 复制到另一个远程仓库 并保留commit信息

1、下载原远程仓库到本地: git clone 。不要下载zip ,这种方式下载不了 .git 文件。
2、新建一个新远程仓库。
3、修改本地仓库关联的远程仓库:文件.git/config里修改 url = 后的链接为 新远程仓库的地址。
3、git push origin master,提交本地仓库到新远程仓库。

二、关于Git代码提交到远程仓库怎么撤回

在实际开发过程中经常会遇到代码提交的误操作问题,即不小心将代码提交到远程仓库发现提交错误,想将提交记录删除,回到上一版本,具体步骤如下:

1.首先git log查看当前提交历史。
运行git log启动一个交互式会话,允许您滚动输出。例如,您可以按空格键移至下一页,并使用向上和向下箭头浏览日志。要退出,请按q

2.使用指令git reset --hard <撤销到的版本的commit-id>回到那个版本

3.使用指令git push -f 强制提交

4.ok,此时之前自己的提交误操作将从远程仓库撤销。

三、.gitignore

1、项目里新建一个文件,名字是.gitignore。写入如下内容:

.idea
*.iml
target

创建.gitignore文件的 原因:为了不提交.idea、target文件夹。因为组队做项目时,不同人的项目的.idea文件夹里的文件的内容不一样,提交了这个文件夹,会显示修改了很多.idea文件夹里的东西,这些东西都不重要不需要


如果此前没有 .gitignore 文件,而.idea 目录或者文件已经被 git 跟踪,此时再加入 .gitignore 就无法屏蔽了。
git 设置本地忽略必须保证 git 的远程仓库分支上没有这个要忽略的文件。如果远程分支上存在这个文件,本地再设置 ignore,将不起作用。
解决方法:

  1. 剪切 .idea 目录到其他地方
  2. .gitignore 文件中添加 .idea
  3. git push到远程仓库后,再把.idea目录剪切回来。

四、git pull 时提示 Please enter a commit message to explain why this merge is necessary.如何退出

完整内容如下:

Merge branch 'master' of gitee.com:snow_night/nowcoder-community
# Please enter a commit message to explain why this merge is necessary,
# especially if it merges an updated upstream into a topic branch.
#
# Lines starting with '#' will be ignored, and an empty message aborts
# the commit.

提示输入为何需要merge操作,需要输入或者跳过这一步:

  1. i键,进入插入(insert)模式,可以选择输入/不输入
  2. Esc键,结束插入模式
  3. :wq,表示保存并结束本次操作
  4. enter键即可结束本次错误信息

以上是关于Git 如何迁移仓库并保留 commit 记录?的主要内容,如果未能解决你的问题,请参考以下文章

Git远程仓库 复制到另一个远程仓库 并保留commit信息。关于Git代码提交到远程仓库怎么撤回。.gitignore。git pull 时提示为何需要merge操作如何退出

Git远程仓库 复制到另一个远程仓库 并保留commit信息。关于Git代码提交到远程仓库怎么撤回。.gitignore。git pull 时提示为何需要merge操作如何退出

Git仓库完整迁移

如何把其他代码托管平台git仓库迁移到github还保留历史日志记录?图解步骤,值得收藏!

如何把其他代码托管平台git仓库迁移到github还保留历史日志记录?图解步骤,值得收藏!

只需3步完成,git迁移仓库地址,保留分支和历史记录