这篇文章将为大家详细讲解有关服务器中如何使用特定的执行程序来阻止操作,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
使用特定的执行程序来阻止操作
因为一个缓慢的操作而使整个服务器变得无响应,这通常不是开发人员想要的。不幸的是,对于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());});}
关于“服务器中如何使用特定的执行程序来阻止操作”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
服务器会影响网站排名的几个关键因素是什么?
「服务器」解决PHP高级问题的两大利器
服务器配置(php)
Swoole就能实现高性能HTTP服务器
MySQL 管理
如何运用PHP+REDIS解决负载均衡后的session共享问题
一步一步来:MQTT服务器搭建、MQTT客户端使用
PHP分布式架构RPC介绍以及手写RPC框架
高效python脚本,6小时获取上千台mysql数据库服务器(上)
OpenSSL修复可被黑客攻击的服务器崩溃高危漏洞
用户名
密码
记住登录状态 忘记密码?
邮箱
确认密码
我已阅读并同意 用户协议