当前位置: 首页 > news >正文

网站建设域名是什么简单做网站的软件

网站建设域名是什么,简单做网站的软件,wordpress添加主题后怎么添加内容,wordpress评论区美化背景 有了前两篇的帐号权限提取和功能设置提取的架构演进后,有一个问题就紧接着诞生了,对于诸多业务方来说,关键数据源的迁移如何在各个产品落地? 要知道这些数据都很关键: - 对于帐号,获取不到帐号信息是…

背景

有了前两篇的帐号权限提取和功能设置提取的架构演进后,有一个问题就紧接着诞生了,对于诸多业务方来说,关键数据源的迁移如何在各个产品落地?

要知道这些数据都很关键: - 对于帐号,获取不到帐号信息是无法让用户约会和入会的; - 对于权限,用户有没有某个功能,如海外加速,直播、虚拟背景,完全依赖于权限数据; - 对于功能设置,参会人入会是否要静音,是否能开启视频则取决于用户的功能设置项;

这么关键的数据,又做了如此大的调整,从业务方角度不得不考虑两个问题:

  1. 如何降低各个业务服务的接入难度?
  2. 即使各个服务都费力的将代码接入,一旦上线后发现问题如何快速补救?

这是一个全局性的问题,需要统一考虑,否则之前看似合理的架构优化却可能因为对接时的实际困难而落不了地。

也就是这些非功能层面的问题,却有可能让一个架构优化中途夭折,我们需要从软件工程层面解决这些问题。

2. 思路

从业务对接的角度来看,我们要解决两个典型问题:

  • 如何减少对接的工作量;
  • 如何降低对接后的上线风险;

这两个问题,我们通过以下4步来解决。

2.1 代码调用归一化处理

当系统中各个业务层都直接访问DB时,我们是很难作数据源调整的,所以我们首先要作的是:数据访问的归一化处理。简单讲:就是把业务层对DB的访问收扰到一个公共库中,包括两个层面:

  1. 服务内部,所有业务接口访问帐号设置类数据都通过公共库来访问;
  2. 系统层面,所有服务访问帐号设置类数据都通过公共库来访问;

如下图所示:

在这个收拢的过程中我们主要做几件事:

  1. 统一封装数据的访问接口,各个业务都走相同的接口来访问数据;
  2. 统一数据格式,例如:所有业务访问帐号都返回同一套数据结构体;
  3. 数据源没有改变,但各个服务由直接依赖DB改为依赖公共库;

2.2 接入新数据源

作了代码调用的归一化处理后,我们接入新数据源基本只需要改动公共库。具体工作为:

  • 抽象一套数据访问的接口,让新数据源和老数据源都实现同一套接口;
  • 从新数据源获取到数据后,可能需要做下数据格式的转换,让新、老数据源返回的数据格式统一;

抽象接口定义类图如下所示:

这套接口,屏蔽了老数据源和新数据源的获取差异,这样业务服务接入新数据源的工作量能降到最小。

2.3 快速回退支持

通过前面两步,公共库已经提供了新、老两套数据访问接口,业务方可能只需要一行代码改动做个选择即可。这里我们想讨论的一个问题是:当接入新数据源上线后,发现问题如何处理?

  • 第一种选择:把版本回退,回退到老数据源的版本,这会带来其它修改(如客户故障修复)也被牵连回退;
  • 第二种选择:我们做一个配置开关,通过修改配置,快速回退到老版本,其它修改都不受影响;

不难发现,第二种方式明显更稳妥,配置简单示意如下:

# AccountStore的实现版本选择
AccountStoreMode = v2

可能还需要在AccountStore的初始化代码中作一点改动来支持版本选择,比较简单,这里就不示例了。

2.4 降级处理

回退主要是解决已经出故障后如何快速恢复的问题,也就是不论我们恢复多快,至少已经有一部分用户受到了影响,那是否有什么办法来避免故障发生呢?

有,我们可以做数据获取的降级处理,做法也比较简单:当从新数据源获取不到时,可以尝试从老数据源再获取一次。

有同学可能有疑问:降级会不会带来数据的正确性问题?

确实有一定的概率,用户的帐号权限已经在新数据源发生变更,降级访问老数据获取到的还是旧数据,如果用户正好要使用依赖此权限项的功能,则有一定概率与用户预期不符。

但是问题在于:当面临帐号都获取不到的产品可用性问题时,个别功能是否符合预期这类局部问题,还有那么重要吗?而且还是一定概率。

这时候我们就要做权衡,评估哪个问题带来的影响更小,两害取其轻。

软件开发中往往很难有完美的方案,有时候因为技术复杂度,有时候因为成本,这时候做权衡就很重要,选一个我们能够掌控团队有能力实施结果有一点折扣但也能接受的方案,往往更实用。

小结

本文以前面两篇文章账号权限提取和功能设置提取为背景,介绍了当外部依赖发生变化时,如何及时调整业务服务的结构设计。通过引入外部依赖防腐层,来减化架构调整带来的对接工作量,并降低对接新数据源的上线风险。

在软件设计中,防腐层往往被描述为一个适配器,用以将外部依赖和内部业务逻辑解耦。还是之前那个观点,名称叫什么不重要,重在能用它解决项目中的实际问题。

防腐层的适用范围远不止于此,其实从长远角度考虑,产品系统中很多模块都应该设计外部依赖防腐层,像数据库、外部服务接口、消息队列、缓存等。这些看似稳定不变的基础设施,却会在某天因为一个市场风向或客户需求,而被公司要求果断的替换掉,例如:信创带来的技术国产化浪潮……

参考阅读

  • 从帐号权限提取的视角来看架构演进
  • 从功能设置提取的视角来看架构演进
http://www.yayakq.cn/news/97122/

相关文章:

  • 网站建设与管理的内容温州建设
  • 腾讯云网站免费建设php做网站参考文献
  • 西安优秀的集团门户网站建设企业动态模板网站建设
  • 自已如何建网站wordpress吐槽插件
  • 网络营销网站设计怎么自己制作一个网站
  • 北京企业建站系统费用怎么把图片做成链接形式
  • 做网站要用到ps吗在百度上注册公司网站要多少钱
  • 做软件界面的网站c2c电子商务网站的建站目的
  • 公司做网站要三千多吗分类目录网站有哪些
  • 环境网站模板网站建设标题
  • 网贷网站开发北京建设教育协会
  • 网站建设 服务流程深圳招聘网官方网站
  • 漯河做网站的店杭州产品设计公司有哪些
  • 东莞做网站网站建设运行
  • 烟台装修行业网站建设方案wordpress代码高亮太慢
  • 南京市溧水区建设局网站网页制作专业怎么选
  • 山西教育平台网站建设购买网站设计制作
  • dedecms网站信息统计设计师网站接单
  • 重大违法建设项目举报网站网站管理后台下载
  • 点样用外网访问自己做的网站wordpress建手机版目录
  • 免费制作微信小程序的网站网上做效果图网站
  • 网站做国际化太原网站建设推广
  • 做网站难吗_挣钱吗南京建设网站公司哪家好
  • 成都网站系统开发网站建设中页面设计
  • 门户网站开发研究报告巩义做网站xd seo
  • 运城可以做网站的公司简约好看的网站
  • 柳州市诚信体系建设网站网站建设全域云
  • dw做游戏网站代码wordpress性能优化
  • 浙江平安建设信息系统网站网站互动性
  • 李沧建网站公司shopify如何做瀑布流网站