千家信息网

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

发表于:2024-11-18 作者:千家信息网编辑
千家信息网最后更新 2024年11月18日,这篇文章将为大家详细讲解有关服务器中如何使用特定的执行程序来阻止操作,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。使用特定的执行程序来阻止操作因为一个缓慢的操作而使
千家信息网最后更新 2024年11月18日服务器中如何使用特定的执行程序来阻止操作

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

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

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

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

@GET@Path("/genre/{name}")@Produces(MediaType.APPLICATION_JSON)public Response getGenre(@PathParam("name") String genreName) {        Genre genre = potentiallyVerySlowSynchronousCall(genreName);        return Response.ok(genre).build();}

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

@GET@Path("/genre/{name}")@Produces(MediaType.APPLICATION_JSON)public void getGenre(@PathParam("name") String genreName, @Suspended AsyncResponse response) {        response.setTimeout(1L, TimeUnit.SECONDS);        executorService.submit(() -> {                Genre genre = potentiallyVerySlowSynchronousCall(genreName);                return response.resume(Response.ok(genre).build());        }        );}

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

0