消灭git 拦路虎,好教程!
http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000
一.创建版本库
①初始化一个Git仓库:git init
②添加文件到Git仓库:1.git add
; 2.git commit
二.时光机穿梭
①查看工作区状态,文件是否被修改过:git status
②查看修改的内容:git diff
1.版本回退
①HEAD:当前版本
②HEAD^:上个版本
③定位版本:
git reset --hard commit_id
④git log:穿梭前,用
git log
可以查看提交历史,以便确定要回退到哪个版本⑤git reflog:要重返未来,用
git reflog
查看命令历史,以便确定要回到未来的哪个版本。2.工作区和暂存区
①工作区:就是你在电脑里能看到的目录,比如我的
learngit
文件夹就是一个工作区②版本库:工作区有一个隐藏目录
.git
,这个不算工作区,而是Git的版本库。③暂存区:Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区。
第一步是用`git add`把文件添加进去,实际上就是把文件修改添加到暂存区; 第二步是用`git commit`提交更改,实际上就是把暂存区的所有内容提交到当前分支。
3.管理修改
①每次修改,如果不add到暂存区,就不会加入到commit中
4.撤销修改
①git checkout – file:丢弃工作区的修改
②git reset HEAD file:把暂存区的修改撤销掉,重新放回工作区
5.删除文件
①git rm:从版本库中删除文件
三.远程仓库
1.添加远程库
①关联一个远程库:git remote add origin git@server-name:path/repo-name.git
②关联后第一次推送master分支的所有内容:git push -u origin master
③此后,每次本地提交后,只要有必要,就可以使用命令git push origin master
推送最新修改
ps:由于远程库是空的,我们第一次推送master
分支时,加上了-u
参数,Git不但会把本地的master
分支内容推送的远程新的master
分支,还会把本地的master
分支和远程的master
分支关联起来,在以后的推送或者拉取时就可以简化命令。
2.从远程库克隆
①要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone
命令克隆
②Git支持多种协议,包括https
,但通过ssh
支持的原生git
协议速度最快
四.分支管理
1.创建与合并分支
①查看分支:git branch
②创建分支:git branch
③切换分支:git cheakout
④创建+切换分支:git cheakout -b
⑤合并某分支到当前分支:git merge
⑥删除分支:git branch - d
2.解决冲突
①查看分支合并图:git log – graph
eg:git log –graph –pretty =oneline –abbrev -commit
3.分支管理策略
①合并分支时加–no-ff参数:普通模式合并,合并后的历史有分支,禁用fast forward
eg:git log –no-ff-m”merge with no–ff”dev
4.Bug分支
①git stash:把当前工作现场隐藏起来,去修复bug
②git stash pop:恢复工作现场同时删除stash内容
5.Feature分支
①开发一个新feature,最好新建一个分支;
②如果要丢弃一个没有被合并过的分支,可以通过git branch -D
强行删除
6.多人协作
①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:建立本地分支和远程分支的关联
五.标签管理
1.创建标签
①git tag
②git tag -a
③git tag -s
④git tag:查看所有标签
2.操作标签
①git push origin
②git push origin –tags:推送全部未推送过的本地标签
③git tag -d
④git push origin :refs/tags/
六.使用GitHub
①在GitHub上,可以任意Fork开源仓库;
②自己拥有Fork后的仓库的读写权限;
③可以推送pull request给官方仓库来贡献代码。
七.自定义Git
1.忽略特殊文件
①忽略某些文件时,需要编写.gitignore
;
2.配置别名
①我们只需要敲一行命令,告诉Git,以后st就表示status:``git config --global alias.st status
eg:
|
|
3.搭建Git服务器
GitHub就是一个免费托管开源代码的远程仓库。但是对于某些视源代码如生命的商业公司来说,既不想公开源代码,又舍不得给GitHub交保护费,那就只能自己搭建一台Git服务器作为私有仓库使用。
例如大众点评code.dianpingoa.com