服务器中如何使用特定的执行程序来阻止操作

服务器中如何使用特定的执行程序来阻止操作

这篇文章将为大家详细讲解有关服务器中如何使用特定的执行程序来阻止操作,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

使用特定的执行程序来阻止操作

服务器中如何使用特定的执行程序来阻止操作

因为一个缓慢的操作而使整个服务器变得无响应,这通常不是开发人员想要的。不幸的是,对于RPC,响应时间通常是不可预测的。

假设服务器有100个工作线程,有一个端点,称为100 RPS。在内部,它发出一个RPC调用,通常需要10毫秒。在某个时间点,此RPC的响应时间变为2秒,在峰值期间服务器能够做的惟一的一件事就是等待这些调用,而其他端点则无法访问。

@GET@Path("/genre/{name}")@Produces(MediaType.APPLICATION_JSON)publicResponsegetGenre(@PathParam("name")StringgenreName){Genregenre=potentiallyVerySlowSynchronousCall(genreName);returnResponse.ok(genre).build();}

解决这个问题最简单的方法是提交代码,它将阻塞调用变成一个线程池:

@GET@Path("/genre/{name}")@Produces(MediaType.APPLICATION_JSON)publicvoidgetGenre(@PathParam("name")StringgenreName,@SuspendedAsyncResponseresponse){response.setTimeout(1L,TimeUnit.SECONDS);executorService.submit(()->{Genregenre=potentiallyVerySlowSynchronousCall(genreName);returnresponse.resume(Response.ok(genre).build());});}

关于“服务器中如何使用特定的执行程序来阻止操作”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

发布于 2022-03-19 21:13:40
收藏
分享
海报
0 条评论
31
上一篇:RGB和Lab色彩模型是什么 下一篇:vcftools过滤如何指定缺失率的变异位点
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码