基本操作
git config -l 查看git配置
git config --global core.excludesfile ~/.gitignore 配置全局的 定义Git全局的 .gitignore 文件
git config --global http.postBuffer 524288000 配置文件大小限制 500M
git ls-files 查看本地缓存(就是commit之后存在本地的文件)
git rm -r --cached . 删除本地缓存 --cached + (文件路径)
git commit --amend -CHEAD (使用完--cached就用 commit --amend -CHEAD 配合使用)
git commit --amend amend具有修改最后一次commit提交的功能
git init 初始化本地库
git status 查看工作区、暂存区的状态
git add <file name> 将工作区的“新建/修改”添加到暂存区
git rm --cached <file name> 移除暂存区的修改
git commit <file name> 将暂存区的内容提交到本地库
git commit -m "提交日志" <file name> 文件从暂存区到本地库
打tag(发布版本)
git tag -m "tag 描述" "tag版本号" 打上标签,这个很重要
git push --tags 推送tag到远端仓库
远端交互
git clone <远程库地址> 克隆远程库
git remote -v 查看远程库地址别名
git remote add <别名> <远程库地址> 新建远程库地址别名
git remote rm <别名> 删除本地中远程库别名
git push <别名> <分支名> 本地库某个分支推送到远程库,分支必须指定
git pull <别名> <分支名> 把远程库的修改拉取到本地(该命令包括git fetch,git merge)
git log:查看历史提交(空格向下翻页,b向上翻页,q退出)
git log --pretty=oneline:以漂亮的一行显示,包含全部哈希索引值
git log --oneline:以简洁的一行显示,包含简洁哈希索引值
git reflog:以简洁的一行显示,包含简洁哈希索引值,同时显示移动到某个历史版本所需的步数
分支操作
git branch -l 查看本地分支
git branch -r 查看远端分支
git branch -a 查看全部分支(本地和远端)
git branch -v 查看所有分支
git branch -d <分支名> 删除本地分支
git branch -r -d origin/<分支名> 删除远程分支
git push origin <分支名> 删除远程分支
git branch <分支名> 新建分支
git checkout <分支名> 切换分支
git merge <被合并分支名> 合并分支
版本控制
git reset --hard 简洁/完整哈希索引值:回到指定哈希值所对应的版本
git reset --hard HEAD:强制工作区、暂存区、本地库为当前HEAD指针所在的版本
git reset --hard HEAD^:后退一个版本(一个^表示回退一个版本)
git reset --hard HEAD~1:后退一个版本(波浪线~后面的数字表示后退几个版本)
比较差异
git diff:比较工作区和暂存区的所有文件差异
git diff <file name>:比较工作区和暂存区的指定文件的差异
git diff HEAD|HEAD^|HEAD~|哈希索引值 <file name>:比较工作区跟本地库的某个版本的指定文件的差异
实际操作
迁移(示例)
- 1.从原地址克隆一份裸版本库,比如原本托管于 GitHub。
git clone --bare git://github.com/username/project.git
2.然后到新的 Git 服务器上创建一个新项目,比如 GitCafe。
3.以镜像推送的方式上传代码到 GitCafe 服务器上。
cd project.git
git push --mirror git@gitcafe.com/username/newproject.git
- 4.删除本地代码
cd ..
rm -rf project.git
- 5.到新服务器 GitCafe 上找到 Clone 地址,直接 Clone 到本地就可以了。
git clone git@gitcafe.com/username/newproject.git
- 6.显示本地 tag
git tag
Remote_Systems_Operation
- 7.删除本地tag
git tag -d Remote_Systems_Operation
- 8.用push, 删除远程tag
git push origin :refs/tags/Remote_Systems_Operation
git stash(暂存命令-很实用)
git stash 可用来暂存当前正在进行的工作, 比如想pull 最新代码, 又不想加新commit, 或者另外一种情况,为了fix 一个紧急的bug, 先stash, 使返回到自己上一个commit, 改完bug之后再stash pop, 继续原来的工作。
基础命令:
git stash 存储当前未提交的文件
git stash list 列出当前git的所有暂存清单
git show stash@{0} 指定回到0的暂存文件
git stash pop 回归到最后一个暂存清单并且删除该暂存清单
git stash clear 清空暂存清单
git stash --help 查看更多信息