如何从产品架构层面去设计SAAS产品

作者: leo 分类: 精彩设计 发布时间: 2020-01-20 09:12 ė125次查看 6没有评论
曾经有面试官给出过这样一个问题,“如果给你做一个SaaS产品,如何从产品架构层面去设计?

图1 what
当医微达听到这个问题的时候,腹诽了一下,确定这个问题的每个字我都认识,每个词组单独拉出来我也能清晰的理解,但是组合起来就有点费解了。所以医微达委婉的说道:“不好意思,能再解释一下吗?”

图2 sorry
面试官可能看出了疑惑,不知道要回答些什么,然后说,“就是让你负责做一个SaaS你都会做些什么,比如有哪些模块?”这么一说,医微达就懂了,这里要注意,参加面试的朋友遇到开放式命题的时候,第一点要表述的一定是设定场景。这里有两个好处,第一是尽可能设定自己熟悉的场景,避免犯错,第二是面试官如果觉得这个场景过于简单,会给出他想要的场景,这样就能更加清楚的了解面试官希望你回答的范畴在哪。

医微达设定的场景是比如说我们做的是一个电商场景的SaaS,这个产品类似于有赞,那么经过了一系列需求收集分析后,针对电商场景,简单的划分为前台用户端,后台商家端,平台管理端等端口。

用户前台和用户后台

用户端的核心业务流程就是浏览商品>下单>支付>发货>收货>评价>订单完成,商家端的核心业务流程有几个,分别是用户管理、商品管理、供应商管理、营销活动、订单、支付、快递、财务、数据报表等等。

面试官听完之后又问道:“那你是依据什么构建的这个产品框架的呢?或者说基于什么原因这么划分模块?”,医微达回归到现实工作中,如何划分这些模块的依据或者来源大致可以分为:1.竞品分析;2.需求分析;3.流程梳理。

三种方法

通过竞品分析,我们能知道在一般情况下别人是怎么做的,我们不能说他都是对的,但是必定有其道理,如果只是去看别人有什么你就要有,那这是不可理喻的,要分析他为什么要这么做,找到一个根本原因或者依据,而不是一句“存在即合理”就解释了。医微达认为在产品的实际工作中,很多产品经理要做的产品都已经珠玉在前了,重新制造一个轮子并不能说它一定是毫无意义,但是绝大多数企业确实是毫无意义甚至还不如前者。美其名曰借鉴,其实就是抄。当然抄也不是全都照搬,也会根据实际的业务情况、资源配置等等因素去权衡,优化或删减,从而达到既符合企业定位、满足市场需求的同时,又能为产品节省资源。

需求分析,这也是医微达常说的,但是在需求分析的过程中我们可以做很多,其中用户访谈,是医微达认为做SaaS或者做定制化产品很常见的。

比如在做财务系统时,与财务总监、会计、出纳沟通,甚至还需要与CFO、法务沟通,在了解财务的工作内容的时候,就可以通过他们的一些工作习惯和认知,去定义或划分功能模块。这也与尼尔森的“一致性原则”中与用户预期保持一致性相同,甚至也可以说这是与现实映照。

流程梳理,其实这也是需求分析中的一个必然步骤,之所以拉出来说,是因为在做SaaS的时候,有些业务的模式的创新性导致没有一般等价物作为参照,我们需要根据实际商业模式去设计适合他的业务流程和规范,并且为之提供切实有效的系统作为商业开展的保障。在梳理整个业务流程的时候,有哪些场景、哪些角色、哪些流程对应的都需要什么,抽象出来,一目了然。

比如审核,一般SaaS产品都会有工作台,有审核模块,将用户可见、参与的审核信息聚合统一处理,并且大一些的SaaS组合产品会将流程引擎与审核中心独立成SaaS产品给各业务引用,这都是在流程梳理时,通过抽象聚合出来的。

医微达再次重申这个问题:“如果给你做一个SaaS产品,如何从产品架构层面去设计?”这里面有两个名词:SaaS产品,产品架构

那么什么是架构呢?医微达查了百度词条显示:架构,又名软件架构。软件架构(software architecture)是一系列相关的抽象模式,用于指导大型软件系统各个方面的设计。软件架构是一个系统的草图。软件架构描述的对象是直接构成系统的抽象组件。各个组件之间的连接则明确和相对细致地描述组件之间的通讯。在实现阶段,这些抽象组件被细化为实际的组件,比如具体某个类或者对象。在面向对象领域中,组件之间的连接通常用接口(计算机科学)来实现。

翻译成一个词就是高屋建瓴,大白话就是从整体上,将软件高度抽象成组件,通过架构图直观的去表达所规划软件的各个组件以及各个组件之间的关系,并传达软件的业务流程、数据流转。在老王看来,从商业的角度来说,制定一个商业模式也算是一次架构,从企业角度来说,部门的设立与调整也是一次架构。看一下医微达画的一个架构图,想来能有一个较为清楚的认知了。

图7 三层架构图

那么产品架构是什么呢?这里我们只讨论互联网以及软件产品经理的思考,从整体上规划产品,将具象化的产品功能或业务高度抽象并清晰的表达,从产品设计上高度契合软件架构所要达到的效果。软件架构的非功能性特征包括:可靠性;易用性;可扩展性;强壮性;灵活性;性能等等。那么,在做产品规划与设计时,也必须时刻关注这些非功能性特征。

在我们了解了这些之后,再来看这道题就变成了:从整体上规划、设计一个SaaS产品,将具象化的产品功能或业务高度抽象并清晰的表达。虽然分析到这个地步了,但是貌似也没有拿出一个实际有效的答案,属实有点尴尬。在老王看来,这个时候画一个产品架构图来就最好了,但是面试嘛,更多的是口头表述,那医微达就抛砖引玉一下吧。

“针对这个问题,我想首先拟定一个场景,我们假定要做一个电商SaaS产品,那么作为SaaS产品,一般是要具有一些行业通用性,假设我们已经做过了用户调研、竞品分析、需求分析,得出了以下几个需求:1.用户购买商品;2.商家管理商品并且需要给用户发货;3.用户收到货物会评价等等。”

“那么,在经过上述分析之后,我们可以得到一些内容:这个产品至少有三个角色,用户,商户,公司,也就至少有三个终端,我们分为用户前台、商户后台、公司运营平台。那么前台都需要些什么呢,需要商品展示、支付、订单查询、评价,甚至是商品的分类和搜索,未来可能还有会员体系等等。”

“商户后台,根据需求,需要用户管理、商品管理、订单管理、评价管理、供应商管理,未来还会有营销、财务、数据、仓储、物流等等等等,这些模块或者系统来支撑商户后台。公司运营平台也会有客户管理、订单管理、财务管理等等一系列模块或系统。”

“以上其实就是一种产品架构,这是从功能模块来划分的,当业务进一步做大的时候,技术得到了一定的发展,就需要从产品、服务和技术层面去规划产品架构,这个就类似于编程中的MVC框架,对应的产品表现层、服务逻辑层、数据服务层。”(这里大家的叫法和用法都有所区别,不过都是对应MVC中的model-view-controller这种结构)

“至于划分依据,有几个方面:1.竞品分析,根据该领域头部玩家的经验,在其基础上去优化沉淀自有品牌的优势;2.需求分析,在于客户或行业资深专家的沟通中,不难发现一些行业规律,依照行业规律划分也是符合用户行为习惯的;3.流程梳理,在梳理的过程中根据流程的必要性,以降低耦合为目的去划分和提炼必要的模块和功能。”

医微达相信大部分产品经理其实很少正经做产品架构,日常的工作更多的是接到需求,分析需求,然后设计产品。但殊不知又时刻与产品架构保持联系,因为你的每一次新增、改动都会影响整个产品的架构。医微达建议可以试着做一个产品架构,不一定从无到有,也不一定要面面俱到,只要将现有的产品或者模块遵照MVC的三层关系,去抽象并且清晰的表达你所做的产品与其他产品或模块的对应关系和一来关系,就可以了。

0

本文永久链接: http://www.e-weida.com/17622.html

发表评论

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong>

微信二维码
全国分支机构
  • 电话:400-888-9746
  • 邮箱:医微达邮箱地址
  • 网址:www.e-wangbao.com
  • QQ:2021627922
  • 青岛总部地址:青岛市北区开封路88号百洋科技园6楼
  • 上海地址:上海长宁区长宁路1027号3308室
  • 北京地址:北京市东城区东长安街1号东方广场E1-21层

医微达攻略 |  微营销分享 |  案例分享 |  服务资费 |  了解医微达 |  友情链接