异构微服务技术实践

一、关于异构微服务

异构微服务 = 异构 + 微服务
异构:系统中的不同功能,使用不同的技术栈。
微服务:系统可以被拆分为多个功能,这些被拆分出来的功能,可提供独立的服务,被称为微服务

二、异构微服务的必要性

2.1异构微服务难点:

  • 异构微服务涉及更多的技术栈,更多种类的开发技能,如果只用一套Python Django开放框架,那开发人员只需要学习Django, 如果要同时使用Node.js的egg,那开发人员既要学习Django, 又要跨语言学习egg

  • 团队成员之间的协作性降低。异构微服务,为了提升效率,不同语言的服务,由不同的人来写,一个只写Python的开发者,可能根本没有指针的概念,和C++开发者交流起来就会比较困难,协作性降低。

  • 不同编程语言的模块之间难以直接复用,通信管理较麻烦,毕竟不同的编程语言,使用不同的解释器,进程之间的通信是一门学问,当然,如果大家都使用标准接口进行通信,通信问题可以解决。

2.2 异构微服务的使用场景

  • 老的技术栈已经不能满足需求,需要通过异构微服务,逐步替换旧的技术栈模块,比如创业公司用Python写了很多服务,随着业务量的加大,Python出现性能瓶颈,需要用用Go语言进行重构,此时,就可以采用异构微服务的技术,使用高性能的Go逐步替换旧的Python模块。

  • 不同的技术栈有各自擅长的领域,虽然超大系统都在用Java,但Python写爬虫真的很快,异构微服务可以让整个系统95%的Java, 5%的Python,既稳定又敏捷。异构微服务,相当于网游中的散人,不拘泥于一个职业的玩法,拥有多个职业的招牌技能,可以轻易应对各种复杂棘手的场景。

  • 平台产品需要提供多种技术栈的接入方式,各种云产品,比如华为云,提供文件存储服务,但也要满足多种语言的接入,这时,华为云的开发者就要给出Python, Java, Node.js,Go 多语言的接入代码。另外微信开放平台的二次开放规范,也提供多种语言的接入,比如PHP,Node.js, Java。谷歌机器学习开源框架TensorFlow也是原生支持多种语言的接入比如Python, Node.js, 其实接入多种平台的需求很容易理解,我们使用腾讯家的QQ,QQ有Mac版,有Windows版,Linux版,安卓版,iOS版,多种版本满足多种平台用户的接入需求,游戏《原神》也时支持多种技术栈接入,既有Windows版,又有iOS版,又有安卓版,又有Ps4版,所以火的一塌糊涂,《原神》跨平台游戏的设计,也体现了异构微服务的设计思想。

三、异构微服务面临的问题

3.1 不同技术栈注册方式不一样,难以统一管理

Restful已经够用了, 但总有一些技术栈,不支持Restful,为了统一管理,我们需要做一个规范,兼容各种微服务的接入行为。

3.2 应用元数据管理方式不同,不能相互理解

元数据本身是规范的数据,通过程序对元数据进行解析,转换为通用的格式,通过程序,实现不同元数据的之间的相互翻译。相互翻译其实是个巨大的工程么,需要N*N种规则,这个可以借鉴谷歌翻译的做法,收录几百种语言,将几百种语言分为几个大类(比如拉丁文,英文算是一个大类,中文,日文,韩文算是一大类),从大类中选择一门语言做代表,比如选中文,日文,韩文中的的中文为代表,先完成中文对日文,和中文对韩文的翻译,最后完成中文对英文的翻译,当完成中文对英文的翻译后,也就完成了日文对英文的翻译,韩文对英文的翻译,极大减少相互翻译的工作量。

3.3 通信协议和编码协议不一致,不能相互通信;

互联网企业都想做平台,有了平台就可以利用平台优势,躺赚!技术框架都想制定标准,有了标准就可以提升锁住开发者,让开发者对框架产生依赖。IE浏览器标准就是很好的例子,虽然IE的标准,但依靠市场份额,依然把适配IE的开发者们搞到崩溃,最终放下狠话 用IE6的人,吃方便面没有调料包!

异构微服务也面临通信协议很编码协议不一致的问题,要顺利完成整合,需要尽可能的兼容各种通信协议和编码协议,让微服务之间可相互通信。

3.4 管理方式有差异,不能统一管理

异构微服务要处理复杂的兼容问题,这些问题五花八门,只能由管理平台参考已有的业务需求,出一个标准,只允许符合标准的微服务接入,对不符合标准的微服务进行改进。

异构微服务管理平台就像是一个考官,出一份试卷,需要接入的微服务,通过考核才可以接入,如果考核不通过,只能补全所需的接入条件,再尝试接入管理平台。

四、异构微服务实践

4.1 统一管理

以中间件的形式,将微服务接入管理中心。
微服务的版本信息和配置信息存入管理中心。
管理中心可以监控每个微服务的运行情况,支持新增,重启,关闭单个微服务。

4.2 透明通信

不要搞一些私有化的东西!所有通信的协议都要有明确的文档,所有接入的微服务严格按照文档实现透明通信,唯有通信透明,控制台才方便管理各种微服务,微服务之间也方便进行数据交互。

4.3 服务治理

异构微服务平台,提供不同技术栈的各类中间件,不同技术栈的微服务,接入平台时,需要使用平台提供的对应中间件,异构微服务控制台通过微服务中的中间件,实现服务治理。

小结

系统把任务外包出去,让各种外部服务完成这些任务,系统本身只负责调度和组装,这便是微服务的思想。

异构微服务距我们也并不遥远,比如建一个网站,建站程序可以用WordPress,数据库要使用Mysql, WordPress和Mysql可以看作是两个微服务,控制中心就是你自己,你只要把WordPress和Mysql组装到一起,就有了个人网站这个系统。

把手机看作一个系统,那手机中安装的App,就是一个个异构微服务,App们被不同的开发者开发,拥有不同的功能,拥有不同的界面,可以被任意删除和新增,可以被系统控制权限,并且可以对进行升级和更新。我们作为用户,只负责安装和删除App, 并不负责开发功能。

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

推荐阅读更多精彩内容