2019-07-23 11:36:05 -07:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
|
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
import jdk.jfr.Event;
|
|
|
|
import jdk.jfr.Description;
|
|
|
|
import jdk.jfr.Label;
|
|
|
|
|
2024-11-25 09:13:10 +00:00
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
|
2019-07-23 11:36:05 -07:00
|
|
|
|
2019-08-29 15:50:45 -07:00
|
|
|
// This class generates simple event in a loop for a specified time.
|
2019-07-23 11:36:05 -07:00
|
|
|
public class EventGeneratorLoop {
|
2019-08-29 15:50:45 -07:00
|
|
|
public static final String MAIN_METHOD_STARTED = "MAIN_METHOD_STARTED";
|
2019-07-23 11:36:05 -07:00
|
|
|
|
|
|
|
@Label("SimpleEvent")
|
|
|
|
@Description("Simple custom event")
|
|
|
|
static class SimpleEvent extends Event {
|
|
|
|
@Label("Message")
|
|
|
|
String msg;
|
|
|
|
|
|
|
|
@Label("Count")
|
|
|
|
int count;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
|
|
if ((args.length < 1) || (args[0] == null)) {
|
|
|
|
throw new IllegalArgumentException("Expecting one argument: time to run (seconds)");
|
|
|
|
}
|
|
|
|
int howLong = Integer.parseInt(args[0]);
|
2024-11-25 09:13:10 +00:00
|
|
|
long endTime = System.nanoTime() + TimeUnit.SECONDS.toNanos(howLong);
|
2019-07-23 11:36:05 -07:00
|
|
|
|
2019-10-11 09:55:35 +02:00
|
|
|
System.out.println(MAIN_METHOD_STARTED + ", argument is " + howLong);
|
2019-08-29 15:50:45 -07:00
|
|
|
|
2024-11-25 09:13:10 +00:00
|
|
|
int count = 0;
|
|
|
|
while (System.nanoTime() < endTime) {
|
2019-07-23 11:36:05 -07:00
|
|
|
SimpleEvent ev = new SimpleEvent();
|
|
|
|
ev.msg = "Hello";
|
2024-11-25 09:13:10 +00:00
|
|
|
ev.count = count++;
|
2019-07-23 11:36:05 -07:00
|
|
|
ev.commit();
|
|
|
|
|
2024-11-25 09:13:10 +00:00
|
|
|
try {
|
|
|
|
Thread.sleep(1000);
|
|
|
|
} catch (InterruptedException ignore) {
|
|
|
|
}
|
2019-07-23 11:36:05 -07:00
|
|
|
System.out.print(".");
|
|
|
|
}
|
2019-10-11 09:55:35 +02:00
|
|
|
|
|
|
|
System.out.println("EventGeneratorLoop is coming to an end");
|
2019-07-23 11:36:05 -07:00
|
|
|
}
|
2019-08-29 15:50:45 -07:00
|
|
|
|
2019-07-23 11:36:05 -07:00
|
|
|
}
|