我正在一个XSEDE资源上运行一个基因组组装程序*Trinity,http://trinityrnaseq.sourceforge.net/,如果感兴趣的话。硬件将线程数限制在2500,程序总是希望超过2500。有没有一种简单的方法来限制执行的线程数量?我尝试过-XX:ParallelGCThreads=16,但这似乎引入了新的错误。
那么,有没有一个运行时命令来限制线程总数呢?
发布于 2011-12-10 04:30:53
使用Executor或ExecutorService。按照吹牛男孩的建议做,但它是内置在Java中的。
发布于 2011-12-10 02:24:43
您可以使用作为处理线程数量限制的单独进程运行的自定义队列。这样做的好处是,您可以选择限制线程数,也可以继续增加线程数。您可能会有一个addToQueue(Thread t)类,随后会有一个消费者使用所有这些线程。队列将知道有多少线程正在运行。如果线程在该范围内,守护进程将随意触发此队列的consume()方法。并且在每个线程完成或完成它的任务之后,它将报告回队列。如果您认为正在运行的任务应该具有优先级,则您维护的队列可以是优先级队列。这不仅消除了对JVM的依赖,而且使您的程序看起来更干净。
https://stackoverflow.com/questions/8449714
复制相似问题