Git常用指令总结
2018-03-07
Git
原创文章,转载请注明:转自Luozm's Blog1. 常用操作
- 提交暂存:
git add .
- 提交改动:
git commit -m "comments"
- 推送改动:
git push origin master
2. 新建Repo
- 克隆Repo:
git clone *.git
- 新建Repo:
git init
- 添加远程Repo:
git remote add origin *.git
3. 分支
- 创建分支并切换:
git checkout -b branch
(若有改动需要先add,不commit) - 切换回主分支:
git checkout master
- 删除分支:
git branch -d branch
- 推送分支:
git push origin branch
4. 更新合并
- 更新至最新版本:
git pull
(=fetch
+merge
) - 获取改动:
git fetch <branch>
- 合并改动:
git merge <branch>
- 查看不同:
git diff <source_branch><target_branch>
- 解决冲突:
git mergetool
- 强制同步到远程版本:
git fetch
,git reset --hard origin/master
,git pull
5. 回滚
- 查看历史改动(commit level):
git log <--oneline>
- 查看某个历史版本:
git checkout "commit number"
(返回主分支:git checkout master
) - 撤销最新commit(分离HEAD):
git checkout -- <file>
- 撤销暂存(不保存暂存,仅在本地使用):
git reset HEAD<~N> .
- 撤销暂存(创建新commit,保存之前的暂存,在公共分支使用):
git revert HEAD<~N> .
- 追加暂存内容到最新commit:
git commit --amend
6. 忽略文件
使用.gitignore
文件来忽略文件,具体规则如下:
# 此为注释 – 将被 Git 忽略
*.a # 忽略所有 .a 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
解决改动.gitignore
不生效的问题:
有时候在项目开发过程中,突然心血来潮想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交:
git rm -r --cached .
git add .
git commit -m 'update .gitignore'