Git 基础操作

基本操作

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  将工作区的“新建/修改”添加到暂存区

git rm --cached  移除暂存区的修改

git commit  将暂存区的内容提交到本地库

git commit -m "提交日志"  文件从暂存区到本地库

打tag(发布版本)

git tag -m "tag 描述" "tag版本号" 打上标签,这个很重要

git push --tags 推送tag到远端仓库

git 删除本地标签:

git tag -d   标签名

git 删除远程标签:

git push origin :refs/tags/标签名

远端交互


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 :比较工作区和暂存区的指定文件的差异

git diff HEAD|HEAD^|HEAD~|哈希索引值 :比较工作区跟本地库的某个版本的指定文件的差异

实际操作

迁移(示例)

  • 1.从原地址克隆一份裸版本库,比如原本托管于 GitHub。
 git clone --bare git://github.com/username/project.git
  • 2.然后到新的 Git 服务器上创建一个新项目,比如 GitCafe。

  • 3.以镜像推送的方式上传代码到 GitCafe 服务器上。

cd project.git

git push --mirror [email protected]/username/newproject.git
  • 4.删除本地代码
cd ..

rm -rf  project.git
  • 5.到新服务器 GitCafe 上找到 Clone 地址,直接 Clone 到本地就可以了。
git clone [email protected]/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   查看更多信息

后续有记录将持续更新

你可能感兴趣的:(Git 基础操作)