git 学习笔记

一、常用 git 命令

1.1 将本地分支的更新推送到远程仓库,并将本地分支与远程分支建立关联关系:
复制代码
git push -u origin <远程分支名>
1.2 将本地分支的更新推送到远程仓库,并且在推送的同时设置上游(upstream)分支。上游分支是指与本地分支关联的远程分支:
复制代码
git push --set-upstream origin <远程分支名>
1.3 从远程仓库拉取指定远程分支的更新,并将其合并到指定的本地分支,如果本地分支不存在则会创建,但不会被关联:
复制代码
git pull origin <远程分支名>:<本地分支名>
1.4 删除本地分支:
复制代码
git branch -d <本地分支名>
git branch -D <本地分支名>  # 强制删除,即使分支上有未合并的更改
1.5 删除远程分支:
复制代码
git push origin --delete <远程分支名>

二、commit message 命名规范

commit message 格式:<type>(<scope>): <subject>

type (必须,用于说明 git commit 的类别,只允许使用下面的标识):

  • feat:新功能(feature)。
  • fix/to:修复 bug。
    • fix:产生 diff 并自动修复此问题,适合于一次提交直接修复问题。
    • to:只产生 diff 不自动修复此问题,适合于多次提交,最终修复问题提交时使用 fix。
  • docs:文档(documentation)。
  • style:格式(不影响代码运行的变动)。
  • refactor:重构(即不是新增功能,也不是修改 bug 的代码变动)。
  • perf:优化相关,比如提升性能、体验。
  • test:增加测试。
  • chore:构建过程或辅助工具的变动。
  • revert:回滚到上一个版本。
  • merge:代码合并。
  • sync:同步主线或分支的 bug。

scope (可选,用于说明 commit 影响的范围,比如数据层、控制层、视图层等等,视项目不同而不同)

subject (必须,commit 目的的简短描述,不超过 50 个字符,结尾不加句号或其他标点符号)

三、git 分支合并发布流程

正常合并:

shell 复制代码
git add .  # 将所有新增、修改或删除的文件添加到暂存区
git commit -m "message"  # 将暂存区的文件提交
git status  # 查看是否还有文件没有发布上去
git checkout master  # 切换到要合并的分支
git pull  # 在 master 分支上拉取最新代码,避免冲突
git merge t231201  # 在 master 分支上合并 t231201 分支上的代码
git push  # 上传合并后的代码

存在合并冲突:

shell 复制代码
git checkout master  # 切换到要合并的分支
git pull  # 在 master 分支上拉取最新代码,避免冲突
git merge t231201  # 在 master 分支上合并 t231201 分支上的代码
# 如果存在合并冲突,在代码中解决冲突
git add .  # 将处理冲突后的代码提交到暂存区
git merge --continue  # 继续合并
git push  # 上传合并后的代码

参考:

https://zhuanlan.zhihu.com/p/182553920
https://blog.csdn.net/Fan0920/article/details/120128883
https://blog.csdn.net/qq_45677671/article/details/122574671

相关推荐
渣渣小码2 小时前
GIT快速上手(常用指令)
git
会豪18 小时前
Git命令-图解-小白专享
git
韦禾水18 小时前
IntelliJ IDEA 2023更新git凭据
git·intellij idea
Yvonne爱编码19 小时前
构建高效协作的桥梁:前后端衔接实践与接口文档规范详解
前端·git·ajax·webpack·node.js
@CLoudbays_Martin1120 小时前
CDN是否能有效检测并且同时防御Ddos 和 CC 攻击?
java·服务器·网络·数据库·git·数据库开发·时序数据库
oscar9991 天前
Monorepo 全面解析:优势、挑战与适用场景
git·monorepo
龙之叶2 天前
Git Commit 生成与合入 Patch 指南
git
裸奔的大金毛2 天前
Tekton - 自定义镜像配置git仓库克隆
git·ci/cd·devops·tekton
Adorable老犀牛2 天前
可遇不可求的自动化运维工具 | 2 | 实施阶段一:基础准备
运维·git·vscode·python·node.js·自动化
xiaok2 天前
把代码上传到gitee的时候,怎么忽略node_modules文件夹
git·gitlab·github