Git 操作总结

Git是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。与常用的版本控制工具 CVS、Subversion等不同,它采用了分布式版本库的方式,不必服务器端软件支持。

基本概念

  • 工作区 被git索引的目录
  • 暂存区
  • 版本库
  • 远程仓库

常用命令

分支管理

  • 创建
git branch dev    创建dev分支
git checkout -b dev    创建并切换到dev分支
  • 编辑
git diff HEAD -- readme.txt 用于比较工作区和版本库中指定节点文件的差分
git reset --hard HEAD^ 回退到HEAD指针的上一个节点位置,^代表回溯到上一个节点,以此类推
首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交3628164...882e1e0(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
git reset --hard 3628164  版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了。
Git提供了一个命令git reflog用来记录你的每一次命令,结合上面的reset回滚,一起服用效果更佳。
命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况:
一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
总之,就是让这个文件回到最近一次git commit或git add时的状态。
git checkout 其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
git checkout -- file命令中的--很重要,没有--,就变成了“切换到另一个分支”的命令,我们在后面的分支管理中会再次遇到git checkout命令。
  • 合并
  • 删除
    git branch -d 删除分支
    如果要丢弃一个没有被合并过的分支,可以通过git branch -D 强行删除。

远程管理

git push -u origin master
由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
git remote add origin [email protected]:michaelliao/learngit.git 添加远程库

补充知识:gerrit

git push origin master:refs/for/master
Gerrit 不允许用户直接push代码到分支上
正确的做法是所有提交都push到 HEAD:refs/for/分支名 :

格式如:git push origin HEAD:refs/for/分支名

代码review通过后才能合并到git lab中的指定分支

常用alias

git config --global alias.st status
git config --global alias.ci commit
git config --global alias.co checkout
git config --global alias.br branch
git config --global color.ui true
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset %C(bold blue)<%an>%Creset ---%C(yellow)%d%Creset %s %Cgreen(%cr)' --abbrev-commit"

git push --force
git push --force-with-lease
二者区别,force-with-lease是更为安全的指令,force-with-lease会检查本地对远程分支的引用,和远程分支实际引用指针是否一致,如果不一致,push会失败。
此时说明,线上存在本地没有合并的提交。

你可能感兴趣的:(Git 操作总结)