Java的Executors框架提供的定长线程池内部默认使用LinkedBlockingQueue作为任务的容器,这个队列是没有限定大小的,可以无限向里面submit任务. 当线程池处理的太慢的时候,队列里的内容会积累,积累到一定程度就会内存溢出.即使没有内存溢出,队列的延迟势必会变大,而且如果进程突然遇到退出信号,队列里的消息还没有被处理就被丢弃了,那必然会对系统的消息可靠性造成重大影响. 那如何解决线程池的过饱问题呢?从队列入手,无外乎两种方法 增加消费者,增加消费者处理效率 限制生产者生产…