1. 将repo_a的分支提交到repo_b分支

repo_a:表示原始git库地址;repo_b:表示新增的git库地址。

git remote add new_remote repo_b:new_remote 是repo_b在repo_a中的别名。为本地repo_a新建remote名称,也即另一个repo。

在.git/config中就会新增一个remote:

[remote "new_remote"]
url = http://.../linux.git
fetch = +refs/heads/*:refs/remotes/new_remote/*

git push new_remote master:是将本地的repo_a master分支upload到repo_b master分支。

git push new_remote fpga:master:是将本地的repo_a fpga分支upload到repo_b master分支。

2. 删除远程分支

git push to_origin --delete master:删除to_origin指向的repo的master分支。

git push origin HEAD:origin/update_csky_kernel

将repo_b分支branch_a cherrypick到分支branch_b

3. 修改gitlab.com Default Branch

Setting->Edit Porject->Default Branch下拉列表中选择想要设置的Branch名称。

4. git format-patch和git am

git format-patch commit-id:从commit-id开始(不包括),生成相应的patch。

git am *.patch:将*.patch补丁。

5. tag相关

git tag -a v0.0.0 -m "First demo version."---------新建v0.0.0的tag,并且注释。
git tag--------------------------------------------显示新增的tag。
git push origin --tags-----------------------------将tag上传到服务器。
git show v0.0.0------------------------------------显示tag详情。
git tag -d v0.0.0----------------------------------删除tag。

6. 本地目录提交远程

将本地代码上传到git服务器进行管理,如下:

git init----------------------------------------------------在当前目录创建git仓库。
git add .---------------------------------------------------将所有文件加入到仓库。
git commit--------------------------------------------------增加commit message。
git remote add origin http://.../busybox.git----------------增加remote git服务器。
git push -u origin master-----------------------------------提交commit到远程服务器。

7. 子模块submodule

当项目越来越庞大之后,不可避免需要拆分成多个子模块。

如果希望各个子模块独立版本管理,就需要git submodule功能。

7.1 引入子模块,并提交子模块信息

git submodule add http://../submodule.git submodule_folder---------------其中submodule.git是待引入子模块的git,submodule_folder是当前project下面一个目录。
git status---------------------------------------------------------------可以看出会增加一个.gitmodules文件以及submodule_folder目录,这两个都需要提交。
git diff
git add .----------------------------------------------------------------add两个文件.gitmodule和submodule_folder。
git commit -m "add submodule"
git push origin master---------------------------------------------------提交到远程。

7.2 下载子模块

在clone project的时候,带submodule的时需要附上--recursive。

就可以将submodule一并更新。

git clone --recursive http://.../project.git

如果在clone的时候没有附带--recursive,可以在clone之后如下操作。

在project目录,同样可以更新submodule:

git submodule init
git submodule update

7.3 更新子模块commit id

当需要跟随submodule更新时,只需要更新submodule指向的commit id。

git checkout master-----------------进入submodule目录,切换到master分支。
git pull----------------------------更新到最新的submodule。

然后在上一层目录中git status可以看到,显示对应submodule目录的仅更新了commit id。

然后执行git add pre_dl、git commit、git push即可更新。

参考文档:《Git Submodule管理项目子模块

8. patch -p1 < ../linux-4.9.56.patch

9. git archive只取git中单个文件

git archive --remote=/path/to/repo HEAD:/path/to/file file | tar -x

0. 其他常用

git config --global credential.helper store:永久记住密码。

git config –global credential.helper cache:默认记住15分钟。

git config credential.helper ‘cache –timeout=3600’:下面是自定义配置记住1小时。

												

GIT归纳整理的更多相关文章

  1. Git 初学者使用指南及Git 资源整理

    Git 资源整理 Git is a free and open source distributed version control system designed to handle everyth ...

  2. 归纳整理Linux下C语言常用的库函数----内存及字符串控制及操作

    在没有IDE的时候,记住一些常用的库函数的函数名.参数.基本用法及注意事项是很有必要的. 参照Linux_C_HS.chm的目录,我大致将常用的函数分为一下几类: 1. 内存及字符串控制及操作 2. ...

  3. git相关整理

    title: git相关整理 toc: false date: 2018-09-24 20:42:55 git merge 和 git merge --no--ff有什么区别? git merge命令 ...

  4. 归纳整理Python中的控制流语句的知识点

    归纳整理Python中的控制流语句的知识点 Python 解释器在其最简单的级别,以类似的方式操作,即从程序的顶端开始,然后一行一行地顺序执行程序语句.例如,清单 1 展示了几个简单的语句.当把它们键 ...

  5. 订单退款&重复支付需求疑问点归纳整理

    更新历史记录: 更新内容 更新人 更新时间 新建 Young 2020.12.10  16:45 更新产品疑问解答 Young 2020.12.11  10:14 更新退款权益终止时间 Young 2 ...

  6. Git 常见问题整理

    在学习git的过程中,遇到如下问题,特整理如下: 1 error:src refspec master does not match any 问题产生 a git服务器使用如下命令新建一个项目 $ c ...

  7. 常用git命令整理

    花了一点时间来熟悉和整理git常用命令. 推荐的git学习资料:1.搜“Git Community Book 中文版.pdf”,git社区书,内容全面且简明扼要,第一推荐2.搜“Git权威指南.pdf ...

  8. Git使用整理

    [本文由水木桶首发于博客园,原文地址:https://www.cnblogs.com/shuimutong/p/11404664.html,未接允许,严禁转载] 背景 很久之前使用的是svn,直接在E ...

  9. 常见 git 需求整理(持续更新中)

    首发于 语雀文档 突然感觉自己对 git 还是挺熟悉的,因为团队里新来的七八号应届生来问我 git 问题,基本没有答不上的情况,但为了能更好地对知识进行整理,还是记录一下为好. (希望能)持续更新.. ...

随机推荐

  1. Docker系列07—Dockerfile 详解

    本文收录在容器技术学习系列文章总目录 1.认识Dockerfile 1.1 镜像的生成途径 基于容器制作  dockerfile,docker build 基于容器制作镜像,已经在上篇Docker系列 ...

  2. 只需要4步就可以将asp.net mvc变成SPA(单页面)应用,实现无刷新页面切换!

    SENNA.js Senna.js是一个超快速的单页面应用程序引擎,轻松构建基于Web的现代应用程序,只有大约8KB的JavaScript而没有任何依赖性.还提供非常酷炫的动画效果.想要详细了解的朋友 ...

  3. SpringBoot系列——i18n国际化

    前言 国际化是项目中不可或缺的功能,本文将实现springboot + thymeleaf的HTML页面.js代码.java代码国际化过程记录下来. 代码编写 工程结构 每个文件里面的值(按工程结构循 ...

  4. eclipse创建的maven项目,pom.xml文件报错解决方法

    [错误一:]maven 编译级别过低 [解决办法:] 使用 maven-compiler-plugin 将 maven 编译级别改为 jdk1.6 以上: <!-- java编译插件 --> ...

  5. 解决MySQL报错The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents .....

    1.前言 今天在用SpringBoot2.0+MyBatis+MySQL搭建项目开发环境的时候启动项目发现报了一个很奇怪的错,报错内容如下: java.sql.SQLException: The se ...

  6. 百度图片objURL解密vb.net版

    Function Baidtu_Uncomplie(k As String) As String Dim c = {"_z2C$q", "_z&e3B" ...

  7. 百万级开源MQTT消息服务器 搭建

    下载地址:http://emqtt.com/downloads 文档地址:http://emqtt.com/docs/v2/index.html 开始使用EMQ 2.0 消息服务器简介EMQ (Erl ...

  8. Java开发笔记(二十六)方法的输出参数

    前面介绍了方法的输入参数,与输入参数相对应的则为输出参数,输出参数也被称作方法的返回值,意思是经过方法的处理最终得到的运算数值.这个返回值可能是整型数,也可能是双精度数,也可能是数组等其它类型,甚至允 ...

  9. Go开发之路 -- 流程控制

    1. if else if 条件 { } else { // else必须写在这里 } // 写一个程序, 从终端读取输入, 并转成整数. 如果转成整数出错, // 则输出'can not conve ...

  10. django项目环境搭建

    本文转载自: https://blog.csdn.net/xiaogeldx/article/details/89038299 在码云平台创建项目 版本控制的种类 主要使用github(最主流) 国内 ...