首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

天元平台-波分DWDM资源巡检架构

我们都知道当今互联网发展特点就是快,我们作为研发所开发的任何产品,包括不限于APP、WEB端、WISE、H5等。本人经历过产品经理提出过要求研发team一个月开发一款新的APP上线,接下来就是避免重复造轮子似的“Ctrl+c&&Ctrl+v”,上线过后的代码运行阶段的稳定性结局可想而知。所以始终牢记一点,写常规代码的过程相对容易,但如何保证线上代码长期稳定的运行才是一个系统能否生存下去的关键,就好比开发一款产品是“0-1”的过程,类比于“婴儿”出生,成长的过程的稳定和恰到好处的高可用率是我们作为研发(“父母”)需要付出很多关心的地方。故而作为一名研发,当前系统在长期运行阶段,暴露许多数据资源不一致问题,这些问题有大有小,严重的影响波分快速扩容带宽需求的业务下发成功率,以及对Controller管控设备产生影响。并且对于整体波分系统的控制通道发生的设备托管问题较为频繁且严重,针对以上特点问题,天元平台项目启动。下文主要从项目概述、数据库、高并发架构、golang高级特性,以下都是我在开发过程中用到的一些经验和技术手段分享,没有最好的技术,只有合适的技术,因此也称不上是最佳实践,仅供参考。

03

Redis与数据库数据一致性

可能谈到保持Redis与Mysql双库的数据一致性,可能很多人最先想到的方案就是读请求和写请求串行化,串到一个内存队列里去。但是这个方案有着一个致命的缺点:读请求和写请求串行化会导致系统的吞吐量大幅度降低,需要使用比正常情况下多几倍的机器去支撑线上的一个请求。Redis与Mysql双库的数据一致性问题为何会出现呢?其实我们可以考虑这么一个业务场景:我们需要更新部分数据,我们首先更新数据库数据,然后清除Redis缓存中的数据。但是数据库更新操作成功了,然而Redis清除缓存出现异常了,这样会导致出现这么一种情况:数据库中的数据已经更新为最新数据,但是Redis缓存中的数据依旧还是老数据,这时候就会出现Redis与Mysql双库的数据一致性问题。

04
领券