博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
play2.0文档-面向java开发者(7)异步HTTP编程
阅读量:6304 次
发布时间:2019-06-22

本文共 3421 字,大约阅读时间需要 11 分钟。

  hot3.png

Handling asynchronous results

处理异步results

Why asynchronous results?

为啥需要异步results

Until now, we were able to compute the result to send to the web client directly. This is not always the case: the result may depend of an expensive computation or on a long web service call.

到目前为止,我们可以直接计算出发送到web客户端的结果。而不会总是这样:结果需要经过耗时的计算或web service调用。

Because of the way Play 2.0 works, action code must be as fast as possible (i.e. non blocking). So what should we return as result if we are not yet able to compute it? The response should be a promise of a result!

play2.0要求action代码必须尽可能的快(例如非阻塞),如果我们一时还不能计算它,那么我们应该返回什么?答案是一个结果的Promise(承诺)!

Promise<Result> will eventually be redeemed with a value of type Result. By giving a Promise<Result> instead of a normal Result, we are able to compute the result quickly without blocking anything. Play will then serve this result as soon as the promise is redeemed.

一个 Promise<Result> 实际上最终会返回一个 Result值。用 Promise<Result> 代替Result,我们就能够无阻塞的快速计算结果。一旦promise完成了,play就会返回这个结果。

The web client will be blocked while waiting for the response but nothing will be blocked on the server, and server resources can be used to serve other clients.

web客户端在等待应答的时候会被阻塞住,但是服务器端不会阻塞,服务器还能给其他客户端提供服务.

How to create a Promise<Result>

如何创建 Promise<Result>

To create a Promise<Result> we need another promise first: the promise that will give us the actual value we need to compute the result:

为了创建一个 Promise<Result> ,我们首先需要另外一个promise:这个promise将会返回一个需要计算结果的实际值:

 

Promise<Double> promiseOfPIValue = computePIAsynchronously();

Promise<Result> promiseOfResult = promiseOfPIValue.map(

new Function<Double,Result>() {

public Result apply(Double pi) {

return ok("PI value computed: " + pi);

}

} );

Note: Writing functional composition in Java is really verbose for at the moment, but it should be better when Java supports .

注意:目前在java里写函数组合非常的罗嗦,但是等java支持lamba表达式的时候情况会好一些。

Play 2.0 asynchronous API methods give you a Promise. This is the case when you are calling an external web service using the play.libs.WS API, or if you are using Akka to schedule asynchronous tasks or to communicate with Actors usingplay.libs.Akka.

当你用 play.libs.WS API调用外部的webservice或者用AKKA调度异步任务或使用play.libs.Akka进行异步通讯时,Play 2.0异步API方法就会返回一个 Promise.

A simple way to execute a block of code asynchronously and to get a Promise is to use the play.libs.Akka helpers:

异步的执行一个代码块的简单方式是使用 play.libs.Akka 便利方法:

Promise<Integer> promiseOfInt = Akka.future(

    new Callable<Integer>() {

        public Integer call() {

            intensiveComputation();

        }

   } );

Note: Here, the intensive computation will just be run on another thread. It is also possible to run it remotely on a cluster of backend servers using Akka remote.

注意:这里,密集的计算会在其他线程里执行。也有可能在后端服务器集群上远程执行.

AsyncResult

异步结果

While we were using Results.Status until now, to send an asynchronous result we need an Results.AsyncResult that wraps the actual result:

当我们使用 Results.Status 时,为了发送一个异步result,我们需要一个包含了实际的result的 Results.AsyncResult :

 

public static Result index() {

Promise<Integer> promiseOfInt = Akka.future(

new Callable<Integer>() {

public Integer call() {

 

intensiveComputation();

}

}

);

async(

promiseOfInt.map(

new Function<Integer,Result>() {

public Result apply(Integer i) {

return ok("Got result: " + i);

}

}

)

);

}

Note: async() is an helper method building an AsyncResult from aPromise<Result>.

注意: async() 是一个根据Promise<Result>构建 AsyncResult 的便利方法。

转载于:https://my.oschina.net/gai/blog/54029

你可能感兴趣的文章
idea springboot热部署无效问题
查看>>
第八章 进程间通信
查看>>
HttpSession接口中的方法(Jsp中的session类的用法)
查看>>
「镁客早报」AI可预测心脏病人死亡时间;机器人开始在美国送外卖
查看>>
MoQ(基于.net3.5,c#3.0的mock框架)简单介绍
查看>>
物联网全面升级,十年内推动工业进入智能化新阶段
查看>>
spring-通过ListFactory注入List
查看>>
一种基于SDR实现的被动GSM嗅探
查看>>
阿里云ECS每天一件事D1:配置SSH
查看>>
SQL Server 性能调优(性能基线)
查看>>
uva 10801 - Lift Hopping(最短路Dijkstra)
查看>>
[Java Web]servlet/filter/listener/interceptor区别与联系
查看>>
POJ 2312Battle City(BFS-priority_queue 或者是建图spfa)
查看>>
从零开始学MVC3——创建项目
查看>>
CentOS 7 巨大变动之 firewalld 取代 iptables
查看>>
延时任务和定时任务
查看>>
linux下的权限问题
查看>>
教你如何使用Flutter和原生App混合开发
查看>>
Spring Boot 整合redis
查看>>
CSS hover改变背景图片过渡动画生硬
查看>>