科技一站

 找回密码
 立即注册
查看: 115|回复: 1

如何撰写好技术方案设计-真实案例干货分享

[复制链接]

2

主题

3

帖子

6

积分

新手上路

Rank: 1

积分
6
发表于 2022-9-20 15:35:50 | 显示全部楼层 |阅读模式
一、 前言

作为一个技术开发者,特别是高级、资深、架构师等,往往会遇到根据需求撰写技术方案。那么如何撰写一篇好的技术方案设计,我们今天就来聊一聊这个话题。
二、 技术方案是否有必要

答案是肯定的。
我见过太多由于前期规划不到位(甚至是没有技术方案设计,开个技术讨论会口头沟通一下,就直接评工期开干的),这其中不乏很重要,工期很长的项目。而最后呢,到联调阶段各组串不起来,更可笑的是,产品和产品同学之间都没沟通清楚。导致最终很被动,到处挖坑补洞,而且又花费了更多的时间和精力,甚至导致项目延期,后续扩张性不强等等问题。
所以我认为,技术方案是必不可少的一个环节。往往很多坑在这个阶段就可以避免的。
古人云:"磨刀不误砍柴工",技术方案就是磨刀的过程。


)
三、 如何写好技术方案


  • 要贴合需求,满足需求是大方向。
  • 可实施。要考虑当前条件下是否可落地,如:


  • 团队人员接受能力:技术选型的时候,要考虑团队成员接受能力,盲目引入新技术,可能造成不可预知的问题。
  • 时间成本: 一般来说Java 或者 PHP 后端项目(c语言项目可能会做一年甚至更长时间),3个月时间周期算是比较长的了,假如按照此方案,需要半年甚至更长时间,那可能也不切实际。
  • 资源成本: 例如,项目可能需要引入Redis,Mysql,ES, MongoDB 等基础资源,那公司是否能提供这些资源(服务器是要钱的)。 如果不能,在写技术方案时候,可能就需要考虑是否有替代方案。

  • 应急处理&可靠性保障 只要人能想到的问题,就一定会发生,不能有侥幸心理。 所以要做好出现问题的应对策略,这里就必须做好如:


  • 灰度方案
  • 降级方案
  • 异常处理
  • 容量评估
四、技术方案模板

下面是我总结的技术方案设计模板,希望对大家所有帮助。
1、背景

目前的背景现状,简要说明以往业务所遇到的问题,给出本次项目迭代的原因,解决的技术痛点或业务痛点
2、目标

通过次方案要达到什么样的业务指标,例如,支撑多少QPS,性能相比现在提升多少倍,为后期水平扩展做铺垫
3、整体方案

1)架构图 2)流程图 3)时序图 4)调用链路图
4、存储设计

如Mysql表结构设计,缓存设计,ES存储设计等等,说明Schema、字段类型、默认值、描述信息等。
5、接口定义

列举出接口的结构,参数,返回值等
6、灰度方案

按什么方式灰度,如何做灰度方案,用表格的形式列出分几个阶段灰度,每个阶段大概时间多长。
7、降级方案

当出现问题如何降级操作,如何回滚。将风险降到最低程度。
8、关联系统(功能)影响

重点需要各组注意的地方,相关人员需要特别关注,一一确认到位
9、资源分配情况


  • 人力资源: 实现方案需要多少人力投入(开发人力,测试人力,运维人力)等。
  • 硬件资源: 实现上述方案,需要哪些物理机器资源,运维人员需提前准备。
10、预估工期及时间节点

列举出工期及关键时间节点,如,什么时候联调,什么时候提测,什么时候开始灰度上线,以及后续的迭代完善计划等。
五、温馨提示

我也给大家总结了我之前做系统重构写的技术方案设计文档-PDF版本(已脱敏),给大家总结了2套, 有需要的朋友可以公众号“浅谈架构”后台留言"方案"即可获取。
回复

使用道具 举报

2

主题

4

帖子

10

积分

新手上路

Rank: 1

积分
10
发表于 2025-3-12 04:49:47 | 显示全部楼层
众里寻他千百度,蓦然回首在这里!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|科技一站

GMT+8, 2025-4-9 08:23 , Processed in 0.083029 second(s), 22 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表