git init
git add .
git commit -m “”
git status
git diff
工作区-》版本库-》暂存区stage、master分支、指针HEAD-》
add放到暂存区,commit放到分支
git log
reset可以回退版本,还可以撤销add到暂存区的内容,重新回到工作区,可以再次checkout --
撤销commit:git reset --hard HEAD^
git reflog
撤销add前:git checkout -- readme.txt
撤销add:git reset HEAD readme.txt
git rm test.txt + commit 删除
git checkout -- test.txt 找回
/* 掌握命令:vim touch cat ls pwd cd echo */
在http://git.oschina.net创建库:
1.ssh-keygen -t rsa -C "xxxxx@xxxxx.com"# Creates a new ssh key using the provided email
# Generating public/private rsa key pair...
2.cat ~/.ssh/id_rsa.pub
# ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC6eNtGpNGwstc.... 将public key添加
3.ssh -T git@git.oschina.net
4.Welcome to Git@OSC, yourname!
//1.远程库origin与本地关联
git remote add origin git@github.com:michaelliao/learngit.git
//2.将本地库中的所有内容推送到远程库中
git push -u origin master
//3.以后推送使用以下命令
git push origin master
分支:
//创建+切换
git checkout -b 分支名second ->相当于 git branch second + git checkout second
//查看
git branch
//与master合并
git merge second
//删除
git branch -d second
解决冲突:
//查看冲突
git status
//查看分支的合并情况 git log --graph
git log --graph --pretty=oneline --abbrev-commit
分支管理策略:
//禁用”fast forward” 并且加上了commit描述
git merge --no-ff -m "merge with no-ff" second
bug分支:
git stash
git stash list
git stash apply + git stash drop / git stash pop
feature分支
//强行删除分支:如果分支还没有被合并,如果删除将丢失掉修改
git branch -D name
本地分支:master,dev,bug,feature
//从远程抓取新提交
git pull
多⼈人协作的⼯工作模式通常是这样:
- 首先,可以试图⽤git push origin branch-name推送⾃自⼰己的修改;
- 如果推送失败,则因为远程分⽀支⽐比你的本地更新,需要先⽤用git pull试图合并;
- 如果合并有冲突,则解决冲突,并在本地提交;
- 没有冲突或者解决掉冲突后,再⽤用git push origin branch-name推送就能成功!
标签
git tag v1.0
git log --pretty=oneline --abbrev-commit
git tag
git show tangle
git tag -d v1.0
git push origin v1.0
git push origin --tags
//删除远程标签需要先删除本地标签
git tag -d v1.0
git push origin :refs/tags/v1.0
git config --global alias.st status
$ 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 --
参考:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/
http://blog.****.net/windows_nt/article/details/24557831
http://blog.****.net/ithomer/article/details/7529022
http://blog.****.net/ithomer/article/details/7529841