Git简易参考手册
如果用过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简易参考手册的更多相关文章
- Git命令参考手册(文本版)
git init # 初始化本地git仓库(创建新仓库) git config --global user.name "xxx" # 配置用户名 git config --glob ...
- Git命令参考手册(转)
git init # 初始化本地git仓库(创建新仓库) git config --global user.name "xxx" # 配置用户名 git config --glob ...
- git 命令参考手册 git中文命令参考手册大全
git init # 初始化本地git仓库(创建新仓库)git config --global user.name "xxx" # 配置用户名git config --global ...
- Git命令参考手册
git init # 初始化本地git仓库(创建新仓库) git config --global user.name "xxx" # 配置用户名 git config --glob ...
- [转帖]git命令参考手册
git init # 初始化本地git仓库(创建新仓库) git ...
- git 命令参考手册
你的本地仓库由 git 维护的三棵“树”组成.第一个是你的 工作目录,它持有实际文件:第二个是 缓存区(Index),它像个缓存区域,临时保存你的改动:最后是 HEAD,指向你最近一次提交后的结果. ...
- git简易操作手册
从远程仓库新建 $ git clone https://github.com/xxxr/Repository.git $ cd Repository/ $ git config --global us ...
- Git Hub 使用手册参考
参考信息 1.http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b0002.http://ww ...
- Git 安装配置手册
Git 安装配置手册 首先我们要了解 Git 是类似于 SVN 用来管理项目的 首先要先下载 Git ,这个东西相当于一个核,是该功能的核心 下载地址(<https://gitforwindow ...
随机推荐
- 关于个人编辑器sublime text3使用指南
用过了好多编辑器,前些年用的zend studio,phpstorm近两年转为nodepad++(因为写的语言种类比较多了,shell,python,php,前端等),相对于nodepad++, s ...
- CentOS6 安装Sendmail + Dovecot + Roundcubemail
前言 本文是继CentOS6 安装Sendmail + Dovecot + Squirrelmail 关于邮箱服务器配置的第二篇文章,因为关于使用Sendmail进行相关配置的文章.资料等太老,而且资 ...
- HTML <div>和<span>
块代码 <div>和<span> 1.. <style> .ccwTest { font-family: '.PingFang SC';">; co ...
- sshpass做秘钥分发,ansible做自动化运维工具
最近公司机器的增多,顺便还要上报表系统,考虑到服务器越来越多,手工的管理显得越来的越吃力,所以打算推进公司自动化运维工具的使用. 推进的过程中,一步一个坑踩过来的.由于公司之前未运用过自动化运维工具, ...
- [ZYNQ-7]PS处理PL外部中断的简单实例的剖析 (参考米联miz702n)
Zynq的ARM通过GIC中断控制器来接收核仲裁所有的中断.由于中断向量表只有4Bytes大小,仅仅正好存放一条跳转语句,因此当产生一个外部中断时,中断处理的大致过程:PC内容保存到LR_IRQ用于中 ...
- 重定向URL
重定向的原因有哪些?[1]网址变更了[2]权限不够 [1]网址变更了 [举例]以google为例,之前我们可以访问www.google.cn,但是后来Z.F不让我们访问它了,那么google公司为了避 ...
- AIX缩小逻辑卷报错chfs: 0506-964
--AIX缩小逻辑卷报错chfs: 0506-964 -----------------------------------------2013/10/29 通过smit chfs/或 chfs命令 ...
- python join 和 split的常用使用方法
函数:string.join()Python中有join()和os.path.join()两个函数,具体作用如下: join(): 连接字符串数组.将字符串.元组.列表中的元素以指定的字符 ...
- java 面试,java 后端面试,数据库方面对初级和高级程序员的要求
本内容摘自 java web轻量级开发面试教程 对于合格的程序员,需要有基本的数据库操作技能,具体体现在以下三个方面. l 第一,针对一类数据库(比如MySQL.Oracle.SQL Server等 ...
- python中的collections.namedtuple
简介 collections.namedtuple是一个工厂方法,它可以动态的创建一个继承tuple的子类.跟tuple相比,返回的子类可以使用名称来访问元素. 使用方法 用一个例子来介绍: > ...