一、简介:
Git是分布式版本控制系统
分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,
分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,
没有它大家也一样干活,只是交换修改不方便而已。
不需要联网,安全性高,

CVS及SVN都是集中式的版本控制系统
版本库是集中存放在中央服务器的,而干活的时候,用的都是自己的电脑,
所以要先从中央服务器取得最新的版本,然后开始干活,干完活了,再把自己的活推送给中央服务器。
必须联网才能工作,

二、命令使用:

每个机器都必须自报家门:你的名字和Email地址
git config --global user.name lijun
git config --global user.email 574747217@qq.com

创建版本库repository:
#把这个目录变成Git可以管理的仓库
mkdir project && cd project
git init

#把文件添加到仓库
git add

#把文件提交到仓库
git commit -m "说明注释"

#查看文件修改内容:
git diff readme.txt

git status

#查看仓库提交历史记录:
git log

#版本回退:commit_id没必要写全,前几位就可以了,Git会自动去找
git reset --hard commit_id

#每一次命令的记录:
git reflog

--工作区:就是你在电脑里能看到的目录
--版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
版本库里包括暂存区,还有自动创建的第一个分支master,以及指向master的一个指针叫HEAD。
git add把文件添加进去,实际上就是把文件修改添加到暂存区;
git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。

场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。

场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,
第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操作。

场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

#删除文件:先手动删除文件,然后使用git rm <file>和git add<file>效果是一样的。
git rm

三、远程仓库:
注册github,ssh-keygen -t rsa生成公钥,并将公钥配置至github

Quick setup — if you’ve done this kind of thing before
https://github.com/lijun47/learngit.gitWe recommend every repository include a README, LICENSE, and .gitignore.

…or create a new repository on the command line
echo "# learngit" >> README.md
git init
git add README.md
git commit -m "first commit"
git remote add origin https://github.com/lijun47/learngit.git
git push -u origin master

…or push an existing repository from the command line
git remote add origin https://github.com/lijun47/learngit.git

#把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。
#由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送到远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。
git push -u origin master

#更换成ssh方式推送到远程仓库:
git remote -v
git remote rm origin
git remote add origin git@github.com:lijun47/learngit.git
git push origin master

#从远程克隆仓库:
git clone https://url

Git支持多种协议:默认的git://使用ssh,但也可以使用https等其他协议
使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令,
但是在某些只开放http端口的公司内部就无法使用ssh协议而只能用https。

#创建和合并分支:
git checkout -b dev #-b参数表示创建并切换,git branch dev git checkout dev

#用git branch命令查看当前分支:
git branch

#合并:用于合并指定分支到当前分支。Fast-forward
git merge dev
git branch -d dev #合并后删除分支

#Git鼓励大量使用分支:

查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name>