分支(Branches):
功能开发:当团队成员需要开发新的功能时,可以创建一个新的功能分支。这个分支可以独立于主开发线,不影响其他开发工作,同时允许团队成员在不干扰主要开发线的情况下进行工作。
Bug 修复:如果在主开发线上发现了 Bug,团队可以创建一个专门的修复分支来解决问题,而不必等待当前正在进行的开发完成。
版本发布:在准备发布新版本时,可以为发布创建一个专门的分支。这样团队可以继续在主开发线上进行新功能的开发,同时在发布分支上进行最后的稳定性测试和 bug 修复。
标签(Tags):
版本发布:当软件达到一个里程碑式的版本,比如一个重要的发布版本或者里程碑版本,团队可以为该版本创建一个标签。这个标签可以被用来标识对应版本的代码状态,方便日后回溯和管理。
重要事件:有些团队会在代码中打标签以标识重要事件,比如重大功能上线、重要的架构调整等,以便日后追踪了解项目发展的历程。
开发(Development):
代表着程序员或开发团队编写、调试和测试新功能或修改现有功能的阶段。
在开发环境中,开发人员可以自由地进行代码编辑、构建和调试,以实现新功能或解决现有问题。
这个阶段通常是代码变动最频繁、灵活度要求最高的阶段。
测试(Testing):
代表着对开发完成的功能、模块或整体系统进行各种测试,包括单元测试、集成测试、验收测试等。
在测试环境中,测试人员或自动化测试工具会对软件进行严格的测试以确保其功能的正确性、性能的稳定性等。
这个阶段的重点是验证软件的质量,发现并修复潜在的缺陷。
演示(Staging):
代表着将已经通过开发和测试的功能部署到一个类似生产环境的环境中进行最终的集成测试和验证。
在演示环境中,通常会模拟真实的生产环境配置,包括数据库、缓存、消息队列等,以确保软件能够正常运行并与其他系统协作。
这个阶段的目标是确保部署到生产环境之前的系统稳定性和一致性。
生产(Production):
代表着最终用户会接触到的实际运行环境,软件在这里提供服务并处理真实的数据和用户请求。
在生产环境中,软件需要保持高可用性、高性能和安全性,并且通常需要与监控系统结合以及随时准备应对故障。
这个阶段的关注点是确保系统可靠地为最终用户提供服务,并及时响应和处理各种异常情况。
1.3.分支与标签的关系
"dev"阶段对应"alpha"状态,表示正在开发阶段的软件版本。
"test"阶段对应"beta"状态,表示正在测试阶段的软件版本。
"pre"阶段对应"rc"状态,表示预发布或者灰度测试阶段的软件版本。
"pro"阶段对应"r"状态,表示正式发布或者生产环境中的软件版本。
1.二、Git分支的讲解
git branch //查看本地分支
git branch -a //查看远程分支
创建分支git branch name //仅仅保存本地,远程还需要push
切换分支git checkout name
当前切换到了dev下
合并某分支到当前分支 git merge name
我先在dev提交五个文件后再到test合并
分支提交远程git push origin name
删除分支(先删除本地才能删除远程,删除本地需要先切其他分支)
git branch -d name //删除本地分支
git push origin --delete dev //删除远程分支
删除就不为大家演示了,自己去尝试就可以啦。
右键git工程,进入git,选择Branches
选择要切换的分支
当前的分支是master,我新建一个dev并切换
现在已经切换到dev里面了
但是 “Remote Branches” 下依然只有一个 master 分支,表明在我们的远程仓库依然只有一个master 分支,因此我们还需要把在本地仓库新建的分支推送到远程仓库中,这样就可以在远程仓库中看到新建的分支了。
单击dev2 ,然后在左边单击 “Push” ,弹出推送对话框。单击 “Push” 推送到远程仓库,这样分支新建操作彻底完成,可以看到在"Remote Branches"分支下面出现了“dev2 ”,我们可以在该分支进行编码并进行拉取和推送操作。
如果删除分支之前,建议先切换到(Checkout)其他分支,例如,Checkout到master分支,当然这并不强制,只是为了方便删除分支而已
删除就不给大家演示了。
发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本。将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。所以,标签也是版本库的一个快照。
首先,切换到需要打标签的分支上,例如:test,再创建标签
创建好啦
推送标签到远程git push origin
删除tag
如果标签已经推送到远程,要删除远程标签就麻烦一点,先从本地删除
git tag -d 1.0.0-alpha
然后,再从远程删除。删除命令也是push,但是格式如下:
git push origin :refs/tags/1.0.0-alpha
删除就不演示了,有兴趣自己尝试。
idea创建tag
可以右键项目,然后按照 Git -> Repository -> Tag… 创建tag。
或 顶部菜单栏 按照 VCS -> Git-> Tag… 创建tag