GIT企业开发使用介绍
0.认识git
git就是一个版本控制器,记录每次的修改以及版本迭代的一个管理系统
至于为什么会有git的出现,主要是为了解决一份代码改了又改,但最后还是要第一版的情况

- git 可以控制电脑上所有格式的文档
1.安装git

- sudo yum install git -y
2.基本操作
2.1 初始化本地仓库-git init
.git这个文件是用来追踪管理仓库的

- mkdir gitcode
- cd gitcode
- git init
2.2 新增配置项
- git config user.name "xxxx"
- git config user.email "xxxxx"
- 查看配置项: git config -l
- 重置配置项:git config --unset user.name/user.email

- 加了global之后就是配置的全局
- git config -global user.name "xxxx"
- git config -global user.email "xxxxx"
- 重置配置项:git config --global --unset user.name/user.email
2.3 工作区 && 暂存区 && 版本库

- 使用git add时,是把文件放入到了版本库中的暂存区中,也有index索引
- 使用git commit时,通过HEAD指针,将文件提交到master中的各个分支中
- 而git能实现版本控制是通过objects实现的,修改的工作区内容会写入对象库的一个新的git对象中
2.4 添加 && 提交

- git add 文件名(一个或多个)
- git commit -m "这次提交的日志信息"
2.5 查看.git文件
- 由于之前进行了代码的提交,.git中也出现了index索引,而HEAD指针是指向的第一个文件的gitID,也就是我们之前提交的那个文件,并且通过 git cat-file -p gitID,也可以查看文件的信息
2.6 修改文件 && 查看文件状态

- git status
- git diff 文件名
2.7 版本回退 && 查看历史版本
| 工作区 | 暂存区 | 版本库 | |
| git reset -- sort | 无 | 无 | 有影响 |
| git reset -- mixed(默认) | 无 | 有影响 | 有影响 |
| git reset -- hard(慎重) | 有影响 | 有影响 | 有影响 |


- git log --pretty=oneline #查看历史版本
- git reflog --pretty=oneline #查看历史所以版本
- git reset --sort --mixed --hard #版本回退
2.8 撤销修改
注:^表示上一版本,^^表示上二个版本
这些撤销操作都不会影响远程仓库的代码,因为没git push
| 工作区 | 暂存区 | 版本库 | 解决方式 |
| xxx code | 1.手动撤销 -- 不推荐,容易出差 2.git checkout -- [filename] -- 推荐 | ||
| xxx code | xxx code | git reset --hard HEAD [filename] git checkout -- [filename] | |
| xxx code | xxx code | xxx code | git retset --hard HEAD^ |

- git checkout -- [filename] -- 推荐

- git reset --hard HEAD [filename]
- git checkout -- [filename]

- git retset --hard HEAD^
2.9 删除文件

- git rm [filename] 会删除工作区,暂存区中的文件
3. 分支管理
3.1 理解分支


- git 版本库中有个HEAD指针,指向master主分支,指向的是最新一次提交

- 既然master是主分支,那么自然就可以在它的基础上,创建分支 && 合并分支
3.2 创建&&切换&&合并分支
查看当前分支: git branch


- 创建分支: git branch [分支名]


- 切换分支:git chekout [分支名]

- 在dev分支下对Readme文件,多增加了一行代码,dev中HEAD指针指向的是最新一次修改
- 所以dev分支和master分支中看到的Readme文件是不同的


- 合并分支: git merge [分支名]
3.3 删除分支

- 删除分支: git branch -d [filename]
3.4 合并冲突



- 合并分支发生了冲突,因为master分支和dev分支都对Readme文件进行了修改,
- 导致git不知道该怎么合并了
解决办法:手动修改解决冲突,重新add 和commit



- 查看分支以图形结构显示:git log --graph --abbrev-commit
- 简短的查看日志: git log --pretty=oneline --abbrrev-commit
3.5 合并模式
- 使用git merge [分支名],合并的分支是看不出结构的(在回顾日志的时候

- 推荐在合并分支时:git merge --no-ff -m "xxx" [分支名]
3.6 分支策略
3.7 bug分支
假如我们现在正在 dev 分⽀上进⾏开发,开发到⼀半,突然发现 master 分⽀上⾯有 bug,需要 解决
- git stash 命令,可以将当前的⼯作区信息进⾏储藏,被储藏的内容可以在将来某个时 间恢复出来( git stash pop )
- 储藏 dev ⼯作区之后,由于我们要基于master分⽀修复 bug,所以需要切回 master 分⽀,再新建临时分⽀fix-bug来修复 bug
- 之后再把fix-bug 和 master分支合并
3.8 强制删除分支

- 强制删除分支 git branch -D [分支名]
4. 远程操作
4.1 理解分布式版本控制系统

4.2 创建远程仓库



4.3 克隆远端仓库-HTTPS


- 克隆远端仓库: git clone 地址
4.5 克隆远端仓库-SSH
ssh的链接会以https链接更加安全,因为克隆远端仓库,需要配置公钥



- ssh-keygen -t rsa -C "邮箱名字"
- cat .ssh/id_rsa.pub #查看公钥
4.6 向远端仓库推送

- 向远端仓库推送:git push
4.7 拉取远程仓库

- 当远端仓库 比 本地仓库更新的时候,就可以进行pull操作(本质就是2个分支的合并)
- 拉取远程仓库 :git pull origin master : master
4.8 忽略特殊文件
当在开发过程中,需要忽略一些文件,并将其不被提交时,可以添加到.gitignore


- !b.so表示b.so可以被git提交
4.9 配置命令别名
- 配置命令别名:git config --global alias.别名 ‘指令’
4.10 删除在本地显示远端也删除的分支
- 命令:git remote prune origin
- 将远程仓库的分支删除之后,再使用git branch -d 分支名,删除本地分支
5.标签
5.1 操作标签

- 添加标签:git tag 标签名 gitID,git tag -a 标签名 -m "xxx" gitID,不写gitID默认是最新一次提交
- 查看所有标签:git tag
- 详细查看标签信息:git tag 标签名
- 删除标签:git tag -d 标签名
5.2 推送标签


- 将本地标签->远端:git push origin 标签名(推送某一个标签),git push origin --tags(推送所有标签)
- 将本地删除的标签->远端:git push origin :标签名
6. 多人协作
同一分支下的多人协作 或 不同分支下的多人协作
6.1 本地分支 与 远程分支关联


- 查看所有分支:git branch -a
- 关联分支: git checkout -b [分支名] origin/分支名
6.2 Pull Requst表单推送





- 使用这种办法进行合并分支到master中,有一个好处,最后这个表单(提交的各种代码信息)
- 项目经理就会查看一番,更加的安全,维护性也更好
7.企业级开发模型
7.1 企业级开发流程

7.2 系统开发环境
7.3 git分支设计模型
| 分⽀ | 名称 | 适⽤环境 |
| master | 主分⽀ | ⽣产环境 |
| release | 预发布分⽀ | 预发布/测试环境 |
| develop | 开发分⽀ | 开发环境 |
| feature | 需求开发分⽀ | 本地 |
| hotfix | 紧急修复分⽀ | 本地 |
master 分⽀
- master 为主分⽀,该分⽀为 只读且唯⼀分⽀ 。⽤于部署到正式发布环境,⼀般由合并release 分⽀得到
- 主分⽀作为稳定的唯⼀代码库,任何情况下不允许直接在 master 分⽀上修改代码
- 产品的功能全部实现后,最终在master分⽀对外发布,另外所有在master分⽀的推送应该 打标签 (tag) 做记录,⽅便追溯
- master 分⽀不可删除。
release 分⽀
- release 为预发布分⽀,基于本次上线所有的 feature 分⽀合并到 develop 分⽀之后,基于 develop 分⽀创建。可以部署到测试或预发布集群
- 命名以 release/ 开头,建议的命名规则: release/version_publishtime 。
- release 分⽀主要⽤于提交给测试⼈员进⾏功能测试。发布提测阶段,会以 release 分⽀代码为基准进⾏提测
- 如果在 release 分⽀测试出问题,需要回归验证 develop 分⽀看否存在此问题
- release 分⽀属于临时分⽀,产品上线后可选删除
develop 分⽀
- develop 为开发分⽀,基于master分⽀创建的只读且唯⼀分⽀,始终保持最新完成以及 bug 修复后的代码。可部署到开发环境对应集群。
- 可根据需求⼤⼩程度确定是由 feature 分⽀合并,还是直接在上⾯开发(⾮常不建议
feature 分⽀
- feature 分⽀通常为新功能或新特性开发分⽀,以 develop 分⽀为基础创建 feature 分
- 命名以 feature/ 开头,建议的命名规则: feature/user_createtime_feature
- 新特性或新功能开发完成后,开发⼈员需合到 develop 分⽀
- ⼀旦该需求发布上线,便将其删除
hotfix 分⽀
- hotfix 分⽀为线上 bug 修复分⽀或叫 补丁分⽀ ,主要⽤于对线上的版本进⾏ bug 修复。当线上出现紧急问题需要⻢上修复时,需要基于 master 分⽀创建 hotfix 分
- ⽀
- 命名以 hotfix/ 开头,建议的命名规则: hotfix/user_createtime_hotfix
- 当问题修复完成后,需要合并到 master 分⽀和 develop 分⽀并推送远程。⼀旦修复上线,便将其删除
7.4 企业级项目管理
Gitee 企业版 - 企业级 DevOps 研发效能平台
=========================================================================
相关文章:
GIT企业开发使用介绍
0.认识git git就是一个版本控制器,记录每次的修改以及版本迭代的一个管理系统 至于为什么会有git的出现,主要是为了解决一份代码改了又改,但最后还是要第一版的情况 git 可以控制电脑上所有格式的文档 1.安装git sudo yum install git -y…...
文件上传-前端验证
查看源代码(找验证代码) 1、源代码直接找到验证代码 示例: function checkFileExt(filename){var flag false; //状态var arr ["jpg","png","gif"]; //允许上传的文件//取出上传文件的扩展名var index f…...
ROT加密算法login-RESERVE
ROT算法(字母轮换加密) 也称为Caesar加密,是一种简单的字母替换加密算法。它通过将字母表中的每个字母向后(或向前)移动固定的位置来加密文本。 加密步骤: 选择一个固定的偏移量(通常是1到25之间的整数)&…...
C++ 新特性 | C++20 常用新特性介绍
目录 1、模块(Modules) 2、协程(Coroutines) 3、概念(Concepts) 4、范围(Ranges) 5、三向比较符(three-way comparison) C软件异常排查从入门到精通系列教程(专栏文章列表,欢迎订阅,持续更新...)https…...
Java设计模式之策略模式实践
1、策略接口 /*** 策略接口*/ public interface DemoStrategy {Result execute(); } 2、策略工厂 /*** 策略工厂*/ Component public class DemoFactory {Resourceprivate final Map<String, DemoStrategy> demoStrategy new ConcurrentHashMap<>();public Demo…...
C语言——结构体数组、结构体指针、结构体函数与二级指针
C语言中的结构体(struct)是一种用户自定义的数据类型,它允许你将不同类型的数据项组合成一个单一的类型。结构体数组则是一种特殊的数组,其元素为结构体类型。这意味着你可以在一个数组中存储多个具有相同结构的记录。 定义结构体…...
【4】策略模式
如上图所示,如果要加入一个新的货币,那么就需要对类中的Calculate函数进行修改,这违背了封闭开放原则。 上图中的方式更加合适,搞一个抽象类(方法中可以用多态调用),然后每个货币自己是一个类&a…...
BGP 反射器联邦实验
要求: 1.如图连接网络,合理规划IP地址,AS 200内IGP协议为OSPF 2.R1属于AS 100;R2-R3-R4小AS 234 R5-R6-R7小AS 567,同时声明大AS 200,R8属于AS 300 3.R2-R5 R4-R7 之间为联邦EBGP邻居关系 4.R1-R8之…...
stm32入门学习13-时钟RTC
(一)时钟RTC stm32内部集成了一个秒计数器RTC,用于显示我们日常的时间,如日期年月日,时分秒等,RTC的主要原理就是进行每秒自增,如果我们知道开始记秒的开始时间,就可以计算现在的日…...
vuex properties of undefined (reading ‘getters‘)
前言: 最近打算用vue 写个音乐播放器,在搞 vuex 的时候遇到一个很神奇报错;vuex 姿势练了千百次了,刚开始的时候我一直以为是代码问题,反复检查了带了,依旧报错。 Error in mounted hook: "TypeError:…...
再谈表的约束
文章目录 自增长唯一键外键 自增长 auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。 自增长的…...
认识一下测试策略与测试方案
目录 测试方案 测试策略 测试策略的内容主要包括 测试技术和工具 测试启动、停止和完成标准 风险分析和应对方案 测试范围 测试角色和职责 测试方法和类型 测试工具 测试层级 测试指标 测试可交付成果 测试方案的内容包括 测试目标 测试范围 测试环境 测试策略…...
Gradle 查看包的依赖关系
在 Terminal 中可以通过 gradle 的命令查看项目中使用的依赖库及其版本,并且可以更加直观的看到各个模块中库之间的依赖关系。同时也可以跟踪并解决与库版本冲突有关的问题。 工具查看 在 Android Studio 中选择 View > Tool Windoors > Gradle 或者直接选择…...
虚幻5|给攻击添加特效
一,打开武器蓝图 选择武器网格体,在细节处找到组件开始重叠,点击 写下以下蓝图,这是最终蓝图,后面会分讲要点 二,actor拥有标签,就是被击打的敌人,我们给actor添加标签 到主界面&am…...
Delphi包管理与依赖:掌握GetIt与DelphiPI的艺术
标题:Delphi包管理与依赖:掌握GetIt与DelphiPI的艺术 在Delphi的广袤生态中,包管理和依赖解决方案是构建大型项目不可或缺的工具。本文将深入探讨Delphi中的两种主要包管理工具:GetIt包管理器和DelphiPI,通过实际代码…...
如何使用unittest和pytest进行python脚本的单元测试
1. 关于unittest和pytest unittest是python内置的支持单元测试的模块,他提供了核心类,TestCase,让单元测试 代码的编写不再是从0开始,不再是作坊式,而是标准化,模板化,工厂化。 pytest是第三方…...
Java中的值传递与引用传递
Java中的值传递与引用传递 在Java编程中,理解值传递与引用传递的概念是编写无误代码的关键。这两个概念有时会让人感到困惑,特别是当它们与对象有关时。现在,我们将一步步地解释这两个概念,帮助你彻底理解它们。 1. 值传递与引用…...
Seaborn库
目录 主要功能和特点 使用方法 实例应用 Seaborn库的最新版本有哪些新功能和改进? 如何在Seaborn中实现复杂的数据预处理步骤,例如数据清洗和转换? Seaborn与其他数据可视化库(如Matplotlib、Plotly)相比有哪些优…...
openresty整合modsecurity
安装依赖包 安装依赖 yum -y install gcc-c flex bison yajl yajl-devel curl-devel curl GeoIP-devel doxygen zlib-devel libtool libxml2-devel libxslt-devel安装依赖包 ftp://ftp.icm.edu.pl/vol/rzm7/linux-centos-vault/7.8.2003/sclo/x86_64/rh/Packages/d/devtools…...
结构体structure、共用体union
目录 结构体 结构体类型的定义形式 结构体类型的大小 内存计算例子 共用体union 用共用体判断大小端 结构体和共用体对比 qsort() 结构体 结构体类型——用来描述复杂数据的一种数据类型 构造类型(用户自定义类型) struc…...
XCTF-web-easyupload
试了试php,php7,pht,phtml等,都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接,得到flag...
零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?
一、核心优势:专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发,是一款收费低廉但功能全面的Windows NAS工具,主打“无学习成本部署” 。与其他NAS软件相比,其优势在于: 无需硬件改造:将任意W…...
React hook之useRef
React useRef 详解 useRef 是 React 提供的一个 Hook,用于在函数组件中创建可变的引用对象。它在 React 开发中有多种重要用途,下面我将全面详细地介绍它的特性和用法。 基本概念 1. 创建 ref const refContainer useRef(initialValue);initialValu…...
ssc377d修改flash分区大小
1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...
苍穹外卖--缓存菜品
1.问题说明 用户端小程序展示的菜品数据都是通过查询数据库获得,如果用户端访问量比较大,数据库访问压力随之增大 2.实现思路 通过Redis来缓存菜品数据,减少数据库查询操作。 缓存逻辑分析: ①每个分类下的菜品保持一份缓存数据…...
uniapp微信小程序视频实时流+pc端预览方案
方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度WebSocket图片帧定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐RTMP推流TRTC/即构SDK推流❌ 付费方案 (部分有免费额度&#x…...
IT供电系统绝缘监测及故障定位解决方案
随着新能源的快速发展,光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域,IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选,但在长期运行中,例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...
Reasoning over Uncertain Text by Generative Large Language Models
https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829https://ojs.aaai.org/index.php/AAAI/article/view/34674/36829 1. 概述 文本中的不确定性在许多语境中传达,从日常对话到特定领域的文档(例如医学文档)(Heritage 2013;Landmark、Gulbrandsen 和 Svenevei…...
Web后端基础(基础知识)
BS架构:Browser/Server,浏览器/服务器架构模式。客户端只需要浏览器,应用程序的逻辑和数据都存储在服务端。 优点:维护方便缺点:体验一般 CS架构:Client/Server,客户端/服务器架构模式。需要单独…...
Kubernetes 网络模型深度解析:Pod IP 与 Service 的负载均衡机制,Service到底是什么?
Pod IP 的本质与特性 Pod IP 的定位 纯端点地址:Pod IP 是分配给 Pod 网络命名空间的真实 IP 地址(如 10.244.1.2)无特殊名称:在 Kubernetes 中,它通常被称为 “Pod IP” 或 “容器 IP”生命周期:与 Pod …...








