ZeroMQ之Request/Response (Java)
自己最开始是在cloud foundry中接触过消息服务器(nats),或者说是消息中间件,也算是初步知道了一个消息服务器对于分布式的网络系统的重要性,后来自己也曾想过在一些项目中使用它,尤其是在一些分布式的环境下,可以极大的方便整个系统的实现。。。。
例如如下的形式:
在中间通过一个消息中间件,可以很方便的将各个woker的数据发送到最终的统计服务器来做数据的统计,从而减少很多在网络通信中会消耗的编程时间。。。。
ZeroMQ算是在在网上能搜到的较为出名的消息中间件了吧,不过其实看了它的用法之后越来越觉得它是非典型的消息中间件,而且更像是一个网络通信框架。。。。
初步了解之后,对其的强大功能所折服,但是发现其实能查到的中文材料很少,难道是在国内的使用并不多。。。?这么强大的神器。。。。好吧,那就自己先来写一下ZeroMQ的入程吧。。。其实也就是将http://zguide.zeromq.org/page:all#Handling-Multiple-Sockets 这里的内容翻译了一下而已。。。
首先要说一下,ZeroMQ有多语言的实现方式,其中C语言的实现性能是最高的,除此以外也有纯java的实现,官方的说明是比C语言的实现在性能上要差10%-20%,不过我觉得已经足够用了。。。。
那么这篇文章来讲最简单的一种通信模式吧:Request/Response
场景说明:client向server发送hello,server向client返回world。。。如下图所示:
按照我们常规的想法,我们可能会想到首先在服务器端建立一个ServerSocket的监听,然后客户端向服务端发起socket的连接,建立连接了之后,再进行数据通信。。。。
说起来很简单,但是实际处理起来却很麻烦。。。
那么我们来看看用ZeroMQ这个实现起来将会是多么轻松加愉快吧:
先来看看server端的代码:
- package fjs;
- import org.zeromq.ZMQ;
- public class Response {
- public static void main (String[] args) {
- ZMQ.Context context = ZMQ.context(1); //这个表示创建用于一个I/O线程的context
- ZMQ.Socket socket = context.socket(ZMQ.REP); //创建一个response类型的socket,他可以接收request发送过来的请求,其实可以将其简单的理解为服务端
- socket.bind ("tcp://*:5555"); //绑定端口
- int i = 0;
- int number = 0;
- while (!Thread.currentThread().isInterrupted()) {
- i++;
- if (i == 10000) {
- i = 0;
- System.out.println(++number);
- }
- byte[] request = socket.recv(); //获取request发送过来的数据
- //System.out.println("receive : " + new String(request));
- String response = "world";
- socket.send(response.getBytes()); //向request端发送数据 ,必须要要request端返回数据,没有返回就又recv,将会出错,这里可以理解为强制要求走完整个request/response流程
- }
- socket.close(); //先关闭socket
- context.term(); //关闭当前的上下文
- }
- }
上述的代码够简单吧,而且基本就算不懂ZeroMQ也能基本看懂这段代码是什么意思。。。
首先建立了一个包含有一个I/O线程的context,接着创建了一个REP,也就是response类型的socket,并将其绑定到5555端口上,接着就进入了循环,不断的从socket中读取数据,然后再返回数据给request端,也就是客户端。。。
啊,现在还要感叹一下,代码好简单,,,这里我还加上了一些自己的其余的代码,总共也没写多少行。。。。
好了,接下来来看客户端的实现代码吧:
- package fjs;
- import org.zeromq.ZMQ;
- public class Request {
- public static void main(String args[]) {
- for (int j = 0; j < 5; j++) {
- new Thread(new Runnable(){
- public void run() {
- // TODO Auto-generated method stub
- ZMQ.Context context = ZMQ.context(1); //创建一个I/O线程的上下文
- ZMQ.Socket socket = context.socket(ZMQ.REQ); //创建一个request类型的socket,这里可以将其简单的理解为客户端,用于向response端发送数据
- socket.connect("tcp://127.0.0.1:5555"); //与response端建立连接
- long now = System.currentTimeMillis();
- for (int i = 0; i < 100000; i++) {
- String request = "hello";
- socket.send(request.getBytes()); //向reponse端发送数据
- byte[] response = socket.recv(); //接收response发送回来的数据 正在request/response模型中,send之后必须要recv之后才能继续send,这可能是为了保证整个request/response的流程走完
- // System.out.println("receive : " + new String(response));
- }
- long after = System.currentTimeMillis();
- System.out.println((after - now) / 1000);
- }
- }).start();;
- }
- }
- }
这里的代码,应该也能够很容易的读懂吧,首先创建了包含一个线程的context,然后创建了一个REQ,也就是request类型的socket,然后与5555端口建立连接,然后就进入了循环,不断的向服务端发送数据,然后接收数据。。。
这样到此为止,服务端和客户端的代码都已经贴出来完了。。。当然要使用ZeroMQ,我是用Maven直接引入的,依赖如下:
- <dependency>
- <groupId>org.zeromq</groupId>
- <artifactId>jeromq</artifactId>
- <version>0.3.1</version>
- </dependency>
可以得出结论,ZeroMQ可以极大的简化我们网络通信编程的工作,觉得可以称得上是神器了。。而且性能很好。。。
ZeroMQ之Request/Response (Java)相关推荐
- 3.request response
rr的介绍 request是代表请求,response是响应 执行流程: 1.浏览器发送请求 2.服务器接受请求,创建两个对象,将请求信息封装给request,将两个对象发送给对应的servlet 3 ...
- Filter若不写chain.doFilter(request,response)原Servlet路径代码不会被执行
为什么80%的码农都做不了架构师?>>> Filter如果不写chain.dofilter(request,response) 那么对应的Servlet URL 是不会执行的. ...
- 【Servlet】Request/Response/Cookie/Session中常用方法
#1.Request package com.tcb.servlet;import java.io.IOException; import javax.servlet.ServletException ...
- request,response传入线程值会变为null
request,response传入Thread线程值会变为null Exception in thread "Thread-21" java.lang.NullPointerEx ...
- Request Response
目录 1. Request和Response的概述 2. Request对象 2.1 Request继承体系 2.2 Request获取请求数据 2.2.1 获取请求行数据 2.2.2 获取请求头数据 ...
- JavaWeb - Request Response
Request & Response 1,Request和Response的概述 为什么运行项目后默认打开index.html - 是因为 tomcat 配置文件中事先配好了 ==Reques ...
- 观看慕课老师milanlover视频JSP内置对象+getpost+request+response+请求转发与请求重定向
out是内置对象,不用new来创建. 把饭盛到碗里,碗相当于程序中的缓冲区. <%@ page language="java" import="java.util. ...
- 【错误记录】Android Studio 配置 GitHub 报错 ( Can‘t login using given credentials: Request response: 401 Una )
文章目录 一.报错信息 二.解决方案 一.报错信息 使用账号密码配置 , 出现如下错误 ; Can't login using given credentials: Request response: ...
- MATLAB报错“Exception in thread FileDecorationCache request queue java.lang.OutOfMemoryError: Java “
打开matlab时命令行里遇到错误: Exception in thread "FileDecorationCache request queue" java.lang.OutOf ...
- no suitable HttpMessageConverter found for request type [java.lang.Integer]
今天在使用Spring Template的时候遇到了这个异常: no suitable HttpMessageConverter found for request type [java.lang.I ...
最新文章
- vue 双向数据绑定的实现学习(一)
- PostgreSQL学习笔记9之事务隔离
- [BZOJ3791]作业
- 漏洞挖掘、漏洞分析和漏洞利用
- 利用Python解决豆瓣验证码,实现模拟登陆!
- 我遇到了Hibernate异常
- linux中,添加cvs用户,实质就是添加linux用户 (extssh 连接方式)。 (添加时,注意是否要分组。)
- Oracle 11g vs 12c 内存、优化器等默认参数对比
- Carplay测试-Carplay认证预测试服务-Siri AudioTest-ITU-T P.1110 测试-ITU-T P.1100车载免提音测试
- flowable工作流所有业务概念
- 批量 材质 调整_3dmax怎么批量修改材质
- 关于保险的“损失补偿原则”
- halcon轮廓擦除_HALCON高级篇:轮廓处理
- 线性代数的本质(第一部分)
- LeetCode LCP 03. 机器人大冒险(前缀和)
- 华文行楷字帖欣赏_毛笔行书欣赏,华文行楷在线转换,偏旁部首练字帖,
- 如何理解GPO版本号
- python中search、findall、finditer的区别
- 编写价格排序程序C语言,C语言程序简单例子
- grep命令详解(如何匹配多个字符串)(grep指令)(grep -q)
热门文章
- java文件上传中间件_maven工程 java 实现文件上传 SSM ajax异步请求上传
- java和python有什么区别_Python与Java、C、Ruby、PHP等编程语言有什么区别?
- poythoncode-实战4--读取文本文件,csv文件,存到系统中以大列表方式进行存储
- Ubuntu系统重装 -- 制作启动盘、装机过程问题、环境配置
- deeplearning.ai——构建循环神经网络
- 面向过程编程与面向对象编程
- 探秘Runtime - Runtime介绍
- Apache构建虚拟web主机
- Spring-boot + Mybatis-plus 3.0-gamma 配置记录
- python对象之间的关系