CountDownLatch 压测教程

在实战项目中,我们除了使用 jemter 等工具进行压测外,还可以自己动手使用 CountDownLatch 类编写压测代码。可以说 jemter 的并发压测背后也是使用的 CountDownLatch。可见掌握 CountDownLatch 类的使用是有多么的重要。

CountDownLatch是Java多线程同步器的四大金刚之一,CountDownLatch能够使一个线程等待其他线程完成各自的工作后再执行。本文介绍 CountDownLatch 的相关用法。

使用CountDownLatch让线程集中执行,代码如下:

private static void latchTest() throws InterruptedException {
	final CountDownLatch start = new CountDownLatch(1);
	final CountDownLatch end = new CountDownLatch(300);
	ExecutorService exce = Executors.newFixedThreadPool(300);
	for (int i = 0; i < 300; i++) {
		Runnable run = new Runnable() {
			@Override
			public void run() {
				try {
					start.await();
					// 测试执行具体的方法
					testLoad();
				} catch (InterruptedException e) {
					e.printStackTrace();
				} finally {
					end.countDown();
				}
			}
		};
		exce.submit(run);
	}
	start.countDown();
	end.await();
	exce.shutdown();
}

简简单单的几行代码就可以实现300的压测。

除了 CountDownLatch 之外,我们还可以使用 java 线程的 join 方法。

join用于让当前执行线程等待join线程执行结束。其实现原理是不停检查join线程是否存活,如果join线程存活则让当前线程永远wait,代码片段如下,wait(0)表示永远等待下去。

while (isAlive()) {
	wait(0);
}

直到join线程中止后,线程的this.notifyAll会被调用,调用notifyAll是在JVM里实现的,所以JDK里看不到,有兴趣的同学可以看看JVM源码。JDK不推荐在线程实例上使用wait,notify和notifyAll方法。

CountDownLatch 压测教程

: » CountDownLatch 压测教程

原创文章,作者:bd101bd101,如若转载,请注明出处:https://blog.ytso.com/251784.html

(0)
上一篇 2022年5月3日
下一篇 2022年5月3日

相关推荐

发表回复

登录后才能评论