分布式系统:分布式架构服务调用

开发
Zuul是spring cloud中的微服务网关。网关: 是一个网络整体系统中的前置门户入口。请求首先通 过网关,进行路径的路由,定位到具体的服务节点上。可以使用zuul的过滤器的请求转发去解决跨域问题。

一、服务调用

和传统的单体架构相比,分布式多了一个远程服务之间的通信,不管是 soa 还是微服务,他们本 质上都是对于业务服务的提炼和复用。那么远程服务之间的调用才是实现分布式的关键因素。

二、实现方式

1、HTTP 应用协议的通信框架

1. HttpURLConnection java 原生 HttpURLConnection是基于http协议的,支持get,post,put,delete等各种请求方 式,最常用的就是get和post

2. Apache Common HttpClient HttpClient 是Apache Common 下的子项目,可以用来提供高效的、最新的、功能丰富的支持 HTTP 协议的客户端编程工具包,并且它支持 HTTP 协议最新的版本。

  • 实现了所有 HTTP 的方法(GET,POST,PUT,HEAD 等)
  • 支持 HTTPS 协议
  • 支持代理服务器等

3. OKhttp3 OKHttp是一个当前主流的网络请求的开源框架, 用于替代HttpUrlConnection和Apache HttpClient

  • 支持http2.0,对一台机器的请求共享一个socket。
  • 采用连接池技术,可以有效的减少Http连接数量。
  • 无缝集成GZIP压缩技术。
  • 支持Response Cache,避免重复请求 域名多IP支持

4. RestTemplate Spring RestTemplate 是 Spring 提供的用于访问 Rest 服务的客户端,RestTemplate 提供了多 种便捷访问远程Http服务的方法,能够大大提高客户端的编写效率,所以很多客户端比如 Android 或者第三方服务商都是使用 RestTemplate 请求 restful 服务。

  • 面向 URL 组件,必须依赖于主机 + 端口 + URI
  • RestTemplate 不依赖于服务接口,仅关注 REST 响应内容
  • Spring Cloud Feign

2、RPC 框架

RPC全称为remote procedure call,即远程过程调用。借助RPC可以做到像本地调用一样调用远 程服务,是一种进程间的通信方式. 。常见的RPC框架有以下几种。

1. Java RMI Java RMI(Romote Method Invocation)是一种基于Java的远程方法调用技术,是Java特有的一 种RPC实现。

2. Hessian

Hessian是一个轻量级的remoting onhttp工具,使用简单的方法提供了RMI的功能. 相比 WebService,Hessian更简单、快捷。采用的是二进制RPC协议,因为采用的是二进制协议,所以 它很适合于发送二进制数据。

3. Dubbo

Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服 务的输出和输入功能,可以和Spring框架无缝集成。Dubbo是一款高性能、轻量级的开源Java RPC 框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注 册和发现。

4. gRPC

gRPC是由Google公司开源的一款高性能的远程过程调用(RPC)框架,可以在任何环境下运行。该 框架提供了负载均衡,跟踪,智能监控,身份验证等功能,可以实现系统间的高效连接。

3、跨域调用

1、跨域

在分布式系统中, 会有调用其他业务系统,导致出现跨域问题,跨域实质上是浏览器的一种保护处 理。如果产生了跨域,服务器在返回结果时就会被浏览器拦截(注意:此时请求是可以正常发起的,只是 浏览器对其进行了拦截),导致响应的内容不可用. 产生跨域的几种情况有一下:

2、常见解决方案

1. 使用jsonp解决网站跨域 缺点:不支持post请求,代码书写比较复杂

2. 使用HttpClient内部转发

3. 使用设置响应头允许跨域 response.setHeader(“
Access-Control-Allow-Origin”, “*”); 设置响应头允许跨域.

4. 基于Nginx搭建企业级API接口网关

5. 使用Zuul搭建微服务API接口网关

Zuul是spring cloud中的微服务网关。网关: 是一个网络整体系统中的前置门户入口。请求首先通 过网关,进行路径的路由,定位到具体的服务节点上。可以使用zuul的过滤器的请求转发去解决跨域问题

责任编辑:武晓燕 来源: 今日头条
相关推荐

2019-10-10 09:16:34

Zookeeper架构分布式

2017-10-27 08:40:44

分布式存储剪枝系统

2023-10-26 18:10:43

分布式并行技术系统

2023-05-12 08:23:03

分布式系统网络

2018-12-14 10:06:22

缓存分布式系统

2023-02-11 00:04:17

分布式系统安全

2017-09-01 05:35:58

分布式计算存储

2019-06-19 15:40:06

分布式锁RedisJava

2017-10-17 08:33:31

存储系统分布式

2017-12-20 16:15:30

分布式系统架构

2019-12-26 08:59:20

Redis主从架构

2017-01-16 14:51:26

京东分布式服务CallGraph

2019-08-05 07:58:01

分布式架构系统

2011-04-18 14:43:23

分布式测试分布式测试

2010-03-24 17:07:52

无线分布式系统

2010-11-01 05:50:46

分布式文件系统

2024-03-01 09:53:34

2018-07-17 08:14:22

分布式分布式锁方位

2022-06-27 08:21:05

Seata分布式事务微服务

2023-02-23 07:55:41

点赞
收藏

51CTO技术栈公众号