博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
微服务概述之架构演变
阅读量:6511 次
发布时间:2019-06-24

本文共 2261 字,大约阅读时间需要 7 分钟。

hot3.png

写在前面的话

跟同事闲聊,大部分同事对微服务的困惑来源与两点 1.各种名词,不太明白意思 2.对微服务的整体架构不太了解,管中窥豹,比较困惑 所以试着整理以下内容交流探讨,因目前做的ERP系统,所以以ERP系统来进行演化说明, 各ERP模块名词,来源与ORACLE EBS

1.单体结构

1.1 初始阶段

公司刚发展,才一两百的时候,上了一个ERP系统,那时候系统业务量比较小, 所有的代码、数据库、文件都部署在一台服务器上。

1.2 应用服务与数据服务分离阶段

随着公司业务的发展,一台服务器逐渐无法满足需求,越来越多的人来访问,导致性能越来越差,越来越多的数据导致存储空间不足,这时候需要将应用分离;整个网站有三台服务器,应用服务器、文件服务器、数据库服务器

1.3 增加缓存

但是随着公司业务发展到全国,使用的用户越来越多,数据库压力太大导致访问延迟,影响网站的性能,用户体验受到影响。分析后发现,大量的查询来源与ERP-AP ERP-AR ERP-GL 等财务模块的查询操作,增加缓存服务器,对大量发票,应收应付账款来查询进行缓存

2.集群结构

使用缓存后,数据库的访问压力得到缓解,但是单一服务器能处理的连接请求有限 ,在使用高峰,应用服务器会成为整个网站的瓶颈,此时就需要使用到应用服务器集群,增加几台服务器来分担原有服务器的访问及存储压力。

2.1负载均衡

当应用服务器有多台时,例如

192.168.5.1:8089 192.168.5.2:8089 192.168.5.3:8089

当出现三台应用服务器,但是用户只有一个入口www.erp.com,此时就需要在三台服务器之前,出现一台负载均衡服务器(nginx),来统一协调分发用户的请求,使三台服务器平均承担这些请求

2.2反向代理

用户通过www.erp.com来访问负载均衡代理服务器,由代理服务器进行分发请求,称之为反向代理;客户端感知不到代理的存在

2.3正向代理

比如大家常用的VPN工具,访问www.google.com时,无法进行访问;通过登陆到国外的代理服务器,让代理服务器来访问google.com就能访问成功,称之为正向代理。正向代理,隐藏了真实的请求客户端,服务器端不知道真实的客户是谁,客户端的请求的服务都被代理服务器代替来请求了。

2.4数据库读写分离

当网站使用缓存和集群后,绝大部分数据的读写操作可以不通过读取数据库完成。单仍有一部分读操作(缓存访问不命中、缓存过期)和全部的写操作需要访问数据库,当用户量和高峰数据量时,数据库应为负载压力过高,而成为网站的瓶颈,再此我们做数据库的主从备份,来进行读写分离,一台服务器为主数据库服务器,只做修改更新删除操作,另外一台服务器做查询操作,两台服务器从过主从复制机制,把主服务器的数据同步到从服务器上,这样当有应用服务器做读取查询操作时,就可以通过从服务器来读取数据

3.分布式系统

随着公司业务发展,用户规模越来越大,基于全球复杂的业务环境,各国业务合同,海关仓储流程,财务结算等业务都不一致,系统代码越写越大,部署服务越来越慢,一点改动,所有系统模块流程要全部测试一遍,才能上线,上线流程时间长,部署时间长,无法跟上公司业务发展,所以把一个网站拆分成许多不同的应用,每个应用进行独立开发、测试、部署、运维,应用之间通过消息队列的数据分发,或者访问同一个数据存储来构成一个关联的完整系统 例如 ERP这个系统拆分成

财务类: ERP-GL 总账管理系统 ERP-AP 应付账管理 ERP-AR 应收帐管理 ERP-PA 项目会计 ERP-FA 固定资产管理 分销类 ERP-INV 库存管理 ERP-PUR 采购管理 其他 ERP-BIS 商业智能分析系统 ERP-DOC 公共文档存储系统

4.微服务架构

微服务架构实际上是相对于SOA而言,以去中心统一化为特点,微服务架构大体是从互联网企业中兴起的,由于大规模用户,对分布式系统的要求很高,并且业务发展快速,迭代周期很短,一周可能发布一个版本,且不同子系统的发布周期不一样,子系统也不像原有企业计算分布式那样采用集中式存储。 以淘宝的中途岛架构为例,采取前后端分离的方式,对单个业务系统内部实现真正的组件化,并且不同服务之前采用轻量级的交互机制进行通讯。每个服务子系统之间有明确的边界,以子系统为分割,并且不同子系统根据其业务特点,采用不同的语言架构和数据存储方式,运行在自己的容器中。当Docker容器出现、结合敏捷开发管理等方式后,微服务才真正好的落地.当然微服务也带来了改动测试个系统的沟通成本及复杂度,运维和监控的复杂度

5.云服务

系统既然解决了如此多的技术问题,业务复杂度也足够包含,那么可以把整个ERP系统打包成小微型企业、小型企业、中大型企业的解决方案,作为云计算平台的一部分,中小企业不用在去关系技术架构与业务处理,只需要按需付费,就可以是网站随着业务的增长获得更大的存储空间更多的计算资源,和贴合公司业务的业务服务。

参考: [大型网站技术架构 核心原理与案例分析-李智慧](https://item.jd.com/11322972.html)[CSND-博文:面向服务与微服务架构](http://blog.csdn.net/mindfloating/article/details/24583369)

转载于:https://my.oschina.net/Alexyeh/blog/1620881

你可能感兴趣的文章