阿里、滴滴钟爱的微服务为何能与区块链完美融合?

近几年微服务架构技术的成熟,让我们看到了,包括阿里、滴滴、唯品会等,越来越多知名企业开始使用微服务对自身的系统进行重构。甚至在2017年开始大火的区块链行业中,也有区块链项目开始使用微服务架构。

为何这些知名企业都开始抛弃单体架构,转而使用微服务?大火的区块链又为何能和微服务结合在一起呢?

什么是单体架构

从Web应用的早期开始,单体架构就是软件系统架构中最主流的架构,那什么是单体架构呢?

举个例子,假设你要开发一个电子商务系统,其中包含了订单、客户、商品等不同功能的模块。开发完成之后,你将所有的程序统一打包,然后部署到一个服务器中,用户访问系统的所有功能,都是依靠这一个服务器来提供。

像这样,所有功能都部署在同一个服务器中的系统,采用的架构就是单体架构。

单体架构的缺陷

维护过拥有单体架构的大型软件系统的人一定有过这样的体会:当你需要为系统新增一个业务功能时,你需要从代码库中下载所有模块的代码,在IDE中进行部署,然后才能进行开发和测试;本来在某个已有的模块中,已经完成了你需要的部分编码,但是你却无法直接调用,只能拷贝一份同样的代码,然后进行修改,实现新增的业务功能。

这些都是单体架构中模块耦合度高、代码复用性差、可扩展性低的表现。在小型软件系统中,因为业务不会过于复杂,在平衡开发成本之后,通常也可以采用单体架构。

但在大型软件系统中,维护和迭代是持久性的,如何保障开发完成之后,更好的对系统进行维护是必须要重点考虑的,而微服务正是一种能够有效节省维护成本的架构设计。

微服务架构及其特性

微服务是一种架构风格。它将一个复杂的大型软件系统,根据业务的不同,拆分成不同的模块,每个模块可以被独立部署,并对外提供服务。

如果你开发过微服务架构的系统,你会发现,业务驱动,是微服务架构的一个典型特征。

在上世纪80年代初,RPC(远程过程调用)技术出现之后,开发者开始应用RPC来构建大型系统,在这个过程中,开发者发现不是所有技术上能够拆分的功能,都应该被拆分。由此得出的结论是:根据业务进行拆分功能更加合理。这一经验最终进化成为微服务架构中的设计原则之一:业务驱动。

微服务架构的另一个特征是模块化服务。这是什么意思呢?

采用微服务架构开发的系统,每一个独立的业务单元被划分为一个单独的模块,而每一个模块可以被独立的部署在服务器中,提供相应的业务服务。最终所有模块提供的服务组合在一起,就可以形成一套完整的业务流程,成为一个系统。

业务驱动和模块化很好的解决了单体架构系统中存在的问题。模块之间相互独立,通过接口完成模块间的通信,有效降低了代码的耦合度。在开发新增的业务功能时,你只需要从代码库中下载你需要的模块,并不需要下载所有的代码,开发和测试将会更加简单,并且新功能不会对原有的系统产生任何影响,系统的可扩展性得到了有效的提升。

NULS区块链与微服务的完美融合

不仅阿里和滴滴等传统互联网知名企业喜欢微服务架构,从2017年开始大火的区块链行业,也有项目率先使用微服务架构做出了创新。

在2018年7月正式完成主网上线,获得比特大陆战略投资的NULS公有链项目,在1.0的设计中就采用了模块化的思想,想要实现一个可定制的区块链基础设施。

但是NULS1.0的设计并没有做到完美的地步,依然有许多需要优化的地方,其中就包括如下三个主要问题:

l 测试和部署仍然必须应用于整个项目;

l 用户界面仍然是代码库不可分割的一部分;

l 只有一种开发语言可以用来增强系统并进行修改。

为了解决这些问题,进一步优化NULS的整体设计,NULS核心团队和社区成员共同设计了基于微服务的NULS2.0全新架构。

NULS****模块仓库,你的区块链乐高

在使用微服务架构对NULS进行优化之后,NULS将利用微服务模块化的特性,构建一个模块仓库,里面将包含搭建区块链所需要的所有基础模块。

模块仓库的成功构建,让企业或机构定制自己想要的区块链,变成了像是一个搭乐高的过程。例如,一家金融机构,想要用NULS模块仓库搭建一个满足自己业务的区块链系统,这时候可以直接从模块仓库中挑选账户、交易、区块等基础模块进行使用,然后再根据自己的业务需求开发相应的业务模块即可。

之所以说,这像是一个搭乐高的过程,还有一个原因是一个已经开发完成的模块,可以被独立的部署,并对外提供服务,这样每个模块就可以被多个区块链重复使用。这就像你搭乐高,一个模块不仅可以用来搭火车,还可以用来搭汽车。这样模块的复用性就提高了,灵活性也提高了。

完善的开发库,让开发区块链更简单

使用微服务的系统,解决好模块间通信的问题是必须要考虑的,NULS在这一点上也提供了自己的解决方案。

[图片上传失败...(image-6d2699-1547466587135)]

模块间通信是每个模块都必须要处理的任务,为了方便开发,避免重复性的工作,每个基础模块中都会添加一个服务基础库。这样基础模块就可以方便的继承所描述的通用方法,不需要重新编写相应的代码。

[图片上传失败...(image-d947d6-1547466587135)]

为了进一步的减少开发者的工作量,方便外部程序与平台的无缝连接,NULS2.0的架构中,还设计了适应各种终端的基础应用程序库。这些库是一些代码,提供了关于如何管理网络资源的复杂细节,即设计消息,协议处理等,这样的话开发人员就只需要关注他们的应用程序想要解决的问题,而不用关心如何将其集成到平台中。随着时间的推移,这些库可以移植到多种开发语言中,从而吸引更多的外部开发人员加入到项目中。

[图片上传失败...(image-259942-1547466587135)]

NULS是一个面向可定制化服务的区块链基础设施,是全球性区块链开源社区项目,完整的NULS2.0的微服务架构主要分为三层:

第一层:微服务基础架构层;

第二层:区块链基础服务层;

第三层:DAPP应用层。

这个设计跳出了常见的区块链思维局限,从更高的维度对NULS进行了重构。NULS核心团队决定在这个架构基础上来进行NULS2.0的架构重构。这样的设计让NULS将不仅仅是区块链底层基础设施,还是与区块链系统无缝结合的分布式系统基础架构,它将成为一个不同系统间可以进行无缝通信的平台,这将使围绕NULS构建的企业能够更快地蓬勃发展,同时大大降低开发成本。

未来,当NULS真正成为一个强大灵活的平台之后,那番景象一定不可想象!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容