好久没有使用git了,突然项目中采用git 发现很多的命令都忘记了,于是就有了这篇文章,果然好记性不如烂笔头啊!
git 全终端命令
git clone xxxx 从xxx 上下载代码
git branch -a 查看所有分枝和主干
git branch -l 查看本地分枝
git branch -r 查看远程分枝
git rm raindow -r -f 删除raindow文件夹以及其下所有的文件
分枝操作
基本操作
git branch demo 命令创建新分支
git push origin demo:demo 将创建的本地分枝推到远程上
git checkout -b demo 创建一个dev分枝并且切换到分枝dev上
git checkout demo 命令切换到新分支
git branch r 命令查看远端库的分枝情况
git branch -d demo 删除本地分枝
git push origin --delete xxx 删除远程分枝
git merge demo 把demo分支的更改和master合并
git fetch origin demo:demo 拉起远程分枝并且创建本地分枝
重命名远程分枝 命令行
原理 在git中重命名远程分支,其实就是先删除远程分支,然后重命名本地分支,再重新提交一个远程分支
git branch -av
git push --delete origin xxx
git branch -m xxx yyy (其中xxx 为原名字,yyy 为新名字)
e.g. : git branch -m devel develop 将devel 命名为develop
gi t push origin develop 将重命名的develop 推送到远程上
git 回滚命令
* 未commit 的代码回滚
* 已经添加至缓存区,但是并没有commit
* 已经commit 但是没有push 的代码回滚
* 已经push的代码回滚
未commit 的代码回滚
直接采用 git checkout . 撤销所有的修改 或者 git checkout xxxx 可以撤销某一个文件的全部修改
已经添加至缓存区,但是并没有commit
git reset HEAD <file> 来取消缓存去的修改
已经commit 但是并没有push 的回滚
已经push 的回滚
git checkout . 撤销所有的修改
git revert HEAD 撤销前一次 commit
git revert HEAD^ 撤销前前一次 commit
git revert commit-id (比如 fa042ce57ebbe5bb9c8db709f719cec2c58ee7ff)撤销指定的版本,撤销也会作为一次提交进行保存。git revert是提交一个新的版本,将需要revert的版本的内容再反向修改回去,版本会递增,不影响之前提交的内容
git merge 和git rebase 命令功能类似
git checkout -b 2017-08-14release 2017-08-14release
You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.
Git clone 整个仓库后使用 git checkout tag_name 就可以取得该 tag 对应的代码了。
但是,这时候 git 可能会提示你当前处于一个“detached HEAD" 状态,因为 tag 相当于是一个快照,是不能更改它的代码的,如果要在 tag 代码的基础上做修改,你需要一个分支:
git checkout -b branch_name tag_name
这样会从 tag 创建一个分支,然后就和普通的 git 操作一样了。