如果用过mercury(HG),那么理解Git的运作方式就轻松多了。两者是相同的分布式版本管理工具,只是某些功能有着细微的差别 - Git的管理粒度更加细腻,因此操作上也比HG复杂一点。例如,修改文件并提交,hg会自动跟踪到,并不需要你去手动add,但是在git里,无论新增还是修改,都必须add相应的文件才可以commit.这样概念上可以保持一致性(计算机的美学)。

安装和创建版本库:

sudo apt-get install git

创建全新仓库:

mkdir new_repo

cd new_repo

git init

此时即可创建一个全新的仓库。命令执行后,可以看到.git的隐藏文件夹,这是跟踪版本仓库的数据库。

远程克隆仓库:

git clone git@github.com:homer_simpson/repo_one.git

执行后会在本地创建同名文件夹repo_one

基本操作:

git reflog   // git历史操作

git add <filename>   // 新增filename 到版本库,或者修改了filename,提交到暂存区

git rm <filename>    // 从版本库移除filename

git commit -m "comment"  // 提交暂存区的内容到changeset,如果修改没有add/rm到暂存区,则提交不了修改

git log  // 查看历史提交,完整信息

git log --pretty=oneline  // 查看历史提交,单行显示

git log --graph   // 分支图形方式显示LOG

git log --abbrev-commit // 缩写方式显示LOG

git diff (<filename>)  // 查看未add/rm的修改内容

git diff HEAD -- readme.txt  // 查看已提交的修改内容

git status // 查看文件状态,新增/修改/删除,工作区/暂存区

git checkout -- <filename>  // 撤销修改 - 修改但未添加到暂存区

git reset HEAD <filename> // unstage,暂存区撤销回工作区

git reset --hard HEAD^|<commit id>  // 修改HEAD指针到新位置(等效于撤销已提交的修改,放弃commit id后的所有修改)

HEAD代表当前指针,HEAD^前一个版本,HEAD^^往前第二个版本,HEAD~50往前50个版本

分支操作:

GIT管理系统里,每个分支对应一个指针指向当前分支的头部节点,HEAD通过指向分支指针从而指向某一分支的头部节点。

master分支是始终存在的。

如无特殊说明,merge分支优先使用fast-forward模式,如果不能FF,则用普通的merge

merge冲突时,Git用<<<<<<<,=======,>>>>>>>标记出不同分支的内容,此时直接编辑文件,add 文件并commit

git branch  // 查看分支

git branch <branch name>  //创建分支

git branch -d <branch_name >  // 删除分支

git branch -D <branch_name> // 强制删除分支(一般当这个分支没有merge到其他分支而被丢弃时)

git checkout <branch_name> // 切换分支

git checkout -b <branche_name> // 创建分支并切换过去

git merge <branch_name> // 将branch_name merge到当前分支,包括合并文件,add文件+commit

git merge -m "comment" <branch_name>  // 为merge的commit添加注释

git merge --no-ff -m "comment" <branch_name> // 禁用ff模式

工作区暂存:

git stash  // 当前分支的工作区内容暂存起来。此时git status是干净的

git stash list // 列出暂存区

git stash apply <stashname> // 恢复工作区

git stash drop <stashname> // 删除stash列表项

git stash pop  // 恢复stash顶端并删除

标签管理;

git tag // 查看标签

git tag <tag_name> // 在当前分支当前头打上标签

git tag <tag_name>  <commit id>  // 在某个commit上打上标签

git show <tag_name>  // 显示标签对应commit的内容

git tag -a <tag_name> -m "blablabla..."  //添加标签信息

git tag -d <tag_name>   // 删除本地标签

git push origin <tag_name>  // 推送本地标签

git push origin --tags  // 推送本地所有标签

git push origin :refs/tags/<tag_name>  //删除远程标签

远程协作:

有两个基本操作:建立远程和本地仓库的关联,建立远程仓库分支和本地仓库分支的关联

git remote add origin git@github.com:homer_simpson/repo_one.git   //  创建远程仓库名字,即表示创建本地仓库和远程仓库的连接。origin是约定俗成的远程仓库的名字

git remote // 查看远程仓库

git remote -v // 查看远程仓库的详细信息

在某一个分支下git push/git pull 默认操作对象是当前分支,如果当前分支没有和远程分支建立联系,则出错

git clone操作,会自动创建本地master分支,并且和远程的master分支建立联系

git remote方式关联后,须手动关联master分支,例如git push -u origin master是建立关联并push

git branch --set-upstream branch1 origin/branch1   //  建立本地分支和远程分支的联系

git checkout -b branch1 origin/branch1   // 本地创建和远程分支对应的分支,因为clone时不会创建除了master之外的其他分支

Git系统配置:

git config --global user.name "Your Name"  //设置名字

git config --global user.email "email@example.com"// 设置邮箱地址

git config --global color.ui true  // 显示不同的颜色

git config --global alias.st status  // 配置别名

可在根工作区创建.gitignore,配置GIT不跟踪的文件,但是可用命令git add -f <file_name>强行添加, git check-ignore -v <file_name>可以检查当前文件是否被过滤。

.git/config保存全局配置。

Git简易参考手册的更多相关文章

  1. Git命令参考手册(文本版)

    git init # 初始化本地git仓库(创建新仓库) git config --global user.name "xxx" # 配置用户名 git config --glob ...

  2. Git命令参考手册(转)

    git init # 初始化本地git仓库(创建新仓库) git config --global user.name "xxx" # 配置用户名 git config --glob ...

  3. git 命令参考手册 git中文命令参考手册大全

    git init # 初始化本地git仓库(创建新仓库)git config --global user.name "xxx" # 配置用户名git config --global ...

  4. Git命令参考手册

    git init # 初始化本地git仓库(创建新仓库) git config --global user.name "xxx" # 配置用户名 git config --glob ...

  5. [转帖]git命令参考手册

                      git init                                                  # 初始化本地git仓库(创建新仓库) git ...

  6. git 命令参考手册

    你的本地仓库由 git 维护的三棵“树”组成.第一个是你的 工作目录,它持有实际文件:第二个是 缓存区(Index),它像个缓存区域,临时保存你的改动:最后是 HEAD,指向你最近一次提交后的结果. ...

  7. git简易操作手册

    从远程仓库新建 $ git clone https://github.com/xxxr/Repository.git $ cd Repository/ $ git config --global us ...

  8. Git Hub 使用手册参考

    参考信息 1.http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b0002.http://ww ...

  9. Git 安装配置手册

    Git 安装配置手册 首先我们要了解 Git 是类似于 SVN 用来管理项目的 首先要先下载 Git ,这个东西相当于一个核,是该功能的核心 下载地址(<https://gitforwindow ...

随机推荐

  1. Locust性能测试工具的安装及实际应用

    一.安装Locust 安装Locust之前先安装的库:gevent库:第三方库,gevent为python提供了比较完善的协程支持.使用gevent,可以获得极高的并发性能. pip install ...

  2. sysstat -6.0.2 lib not install

    执行oracle安装包./setup.sh 后跳出,无法执行数据库的安装,并提示类似下面 的错误信息-- ERROR:===wed Aug 15 08:43:23 CST 2012===sysstat ...

  3. 喂,前端,你应该知道的chrome插件

    最近,优点闲. 压力,有点大,回顾,曾今被问,你怎么查看内存泄露,然后,一脸蒙. 工欲善其事, 必先利其器 最近在研究chrome devtools,发现,其实他很强.而且chrome6周一次的更新, ...

  4. JFFS2文件系统的移植

    Linux文件系统的移植-JFFS2 JFFS2是JFFS的后继者,由Red Hat重新改写而成.JFFS2的全名为JournallingFlash File System Version 2(闪存日 ...

  5. RabbitMQ教程(一)——安装配置

    RabbitMQ教程(一)——安装配置 一.前言 由于最近在学习RabbitMQ消息队列,但是鉴于网上对于官网介绍的教程比较少或者由于时间长长期未更新,因此决定将对官网的RabbitMQ入门教程进行翻 ...

  6. JS正则密码复杂度校验之:至少有多种字符中的其中几种

    概述 续接上文的密码校验要求: 这个需求有两个难点,一,是如何使用正则匹配所有半角英文标点符号,二,是如何验证密码段中在要求的四种(大写字母,小写字母,数字,标点符号)类型中至少存在三种. 第一个难点 ...

  7. python_求相邻数

    什么是相邻数? 比如5,相邻数为4和6,和5相差1的数,连续相差为1的一组数 需求: 遍历inputList 所有数字,取出所有数字,判断是否有相邻数, 不相邻数字 和 相邻数字 都以 “数组”形式 ...

  8. python 导入模块 import 理解

    --python 导入模块 import 理解 -----------------------------------2014/03/18 python 导入一个模块的过程要求有一个叫做“路径搜索”的 ...

  9. Android中的文件下载——DownLoadManager

    一.问题概述 在android开发中,经常会使用到文件下载的功能,比如app版本更新等.在api level 9之后,android系统为我们提供了DownLoadManager类,这是android ...

  10. 如何正确地修改.data和.item文件的‘utf-8’格式

    问题:有时候,我们在做分类信息提取的时候文件的格式可能不是我们想要的.txt文件的格式,如何进行修改? 解决:(1)将文件复制一份,并保存为.txt的格式(2)将复制之后的文件通过另存为的方式更改为u ...