webservice、httpClient、dubbo的区别

webservice、httpClient、dubbo的区别

在开发中,对于同一个war包中的对象方法我们可以直接调用,但是很多情况下需要在不同项目或者不同服务器进行相互调用

webservice

webservice技术可以实现不同服务器项目直接的调用和交换数据,即使语言,协议,部署环境不同也可以实现。webService是使用soap协议而不是Http协议 ;WebService曾经认为是解决异构系统间整合的最佳解决方案,不依赖于第三方任何系统的支持(不需要额外部署专门的MQ或者RDBMS服务器),大家只需要按照官方的规范,即可完成相互之间的数据交互。但是,webService存在的问题是,使用SOAP需要对消息进行多层次的封装,webservice之间进行数据交互的效率受到了严重的影响。虽然,webservice能够交互的数据格式多种多样,基本也不存在数据格式不支持的情况。但是,webservice的效率及其webservice的超时等问题,还是困扰了系统厂商。其主要的特点是跨语言、跨平台的。项目中不推荐使用,可用于不同公司间接口的调用;

webservice实现远程调用的步骤分三部(三次握手) 1.请求获取服务对象 2.返回服务对象 3.调用服务对象方法

传统的webservice实现远程调用的方法耦合性较高,web层与服务层直接请求,在请求服务层获取服务对象的过程中,如果服务层因多种原因如网络延迟、请求过多出现迟迟没有返回对象,就会造成请求延迟。解决方案就是使用第三方也就是dubbo服务治理中间件实现解耦和。

随着交互系统的增多,这种方式对系统的侵入性越来越大,关系更为错综复杂,很容易出错

HttpClient

HttpClient用来调用服务,它是模拟一个浏览器,发送Http的请求,服务器会返回请求的一个响应结果;Httpclient然后把响应的结果取出来。HttpClinet相当于一个客户端,使用Http协议调用系统中的方法HTTP 协议可能是现在 Internet 上使用得最多、最重要的协议了,越来越多的 Java 应用程序需要直接通过 HTTP 协议来访问网络资源。HttpClient 是 Apache Jakarta Common 下的子项目,用来提供高效的、最新的、功能丰富的支持 HTTP 协议的客户端编程工具包,并且它支持 HTTP 协议最新的版本和建议。随着httpclient的出现,以及JSON等数据格式的大范围使用,基于http的消息接口,逐渐被大家所青睐。一方面是因为,直接使用httpclient可以模拟浏览器的数据操作与封装;另一方面使用基于http的消息,可以借助于http的成熟、可靠、开源的web集群解决方案来提升总体的效率。还有,就是基于http的消息格式,几乎不受任何限制,常规应用的各种消息格式,基本都能直接使用基于http的消息进行传递。目前,大部分PaaS平台,所提供的API接口,实际上就是使用基于Http的JSON消息,来进行数据传递的。

dubbo+zookeper

使用dubbo。使用rpc协议进行远程调用,直接使用socket通信。传输效率高,并且可以统计出系统之间的调用关系、调用次数。使用Java语言开发,只能用于Java语言开发的项目间的通信,不具备跨语言,跨平台的特点!dubbo服务治理中间件是在soa分布式面向服务项目中用来作为服务远程调用的中间件,它加上zookeper注册中心实现整个分布式项目服务的发布注册和调用功能,核心思想就是实现解耦和。

dubbo的主要功能

1.RPC远程调用,类似webservice,底层原理是hessian

2.使用NIO 也就是newIO,底层实现原理为netty

IO与NIO的区别

1.IO为直接进行数据连接,占用资源较大

2.NIO指的是异步通讯,通过缓存进行数据交互,也实现了解耦

zookeper的作用

1.作为注册中心注册服务对象

2.注册后的对象以URL的形式存储在zookeper中

在分布式项目中使用dubbo+zookeper实现远程调用的大概步骤如下

1.项目启动(先启动服务层),服务容器如toncat容器、spring容器启动会自动将服务注册到zookeper中,

2.web层消费(订阅)服务,

3.dubbo返回给消费者服务对象

4.消费者消费调用服务对象方法

在dubbo中提供了一个monitor监控中心用于统计服务的调用和调用时间。它是阿里提供的一个已经开发好的项目war包,只需要部署到toncat中运行就能自动监控zookeper的服务调用。

内部系统间或遵守dubbo规范的系统间适用性较强。

我的理解就是内部系统服务模块之间用dubbo,当然现在springcloud火力,如果是springcloud框架,当然用springcloud的组件;调用第三方服务用httpClient,webservice尽量不用或少用

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
HttpClient是一个开源的HTTP客户端库,可以用来发送HTTP请求和接收HTTP响应。我们可以使用HttpClient来调用Web服务。 调用Web服务的步骤如下: 1. 创建HttpClient对象 2. 创建HttpPost对象,并设置请求的URL和请求参数 3. 创建HttpEntity对象,并设置请求参数 4. 将HttpEntity对象设置到HttpPost对象中 5. 执行HttpPost请求,并获取响应结果 6. 解析响应结果 示例代码如下: ``` import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpPost; import org.apache.http.entity.StringEntity; import org.apache.http.impl.client.HttpClientBuilder; import org.apache.http.util.EntityUtils; public class HttpClientWebServiceDemo { public static void main(String[] args) throws Exception { // 创建HttpClient对象 HttpClient httpClient = HttpClientBuilder.create().build(); // 创建HttpPost对象,并设置请求的URL和请求参数 HttpPost httpPost = new HttpPost("http://localhost:8080/webservice"); // 创建HttpEntity对象,并设置请求参数 StringEntity stringEntity = new StringEntity("<soapenv:Envelope xmlns:soapenv=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:ser=\"http://service.demo.com/\"><soapenv:Header/><soapenv:Body><ser:sayHello><arg0>world</arg0></ser:sayHello></soapenv:Body></soapenv:Envelope>", "UTF-8"); // 将HttpEntity对象设置到HttpPost对象中 httpPost.setEntity(stringEntity); // 执行HttpPost请求,并获取响应结果 HttpResponse httpResponse = httpClient.execute(httpPost); // 解析响应结果 HttpEntity httpEntity = httpResponse.getEntity(); String responseContent = EntityUtils.toString(httpEntity, "UTF-8"); System.out.println(responseContent); } } ``` 以上示例代码是使用HttpClient调用一个名为sayHello的Web服务,并传递一个参数world。在实际使用中,需要根据具体的Web服务接口和参数进行调整。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值