今天简单说一下基本Http协议来实现RPC框架~

基于Http协议实现RPC框架:

优点:

1、简单、实用、开发方便

缺点:

1、性能不是很稳定,在海量数据时,完全顶不住,容易宕机

2、因为不是走的注册中心,不便于维护、监控以及统计分析

但是对于大多数公司而言,不会又像淘宝、京东那样大的数据量,所以基于Http协议的RPC,实现多个系统间的解耦,还是很实用的~

下面,我们进入正题,通过Java实现简单的RPC调用

一、maven 引入第三方jar包(不是maven项目,可以自己去网上下载一个对应的jar)

            <dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.</version>
</dependency>

二、http的代码实现

1、简易版的Http请求

客户端代码:

    @Test
public void testHttpService() throws UnsupportedEncodingException {
System.out.println("测试http请求开始~");
//封装请求参数
Map map = new HashMap<String, String>();
map.put("reqData","Hello World,世界你好~");
//http://localhost/testHttpService 请求的服务器地址URL
String resp = HttpUtil.post("http://localhost/testHttpService", map);
System.out.println("http服务返回结果为:"+ com.alibaba.fastjson.JSON.toJSON(resp));
}

服务端代码:

服务端 需要提供一个web服务以及相关的请求路径:http://localhost/testHttpService

    @RequestMapping("/testHttpService")
public void testHttpService(HttpServletRequest request,HttpServletResponse response) throws IOException {
logger.info("测试HTTP请求 服务端开始~");
String reqData=request.getParameter("reqData"); //模拟 相关业务逻辑处理
logger.info("处理相关业务~reqData="+reqData); //模拟 返回业务结果
logger.info("业务处理完成,返回结果~");
Map mapResult=new HashMap();
mapResult.put("success",true);
mapResult.put("code","");
mapResult.put("msg","http请求测试成功~");
//防止Http请求中文乱码
response.setHeader("Content-Type", "text/html;charset=utf-8");
PrintWriter printWriter=response.getWriter();
printWriter.write(com.alibaba.fastjson.JSON.toJSONString(mapResult));
printWriter.flush();
logger.info("测试HTTP请求 服务端结束~"); }

测试流程

1、启动WEB服务

2、客户端进行调用

输出结果:

测试http请求开始~
http服务返回结果为:{"code":"","msg":"http请求测试成功~","success":true}

2、升级版的Http请求调用

此处的升级重要是为了传参方便,服务器端不用每个参数都通过request获取到

1、创建一个传输参数的Bean类

package com.jd.test;

/**
* Created by zhanghao10 on 2017/4/17.
*/
public class MapParam { private String reqData;//请求数据 public String getReqData() {
return reqData;
} public void setReqData(String reqData) {
this.reqData = reqData;
}
}

2、客户端代码:

 @Test
public void testHttpServiceEntity() throws IOException {
System.out.println("测试http请求开始~");
//封装请求参数
Map map = new HashMap<String, String>();
map.put("reqData","Hello World,世界你好~"); //封装HTTP请求参数
HttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost("http://localhost/testHttpService");
List<NameValuePair> nameValuePairList = new ArrayList<NameValuePair>();
nameValuePairList.add(new BasicNameValuePair("reqData","Hello World,世界你好~")); httpPost.setEntity(new UrlEncodedFormEntity(nameValuePairList,"UTF-8"));
HttpResponse httpResponse=httpClient.execute(httpPost);
HttpEntity httpEntity = httpResponse.getEntity();
String resp = EntityUtils.toString(httpEntity);
System.out.println("http服务返回结果为:"+ com.alibaba.fastjson.JSON.toJSON(resp));
}

3、服务端代码

@RequestMapping("/testHttpService")
public void testHttpService(MapParam mapParam,HttpSrvletRequest request,HttpServletResponse response) throws IOException {
logger.info("测试HTTP请求 服务端开始~"+ com.alibaba.fastjson.JSON.toJSON(mapParam));
String reqData=request.getParameter("reqData"); //模拟 相关业务逻辑处理
logger.info("处理相关业务~reqData="+reqData); //模拟 返回业务结果
logger.info("业务处理完成,返回结果~");
Map mapResult=new HashMap();
mapResult.put("success",true);
mapResult.put("code","");
mapResult.put("msg","http请求测试成功~");
//防止Http请求中文乱码
response.setHeader("Content-Type", "text/html;charset=utf-8");
PrintWriter printWriter=response.getWriter();
printWriter.write(com.alibaba.fastjson.JSON.toJSONString(mapResult));
printWriter.flush();
logger.info("测试HTTP请求 服务端结束~"); }

测试流程

1、启动WEB服务

2、客户端进行调用

测试结果:

测试http请求开始~
http服务返回结果为:{"code":"","msg":"http请求测试成功~","success":true}

是不是感觉很简单,没错,其实,你要是仔细看代码的话,你会发现,和我们正常的Servlet请求是一样的,不同的是

1、请求的时候需要用HttpClient来模拟浏览器端请求

2、服务器端返回结果 需要通过对应的流,而不是返回到界面

另外顺便说一下,这个项目是基于spring mvc实现的,其实也是Restful架构的具体实现方案~

推荐阅读连接:为什么需要RPC,而不是简单的HTTP接口?

怎样用通俗的语言解释什么叫 REST,以及什么是 RESTful?

基于http协议实现RPC远程调用的更多相关文章

  1. 基于TCP 协议的RPC

    前言: 环境: windown 10 Eclipse JDK 1.8 RPC的概念: RPC 是远程过程调用,是分布式网站的基础. 实验 SayHelloService.java 接口类,用于规范 S ...

  2. 从0到1:全面理解RPC远程调用

    上一篇关于 WSGI 的硬核长文,不知道有多少同学,能够从头看到尾的,不管你们有没有看得很过瘾,反正我是写得很爽,总有一种将一样知识吃透了的错觉. 今天我又给自己挖坑了,打算将 rpc 远程调用的知识 ...

  3. 測试JSON RPC远程调用(JSONclient)

    #include <string> #include <iostream> #include <curl/curl.h> /* 标题:JSonclient Auth ...

  4. 使用Socket&反射&Java流操作进行方法的远程调用(模拟RPC远程调用)

    写在前面 阅读本文首先得具备基本的Socket.反射.Java流操作的基本API使用知识:否则本文你可能看不懂... 服务端的端口监听 进行远程调用,那就必须得有客户端和服务端.服务端负责提供服务,客 ...

  5. Openstack Nova 源码分析 — RPC 远程调用过程

    目录 目录 Nova Project Services Project 的程序入口 setuppy Nova中RPC远程过程调用 nova-compute RPC API的实现 novacompute ...

  6. netcore 基于 DispatchProxy 实现一个简单Rpc远程调用

    前言 netcore 发布以来,一直很关注netcore的进程.目前在公司负责的网站也历经波折的全部有.net framework 4.0 全部切换到netcore 2.2 版本中.虽然过程遇到的坑不 ...

  7. go语言net包rpc远程调用的使用

    一.基于http的RPC 服务端: package main; import ( "net/rpc" "net/http" "log" ) ...

  8. 几种基于HTTP协议的RPC性能比较

    有了整体的了解后,可以发现Hessian的这个远程过程调用,完全使用动态代理来实现的,其实从客户端代码不难看出,HessianProxyFactory的create方法就是创建接口Basic的代理类, ...

  9. dubbo集成zookeeper rpc远程调用

    注:下面使用dubbo依赖的是zookeeper注册中心,这里没有详细的介绍.在配置之前,请自行准备好zookeeper环境. 后续如果写zookeeper的配置会补放链接 添加Gradle依赖 co ...

随机推荐

  1. lxml.etree去除子节点

    去除etree中的某个子节点有两种方法: 1.parentnode.remove(node) 2.etree.strip_elements(html, 'element_name', with_tag ...

  2. 将 R 整合到 markdown 中

    markdown 易于写入和读取,具有编写报告的必要功能,例如简单的文本格式,嵌入图片.链接.表.引用.数学公式以及代码块.虽然在 markdown 中编写纯文本很容易,但是创建具有许多图片和表格的报 ...

  3. 【Python】xlrd,NotImplementedError-formatting_info=True not yet implemented

    前言 Python需要读取Excel(.xls..xlsx)时通常使用xlrd模块:如果要对其内容进行编辑的话稍稍有些麻烦,通常的做法是使用xlutils的copy模块对原文件进行复制,然后保存成新的 ...

  4. Idea使用(摘抄至java后端技术公众号-孤独烟)

    1. idea自动编译需要手动开启: 2. 手动去掉idea自动提示时候不区分字母大小写 3. idea自动导入包 4. 悬浮开关提示:鼠标放上去就给出提示 5. 打开的所有类tabs换行显示,不单行 ...

  5. bzoj2705: [SDOI2012]Longge的问题 欧拉定理

    题意:给定一个整数N,你需要求出∑gcd(i, N)(1<=i <=N). 题解:考虑n的所有因子,假设有因子k,那么对答案的贡献gcd(i,n)==k的个数即gcd(i/k,n/k)== ...

  6. SQL语言的增删改查

    select(查), update(改), delete(删), insert into(增)   select * from table_name 获取表中所有字段 select id, name, ...

  7. UVALive-2531 The K-League (最大流建模+枚举)

    题目大意:有n支足球队,已知每支球队的已胜场数和任意两支球队之间还需要的比赛场数a[i][j],求最终可能夺冠的所有球队. 题目分析:枚举所有的球队,对于球队 i 让它在接下来的比赛中全部获胜,如果这 ...

  8. [转载]Java抽象类和接口的学习

    http://android.blog.51cto.com/268543/385282/ 抽象类 abstract class     包含抽象方法的类,叫抽象类.而抽象的概念就是抽象出共同属性:成员 ...

  9. ActiveX开发

    转自(http://blog.csdn.net/mingojiang/article/details/8159263) 一.ActiveX基础 1.1什么是ActiveX ActiveX是COM规范的 ...

  10. 《转》深入理解Activity启动流程(四)–Activity Task的调度算法

    本文原创作者:Cloud Chou. 出处:本文链接 本系列博客将详细阐述Activity的启动流程,这些博客基于Cm 10.1源码研究. 深入理解Activity启动流程(一)--Activity启 ...