Git介绍
Git是一个优秀的分布式协作版本控制工具。相对于其他版本控制软件更加轻量级,具有一些列优点。
使用
本文主要是是自己学习Git过程中的一些学习记录。学习的时候主要是通过阅读廖雪峰老师的Git教程来学习的。先对一些基础进行总结
安装
linux: sudo apt-get install git
windows msysgit
配置
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
常用命令
初始化仓库:git init
添加文件到Git仓库分为两步:
1. git add <file>
注意,可反复多次使用,添加多个文件
2. git commit -m "提交信息"
工作区状态:git status
查看修改:git diff
回滚:HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id
查看提交记录:git log
查看历史命令:git reflog
删除文件:git rm <file>
关联个远程仓库:git remote add origin git@server-name:path/repo-name.git
第一次推送:git push -u origin master
分支相关:
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
切换和创建分支:git checkout -b <name>
合并分支:git merge <name>
删除分支:git branch -d <name>
注意
合并分支时,加上–no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。
暂存现场:git stash
恢复现场:git stash apply
stash 内容不删除 如需删除使用git stash drop
git stash pop
回复的同时,会删除 stash内容
如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>
强行删除
查看远程库信息: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 tag <name>
用于新建一个标签,默认为HEAD,也可以指定一个commit id;
git tag -a <tagname> -m "blablabla..."
可以指定标签信息;
git tag -s <tagname> -m "blablabla..."
可以用PGP签名标签
git tag
可以查看所有标签
git push origin <tagname>
可以推送一个本地标签;
git push origin --tags
可以推送全部未推送过的本地标签;
git tag -d <tagname>
可以删除一个本地标签;
git push origin :refs/tags/<tagname>
可以删除一个远程标签。