git代码仓库迁移(从github到oschina)【转】

简介:

转自:http://blog.csdn.net/a5244491/article/details/44807937

因为一些特殊原因,需要将公司原来的代码仓库从github移植到oschina上去,项目手工操作很麻烦。自己整理了一下,写了简单的几个脚本来处理了。

在这之前,必须先手动在新的Git仓库上把项目先建立好,否则是不会成功的。(也许有命令行方式,还请告知,我不会)

1 先建立个空的目录,用来down工程以及处理工程

$ mkdir migrate

2 cd migrate  #进入目录

3 执行自己写的迁移工具

$   gitmigrate git@git.oschina.NET:a5244491/xxxx

若有多个工程可把所有工程的ssh git地址都写到文件中,然后一次性处理。

以下是gitmigrate.sh的代码,使用方法就是gitmigrate $原git仓库上某个项目的ssh地址

#!/usr/bin/env bash
1temp=1是源地址temp=1
name=${temp##*/}  #截取 core-lib.git
#tar="git@git.oschina.net:a5244491/"$name
tar="https://git.oschina.Net/a5244491/"name #tar="git@code.csdn.net:lianyin2013/"name #tar="git@code.csdn.net:lianyin2013/"name
name={name%.*}  #截取 core-lib echo "-------------------------git migrate -------------------------" echo "-----from"{name%.*}  #截取 core-lib echo "-------------------------git migrate -------------------------" echo "-----from"
echo "-----to  " tarecho"gitclone"echo"from"tarecho"−−−−−−−−−−−−−−−−−−−−−−−−−gitclone−−−−−−−−−−−−−−−−−−−−−−−−−"echo"−−−−−from"1
git clone 1echo"finishclone"echo"changedir"echo"to"1echo"−−−−−−−−−−−−−−−−−−−−−−−−−finishclone−−−−−−−−−−−−−−−−−−−−−−−−−"echo"−−−−−−−−−−−−−−−−−−−−−−−−−changedir−−−−−−−−−−−−−−−−−−−−−−−−−"echo"−−−−−to"name
cd namegitbranchtrackecho"finishbranchtrack"echo"listbranchtrack"gitbranchecho"changetonewrepo"echo""namegitbranchtrackecho"−−−−−−−−−−−−−−−−−−−−−−−−−finishbranchtrack−−−−−−−−−−−−−−−−−−−−−−−−−"echo"−−−−−−−−−−−−−−−−−−−−−−−−−listbranchtrack−−−−−−−−−−−−−−−−−−−−−−−−−"gitbranchecho"−−−−−−−−−−−−−−−−−−−−−−−−−changetonewrepo−−−−−−−−−−−−−−−−−−−−−−−−−"echo"−−−−−−"tar
git remote set-url origin $tar
echo "-------------------------git fetch all-------------------------"
#git fetch --all
echo "-------------------------tal all-------------------------"
git add .
git commit -m "migrate commit."
echo "-------------------------git push all branchs -------------------------"
git push --all
echo "-------------------------finish git push all branch -------------------------"

git remote -v

 

其中gitbranchtrack

代码如下

#!/usr/bin/env bash

echo "track all branchs exculde master and HEAD"
#!/bin/bash
for branch in `git branch -a | grep remotes | grep -v HEAD | grep -v master`; do
    git branch --track {branch##*/}{branch##*/}branch
done
git fetch --all
git pull --all







本文转自张昺华-sky博客园博客,原文链接:http://www.cnblogs.com/sky-heaven/p/7047726.html,如需转载请自行联系原作者


相关文章
|
2月前
|
开发工具 git Python
代码管理记录(二):Github代码上传实操
本文是关于如何使用Git将本地代码上传到GitHub的实操指南。介绍了Git的基本概念、安装方法,并通过详细的步骤指导用户从GitHub创建仓库到使用Git命令初始化、添加、提交代码,最终将代码推送到远程仓库。同时,还汇总了一些常见的错误及其解决方法。
38 2
代码管理记录(二):Github代码上传实操
|
1月前
|
网络安全 开发工具 git
解决fatal:remote error:You can’t push to git://github.com/username/*.g
通过上述诊断与修复步骤,绝大多数的推送错误都能得到有效解决,确保您的Git工作流顺畅无阻。
35 1
|
2月前
|
Unix Shell 网络安全
git学习六:(bug总结)git@github.com: Permission denied (publickey).等
本文是关于解决在使用Git和GitHub时遇到的“git@github.com: Permission denied (publickey)”错误的指南。文章提供了详细的步骤,包括确认SSH Agent运行状态、检查密钥配置、确保密钥匹配、验证仓库URL、检查权限和代理设置,以及配置SSH文件。这些步骤帮助用户诊断并解决SSH认证问题。
133 0
|
3月前
|
开发工具 git 开发者
掌握版本控制的艺术:Git 与 GitHub 的高效使用指南
在软件开发中,版本控制对于代码管理和团队协作至关重要。本文详细介绍了 Git 的核心概念与命令,包括初始化、创建仓库、文件跟踪、分支管理和远程仓库操作。同时,探讨了如何利用 GitHub 进行项目组织、代码审查及自动化工作流。通过遵循最佳实践,如频繁提交、清晰的信息记录和合理使用分支,开发者可以提升工作效率和团队协作能力,确保项目的持续成功。
|
3月前
|
Shell 网络安全 开发工具
Git,GitHub,Gitee&IDEA集成Git
Git提交项目到GitHub简洁版、版本控制、安装、常用命令、分支、团队协作机制、Github、Gitee远程仓库、IDEA集成Git、IDEA集成Github、IDEA集成Gitee
Git,GitHub,Gitee&IDEA集成Git
|
3月前
|
Shell 网络安全 开发工具
fatal: unable to access 'https://github.com/wolfcw/libfaketime.git/': Encountered end of file
fatal: unable to access 'https://github.com/wolfcw/libfaketime.git/': Encountered end of file
|
前端开发 开发工具 git
一个 git 仓库下拥有多个项目的 git hooks 配置方案
一个 git 仓库下拥有多个项目的 git hooks 配置方案
211 0
|
存储 网络安全 开发工具
百度搜索:蓝易云【Git多账号多仓库配置SSH?】
通过按照以上步骤配置SSH,您将能够在Git中使用多个账号和多个仓库,同时保持它们之间的独立性。请确保在配置和使用时注意使用正确的账号和仓库。
55 0
|
Linux Shell 网络安全
|
网络安全 开发工具 数据安全/隐私保护
版本管理·玩转git(远程仓库配置和配置公钥免密登录)
版本管理·玩转git(远程仓库配置和配置公钥免密登录)
201 0
版本管理·玩转git(远程仓库配置和配置公钥免密登录)