git的常用命令
git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址
git init命令把这个目录变成Git可以管理的仓库
git add <file>,注意,可反复多次使用,添加多个文件
git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的
git status命令可以让我们时刻掌握仓库当前的状态
git diff可以查看修改内容
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id。撤销
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数
git checkout -- readme.txt意思就是,把文件在工作区的修改全部撤销,命令中的--很重要,没有--,就变成了“切换到另一个分支”的命令
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name> 强行删除分支:git branch -D <name>
快速合并xxx分支到master:git merge xxx git merge --no-ff 请注意--no-ff参数,表示禁用Fast forward
查看分支合并图:git log --graph
贮藏当前工作现场: git stash Git还提供了一个stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作
查看贮藏的当前工作现场: git stash list
恢复贮藏的内容到工作区:
一是用git stash apply恢复,但是恢复后,stash内容并不删除,你需要用git stash drop来删除;
另一种方式是用git stash pop,恢复的同时把stash内容也删了
查看远程库信息,使用git remote -v;
要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git
本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用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 pull,如果有冲突,要先处理冲突。
命令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>可以删除一个远程标签
git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址
git init命令把这个目录变成Git可以管理的仓库
git add <file>,注意,可反复多次使用,添加多个文件
git commit命令,-m后面输入的是本次提交的说明,可以输入任意内容,当然最好是有意义的
git status命令可以让我们时刻掌握仓库当前的状态
git diff可以查看修改内容
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id。撤销
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数
git checkout -- readme.txt意思就是,把文件在工作区的修改全部撤销,命令中的--很重要,没有--,就变成了“切换到另一个分支”的命令
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name> 强行删除分支:git branch -D <name>
快速合并xxx分支到master:git merge xxx git merge --no-ff 请注意--no-ff参数,表示禁用Fast forward
查看分支合并图:git log --graph
贮藏当前工作现场: git stash Git还提供了一个stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作
查看贮藏的当前工作现场: git stash list
恢复贮藏的内容到工作区:
一是用git stash apply恢复,但是恢复后,stash内容并不删除,你需要用git stash drop来删除;
另一种方式是用git stash pop,恢复的同时把stash内容也删了
查看远程库信息,使用git remote -v;
要关联一个远程库,使用命令git remote add origin git@server-name:path/repo-name.git
本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用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 pull,如果有冲突,要先处理冲突。
命令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>可以删除一个远程标签