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)
转载至:(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,将不起作用。
解决方法:
- 剪切
.idea
目录到其他地方 - .gitignore 文件中添加 .idea
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操作,需要输入或者跳过这一步:
- 按
i
键,进入插入(insert)模式,可以选择输入/不输入 - 按
Esc
键,结束插入模式 - 按
:wq
,表示保存并结束本次操作 - enter键即可结束本次错误信息
以上是关于Git 如何迁移仓库并保留 commit 记录?的主要内容,如果未能解决你的问题,请参考以下文章
Git远程仓库 复制到另一个远程仓库 并保留commit信息。关于Git代码提交到远程仓库怎么撤回。.gitignore。git pull 时提示为何需要merge操作如何退出
Git远程仓库 复制到另一个远程仓库 并保留commit信息。关于Git代码提交到远程仓库怎么撤回。.gitignore。git pull 时提示为何需要merge操作如何退出
如何把其他代码托管平台git仓库迁移到github还保留历史日志记录?图解步骤,值得收藏!