http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000


本地库管理命令

git init

创建版本库repository

git status

此时目录下多了一个.git文件夹,里面存储了若干自动生成的文件,用来记录修改信息、暂存区信息等。

git add <file>

为批量或者单独向暂存区提交做准备。修改之后的文件,在add之前的状态是:Changes not staged for commit。在add之后的状态是:Changes to be committed

git commit  -m ‘...’

将之前add的内容,从工作区添加到暂存区.将所有的变动都提交之后,git status 的状态会变成nothing to commit (working directory clean)

git checkout -- <file>

如果要撤销工作区(working derectory)的修改,并且还没有add到暂存去,使用git checkout --<file>可以将暂存区当前的内容回复到工作区

git reset HEAD <file>  结合 git checkout  -- <file>

如果错误的修改已经add到暂存区,那么首先利用git reset hEAD <file>  将暂存区的add撤销,之后在用git checkout  -- <file>将暂存区恢复到工作区

git reset --hard commit_id

如果错误修改已经commit,想要恢复到某一个版本,使用上述命令,其中commit_id可以使用,git log或者git reflog来查找

 git rm <file> 结合git commit -m ''

如果确实要删除某个文件,那利用git rm <file> 删除工作区中的文件,最后再用git commit -m'' 将删除提交,此时版本库才算彻底删除

如果是本地的rm命令不小心删除了工作区的某个文件,那么利用gm checkout -- <filename>就可以将版本库中的文件恢复到工作区

分支管理

git branch <branchName>

该命令用于创建分支

git checkout <branchName>

该命令用于切换分支

git branch -b <branchName>

创建并切换分支

git merge <branchName>

将branchName 对应的内容,合并到当前分支上,如果合并后有冲突,那么将冲突部分进行修改,之后重新提交

如果在分支合并到master之前,想要删除该分支,可以利用git branch -D <branchName>进行强制删除

git branch -d <branchName>

删除branchName分支

git branch -D <branchName>

强制删除branchName 分支

git stash  结合 git stash list 结合 git stash apply 或者 git stash pop

保存当前的工作区,通常用于现在的工作还没有完成,来不及提交的情况下,需要开辟其他分支完成其他任务,之后可以利用git stash list 来查看存储的工作现场,在合适的时候再利用git stash pop或者git stash apply恢复工作现场(后者还需要利用git stash drop来输出list中的stash)


远程仓库

本地库和远程库的构建及关联

如果是现有本地库,要依据本地库构造远程仓库

1)登录github,选择create a new repo,创建一个远程仓库

2)之后在本地的版本库目录下运行目录,添加一个远端 git remote add origin git@github.com <username>/<原创仓库名.git>

3) 将本地库的内容推送到远端 git push -u origin master(第一次推送的时候,使用-u参数,该参数首先将本地的master分支和远端的master分支进行关联,之后再进行推送,在之后的推送中,就不再需要-u参数)

经过测试,有时候需要执行这个命令

git branch --set-upstream-to=origin/master master

如果是先有远程库,要依据远程库构建本地库

此时相对简单,使用git clone命令即可 git clone git@github.com:<username>/<远程库名>.git

不过注意此时复制的仅是远程的master分支,其他分支可以参见下面的讲解

和远端进行交互

git remote 或者 git remote -v

查看远端版本库的信息

git push origin <branchName>

向远端推送某个分支(事先需要建立对应分支间的关联,这样才能自动推送到对应的分支)

一般本地和远端的master分支在构建版本库的时候就关联好了,对于clone命令,一般本地只能复制远端的master分支。如果想要在其他分支上开发,以dev分支为例:

1)在本地创建dev分支

git checkout -v dev origin/dev

2)但是这样,还没有建立本地的dev分支和远程dev分支之间的关联,使用下面的命令建立关联

git branch --set-upstream dev origin/dev

建立起关联之后

git push origin <branchName>

就是向远端推送branchName分支对应的内容

git pull 

就是从当前本地工作的分支对应的远端分支拉取内容

冲突解决

从本地推送分支,使用git push origin <branch-name>,如果推送失败,那么首先利用git pull 拉取内容,在本地解决冲突后再提交

标签管理

git tag  -a <tagName> <commit_id> -m'说明文字'

给某个提交版本打上标签,如v1.0

git tag

查看所有标签

git show <tagName>

查看指定的标签

git push origin <tagname>

向远端推送一个标签

git push origin --tags

向远端推送所有标签

git tag -d <tagName>

删除一个本地的标签

git push origin : refs/tags/<tagName>

删除一个远端的标签

git梳理的更多相关文章

  1. Git分支管理的策略梳理

    当下最流行的版本管理系统应该是非Git莫属.相比同类软件,Git有很多优点,其中很显著的一点,就是版本的分支(branch)和合并(merge)十分方便.有些传统的版本管理软件,分支操作实际上会生成一 ...

  2. Git常用命令梳理

    在日常的Git版本库管理工作中用到了很多操作命令,以下做一梳理: 查看分支列表,带有*的分支表示是当前所在分支 [root@115~~]#git branch 查看分支详细情况 (推荐这种方式) [r ...

  3. Git 常用命令和 Git Flow 梳理

    git 用 git 有一段时间了,之前没有详细地了解 git flow,导致协作过程中或多或少出现了一些头疼问题.最近静下心来理了下 git flow 的整个流程,再回头看开朗了不少,总结到这里.介绍 ...

  4. 梳理git分支管理策略

    如果你严肃对待编程,就必定会使用"版本管理系统"(Version Control System). 眼下最流行的"版本管理系统",非Git莫属. 相比同类软件, ...

  5. Git忽略规则.gitignore梳理

    对于经常使用Git的朋友来说,.gitignore配置一定不会陌生.废话不说多了,接下来就来说说这个.gitignore的使用. 首先要强调一点,这个文件的完整文件名就是".gitignor ...

  6. GIT入门笔记(20)- 使用eclipse 基于 git 开发过程梳理

    一.创建本地分支 1.下载/更新 本地 主干 如果本地还没有 本地主干,下载:git clone 如果本地已有了 本地主干,更新:git pull 工程右键菜单:team -> pull 2.基 ...

  7. GIT入门笔记(20)- git 开发提交代码过程梳理

    git开发提交流程新项目开发,可以直接往master上提交老项目维护,可以在分支上修改提交,多次add和commit之后,也可以用pull合并主干和本地master,解决冲突后再push 1.检出代码 ...

  8. SVN和Git对比梳理

    在日常运维工作中,经常会用到版本控制系统,目前用到最广泛的版本控制器就是SVN和Git,那么这两者之间有什么不同之处呢?SVN(Subversion)是集中式管理的版本控制器,而Git是分布式管理的版 ...

  9. Git版本控制器使用总结性梳理

    Git为何物?Git 是什么?大家肯定会说不就是版本控制器嘛,是的Git是目前世界上最先进的分布式版本控制系统(没有之一).1)那什么是版本控制器?举个简单的例子,比如我们用Word写文章,那你一定有 ...

随机推荐

  1. python网络编程-Json序列化功能扩展-软件开发架构-OSI七层协议-TCP-01

    面向对象补充知识点(面向对象的应用) 扩展json序列化所支持的数据类型(分析源码) import json from datetime import datetime, date # ------- ...

  2. 最好用linux版QQ

    这个版本的qq是见过linux下做好用的qq,希望对大家有用; 安装简单,qq易用,不卡死,可以接收文件. 安装过程如下: git clone https://gitee.com/wszqkzqk/d ...

  3. [Nest] 05.nest之数据库

    数据库 Nest 与数据库无关,允许您轻松地与任何 SQL 或 NoSQL 数据库集成.根据您的偏好,您有许多可用的选项.一般来说,将 Nest 连接到数据库只需为数据库加载一个适当的 Node.js ...

  4. sql server select和set赋值的区别

    --SQL Server中对已经定义的变量赋值的方式用两种,分别是 SET 和 SELECT --当表达式返回一个值并对一个变量进行赋值时,推荐使用 SET 方法 (1)SELECT可以在一条语句里对 ...

  5. Linux内核、mysql内核、Tcp/Ip内核、java等知识书籍

    LINUX <linux内核设计与实现>(2011年出版,链接:https://pan.baidu.com/s/107hriLNVt05A8egeU8Du-g  密码:0cgn) < ...

  6. 学习笔记--最近公共祖先(LCA)的几种求法

    前言: 给定一个有根树,若节点\(z\)是两节点\(x,y\)所有公共祖先深度最大的那一个,则称\(z\)是\(x,y\)的最近公共祖先(\(Least Common Ancestors\)),简称\ ...

  7. webpack 四个核心概念

    webpack 是当下最热门的前端资源模块化和打包工具.它可以将许多松散的模块(如 CommonJs 模块. AMD 模块. ES6 模块.CSS.图片. JSON.Coffeescript. LES ...

  8. python之itertools

    Python的内建模块itertools提供了非常有用的用于操作迭代对象的函数. count 创建一个迭代器,生成从n开始的连续整数,如果忽略n,则从0开始计算(注意:此迭代器不支持长整数) 如果超出 ...

  9. 在 Android 中实现 Redux 的一点经验

    简评: Redux 是一个用于应用程序状态管理的开源JavaScript库,其核心是通过可管理和控制的状态来描述一个系统.这意味着其思想其实是可以应用于任何类型应用的开发的,包括移动应用. Redux ...

  10. 结束&新的开始。

    我退役啦. 真的很抱歉,但我的学习周期还是太长了,没能在noi之前让自己变得足够强啊. FareWellOi.虽然很舍不得,但总要告别对吧. 相比竞赛的跳跃性钻研性学习,我的优势在于系统性学习.所以我 ...