golang微服务

栏目: Go · 发布时间: 6年前

内容简介:避免一个模块故障影响整个程序。能够独立部署、运维、升级。服务间通过api通讯。方式2:
golang微服务

避免一个模块故障影响整个程序。能够独立部署、运维、升级。

golang微服务

服务间通过api通讯。

golang微服务
golang微服务
golang微服务
  1. 假设上传服务集群起了多个实例,每个实例相同IP但不同端口,那样对外提供服务呢? 有两种方式:

    方式1:

    上传服务集群向服务注册/发现中心去注册这些对外服务ip+port,然后用户请求上传的时候通过api gw向服务注册/发现中心去请求服务列表,gw拿到服务列表后根据一定的策略(比如随机)返回给客户端,客户端再向具体的服务IP:port去请求上传。

方式2:

上传调度加入LB功能,API网关不直接去服务注册中心去请求服务列表,而是去上传调度去请求一个地址,这个地址是由上传调度根据LB算法返回一个服务IP:PORT,不用gw自己去选择。

  1. api gw的作用:

    可以将用户的请求协议(如http)转换为微服务内部的协议(比如rpc),还可以实现服务的熔断和限流。熔断的意思是某个服务挂掉后,gw就直接告诉用户服务不可用不用阻塞等待了,限流的意思是限制api的访问请求次数。

golang微服务

把上传、下载和API网关分离,因为前两者需要高带宽。。。

这里使用consul进行服务的注册/发现,也可以用etcd,mdms。

微服务的划分粒度要根据具体的场景进行,并不是越细越好。比如上图也可以考虑将transferservice的DB独立出来,只用来存转移相关的数据。uploadservice也可以考虑将普通上传和分块上传隔离出来。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据结构及应用算法教程

数据结构及应用算法教程

2011-5 / 45.00元

《数据结构及应用算法教程(修订版)》从数据类型的角度,分别讨论了四大类型的数据结构的逻辑特性、存储表示及其应用。此外,还专辟一章,以若干实例阐述以抽象数据类型为中心的程序设计方法。书中每一章后都配有适量的习题,以供读者复习提高之用。第1~9章还专门设有“解题指导与示例”一节内容,不仅给出答案,对大部分题目提供了详尽的解答注释;其中的一些算法题还给出了多种解法。书中主要算法和最后一章的实例中的全部程......一起来看看 《数据结构及应用算法教程》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

html转js在线工具
html转js在线工具

html转js在线工具