美文网首页
Git 操作总结

Git 操作总结

作者: sunnyxibei | 来源:发表于2017-08-24 11:42 被阅读15次

    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 <name>强行删除。

    远程管理

    git push -u origin master
    由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
    git remote add origin git@github.com: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 操作总结

          本文链接:https://www.haomeiwen.com/subject/okosdxtx.html