在Java中拥有多个线程池有哪些优缺点?我见过代码,其中有多个线程池用于不同的“类型”任务,我不确定它是更好的设计还是只是开发人员是懒惰的。一个例子是使用ScheduledThreadPoolExecutor来定期执行或超时的任务,并使用另一个ThreadPoolExecutor来完成其他任务。
答案 0 :(得分:11)
具有单独的专用线程池的目的是使活动不会因线程而变得缺乏,因为其他活动占用了所有线程。如果某个服务有自己的线程池,那么可以确保它拥有一定数量的线程,并且对其他服务的要求不敏感。
如果服务需要太多线程,则需要多个专用线程池,然后它必须等待线程可用,将反压引入系统以使其逐渐降级,并且由于其他部分具有自己的线程池,因此它们具有有机会抓住他们的部分。因此,我们的想法是,随着负载的变化,系统应具有更稳定的特性。如果您描述为计划任务设置单独的线程池,请确保无论系统其余部分有多忙,这些任务都会运行。
多个线程池需要调整以确保每个池都有足够的线程而不是太多。使用单个线程池,您不需要调优,有时可能更好地利用所有线程,但您可能无法预测知道某些重要任务会获得及时完成所需的线程。
答案 1 :(得分:2)
只有一个线程池不是一个好的设计,因为在1个线程池的情况下,如果应用程序的一部分变慢,线程将集中在那里。如果未实现适当的超时,线程将保留并消耗资源。很多这样的线程和连接都可能导致我们的系统崩溃,因为没有线程可用于新请求。
另一方面,具有多个线程池可确保问题被包含且不会成为系统范围的故障。我们可以有不同的线程池来接受连接,运行批处理作业,与远程api的数据库对话。它确实在某种程度上降低了效率,但是使我们的系统更强大,更容错。