git-repo

基本涵盖了在开发中用到的git命令,能满足日常需求。


目录

  • 配置
  • 初始化本地仓库
  • 文件状态
  • 日志
  • 克隆
  • 查看分支
  • 切换分支
  • 创建分支
  • 删除分支
  • 重命名分支
  • 代码合并
  • 暂存
  • 删除
  • 提交
  • 推送
  • 提交
  • 拉取最新内容
  • 查看文件的改动
  • 回滚版本
  • 撤销
  • 标签
  • Git Flow
  • 子模块
  • 其他

配置

# 查看配置列表
git config -l

# 查看已设置的用户名
git config --global --get user.name

# 设置用户名
git config --global user.name "xiejiahe"

# 查看已设置的邮箱
git config --global --get user.email

# 设置邮箱
git config --global user.email "example@example.com"
复制代码

初始化本地仓库

# 会在当前目录生成.git
git init
复制代码

文件状态

git status
复制代码

日志

# 查看完整历史提交记录
git log

# 查看前N次提交记录 commit message
git log -2

# 查看前N次提交记录,包括diff
git log -p -2

# 搜索关键词
git log -S 你好

# 列出提交者贡献数量
git shortlog -sn
复制代码

克隆

# https 协议
git clone https://github.com/xjh22222228/git-manual.git

# SSH协议
git clone xjh22222228@github.com/xjh22222228/git-manual.git

# 克隆某个分支, -b 后面分支名字
git clone -b v2.8.0 https://github.com/xjh22222228/git-manual.git

# 递归克隆,如果项目包含子模块就非常有用
git clone --recursive xjh22222228@github.com/xjh22222228/git-manual.git

# 克隆深度为1, 不会把历史的记录也克隆,这样可以节省克隆时间
git clone --depth=1 https://github.com/xjh22222228/git-manual.git
复制代码

查看分支

# 查看所有分支
git branch --all

# 查看本地分支
git branch

# 查看远端分支
git branch -r
复制代码

切换分支

# 2种方法,切换到master分支
git checkout master
git switch master

# 切换上一个分支
git checkout -
复制代码

创建分支

# 创建develop分支
git branch develop

# 创建develop分支并切换
git checkout -b develop

# 切换远端分支
git checkout -t origin/dev
复制代码

删除分支

# 删除本地分支
git branch -d <branchName>

# 删除远程分支
git branch -d -r origin/<branchName>
git push origin :<branchName>
复制代码

重命名分支

# 重命名当前分支
git branch -m <branchName>
复制代码

代码合并

# 两步法, 将 feature/v1.0.0 分支代码合并到 develop
git checkout develop
git merge feature/v1.0.0

# 或者一步法
git merge feature/v1.0.0 develop
复制代码

暂存

# 暂存所有
git add -A

# 暂存某个文件
git add ./README.md

# 添加当前目录所有改动文件
git add .

# 暂存一系列文件
git add 1.txt 2.txt ...
复制代码

删除

git add 的反向操作

# 删除1.txt 文件
git rm 1.txt
复制代码

提交

# -m 提交的信息
git commit -m "changes log"

# 提交显示diff变化
git commit -v
复制代码

推送

# 推送内容到主分支
git push -u origin master

# 本地分支推送到远程, 本地分支:远程分支
git push origin <branchName>:<branchName>

# 简写,默认推送当前分支
git push

# 强制推送, -f 是 --force 缩写
git push -f
复制代码

拉取最新内容

# 推荐使用这个,因为不会做自动合并
git fetch origin master

# 相当于git fetch 然后 git merge
git pull

# 后面的意思是: 远程分支名:本地分支名
git pull origin master:master

# 如果是要与本地当前分支合并,则冒号后面的<本地分支名>可以不写
git pull origin master
复制代码

查看文件的改动

# 查看所有文件改动
git diff

# 查看具体文件的改动
git diff README.md

# 查看某个版本的改动, 后面那一窜是commitId, git log后就能看到
git diff d68a1ef2407283516e8e4cb675b434505e39dc54

# 查看某个文件的历史修改记录
git log README.md
git show d68a1ef2407283516e8e4cb675b434505e39dc54 README.md
复制代码

回滚版本

# 回滚上一个版本
git reset --hard HEAD^

# 回滚上两个版本
git reset --hard HEAD^^

# 回退到指定版本,git log 就能看到commit id了
git reset --hard 'commit id'

# 回滚版本是不保存在 git log,如果想查看使用
git reflog
复制代码

撤销

# 撤销当前目录下所有文件的改动
git checkout -- .

# 撤销指定文件修改
git checkout -- README.md

# 暂存区回到工作区, 指定 ./README.md 文件从暂存区回到工作区
git reset HEAD ./README.md

# 撤销commit, 回到工作区, 一般commit id 是前一个
git reset <commit_id>

# 撤销commit, 并且把修改同时撤销
git reset --hard <commit_id>
复制代码

标签

# 列出标签
git tag

# 按照特定模式查找标签, `*` 模板搜索
git tag -l "v1.0.0*"

# 创建带有附注标签
git tag -a v1.1.0 -m "标签描述"

# 创建轻量标签, 不需要带任何参数
git tag v1.1.0

# 后期打标签, 假设之前忘记打标签了,可以通过git log查看commit id
git log
git tag -a v1.1.0 <commit_id>

# 推送到远程,默认只是本地创建
git push origin v1.1.0

# 一次性推送所有标签到远程
git push origin --tags

# 删除标签, 你需要再次运行 git push origin v1.1.0 才能删除远程标签
git tag -d v1.1.0

# 删除远程标签
git push origin --delete v1.1.0

# 检查标签
git checkout v1.1.0
复制代码

Git Flow

Git Flow 不是内置命令,需要单独安装

初始化 每个仓库都必须初始化一次

# 通常直接回车以完成默认设置
git flow init
复制代码

功能

# 开启新的功能
git flow feature start v1.1.0

# 推送到远程, 在团队协作中这一步少不了
git flow feature publish v1.1.0

# 完成功能, 会将当前分支合并到 develop 然后删除分支,回到 develop
git flow feature finish v1.1.0
复制代码

打补丁 hotfix是针对 master 进行打补丁的

# 开启新的 hotfix
git flow hotfix start v1.1.0_hotifx

# 推送到远程
git flow hotfix publish v1.1.0_hotifx

# 完成新的hotfix, 将当前分支合并到 master 和 develop,然后删除分支,回到 develop
git flow hotfix finish v1.1.0_hotifx
复制代码

发布

# 开启新的 release
git flow release start v1.1.0

# 推送到远程
git flow release publish v1.1.0

# 完成, 将当前分支合并到 master 和 develop,删除当前分支然后回到 develop
git flow release finish v1.1.0
复制代码

子模块 Submodule

具体使用还可以看这里 git submodule子模块使用教程

# 添加子模块
git submodule add https://github.com/xjh22222228/git-manual.git

# 更新,有2种方法
# 一步到位
git submodule update --remote
# 或者进入到子模块项目再拉取
git pull

# 修复子模块分支指向 detached head
git submodule foreach -q --recursive 'git checkout $(git config -f $toplevel/.gitmodules submodule.$name.branch || echo master)'

# 删除子模块 common 为子模块名称,一般删除需要三部
git submodule deinit <common>
#清除子模块缓存
git rm --cached common
# 提交代码并推送
git commit -am "Remove a submodule" && git push
复制代码

其他

# 查看远程仓库地址
git remote -v

# 记住提交账号密码
git config --global credential.helper store

# 清除git已保存的用户名和密码
# windows
git credential-manager uninstall
# mac linux
git config --global credential.helper store

# 清除本地git缓存
git rm -r --cached .
复制代码

觉得不错的点个赞哈,谢了~ git-repo

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论

热门产品

php编程基础教程.pptx|php编程培训,php,编程,基础,教程,pptx
php编程基础教程.pptx

历史上的今天:04月30日

热门专题

大理科技管理学校|大理科技管理中等职业技术学校,大理市科技管理中等职业技术学校
大理科技管理学校
APP开发|app开发_app开发公司_app软件开发_专业app开发_云南app开发公司_app定制_原生app开发定制
APP开发
一年制中专|中专学历,中专是什么学历,中专是什么,中专有什么专业,中专升大专,一年制中专
一年制中专
天麻的功效与作用吃法|天麻的功效与作用,天麻的功效与作用吃法,天麻炖什么治头痛最好,天麻的功效与作用禁忌,天麻多少钱一斤,天麻的功效与作用吃法及禁忌,天麻怎么吃效果最好,天麻粉的功效与作用,天麻怎么吃
天麻的功效与作用吃法
小程序开发|微信小程序,小程序开发,小程序,小程序制作,微信小程序开发,小程序公司,小程序开发公司,分销,三级分销系统,分销系统
小程序开发
易捷尔单招|易捷尔单招,易捷尔单招培训,易捷尔单招报名,易捷尔单招考试,易捷尔单招培训学校,易捷尔单招分数
易捷尔单招
安徽开放大学|安徽开放大学报名,安徽开放大学报考,安徽开放大学,什么是安徽开放大学,安徽开放大学学历,安徽开放大学学费,安徽开放大学报名条件,安徽开放大学报名时间,安徽开放大学学历,安徽开放大学专业
安徽开放大学
金诺幼儿园(春城路金诺幼儿园)|昆明官渡区幼儿园,幼儿园报名,官渡区幼儿园,春城路幼儿园,幼儿园招生,学前班,昆明幼儿园,金诺幼儿园,环城南路幼儿园,石井路幼儿园
金诺幼儿园(春城路金诺幼儿园)

微信小程序

微信扫一扫体验

立即
投稿

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部