博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
微服务实践
阅读量:7060 次
发布时间:2019-06-28

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

hot3.png

什么是微服务

微服务的两个核心:

  • 微:服务粒度更细,即服务要细到API
  • 服务:提供好服务,让服务好用

总结以上两点,来看这张图:

输入图片说明

从图可以看出,微服务很简单,好的架构就应该简单,我们将服务拆API,每个服务服务于一个完整的功能。

我们将所有API扔到“云上”,用户通过连接“云”获取所有服务,“云”保证了更好的服务。

所以做好微服务,“云”是关键。

微服务的实现

输入图片说明

由图可知,微服务的关键是服务网关。

微服务特点

服务需要细化成API:

  • 每个服务由一组API组成
  • 以API形式对外提供统一格式的服务
  • 使用者可直接使用HTTP
  • API服务需要保证安全可靠

微服务解决的问题:

  • 统一入口
  • 安全控制:放刷限流
  • 统一鉴权:应用鉴权,用户鉴权,OAuth鉴权,ACL
  • 协议转换:http,dubbo,protobuf
  • API配置管理
  • API上线,下线
  • API与服务接口映射
  • 监控与报警
  • 整体架构可扩展,高并发,分布式
  • 服务容器自动收缩,扩容

方案

输入图片说明

  • 负载均衡:nginx/lvs/f5
  • 微服务层:高性能服务网关,统一入口,API配置管理,分流鉴权,服务监控,协议转换
  • 服务治理层:成熟的服务治理框架dubbo,MQ服务之间解耦
  • 弹性云:服务docker化,基于访问压力的实时集群调度与管理

弹性云

弹性云可以保证提供更好的服务,这对运维有很高的要求。这里的弹性云是自动化运维解决方案,对访问压力进行监控,根据监控解决调度应用和发布回收。 输入图片说明

转载于:https://my.oschina.net/u/1000241/blog/1573845

你可能感兴趣的文章
git分支管理
查看>>
VS2017 ASP.NET C#编译ScriptManager bug
查看>>
模数混合电路(模拟、数字电源和地)
查看>>
自然语言处理入门
查看>>
Jquery中children、find区别
查看>>
java窗体
查看>>
zipkin-client:brave核心代码思路整理
查看>>
iOS学习31之UITableVIewCell自定义
查看>>
mysql 分区
查看>>
移动端pc端同步测试工具 Browsersync的安装和使用
查看>>
将获得datebox值的文本形式转为日期格式
查看>>
写给大数据开发初学者的话5[转]
查看>>
LDA数学八卦笔记(三)LDA文本建模
查看>>
2017-2018-1 20155229 《信息安全系统设计基础》课下作业
查看>>
python beautifulsoup爬虫
查看>>
Centos6.x X64 飞信安装
查看>>
python Docker 查看私有仓库镜像
查看>>
mysql主从
查看>>
x2engine
查看>>
1084 矩阵取数问题 V2
查看>>