美文网首页
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会失败。
此时说明,线上存在本地没有合并的提交。

相关文章

  • 浅谈gitflow

    之前文章对git的日常操作做了简单的总结,本篇主要对gitflow进行说明和总结。 git日常的基本操作 Git ...

  • git 操作总结

    设置快捷操作的方法:

  • git操作总结

    git是什么 Git是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git的读音为...

  • Git 操作总结

    Git是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。与常用的版本控制工具 CVS、S...

  • Git操作总结

    Git配置 git config [--global/system] <参数(例如下面)> 取消设置 初始化仓库 ...

  • GIT操作总结

    所以创建一个版本库也非常简单,如下我是D盘 –> www下 目录下新建一个testgit版本库。 pwd 显示当前...

  • Git操作总结

    Git一般只添加数据。你执行的 Git 操作,几乎只往 Git 数据库中增加数据。很难让 Git 执行任何不可逆操...

  • Git 操作总结

    一、在A机器上创建项目 1、eclipse创建项目 2、github创建仓库 3、eclipse share pr...

  • Git常用命令

    在此对经常用到的一些git命令进行总结 git基本操作git config --global user.name ...

  • Git命令手册

    以下内容是我在学习和研究Git时,对Git操作的特性、重点和注意事项的提取、精练和总结,可以做为Git操作的字典,...

网友评论

      本文标题:Git 操作总结

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