在Windows上安装Git
在Windows上使用Git,可以从Git官网直接下载安装程序(国内镜像), 按默认选项安装即可。
安装完成后,在安装根目录打开git-bash.exe
在命令行输入:
$ git config --global user.name "your name"
$ git config --global user.email "email@example.com"
因为Git是分布式版本控制系统,所以每个机器都需要设置你的名字和Email地址作为来源标记
初始化一个Git仓库,使用git init
命令
添加文件到Git仓库,分两步:
- 使用命令
git add <file>
,注意,可反复多次使用,添加多个文件; - 使用命令
git commit -m <message>
,完成。
$ git add file1.txt
$ git add file2.txt file3.txt
$ git commit -m "add 3 files."
- 要随时掌握工作区的状态,使用
git status
命令。 - 如果
git status
告诉你有文件被修改过,用git diff
可以查看修改内容。 git log
命令显示从最近到最远的提交日志,如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline
参数
git log --pretty=oneline
- 在Git中,用
HEAD
表示当前版本,上一个版本就是HEAD^
,上上一个版本就是HEAD^^
,当然往上100个版本写100个^
比较容易数不过来,所以写成HEAD~100
。 - 我们要把当前版本回退到上一个版本就可以使用
git reset
命令 - 要重返未来,用
git reflog
查看命令历史,以便确定要回到未来的哪个版本。
$ git reset --hard HEAD^
$ git reset --hard commit_id
git checkout -- file
可以丢弃工作区的修改,让这个文件回到最近一次git commit
或git add
时的状态,git checkout -- file
命令中的--
很重要,没有--
,就变成了“切换到另一个分支”的命令- git reset HEAD <file>,
git reset
命令既可以回退版本,也可以把暂存区的修改回退到工作区。当我们用HEAD
时,表示最新的版本。 - git rm <file>,命令
git rm
用于删除一个文件。先手动删除文件,然后使用git rm <file>和git add<file>效果是一样的。
GitHub的使用
- 先有本地库,后有远程库的时候,要关联一个远程库,使用命令
git remote add origin git@server-name:path/repo-name.git
; - 更改仓库指向git remote set-url origin
git@server-name:path/repo-name.git
- 关联后,使用命令
git push -u origin master
第一次推送master分支的所有内容; - 此后,每次本地提交后,只要有必要,就可以使用命令
git push origin master
推送最新修改; - 假设我们从零开发,那么最好的方式是先创建远程库,然后,从远程库克隆,用命令
git clone
克隆一个本地库 - 创建SSH Key。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有
id_rsa
和id_rsa.pub
这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:
$ ssh-keygen -t rsa -C "youremail@example.com"
分支
- 查看分支:
git branch
- 创建分支:
git branch <name>
- 切换分支:
git checkout <name>
- 创建+切换分支:
git checkout -b <name>
,
可以通过git branch -D <name>
强行删除 - 合并某分支到当前分支:
git merge <name>,
合并分支时,加上--no-ff
参数就可以用普通模式合并,合并后的历史有分支 - 删除分支:
git branch -d <name>
- 看到分支合并图:
git log --graph
$ git checkout -b dev
$ git branch
* dev
master
$ git checkout master
$ git merge dev
$ git merge --no-ff -m "merge with no-ff" dev
$ git branch -d dev
$ git log --graph --pretty=oneline --abbrev-commit
stash
功能,可以把当前工作现场“储藏”起来
- Git还提供了一个
stash
功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作git stash - 刚才的工作现场存到哪去了?用
git stash list
命令看看 - 恢复工作现场有两个办法:一是用
git stash apply
恢复,但是恢复后,stash内容并不删除,你需要用git stash drop
来删除;另一种方式是用git stash pop
,恢复的同时把stash内容也删了 -
$ git stash $ git stash list $ git stash apply $ git stash drop $ git stash pop
多人协作
- 当你从远程仓库克隆时,实际上Git自动把本地的
master
分支和远程的master
分支对应起来了,并且,远程仓库的默认名称是origin,
要查看远程库的信息,用git remote,
用git remote -v
显示更详细的信息 - 本地新建的分支如果不推送到远程,对其他人就是不可见的;
- 从本地推送分支,使用
git push origin branch-name
,如果推送失败,先用git pull
抓取远程的新提交; - 在本地创建和远程分支对应的分支,使用
git checkout -b branch-name origin/branch-name
,本地和远程分支的名称最好一致; - 建立本地分支和远程分支的关联,使用
git branch --set-upstream branch-name origin/branch-name
; - 从远程抓取分支,使用
git pull
,如果有冲突,要先处理冲突。
$ git remote
origin
$ git remote -v
因此,多人协作的工作模式通常是这样:
- 首先,可以试图用
git push origin <branch-name>
推送自己的修改; - 如果推送失败,则因为远程分支比你的本地更新,需要先用
git pull
试图合并; - 如果合并有冲突,则解决冲突,并在本地提交;
- 没有冲突或者解决掉冲突后,再用
git push origin <branch-name>
推送就能成功!
如果git pull
提示no tracking information
,则说明本地分支和远程分支的链接关系没有创建,
用命令git branch --set-upstream-to <branch-name> origin/<branch-name>
。
Rebase 变基
- rebase操作的特点:把分叉的提交历史“整理”成一条直线,看上去更直观。缺点是本地的分叉提交已经被修改过了
- rebase操作可以把本地未push的分叉提交历史整理成直线;
- rebase的目的是使得我们在查看历史提交的变化时更容易,因为分叉的提交需要三方对比。
git rebase
标签管理
- tag就是一个让人容易记住的有意义的名字,它跟某个commit绑在一起,
- 在Git中打标签非常简单,首先,切换到需要打标签的分支上,
git tag <name>
就可以打一个新标签 - 可以用命令
git tag
查看所有标签,标签不是按时间顺序列出,而是按字母排序的,用git show <tagname>
查看标签信息 - 默认标签是打在最新提交的commit上的。有时候,如果忘了打标签,方法是找到历史提交的commit id,然后打上就可以了
- git log --pretty=oneline --abbrev-commit,比方说要对
add merge
这次提交打标签,它对应的commit id是f52c633
,敲入命令 - git tag v0.9 f52c633
- 创建带有说明的标签,用
-a
指定标签名,-m
指定说明文字git tag -a <tagname> -m "blablabla..." - 命令
git push origin <tagname>
可以推送一个本地标签; - 命令
git push origin --tags
可以推送全部未推送过的本地标签; - 命令
git tag -d <tagname>
可以删除一个本地标签; - 命令
git push origin :refs/tags/<tagname>
可以删除一个远程标签 -
git clone 整个仓库后使用,以下命令就可以取得该 tag 对应的代码了。
git checkout tag_name
但是,这时候 git 可能会提示你当前处于一个“detached HEAD" 状态。因为 tag 相当于是一个快照,是不能更改它的代码的。如果要在 tag 代码的基础上做修改,你需要一个分支:
git checkout -b branch_name tag_name
这样会从 tag 创建一个分支,然后就和普通的 git 操作一样了。
git tag v1.0
git tag v0.9 f52c633
git tag -a v0.1 -m "version 0.1 released" 1094adb
git tag
git show v0.1
让Git显示颜色,会让命令输出看起来更醒目
$ git config --global color.ui true
此笔记源自廖雪峰的git教程 教程地址