一、Git简单介绍
Git是眼下世界上最先进的分布式版本号控制系统。其特点简单来说就是:高端大气上档次!
二、Windows上Git安装
最早Git是在Linux上开发的。非常长一段时间内。Git也仅仅能在Linux和Unix系统上跑。只是,慢慢地有人把它移植到了Windows上。如今,Git能够在Linux、Unix、Mac和Windows这几大平台上正常执行了。
msysgit是Windows版的Git,从http://msysgit.github.io/下载。然后按默认选项安装就可以。安装完毕后,在開始菜单里找到“Git”->“Git
Bash”,蹦出一个类似命令行窗体的东西,就说明Git成功安装!
安装完毕后。还须要最后一步设置,在命令行输入:
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
由于Git是分布式版本号控制系统,所以,每一个机器都必须自报家门:你的名字和Email地址。
三、创建版本号库
什么是版本号库呢?版本号库又名仓库,英文名repository。你能够简单理解成一个文件夹,这个文件夹里面的全部文件都能够被Git管理起来,每一个文件的改动、删除,Git都能跟踪。以便不论什么时刻都能够追踪历史。或者在将来某个时刻能够“还原”。
所以,创建一个版本号库很easy。首先,选择一个合适的地方,创建一个空文件夹:
$ mkdir learngit
$ cd learngit
$ pwd
/Users/michael/learngit
pwd命令用于显示当前文件夹。假设你使用Windows系统,为了避免遇到各种莫名其妙的问题,请确保文件夹名(包括父文件夹)不包括中文。
第二步,通过git init命令把这个文件夹变成Git能够管理的仓库:
$ git init
Initialized empty Git repository in /Users/michael/learngit/.git/
这样版本号库就创建好了。
自己主动创建的.git的文件夹。这个文件夹是Git来跟踪管理版本号库的,没事千万不要手动改动这个文件夹里面的文件,不然改乱了,就把Git仓库给破坏了。
第三步,往版本号库加入文件:全部的版本号控制系统,其实仅仅能跟踪文本文件的修改。比方TXT文件,网页。全部的程序代码等等,Git也不例外。其实使用windows的童鞋千万不要使用Windows自带的记事本编辑不论什么文本文件。
建议你下载Notepad++取代记事本。
<span style="color:#000000;">//假如在当前文件夹创建了一个read.txt文件 $git add read.txt; //把文件加入到仓库 $git commit -m "wrote a readme file" //把文件提交到仓库,-m后面输入的是本次提交的说明,能够输入随意内容</span>
四、经常使用命令:
除了git add 和 git commit,其它经常使用命令例如以下:
1、git status:查看仓库当前的状态
2、git diff file:查看文件详细改动的内容,file是文件名称
3、git log:显示从近期到最远的提交日志
4、cat read.txt:查看文件内容
5、git reflog:查看你使用的命令历史
6、git checkout -- read.txt:撤销对read.txt的全部改动,不要丢掉了--
7、git reset --hard id/^HEAD:回退版本号,id是版本号号。^HEAD是指向最新版本号的指针
8、git rm read.txt:删除read.txt文件,记住要用commit提交才干真正从仓库删除。假设误删。能够用git checkout命令撤销
9、git remote add origin git@github.com:dwqs/csdn.git:将本地仓库和Github上的远程仓库关联,记得将dwqs换成你自己的账户名,csdn.git是你在GitHub上创建的仓库
10、git push -u origin master:把本地库的全部内容推送到远程库上,第一次提交加上-u,第二次提交能够不用了:git push origin master
11、git clone git@github.com:dwqs/csdn.git:把远程仓库csdn.git克隆到本地
12、git checkout -b name:创建name分支。该命令等价于:git branch name;git checkout name
13、git branch:查看当前分支
14、git checkout name:切换到name分支
15、git merge name:合并某分支到当前分支
16、git branch -d name:删除name分支
17、git branch -D name:强行删除name分支
18、git push origin name:将name分支推送到远程仓库
19、git remote -v:查看远程仓库信息
20、git tag:查看标签名
21、git tag tagname:创建标签
22、git show tagname:查看标签信息。
注意:标签不是按时间顺序列出,而是按字母排序的。
23、git tag -a tagname -m tagdesc:创建带说明的标签
24、git tag -d tagname:删除指定标签
25、git push origin tagname:推送某个标签到远程仓库
26、git push origin --tags:一次性推送所有尚未推送到远程的本地标签
27、git push origin :refs/tags/tagname:能够删除一个远程标签。
28、git config --global alias.ps push:将ps作为push的别名。此时,git ps 等价于git push