XlightWeb 的使用
本文目的学会使用HttpClient ,同步请求方式, 异步请求方式, timeout设置预处理,发送大数据。
1
XlightWeb是基于xsockets的使用了NIO的框架。
XlightWeb可以构建同步阻塞的或者异步非阻塞的http客户端和http服务器。
2 先看客户端的构建
HttpClient
这幅图的含义是:HttpClient 实现了 IHttpClientEndpoint接口,里边含有若干HttpClientConnection。
而 HttpClientconnection实现了INonBlockingConnection的tcp链接。 也就是说HttpClient是一个非阻塞
的连接池。
示例1 用call方法发送请求
HttpClient httpClient = new HttpClient();
//设置一些httpclient的属性
httpClient.setFollowsRedirect(true);
httpClient.setAutoHandleCookies(false);
//生成request
IHttpRequest request = new GetRequest("http://www.sohu.com");
//设置request属性
request.setHeader("Accept-Encoding", "gzip,deflate");
//call方法是同步方法,知道收到http头后才返回,这个方法会阻塞在这里。
//这里也可以用非阻塞的方式send方法访问 下边示例介绍
HttpResponse response =
(HttpResponse)httpClient
.call(request);
System.out.println(response.getResponseHeader());
//获得http头后,http的body并没有收完,可以用response获得BlockingBodyDataSource
//或者 NonBlockingBodyDataSource 这里用了阻塞同步的方式
BlockingBodyDataSource bodyDataSource = response.getBlockingBody() ;
String data = bodyDataSource.readString( );
System.out.println(data);
httpClient.close();
示例2 加入
Interceptor
Interceptor 允许程序在发送request的是后就是调用call方法之后,call方法返回之前,做一些处理,如
把这个request记录在日志上。上边代码加入如下一句:
.......
httpClient.addInterceptor(new HeaderLogFilter());
.....
.
//最为一个interceptor 要实现
IHttpRequestHandler 接口的onRequest方法
class HeaderLogFilter implements IHttpRequestHandler {
public void onRequest(final IHttpExchange exchange) throws IOException {
System.out.println("-------------------intercepter onRequest----------------");
System.out.println(exchange.getRequest().getRequestHeader());
exchange.forward(exchange.getRequest());
示例3 自动重试
GET DELETE PUT 方法是幂等的,所以多次一样的请求服务器不会出现问题,例如get一个资源失败后再次get
服务器可以返回一样的结果。默认情况下HttpClient在请求失败后不会自动重试,需要设置
setCallReturnOnMessage
HttpClient httpClient = new HttpClient();
httpClient.setCallReturnOnMessage(true);
IHttpResponse response = httpClient.call(new GetRequest("http://www.sohu.com"))
示例4 HttpClient 异步send方式
使用异步的方式有两种 一种是使用FutureResponse 一种是使用 send方法指定ResponseHandler。
这里介绍第二种使用handler
......
//发送请求时生成一个handler 来处理将来的返回
httpClient.send(request, new MyResponseHandler());
.....
//实现
IHttpResponseHandler 接口的Handler
@Execution(Execution.MULTITHREADED)
class MyResponseHandler implements IHttpResponseHandler {
@InvokeOn(InvokeOn.MESSAGE_RECEIVED)
public void onResponse(IHttpResponse response) throws IOException {
System.out.println("-------------------Handler onResponse----------------");
System.out.println(response.getResponseHeader());
}
public void onException(IOException ioe) {
System.out.println("error occured by receiving response " + ioe.toString());
}
}
这里需要注意的是两个
Annotation 。
Execution
两个参数值
MULTITHREADED 指明回调将在一个线程里完成,
NONTHREADED指明回调在I/O主线程完成
InvokeOn
连个参数
MESSAGE_RECEIVED 回调再收到body之后发生,
HEADER_RECEIVED 在收到http头时发生
关于
Execution
的更多信息 参考
xSocket
框架图
The Dispatcher (I/O thread) is responsible to perform the socket read & write I/O operations and to delegate the call back handling. By default
number of CPUs + 1
dispatchers will be created. A connection is bound to one dispatcher during the total lifetime.
xSocket uses the worker pool only to perform the handler's call back method. The pool can be set by calling the appropriate setter method. A worker pool has to implement the java.util.concurrent.Executor interface.
xSocket
底层有个IO线程负责Connection的读写,IO线程个数为cpu个数+1 ,而handler回调是由一个线程池来处理,
每个connection是绑定在一个IO线程上的。 所以如果把回调放入到IO线程中处理时 一定注意能有异常和阻塞方法调用。
否则会只是整个IO线程阻塞。
示例5 处理timeout
有三种timeout类型可以设置,各个类型代表的时间如图
-
ConnectionTimeout
: 获得链接的时间限制
-
ResponseTimeout
: 获得响应的时间限制, 从send到获得header的时间。
-
BodyDataReceiveTimeout
: 获取body的时间间隔最长是多少。
设置timeout
httpClient
.setConnectionTimeoutMillis(24L * 60L * 60L * 1000L);
httpClient
.setResponseTimeoutMillis(2L * 60L * 1000L);
httpClient
.setBodyDataReceiveTimeoutMillis(30L * 1000L);
timeout的处理
使handler实现接口
IHttpSocketTimeout
的
onException(SocketTimeoutException stoe) 方法
class MyHandler implements IHttpResponseHandler, IHttpSocketTimeoutHandler {
public void onResponse(IHttpResponse response) throws IOException { // ... }
public void onException(IOException ioe) { // ... }
public void onException(SocketTimeoutException stoe) { // response timeout occured //}
}
示例6 异步使用流方式发送request的body
这种方法在上传文件等发送大数据的时候很有用。
1
因为body比较大 所以先把reqeust的header 和 body的length发送出去
2 打开文件构建
FileChannel 然后用
BodyDataSink
传送。 BodyDataSink来自send函数返回
// create a response handler
IHttpResponseHandler hdl = new MyResponseHandler();
// get the file to transfer
RandomAccessFile raf = new RandomAccessFile("test.txt", "rw");
FileChannel fc = raf.getChannel();
int bodyLength = (int) fc.size();
// 先构建header发送
IHttpRequestHeader header = new HttpRequestHeader("POST", "http://server:80/in", "text/plain");
// 如果指定了bodylength 那么就会用非chunk的方式传送数据
BodyDataSink bodyDataSink = httpClient.send(header, bodyLength, hdl);
// 这里存在一个同步异步的问题
bodyDataSink.transferFrom(fc);
// finish the send procedure
bodyDataSink.close();
这里需要改进一下发送数据时的方式,默认情况下BodyDataSink是同步发送的,也就是把文件里的数据同步自动写入到了
底层的IO中,这里会造成效率的地下。需要设置为异步的 改动如下
bodyDataSink.setAutoflush(false); // 取消自动写入
bodyDataSink.setFlushmode(FlushMode.ASYNC); // 设置为异步方式
// 写入数据
bodyDataSink.write(bytebuffer);
//手动flush到底层IO
bodyDataSink.flush();
同时要注意,write时候的bytebuffer 不能重用。 如果需要重复使用write时候的bytebuffer 会造成和底层内部IO线程的竞争,致使数据坏掉。如下摘抄自Xsocket
By using the
WritableByteChannel
interface methods write(ByteBuffer) and write(ByteBuffer[]) some restriction exits. Calling such a write method in mode ASYNC causes that the byte buffer will be read asynchronously by the internal I/O thread. If the byte buffer will be accessed (reused) after calling the write method, race conditions will occur. The write(ByteBuffer) and write(ByteBuffer[]) should only called in ASYNC mode, if the byte buffer will not be accessed (reused) after the write operation.
相关推荐
不知道是不是最新的,这是我找的最高版本。 如果有更高的版本,告诉我一下
通常,使用xsocket或xlightweb时,你需要在服务器端创建WebSocket服务器,并监听特定端口,然后在客户端创建WebSocket对象并连接到服务器。之后,你可以发送和接收JSON或其他格式的数据。 总结来说,这个压缩包...
java毕业设计源码,可供参考
Windows下的FRP图形化客户端,对应FRP版本0.61.1,需要64位操作系统
基于优化EKF的PMSM无位置传感器矢量控制研究_崔鹏龙.pdf
旧物置换网站的开发过程中,采用B / S架构,主要使用Java技术进行开发,结合最新流行的springboot框架。中间件服务器是Tomcat服务器,使用Mysql数据库和Eclipse开发 环境。该旧物置换网站包括管理员、用户、卖家。其主要功能包括管理员:首页、个人中心、用户管理、卖家管理、旧物类型管理、旧物信息管理、置换交易管理、系统管理等,卖家后台:首页、个人中心、旧物类型管理、旧物信息管理、置换交易管理。前台首页;首页、旧物信息、网站公告、个人中心、后台管理等,用户后台:首页、个人中心、旧物信息管理、置换交易管理、用户可根据关键字进行信息的查找自己心仪的信息等。 (1)用户功能需求 用户进入前台系统可以查看首页、旧物信息、网站公告、个人中心、后台管理等操作。前台首页用例如图3-1所示。 (2)管理员功能需求 管理员登陆后,主要功能模块包括首页、个人中心、用户管理、卖家管理、旧物类型管理、旧物信息管理、置换交易管理、系统管理等功能。 关键词:旧物置换网站,Mysql数据库,Java技术 springboot框架
项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行;功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用
航天模拟器文件、蓝图、代码
两级式单相光伏并网仿真研究:MATLAB 2021a版本下的DC-DC变换与桥式逆变技术实现功率跟踪与并网效果优化,基于Matlab 2021a的两级式单相光伏并网仿真研究:实现最大功率跟踪与稳定的直流母线电压,两级式单相光伏并网仿真(注意版本matlab 2021a) 前级采用DC-DC变电路,通过MPPT控制DC-DC电路的pwm波来实现最大功率跟踪,mppt采用扰动观察法,后级采用桥式逆变,用spwm波调制。 采用双闭环控制,实现直流母线电压的稳定和单位功率因数。 并网效果良好,thd满足并网要求,附带仿真说明文件 ,两级式单相光伏并网仿真; MATLAB 2021a; DC-DC变换电路; MPPT控制; 扰动观察法; 桥式逆变; SPWM波调制; 双闭环控制; 直流母线电压稳定; 单位功率因数; 并网效果; THD。,MATLAB 2021a双闭环控制两级式单相光伏并网仿真研究
光伏MPPT仿真研究:光照强度和温度对太阳能电池输出特性的影响及调整策略,助力光伏发电学习。,光伏MPPT仿真研究:光照强度和温度对太阳能电池输出特性的影响及调整策略学习指南,光伏mppt仿真:通过调整太阳光照, 温度等因素 , 光照强度和温度对太阳能电池输出特性的影响。 可用于学习光伏发电 ,光伏MPPT仿真;太阳光照调整;温度影响;光照强度;太阳能电池输出特性。,光伏MPPT仿真:光照与温度对太阳能电池输出特性的影响研究
随着互联网技术的高速发展,人们生活的各方面都受到互联网技术的影响。现在人们可以通过互联网技术就能实现不出家门就可以通过网络进行系统管理,交易等,而且过程简单、快捷。同样的,在人们的工作生活中,也就需要互联网技术来方便人们的日常工作生活,实现工作办公的自动化处理,实现信息化,无纸化办公。 本课题在充分研究了在Springboot框架基础上,采用B/S模式,以Java为开发语言,MyEclipse为开发工具,MySQL为数据管理平台,实现的内容主要包括首页,个人中心,综合管理等功能。
航天模拟器文件、蓝图、代码
西门子Smart PLC四轴搬运取料机案例程序:从新手到项目的跃升之路,西门子Smart PLC四轴搬运取料机运动控制案例程序——PLC通信与伺服电机自动化控制解决方案,西门子200smart运动控制四轴搬运取料机案例程序 该程序为两台smart plc通过通讯控制四轴伺服电机的搬运取料机案例工程案例程序。 包含200smar_PLC程序+项目电气接线图(PDF图纸)+程序流程说明+触摸屏程序(步科) 程序包括伺服电机的启动,停止,原点定位,回归原点,位置控制以及方向控制。 包括了所有控制伺服电机的指令,里面有指令的用法的详细解释和程序说明。 拿来就能用的案例程序,结合程序案例中学习,就会轻松快速的掌握。 让你从新手直接能做项目。 动作流程: 客户上好料盒,M1轴伺服跑到第一片料的位置,气缸将料推出到上位置, M2轴在上料位置取件后移动到直线电机的,加工位置,m2轴上通过有上料下料的气缸, 用真空吸住料后m2轴移动到一个二维平台的加工位置,把带加工的料放到加工位置后, 激光器开始加工,加工完成后,通过M2轴把料取下,移动到成品放料位置,放料后, M3轴将成品料推送到M4
航天模拟器文件、蓝图、代码
基于双碳背景下阶梯式碳交易机制与电制氢的综合能源系统热电优化策略研究与求解分析,基于双碳背景下阶梯式碳交易机制与电制氢的综合能源系统热电优化策略及经济性研究,考虑阶梯式碳交易机制与电制氢的综合能源系统热电优化 “双碳”背景下,为提高能源利用率,优化设备的运行灵活性,进一步降低综合能源系统(IES)的碳排放水平,提出一种IES低碳经济运行策略。 首先考虑IES参与到碳交易市场,引入阶梯式碳交易机制引导IES控制碳排放;接着细化电转气(P2G)的两阶段运行过程,引入电解槽、甲烷反应器、氢燃料电池(HFC)替传统的P2G,研究氢能的多方面效益;最后提出热电比可调的热电联产、HFC运行策略,进一步提高IES的低碳性与经济性。 基于此,构建以购能成本、碳排放成本、弃风成本最小的低碳经济运行目标,将原问题转化为混合整数线性问题,运用CPLEX商业求解器进行求解,通过设置多个运行情景,对比验证了所提策略的有效性。 关键词:氢能;阶梯式碳交易机制;热电比可调;综合能源系统;低碳经济 ,关键词:阶梯式碳交易机制;综合能源系统(IES);热电优化;设备运行灵活性;碳排放水平;电转气(P2G);电解槽;氢
MMC分布式储能系统:实现恒功率与恒电压控制的无缝切换技术,MMC分布式储能系统实现恒功率与恒电压控制的无缝切换技术,mmc分布式储能 恒功率控制 恒电压控制 无缝切 ,核心关键词:MMC分布式储能; 恒功率控制; 恒电压控制; 无缝切换。,MMC分布式储能系统:恒功率与恒电压控制的无缝切换技术
多频多快拍稀疏贝叶斯学习目标方位序贯估计_牛海强.pdf
交错并联Boost PFC仿真电路模型:双闭环控制方式下的输出电压与电感电流优化控制,优良波形及Simulink仿真实现,交错并联Boost PFC仿真电路模型:双闭环控制方式下的电压外环与电感电流内环优化,优质波形表现于Simulink仿真中,交错并联Boost PFC仿真电路模型 采用输出电压外环,电感电流内环的双闭环控制方式 交流侧输入电流畸变小,波形良好,如效果图所示 simulink仿真 matlab simulink仿真模型 无报告哈 ,核心关键词:交错并联Boost PFC仿真电路模型;双闭环控制方式;输出电压外环;电感电流内环;交流侧输入电流畸变小;波形良好;Simulink仿真;Matlab Simulink仿真模型。,基于Simulink仿真的交错并联Boost PFC双闭环控制模型优化研究
基于53#三菱PLC与组态王系统的音乐喷泉控制系统设计与组态设计探讨,基于53#三菱PLC的组态王音乐喷泉控制系统设计与实现:音乐喷泉组态设计的探索与实践,53#三菱PLC和组态王音乐喷泉控制系统设计音乐喷泉组态设计音乐喷泉 ,53#三菱PLC; 组态王音乐喷泉控制系统设计; 音乐喷泉组态设计; 音乐喷泉,三菱PLC与组态王协同音乐喷泉控制系统设计
(要求1)基于随机博弈的无人机集群动态对抗决策.pdf