践行微服务理念
2016-08-10 18:34
85 查看
最近看到了一篇介绍微服务理念的文章,恰巧在工作中遇到了需要搭建微服务的场景。
情形是这样的:业务方通过token验证用户权限,用户token存储在单台redis服务器上。DBA为了保证token服务的高可用,打算采用redis cluster来避免单点失败,这需要业务方修改代码。因为用到用户token的业务方不只一个,采用的编程语言也不同,有PHP、nodejs,这样牵扯到的人力资源就比较多,后续的维护成本也比较高。
将用户权限验证做成一个单独的服务是一个合理的解决方案。因为业务方需频繁的调用权限验证接口,需要保证该服务在高并发情形下的性能。
团队目前主要使用PHP作为开发语言,对多种语言编写的服务端程序做了性能测试以后,并考虑了后续的学习成本、维护成本,最终选定了swoole作为底层开发框架。
这样做带来的好处
由访问数据库转变为访问接口,由面向实现转变为为面向接口,即使后续采用别的技术实现高可用,甚至采用别的数据库存储用户token,只要保证接口不变,业务方无需做任何改动
新增的业务方,只需按照接口约定编写权限验证逻辑
带来的坏处
需要服务器部署服务,增加了运维成本
由访问数据库转变为访问接口,牺牲了部分性能
情形是这样的:业务方通过token验证用户权限,用户token存储在单台redis服务器上。DBA为了保证token服务的高可用,打算采用redis cluster来避免单点失败,这需要业务方修改代码。因为用到用户token的业务方不只一个,采用的编程语言也不同,有PHP、nodejs,这样牵扯到的人力资源就比较多,后续的维护成本也比较高。
将用户权限验证做成一个单独的服务是一个合理的解决方案。因为业务方需频繁的调用权限验证接口,需要保证该服务在高并发情形下的性能。
团队目前主要使用PHP作为开发语言,对多种语言编写的服务端程序做了性能测试以后,并考虑了后续的学习成本、维护成本,最终选定了swoole作为底层开发框架。
这样做带来的好处
由访问数据库转变为访问接口,由面向实现转变为为面向接口,即使后续采用别的技术实现高可用,甚至采用别的数据库存储用户token,只要保证接口不变,业务方无需做任何改动
新增的业务方,只需按照接口约定编写权限验证逻辑
带来的坏处
需要服务器部署服务,增加了运维成本
由访问数据库转变为访问接口,牺牲了部分性能
相关文章推荐
- 微服务落地践行渐进,4个Q&A一窥金融微服务现状
- 树立彻底的协作与服务理念
- 【技术维新 践行精彩】+ IBM的IT服务管理产品与企业运维
- 系统架构逻辑参考图【强调了领域模型+面向服务编程理念】
- 系统架构逻辑参考图【强调了领域模型+面向服务编程理念】
- 系统架构逻辑参考图【强调了领域模型+面向服务编程理念】
- 微服务理念
- 从疯狂痴迷数据库存储过程到彻底放弃他(信息化系统从基于数据库技术到基于服务理念的转变)
- 网络即服务理念(NaaS)的真正内涵
- 实录分享|微服务落地践行渐进,4个Q&A一窥金融微服务现状
- 酒店人必知的服务理念20条(你可以看看)
- CIO:树立IT服务的理念的重要性
- 扣扣团:为消费者传达提供最便捷、低廉的消费理念,致力于用最好的服务和产品为您挖掘精彩生活每一天。
- 系统架构逻辑参考图【强调了领域模型+面向服务编程理念】
- SDO(盛大在线)的新服务理念
- 从疯狂痴迷数据库存储过程到彻底放弃他(信息化系统从基于数据库技术到基于服务理念的转变)
- 规划环评是生态文明理念的践行
- (摘要)100个伟大的商业理念:理念12:大规模量身定制服务
- 理念和服务