①初始化一个Git仓库:git initgit
②添加文件到Git仓库:1.git add<file> ; 2.git commitruby
①查看工做区状态,文件是否被修改过:git status服务器
②查看修改的内容:git diffssh
①HEAD:当前版本spa
②HEAD^:上个版本code
③定位版本:git reset --hard commit_id
orm
④git log:穿梭前,用git log
能够查看提交历史,以便肯定要回退到哪一个版本server
⑤git reflog:要重返将来,用git reflog
查看命令历史,以便肯定要回到将来的哪一个版本。ci
①工做区:就是你在电脑里能看到的目录,好比个人learngit
文件夹就是一个工做区开发
②版本库:工做区有一个隐藏目录.git
,这个不算工做区,而是Git的版本库。
③暂存区:Git的版本库里存了不少东西,其中最重要的就是称为stage(或者叫index)的暂存区。
第一步是用git add
把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用git commit
提交更改,实际上就是把暂存区的全部内容提交到当前分支。
①每次修改,若是不add到暂存区,就不会加入到commit中
①git checkout -- file:丢弃工做区的修改
②git reset HEAD file:把暂存区的修改撤销掉,从新放回工做区
①git rm:从版本库中删除文件
①关联一个远程库: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
分支关联起来,在之后的推送或者拉取时就能够简化命令。
①要克隆一个仓库,首先必须知道仓库的地址,而后使用git clone
命令克隆
②Git支持多种协议,包括https
,但经过ssh
支持的原生git
协议速度最快
①查看分支:git branch
②建立分支:git branch<name>
③切换分支:git cheakout<name>
④建立+切换分支:git cheakout -b <name>
⑤合并某分支到当前分支:git merge<name>
⑥删除分支:git branch - d <name>
①查看分支合并图:git log -- graph
eg:git log --graph --pretty =oneline --abbrev -commit
①合并分支时加--no-ff参数:普通模式合并,合并后的历史有分支,禁用fast forward
eg:git log --no-ff-m"merge with no--ff"dev
①git stash:把当前工做现场隐藏起来,去修复bug
②git stash pop:恢复工做现场同时删除stash内容
①开发一个新feature,最好新建一个分支;
②若是要丢弃一个没有被合并过的分支,能够经过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 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>:删除一个远程标签
①在GitHub上,能够任意Fork开源仓库;
②本身拥有Fork后的仓库的读写权限;
③能够推送pull request给官方仓库来贡献代码。
①忽略某些文件时,须要编写.gitignore
;
①咱们只须要敲一行命令,告诉Git,之后
st
就表示status
:git config --global alias.st status
eg:
$ git config --global alias.co checkout $ git config --global alias.ci commit $ git config --global alias.br branch
$ git config --global alias.unstage 'reset HEAD'
$ git config --global alias.last 'log -1'
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
GitHub就是一个免费托管开源代码的远程仓库。可是对于某些视源代码如生命的商业公司来讲,既不想公开源代码,又舍不得给GitHub交保护费,那就只能本身搭建一台Git服务器做为私有仓库使用。
例如大众点评code.dianpingoa.com