学习廖雪峰
git教程,随手笔记,内容比较乱,仅供自己学习参考之用
git简介
集中式SVN和分布式Git版本控制系统
集中式版本控制系统,版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。必须连网
分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
分布式安全性高,因为每个人都有完整的库
分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。
安装
不介绍
创建版本库
几个指令
Mkdir learngit 新建一个文件夹
Pwd 查看当前目录
git init 初始化git仓库,把当前文件夹变成git可以管理的仓库
ls -ah 查看隐藏的文件
(注意:版本控制系统只能跟踪文本文件的改动(因为文本文件是有编码的),比如txt、html、js及其它任何代码,但对二进制文件,比如图片、视频、word、excel等,无法跟踪具体修改了什么,只能知道文件总体的变化,即文件大小的变化)
添加文件到git仓库
在learngit文件夹下新建一个txt文件,写入一些内容,然后将该文件添加到仓库中,需两步:
- 使用git add <文件名> 告诉git,将文件添加到仓库(还没有真正提交,而是添加到暂存区)
- 使用git commit -m “说明内容” 告诉git将文件提交到仓库
git add命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit就可以一次性把暂存区的所有修改提交到分支
当我们再有修改时,也是同样方式提交
另外,
git status
可查看仓库的当前状态,会告诉我们哪些文件有修改git diff
(difference)可查看具体修改了什么内容
版本回退
git log
命令显示从最近到最远的提交日志
嫌输出信息太多,看得眼花缭乱的,可以试试加上–pretty=oneline参数,即:git log --pretty=oneline
显示出的一串数字是commit id( 版本号)
开始回退版本:
Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
git reset --hard HEAD^
回到上一个版本git reset --hard HEAD^^
回到上上个版本
或者使用commit id进行版本间切换:git reset --hard commit_id
用git log
可以查看提交历史,以便确定要回退到哪个版本(英文状态下按Q可退出git log)
用git reflog
查看命令历史,以便确定要回到未来的哪个版本
指令cat readme.txt
可以查看文件readme.txt中的内容
思考:一个项目的目录(不包括.git文件)就是一个工作区,而目录中的.git隐藏文件夹就是该项目的本地版本库,版本库中有很多东西,其中最重要的是暂存区(stage)和一个HEAD指向的分支(master),其中git add会将修改放进stage,而git commit会将暂存区中所有修改放进master
撤销修改
场景一:当你修改了工作区的内容,尚未git add <filename>
,可使用git checkout -- <filename>
来撤销
场景二:当你修改后已经git add <filename>
到暂存区,可先使用git reset HEAD <filename>
撤销暂存区的修改,再使用git checkout -- <filename>
撤销工作区的修改
场景三:当你修改后已经git commit
到版本库,可使用版本回退方式(git reset --hard HEAD^
或git reset --hard commit_id
)回到上一个版本
git checkout
是用版本库中的版本替换修改后的内容
删除文件
场景一:该文件尚未git add
到暂存区及版本库,仅存在于工作区,那么可以使用rm <filename>
直接删除
场景二:该文件已经提交了版本库,想同时删除工作区及版本库中的该文件,应该先git rm <filename>
,再git commit -m "rm file"
场景三:误删工作区某文件,可供过git checkout -- <filename>
将该文件从版本库恢复
添加远程库
git是分布式版本管理系统,但是当不同开发者处于不同的局域网中或关机时,是无法获取对方版本库中的修改的,这时候就需要一个“中转”的服务器作为公共版本库,github正式起到这样一个作用。
创建SSH KEY
由于本地git仓库与github仓库间的传输是通过SSH加密的,所以需要创建SSH KEY:
第一步:ssh-keygen -t rsa -C "youremail@example.com"
用户主目录下将生成.ssh文件,包含id_rsa和id_rsa.pub两个文件,前者是秘钥,后者是公钥。
第二步:
登陆GitHub,打开“Account settings”,“SSH Keys”页面,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容。
本地库与远程库同步
- 首先,github中创建一个仓库,得到一个SSH地址
- 然后,在本地库目录下执行
git remote add origin SSH地址
,关联我们新建的远程仓库,origin即为远程库的默认名字 - 最后,本地库内容第一次推到远程库
git push -u origin master
,其中-u
是指定origin为默认远程库主机,这样以后再提交只需git push
,无需再指定远程库主机名
这样,就添加了远程库,并与本地库建立了连接,且同步了代码。
要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。
Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。
创建分支
git推荐clone项目后,在新建分支上进行代码修改,这样可以随时提交自己的修改到自己的分支,而不会影响master分支,更不会影响别人的开发。
git版本库实际是每次提交记录的时间线,master既是分支名又是代表这个分支的指针,它指向当前分支的最新的提交,而HEAD指向当前的分支。
创建分支,实际就是创建一个新的分支指针,让它指向最新的提交。
切换分支,实际就是将HEAD指向目标分支的指针。
-
git branch
查看分支 -
git branch <branchname>
创建分支 -
git checkout <branchname>
切换分支 -
git checkout -b <branchname>
创建并切换分支 -
git merge <branchname>
合并某分支到当前分支 -
git branch -d <branchname>
删除某分支
解决冲突
当我们的分支内容通过git merge <filename>
合并到master主分支时,如果报存在冲突,此时可在master文本中发现冲突的内容,此时需要我们手动修改掉冲突内容,然后再add和commit主分支master的修改。
git log --graph
命令可以看到分支合并图
Bug分支
当你正在dev分支修改内容,突然需要修改一个bug,此时你需要将未add和commit的内容暂存一下git stash
,再去创建一个用于修改bug的分支,等到bug修好并提交后,再切换回dev分支,将暂存的内容恢复git stash pop
。
-
git stash
保存现场,将修改内容暂存起来 -
git stash list
查看暂存内容在哪里 -
git stash apply
恢复暂存内容,但是不删除暂存区,即git stash list
仍可看到暂存内容,需通过git stash drop
才能删除 -
git stash pop
同时恢复现场且删除暂存内容 -
git stash drop stash@{数字}
删除指定的暂存内容
如果要丢弃一个没有被合并过的分支,可以通过
git branch -D <name>
强行删除
多人协作
git remote -v
查看远程库信息git pull
拉取最新远程库到本地git checkout -b dev origin/dev
创建远程分支的本地分支
多人协作的工作模式通常是这样:
- 首先,可以试图用
git push origin <branch-name>
推送自己的修改; - 如果推送失败,则因为远程分支比你的本地更新,需要先用
git pull
试图合并; - 如果合并有冲突,则解决冲突:切换到master分支,执行
git merge <branch-name>
,可在文件中看到冲突内容,手动修改后,在本地提交add和commit; - 没有冲突或者解决掉冲突后,再用
git push origin <branch-name>
推送就能成功!
如果git pull
提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to origin/branch-name
创建标签
-
git tag v1.0
为当前分支创建标签 -
git tag
查看当前分支的所有标签 -
git tag <tagname> <commit_id>
为某个历史提交创建标签,git log --pretty=oneline --abbrev-commit
查看历史提交的commit_id -
git show <tagname>
查看标签信息 -
git tag -a <tagname> -m "blablabla" <commit_id>
为指定commit_id创建带有说明文字的标签 -
git push origin <tagname>
可以推送一个本地标签; -
git push origin --tags
可以推送全部未推送过的本地标签; -
git tag -d <tagname>
可以删除一个本地标签; -
git push origin :refs/tags/<tagname>
可以删除一个远程标签。