微服务实战系列文章推荐

 微服务是什么?

每个人都有自己的理解;对于从事过大型系统开发的人来说,理解他 更有体会。

2010的时候 我们参与的国家电网95598的系统设计与开发,最开始就是 单体应用;

随着业务的深入理解,安全部署 (内外网隔离)的要求;

单体应用开始分拆成 内网应用服务,内网数据调度中转服务,外网web应用;数据调度中转服务;

那个时候 用的是xfire 进行服务调用;数据中转通过轮询隔离装置 放在 memcached;

每个来调用的人 都给他一个 号(挂号),然后提供一个 获取结果的接口,拿号去轮询获取;


因为 部署的安全要求分拆系统,  这还不够,随着业务的发展,需要做支持 多渠道;

我们支持了 短信服务,app服务,wap网站服务,内部第三方接口服务;

于是又 按照 类型进行 按端拆分,统一后端的服务;

前端通过nginx来 做静态缓存,中间服务集群 通过nginx来做负载分发;通过memcached集群来做 数据缓存;


再后来 用户达到上千万级别的时候,用户服务也进行了拆分,还进行了分库;


总结一下:

当时主要方式是:模块化(分拆为子系统),统一公共服务层,集群部署,拆库。


那么现在 微服务的理念是什么?是全新的么?我 认为不是;

只不过 之前 互联网的大系统少,讨论的不够普遍,现在 接触的人 越来越多了,就会有人去 改进他,优化那些传统的方式方法;

我理解的微服务特点:

按照业务 分拆服务,粒度到功能级别;啊哦,一堆 一堆的 war包或者 jar包;

每个服务可以拥有独立的数据库,可想而知 后面 有一堆 一堆的数据库;

各服务之间 通过接口 或者 MQ进行交互;

当然 每个服务 也是集群部署的;

按照业务拆分的 好处是 灰度发布;一次 升级一次服务,风险控制到最低;

OK 这么多 服务 怎么管理?

于是需要 服务治理; 服务注册 服务发现 服务的监控 负载分发 健康检查(nginx 干的那些事) 接口数据缓存 还有接口权限的管理;

最后 这么一大堆 包  部署 运维 是个麻烦事吧,所以 还需要 自动化运维部署 这些配套设施。

还有一个好处就是 重构 方便,公司中人员流动是很频繁正常的,不要指望 程序员都会按照规范 写代码,坑都是一堆堆的。 

单体项目中 模块之前的依赖 藕断丝连 错综复杂,改了都头疼。

而微服务的理念 可以 解决这个问题,因为足够小,所以即使写的比较糟糕,读懂业务后 就直接 干掉,重写,换个技术框架 甚至语言 都是可以的;

技术上:spring项目换成了springboot,外部 tomcat部署 换成 自带容器jar包启动(启动真心快),rest服务就不说了 之前的xfire+xml 换成springmvc+json

追究 简洁,独立,隔离,高效;


缺点当然 也是很多,我就不啰嗦了,一会看 大神的分析:

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值