开发软件究竟在做什么?

简介: 作为软件行业从业十年的人,在被别人问及你的工作什么的时候。怎么解释你的工作?1. 一个写代码的?(就是码农)2. 一个开发软件的?(就是程序猿)3. 一个做互联网的?(就是在网上买东西的)4. 一个做IT的?(就是修电脑的)

公司级的软件过程实践系列文章,请参见连接。

概述

作为软件行业从业十年的人,在被别人问及你的工作什么的时候。怎么解释你的工作?

  1. 一个写代码的?(就是码农)
  2. 一个开发软件的?(就是程序猿)
  3. 一个做互联网的?(就是在网上买东西的)
  4. 一个做IT的?(就是修电脑的)

这些不能很好的解释我们的工作。就像现在有人找你开发软件,你给他解释了一套之后他还是不理解你到底为啥那么贵一样。

我想了很久,这个问题很难一句话解释清楚。不过还是努力的找了一个比较容易被接受的方式。我是做工程的。因为大家听到工程这两个字最起码会想到复杂的严谨的可靠的有技术含量的等等方面的词。

对于业内人士来说每一个软件都有内部的核心概念与领域,在业务领域内的问题就非常复杂,那将领域问题转换为软件那会同等的复杂。所以才有了DDD这样的解决复杂问题的方法论。在解决这些复杂问题的时候,需要以严谨的态度对待每一个细节。并梳理出各个业务领域的模型与关系。梳理出业务领域模型后将模型以可靠的方式转换为软件实现。并在转换过程中以技术实现为核心。

在现在软件工程与技术还没有发展的比较完备与完善的阶段。很多开发者屈服于现实中的制约与约束,进行不完美的项目实施。这是可以理解的。不过我们软件从业者需要有一颗工程的心,以更加完善,更加可靠的方式想社会各界呈现出更加规范的软件工程。

公司级软件过程

怎么样才能做出完善的工程?虽然软件工程还完美的方法论,但是无外乎这几个方面:蓝图规划,过程域,技术域,运维域,运营域。蓝图规划主要是为公司制定各方面的规划,这样可以在团队运行过程中更有明确的目标。过程域主要有项目管理完成,这个域中主要可以参考PMP。技术域现在是被提及最少,或被忽略的。技术域主要负责公司的技术的一些管理和规划的工作。在运维域中主要负责线上环境,公司基础设施的运维工作。保证线上系统的稳定可用。运营域主要负责线上、线下的运营活动,并需要根据运营决定下一步的开发工作。

这些域每一个都是一个专业性很强的领域。可以说,每一个领域在大学里都对应着一个或者多个专业。用比喻就可以很清楚的看到每个领域都有庞大的知识体系所存在。

这里的域和项目/产品的关系,域和公司的关系都是很复杂的。在产品的生命周期中每时每刻都有这几个域中的工作内容。公司会在这些域中总结出适应于公司的规范和积累。

域与产品生命周期关系

每个域与公司之间的关系会在介绍域时说明。

0. 蓝图规划

现在流行企业进行数字化、信息化转型的工作。企业在做信息化转型时一般的第一步会找个咨询公司咨询需要做什么。一般情况下咨询公司会根据ToGAF的推荐进行数字化转型的分析与咨询工作。

最终会得出企业的信息化的整体规划,以及规划中各项内容的详细分析结果。至于为什么这么做可以参见ToGAF内容。

我最近在写几个系列的Blog。基本上可以映射到这些域上。但是在蓝图规划这方面还没有一个系列的Blog介绍,所以,敬请期待这个域的系列Blog。

1. 过程域(项目管理)

这个域是体现软件实施过程的工程属性最明显的一个域。这里要做的就是怎样在现有的资源下按时按点的交付。这个里面包括所有的PMP的工作,并且还需要进行沉淀与积累。

在过程域最直接的公司级积累就是ISO质量认证和CMMI软件成熟度模型。并且过程域还需要管理公司内部的组织结构,与外部的沟通、对接机制。

这里对应的系列Blog就是本文所在的系列:公司级的软件过程实践

简单的可以分为:

  • 组织管理
  • 过程管理
  • 资源管理

2. 技术域(技术管理)

技术域很多人不知为何物。今天看到一篇文章《雷军点将小米技术委员会:事关生死存亡的四件事》很好的回答了这个问题。公司要想长久的毅力不倒,最主要的是创新力。创新力的力量源泉就是技术。

技术域内的内容可以分为:

  • 技术预演
  • 技术选型
  • 技术设计
  • 技术规划
  • 基础设施

在技术域为公司工程级的技术实施规范,并可以提供工程级的技术支撑。为公司之后的技术发展制定方向与规划。

这里对应的系列Blog就是本文所在的系列:架构设计微服务实践DevOps实践

3. 运维域(软件运行时管理)

运维域保证线上系统的正常运行。这里更加关注线上系统的运行环境,包括:软件环境,硬件环境,网络环境,机房环境,产品的物理架构等等。在做架构设计或者运维设计时需要考虑的最多的内容是做可靠性和可伸缩性。满足这两个就可以满足线上大部分情况。

运维域可以分为:

  • 资产管理
  • 稳定性管理
  • 可靠性管理
  • 安全管理

这里对应的系列Blog就是本文所在的系列:架构设计微服务实践DevOps实践

4. 运营域(运营管理)

运营是我最不熟悉的一个领域。按照我的理解运营是负责产品的方向,针对的客户群分析,业务形态规划等等工作的一个中心。产品是否好用,是否能吸引客户的决定在于这里。

运营域分为:

  • 业务范围
  • 目标客户
  • 目标场景

我觉得运营域的积累是可以为公司积累出在特定领域中的业务模型,并业务分析模型。

这里不熟悉的内容就不出系列的Blog了。

总结

在不断的发展过程中,软件工程不会一直混乱下去。肯定是有更加可控,更加可靠的方法论出现。所以,怎么体现出一个团队或个人的专业能力。专业能力在于能否更加可控,可靠的将团队,产品,公司运营下去。所以,以工程化,体系化的方法论来指导公司、团队运营是必须的过程。这样可以给自己以信心,给外部以可靠。

参考:

TOGAF
PMP

目录
相关文章
|
8月前
|
程序员 测试技术 iOS开发
作为程序员的你,常用的工具软件和普通人有啥不一样呢?
在程序员的世界里面,有哪些新奇的工具软件呢,随小编一起来见证一下吧!
82 0
|
4月前
|
人工智能 程序员 开发工具
『软件工程1』详解软件是什么
该文章探讨了软件工程的基本概念,包括软件的定义、特征、软件危机的原因及其应对策略等内容。
|
数据安全/隐私保护 Windows
工欲善其事,必先利其器,五款实用的办公软件推荐
你电脑中用的最久的软件是哪些?以下是否有你曾经使用过的软件呢?工欲善其事,必先利其器,今天继续分享五款实用的办公软件。
96 0
|
Web App开发 前端开发 开发工具
VisBug,提升web开发者幸福感的开发工具
作为web网页开发者,我们在日常开发过程中经常需要在控制台查看和修改元素的各种属性,以达到我们想要的各种效果。但这种方法往往效率低,而且效果不够直观。今天分享一款浏览器插件VisBug,可以帮助我们更快的查找元素,检查元素属性、间距,调整位置、颜色、字体大小、阴影等等,极大提升我们的开发体验。(支持Chrome、Firefox、Safari、Edge)
VisBug,提升web开发者幸福感的开发工具
|
数据库管理
软件工程——什么是软件
软件工程——什么是软件
587 0
|
缓存 安全 数据库
推荐五款小众又好用的软件,让你眼前一亮
让你眼前一亮的软件,不一定是市面上最流行的。今天,我将推荐给你五款非常小众,但是十分好用的软件。它们功能强大,使用起来也非常方便,而且经过我个人的测试,确保质量有保障。如果你用完后觉得不好用,可以找我哦。
198 0
|
Android开发
分享五款名不见经传但是非常实用的小众软件
我们在使用一些流行的软件的时候,往往会忽略一些知名度不高但是功能非常强大的软件,有的是因为小众,有的是因为名不见经传,总之因为不出名,有许多的好用的软件都不为大众所知道。
210 0
分享五款名不见经传但是非常实用的小众软件
|
前端开发 JavaScript IDE
程序猿开发软件插件推荐
程序猿开发软件插件推荐
216 0
程序猿开发软件插件推荐
|
程序员 iOS开发
程序员们都用什么记笔记软件?
因为有道云和印象笔记的代码框他很不满意 但不出所料的是,下面的回答提供了市面上99%的记笔记软件,毕竟萝卜青菜各有所爱,只要能把看到的技术保存下来,就说明已经学会了
1423 0
程序员们都用什么记笔记软件?

相关实验场景

更多