Git 123

CSDN 直接回车段间距。shift + Enter 段间距

常用指令

回退代码

git reset HEAD^
git reset --hard + commitId

git 修改commitMessage 邮箱

修改第二笔 message信息
git rebase -i HEAD~2

pick 改为edit
git commit --amend
git commit --amend --author "sunlei_2 <sunlei@ktc.cn>"
git rebase --continue

修改第1笔 message信息
git log
git rebase -i HEAD~1
pick 改为edit
git commit --amend --author "sunlei_2 <sunlei@ktc.cn>"
git rebase --continue

git push

一般形式:
git push <远程主机名> <本地分支名>  <远程分支名>
例如 git push origin master:refs/for/master ,即是将本地的master分支推送到远程主机origin上的对应master分支, origin 是远程主机名,第一个master是本地分支名,第二个master是远程分支名
git push origin master
如果远程分支被省略,如上则表示将本地分支推送到与之存在追踪关系的远程分支(通常两者同名),如果该远程分支不存在,则会被新建
git push origin :refs/for/master
如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支,等同于 git push origin --delete master 
git push origin

如果当前分支与远程分支存在追踪关系,则本地分支和远程分支都可以省略,将当前分支推送到origin主机的对应分支
git push
如果当前分支只有一个远程分支,那么主机名都可以省略,形如 git push,可以使用git branch -r ,查看远程的分支名
git push 的其他命令
扩展的用法
(1) git push -u origin master 如果当前分支与多个主机存在追踪关系,则可以使用 -u 参数指定一个默认主机,这样后面就可以不加任何参数使用git push,
不带任何参数的git push,默认只推送当前分支,这叫做simple方式,还有一种matching方式,会推送所有有对应的远程分支的本地分支, Git 2.0之前默认使用matching,现在改为simple方式如果想更改设置,可以使用git config命令。git config --global push.default matching OR git config --global push.default simple;可以使用git config -l 查看配置
(2) git push --all origin 当遇到这种情况就是不管是否存在对应的远程分支,将本地的所有分支都推送到远程主机,这时需要 -all 选项
(3) git push --force origin git push的时候需要本地先git pull更新到跟服务器版本一致,如果本地版本库比远程服务器上的低,那么一般会提示你git pull更新,如果一定要提交,那么可以使用这个命令。
(4) git push origin --tags //git push 的时候不会推送分支,如果一定要推送标签的话那么可以使用这个命令

refs/for

 refs/for 的意义在于我们提交代码到服务器之后是需要经过code review 之后才能进行merge的,

refs/heads 不需要

git push origin HEAD:refs/for/master

     1.git push <remote 名字> <本地分支的名字> : <远程库的名字>

     git push 肯定是推送
     origin : 是远程的库的名字
    HEAD: 是一个特别的指针,它是一个指向你正在工作的本地分支的指针,可以把它当做本地分支的别名,git这样就可以知道你工作在哪个分支
    refs/for :意义在于我们提交代码到服务器之后是需要经过code review 之后才能进行merge的
    refs/heads 不需要

    通过git status命令可以查看当前工作区和暂存区文件的状态。

git 打补丁

git format-patch -n 最近N次提交patch 分别生成patch

git format-patch -1 commitid 是提取单个commitid对应的patch 
git  am  xxx.patch
强制合并不冲突的文件 
git apply --reject patch


git log 相关指令
git log --oneline commitMessage 只显示在同一行
git log --name-only -p -10 获得近十次修改的文件

git log --graph --all --oneline  --author=zhujd | grep -iE "OPS"

所有分支的所有提交记录 git log --graph --all 

所有分支的所有提交记录 显示一行
git log --graph --all --oneline

某人在所有分支的所有提交记录 显示一行
git log --graph --all --oneline  --author=zhujd

某人在所有分支的关于OPS的提交记录 显示一行
git log --graph --all --oneline  --author=zhujd | grep -iE "OPS"

git branch

查看某笔提交所在分支

git branch --contains 0f6f37df6f --all 

git blame   文件名 |  grep -iE "修改内容"

git 配置

git config --list 
git config --global user.name "sunlei_2"

报错

[1]“It looks like git-am is in progress. Cannot rebase.”
rm -rf .git/rebase-apply

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值