当前位置:网站首页>分布式架构服务调用
分布式架构服务调用
2022-08-08 14:52:00 【悠然予夏】
1、服务调用
和传统的单体架构相比,分布式多了一个远程服务之间的通信,不管是 soa 还是微服务,他们本质上都是对于业务服务的提炼和复用。那么远程服务之间的调用才是实现分布式的关键因素。
2、实现方式
2.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.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、跨域调用
3.1、跨域
在分布式系统中, 会有调用其他业务系统,导致出现跨域问题,跨域实质上是浏览器的一种保护处理。如果产生了跨域,服务器在返回结果时就会被浏览器拦截(注意:此时请求是可以正常发起的,只是浏览器对其进行了拦截),导致响应的内容不可用. 产生跨域的几种情况有一下:
3.2、常见的解决方案
1. 使用jsonp解决网站跨域
缺点:不支持post请求,代码书写比较复杂
2. 使用HttpClient内部转发
3. 使用设置响应头允许跨域
response.setHeader(“Access-Control-Allow-Origin”, “*”); 设置响应头允许跨域.
4. 基于Nginx搭建企业级API接口网关
5. 使用Zuul搭建微服务API接口网关
Zuul是spring cloud中的微服务网关。网关: 是一个网络整体系统中的前置门户入口。请求首先通过网关,进行路径的路由,定位到具体的服务节点上。可以使用zuul的过滤器的请求转发去解决跨域问题
边栏推荐
猜你喜欢
随机推荐
如何使用 Eolink 实现 API 文档自动生成
JS Adder (DOM)
儿子满墙奖状却没考上重点高中,妈妈愤怒撕下痛哭:不读出去打工
Interview questions 17.05. Letters and numbers
【小码匠自习室】[NOI Online 2020-2 入门组] 未了:可恶的精度会让你焦头烂额
什么是低代码开发?大家都真的看好低代码开发吗?
HMS Core Analysis Service Intelligent Operation Version 6.5.1 Launched
循环神经网络RNN入门介绍
本机Redis Desktop Manager连不上vmware的redis
领域驱动设计系列贫血模型和充血模型
一打是多少个?
CS231n:6 训练神经网络(一)
兔起鹘落全端涵盖,Go lang1.18入门精炼教程,由白丁入鸿儒,全平台(Sublime 4)Go lang开发环境搭建EP00
在中国银河证券开户安全吗 齐齐哈尔股票开户
浏览器跨域方案,适用于本地调试接口(超简单)
JS加法器(DOM)
零基础入门华为云数据库RDS【华为云至简致远】
shell regular expression, Three Musketeers grep command
[内部资源] 想拿年薪30W的软件测试人员,这份资料必须领取
软考 --- 软件工程(6)软项目管理