美文网首页
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