美文网首页
Git命令行

Git命令行

作者: hui_mamba | 来源:发表于2017-05-28 11:57 被阅读0次

参考Git教程

1. 创建版本库

命令 行为
git init 把当前目录变成Git可以管理的仓库(添加.git文件)
git add <file> 将工作区中的<file>文件添加到暂存区
git commit -m "information" 将暂存区中的<file>文件提交到当前分支

注意理解工作区、版本库、暂存区、分支的概念。

2. 版本回退(工作区、暂存区均重置)

命令 行为
git log 版本控制系统的历史记录
git log --pretty=oneline 将历史记录显示在一行
git reset --hard HEAD^ 回退到上一个版本
git reset --hard HEAD^^ 回退到上上一个版本
git reset --hard <commit id> 回退该版本号
git reflog 用于查找版本号(当前版本之后的版本)

3. 撤销修改

命令 行为
git status 列出工作区、暂存区和当前分支的状态
git checkout -- <file> 撤销工作区修改,使工作区的<file>与当前暂存区的相同
git reset HEAD <file> 撤销暂存区修改,使暂存区的<file>与当前分支的相同,

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD file,就回到了场景1,第二步按场景1操作。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退,不过前提是没有推送到远程库。

4.删除文件

命令 行为
git rm <file> 从暂存区删除<file>,同时删除工作区的<file>

在工作区删除文件后,有两种选择:

  1. 确实要从版本库中删除该文件,那就用命令git rm删掉,并且git commit,现在,文件就从版本库中被删除了。
  2. 另一种情况是删错了,从当前分支恢复到暂存区git reset HEAD <file>,从暂存区恢复到工作区git checkout -- <file>

4. 远程仓库

添加远程库

  • 创建SSH-Key
    ssh-keygen -t rsa -b 4096 -C "your_email@example.com"
  • 将当前版本库与github远程仓库关联 (git remote add)
    git remote add origin git@github.com:michaelliao/learngit.git (复制SSH地址)
  • 将本地仓库的所有内容推送到远程仓库 (git push -u)
    git push -u origin master
    由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

从远程库克隆(git clone)

  • git clone git@github.com:michaelliao/gitskills.git (复制SSH地址)

5. 分支管理

创建与合并分支

命令 行为
git branch dev 创建dev分支
git checkout dev 切换到dev分支
git checkout -b dev 创建并切换到dev分支
git branch 查看分支
git merge dev 合并指定分支到当前分支。Fast-forward表示“快进模式”
git branch -d dev 删除合并过的dev分支
git branch -D dev 删除没有被合并过的dev分支

开发一个新feature,最好新建一个分支;
如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>强行删除。

解决冲突

命令 行为
git log --graph --pretty=oneline --abbrev-commit 可以看到分支合并图

分支管理策略

命令 行为
git merge --no-ff -m "merge with no-ff" dev 禁用Fast forward(快进模式)

合并分支时,加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。

Bug分支

命令 行为
git stash 可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作
git stash list 查看所有工作现场列表
git stash apply stash@{id} 恢复工作现场
git stash drop stash@{id} 删除工作现场
git stash pop stash@{id} 回复后再删除工作现场(只有一个是可省略stash@{id})

因为当前正在做的分支没有commit时,操作其他分支工作区会受到影响,因此需要git stash。修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除;当手头工作没有完成时,先把工作现场git stash一下,然后去修复bug,修复后,再git stash pop,回到工作现场。

多人协作

命令 行为
git remote 查看远程库的信息
git remote -v 查看远程库的详细信息
git push origin dev 将dev分支推送到远程库
git checkout -b dev origin/dev 由于克隆是只克隆master分支,在本地创建和远程分支对应的分支
git pullgit fetch git pull取回远程主机某个分支的更新,再与本地的指定分支合并
git branch --set-upstream dev origin/dev 如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建

多人协作的工作模式通常是这样:

  1. 首先,可以试图用git push origin branch-name推送自己的修改;
  2. 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
  3. 如果合并有冲突,则解决冲突,并在本地提交;
  4. 没有冲突或者解决掉冲突后,再用git push origin branch-name推送就能成功!

6. 标签

命令 行为
git tag v1.0 为当前分支的当前版本创建标签
git tag v1.0 6224937(commit id) 为这个版本创建标签
git tag -a v1.0 -m "version v1.0 released" 6224937 -a指定标签名,-m指定说明信息
git tag 查看所有标签
git show v1.0 查看标签信息
git tag -d v1.0 删除本地标签
git push origin v1.0 推送某个标签到远程
git push origin --tags 一次性推送全部尚未推送到远程的本地标签
git tag -d v1.0git push origin :refs/tags/v1.0 先删除本地标签,再删除远程标签

相关文章

网友评论

      本文标题:Git命令行

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