项目管理与版本控制

简介: 版本控制最主要的功能就是追踪文件的变更。它将什么时候、什么人更改了文件的什么内容等信息忠实地了记录下来。每一次文件的改变,文件的版本号都将增加。除了记录版本变更外,版本控制的另一个重要功能是并行开发。开发往往是多人协同作业,版本控制可以有效地解决版本的同步以及不同开发者之间的开发通信问题,提高协同开发的效率。并行开发中最常见的不同版本软件的错误(Bug)修正问题也可以通过版本控制中分支与合并的方法有效地解决

版本控制最主要的功能就是追踪文件的变更。它将什么时候、什么人更改了文件的什么内容等信息忠实地了记录下来。每一次文件的改变,文件的版本号都将增加。除了记录版本变更外,版本控制的另一个重要功能是并行开发。开发往往是多人协同作业,版本控制可以有效地解决版本的同步以及不同开发者之间的开发通信问题,提高协同开发的效率。并行开发中最常见的不同版本软件的错误(Bug)修正问题也可以通过版本控制中分支与合并的方法有效地解决


版本控制工具所具备的功能:


  • 协调开发与修改


多人开发或修改服务端同一个文件,互不影响,但又相互有所关联


  • 数据备份:


不仅保存文件与目录的当前状态,同时还保留历史、迭代


  • 版本控制


节约空间、提高效率,在保存每一个版本的文件信息的同时不保存重复数据。


  • 权限控制


对团队中开发人员进行权限控制


对团队外开发者所提交内容进行审核(Git独有)


  • 历史记录


查看修改者、修改内容、日志信息等


具有将版本任意恢复到历史状态,快速开发、迭代


  • 分支管理


允许开发团队在工作中多条生产线同时推进任务,进一步提高效率


Git简介


Git是一个免费的、开源的分布式版本控制系统,旨在快速高效地处理任意类型的项目。Git易于学习,占用空间小,性能极快。它比Subversion、CVS、Perforce和ClearCase等SCM工具具有廉价的本地分支、方便的暂存区和多个工作流等特性。


Git工作流:


在项目开发中使用Git的方式


640 (8).png


单机式:


优点:


  • 简单,很多系统中都有内置;


  • 适合管理文本,如系统配置;


缺点:


  • 管理少量文件,不支持项目的管理;


  • 支持的文件类型单一;


  • 不支持远程,网络传输;


集中式:


以中央仓库作为项目所修改的单点实体,所有的编辑修改都提交到主分支上


640 (9).png



优点:


  • 适合多人团队协作开发;


  • 代码集中化管理;


缺点:


  • 单点故障;


  • 必须联网,无法单机工作;


Git Flow:


“功能驱动式开发”(Feature-driven development,简称FDD)。主要体现为通过为功能开发、发布准备、维护、修改、检查为其建立独立的分支,让其迭代过程更为流畅。


优点:


  • 灵活


  • 适合多人团队协作功能开发


  • 代码分布式化管理;


缺点:


  • 架构复杂


  • 容易冲突


640 (10).png


GitForking:


建立在git flow的基础上,充分使用了git中的fork、pull request以达代码审核的目的


如何理解?个人感悟


以大自然中的树(一颗)比喻,形象化以助于理解。除了唯一主干(树根)外其他都是多分叉的

640 (11).png


单机:树根 <- 树干


集中式:树根 <- 树干 <- 树枝


Git Flow:树根 <- 树干 <- 树枝 <- 树杈


Git Forking:树根 <- 树干 <- 树枝 <- 树杈 <- 树叶

目录
相关文章
|
8月前
|
前端开发 项目管理 数据库
项目管理初识
介绍了下软件项目管理方面的一些做法
72 3
|
8月前
|
存储 开发工具 git
Git的正确使用姿势与最佳事件:团队协作开发和版本控制的最佳实践
Git 是目前最流行的分布式版本控制系统之一,它提供了强大而灵活的工具来管理项目的版本和协作开发。无论您是个人开发者还是团队成员,掌握 Git 的使用方法都是必不可少的。本文将引导您从 Git 的基础知识开始,逐步探索 Git 的进阶功能。
|
3月前
|
敏捷开发 监控 数据可视化
项目经理必看:竞争性项目怎么管理?项目管理知识领域有哪些
在现代企业中,项目管理不仅是技能,更是战略。特别是在竞争性项目中,高效管理时间、资源和团队成为企业成功的关键。本文介绍了竞争性项目的特点、管理步骤及十大知识领域,并推荐了板栗看板企业版作为高效的管理工具。
32 0
|
6月前
|
存储 监控 数据安全/隐私保护
ERP系统中的文档管理与版本控制
【7月更文挑战第25天】 ERP系统中的文档管理与版本控制
146 2
ERP系统中的文档管理与版本控制
|
SQL 运维 jenkins
测试思想-流程规范 SVN代码管理与版本控制
测试思想-流程规范 SVN代码管理与版本控制
165 0
|
运维 测试技术 Linux
软件开发版本控制流程
软件开发版本控制流程
1122 0
软件开发版本控制流程
|
Linux 开发工具 开发者
软件开发之版本控制方式
软件开发之版本控制方式
软件开发之版本控制方式
|
开发工具 git
什么是版本控制
什么是版本控制
849 0
|
JavaScript 安全 搜索推荐
功能十分全面的项目管理工具(文档协作、项目计划、文件管理等)
今天给大伙推荐一个项目管理工具,该工具会提供各类:文档协作功能、在线思维导图、在线审批流程图、项目管理、任务分发、在线评论,文件管理等等。该项目管理工具整套架构采用了前后分离模式,支持多节点部署,使用的技术是Java、Vue、Element-UI、postgresql1等技术栈
|
项目管理
艾伟也谈项目管理,【项目管理】关于异地开发中的源代码管理问题
最近在带领一个异地的团队在进行.Net B/S系统开发工作。两地相隔1000多公里, 两地都有开发人员,源码的统一管理就成了需要解决的问题。针对这个问题,想到如下的解决方法: 一、利用Microsoft Visual SourceSafe的Internet功能 优点: 1.考虑使用VSS是因为他与Microsoft Visual Studio集成的很紧密。
1150 0