src/jdk.management.jfr/share/classes/jdk/management/jfr/FlightRecorderMXBean.java
author mbaesken
Fri, 08 Jun 2018 13:06:08 +0200
changeset 50464 102ae98c917c
parent 50113 caf115bb98ad
child 52982 122b1ecfaa6e
permissions -rw-r--r--
8204539: improve error messages in matchJavaTZ [windows] Reviewed-by: coffeys, clanger, goetz
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     1
/*
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     2
 * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     4
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    10
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    15
 * accompanied this code).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    16
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    20
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    23
 * questions.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    24
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    25
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    26
package jdk.management.jfr;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    27
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    28
import java.io.IOException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    29
import java.lang.management.PlatformManagedObject;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    30
import java.time.Instant;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    31
import java.util.List;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    32
import java.util.Map;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    33
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    34
import jdk.jfr.Configuration;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    35
import jdk.jfr.EventType;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    36
import jdk.jfr.Recording;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    37
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    38
/**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    39
 * Management interface for controlling Flight Recorder.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    40
 * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    41
 * The object name for identifying the MXBean in the platform MBean
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    42
 * server is: <blockquote> {@code jdk.management.jfr:type=FlightRecorder} </blockquote>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    43
 * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    44
 * Flight Recorder can be configured in the following ways:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    45
 * <ul>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    46
 * <li><b>Recording options</b><br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    47
 * Specify how long a recording should last, and where and when data
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    48
 * should be dumped.</li>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    49
 * <li><b>Settings</b><br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    50
 * Specify which events should be enabled and what kind information each
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    51
 * event should capture.</li>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    52
 * <li><b>Configurations</b><br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    53
 * Predefined sets of settings, typically derived from a settings file,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    54
 * that specify the configuration of multiple events simultaneously.</li>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    55
 * </ul>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    56
 * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    57
 * See the package {@code jdk.jfr} documentation for descriptions of the settings
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    58
 * syntax and the {@link ConfigurationInfo} class documentation for configuration information.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    59
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    60
 * <h3>Recording options</h3>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    61
 * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    62
 * The following table shows the options names to use with {@link #setRecordingOptions(long, Map)}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    63
 * and {@link #getRecordingOptions(long)}.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    64
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    65
 * <table class="striped">
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    66
 * <caption>Recording options</caption>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    67
 * <thead>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    68
 * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    69
 * <th scope="col">Name</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    70
 * <th scope="col">Descripion</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    71
 * <th scope="col">Default value</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    72
 * <th scope="col">Format</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    73
 * <th scope="col">Example values</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    74
 * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    75
 * </thead>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    76
 * <tbody>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    77
 * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    78
 * <th scope="row">{@code name}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    79
 * <td>Sets a human-readable recording name</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    80
 * <td>String representation of the recording id</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    81
 * <td>{@code String}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    82
 * <td>{@code "My Recording"}, <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    83
 * {@code "profiling"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    84
 * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    85
 * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    86
 * <th scope="row">{@code maxAge}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    87
 * <td>Specify the length of time that the data is kept in the disk repository until the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    88
 * oldest data may be deleted. Only works if {@code disk=true}, otherwise
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    89
 * this parameter is ignored.</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    90
 * <td>{@code "0"} (no limit)</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    91
 * <td>{@code "0"} if no limit is imposed, otherwise a string
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    92
 * representation of a positive {@code Long} value followed by an empty space
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    93
 * and one of the following units,<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    94
 * <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    95
 * {@code "ns"} (nanoseconds)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    96
 * {@code "us"} (microseconds)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    97
 * {@code "ms"} (milliseconds)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    98
 * {@code "s"} (seconds)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
    99
 * {@code "m"} (minutes)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   100
 * {@code "h"} (hours)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   101
 * {@code "d"} (days)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   102
 * </td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   103
 * <td>{@code "2 h"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   104
 * {@code "24 h"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   105
 * {@code "2 d"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   106
 * {@code "0"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   107
 * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   108
 * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   109
 * <th scope="row">{@code maxSize}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   110
 * <td>Specifies the size, measured in bytes, at which data is kept in disk
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   111
 * repository. Only works if
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   112
 * {@code disk=true}, otherwise this parameter is ignored.</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   113
 * <td>{@code "0"} (no limit)</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   114
 * <td>String representation of a {@code Long} value, must be positive</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   115
 * <td>{@code "0"}, <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   116
 * {@code "1000000000"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   117
 * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   118
 * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   119
 * <th scope="row">{@code dumpOnExit}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   120
 * <td>Dumps recording data to disk on Java Virtual Machine (JVM) exit</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   121
 * <td>{@code "false"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   122
 * <td>String representation of a {@code Boolean} value, {@code "true"} or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   123
 * {@code "false"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   124
 * <td>{@code "true"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   125
 * {@code "false"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   126
 * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   127
 * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   128
 * <th scope="row">{@code destination}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   129
 * <td>Specifies the path where recording data is written when the recording stops.</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   130
 * <td>{@code "false"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   131
 * <td>See {@code Paths#getPath} for format. <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   132
 * If this method is invoked from another process, the data is written on the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   133
 * machine where the target JVM is running. If destination is a relative path, it
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   134
 * is relative to the working directory where the target JVM was started.}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   135
 * <td>{@code "c:\recording\recotding.jfr"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   136
 * {@code "/recordings/recording.jfr"}, {@code "recording.jfr"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   137
 * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   138
 * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   139
 * <th scope="row">{@code disk}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   140
 * <td>Stores recorded data as it is recorded</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   141
 * <td><code>"false"</code></td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   142
 * <td>String representation of a {@code Boolean} value, {@code "true"} or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   143
 * {@code "false"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   144
 * <td>{@code "true"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   145
 * {@code "false"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   146
 * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   147
 * <th scope="row">{@code duration}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   148
 * <td>Sets how long the recording should be running</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   149
 * <td>{@code "0"} (no limit, continuous)</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   150
 * <td>{@code "0"} if no limit should be imposed, otherwise a string
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   151
 * representation of a positive {@code Long} followed by an empty space and one
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   152
 * of the following units:<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   153
 * <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   154
 * {@code "ns"} (nanoseconds)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   155
 * {@code "us"} (microseconds)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   156
 * {@code "ms"} (milliseconds)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   157
 * {@code "s"} (seconds)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   158
 * {@code "m"} (minutes)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   159
 * {@code "h"} (hours)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   160
 * {@code "d"} (days)<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   161
 * </td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   162
 * <td>{@code "60 s"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   163
 * {@code "10 m"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   164
 * {@code "4 h"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   165
 * {@code "0"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   166
 * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   167
 * </tbody>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   168
 * </table>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   169
 *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   170
 * @since 9
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   171
 */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   172
public interface FlightRecorderMXBean extends PlatformManagedObject {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   173
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   174
     * String representation of the {@code ObjectName} for the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   175
     * {@code FlightRecorderMXBean}.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   176
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   177
    public static final String MXBEAN_NAME = "jdk.management.jfr:type=FlightRecorder";
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   178
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   179
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   180
     * Creates a recording, but doesn't start it.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   181
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   182
     * @return a unique ID that can be used to start, stop, close and
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   183
     *         configure the recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   184
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   185
     * @throws IllegalStateException if Flight Recorder can't be created (for
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   186
     *         example, if the Java Virtual Machine (JVM) lacks Flight Recorder
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   187
     *         support, or if the file repository can't be created or accessed)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   188
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   189
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   190
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   191
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   192
     * @see Recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   193
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   194
    long newRecording() throws IllegalStateException, SecurityException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   195
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   196
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   197
     * Creates a snapshot recording of all available recorded data.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   198
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   199
     * A snapshot is a synthesized recording in a stopped state. If no data is
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   200
     * available, a recording with size {@code 0} is returned.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   201
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   202
     * A snapshot provides stable access to data for later operations (for example,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   203
     * operations to change the time interval or to reduce the data size).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   204
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   205
     * The caller must close the recording when access to the data is no longer
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   206
     * needed.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   207
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   208
     * @return a snapshot of all available recording data, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   209
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   210
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   211
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   212
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   213
     * @return a unique ID that can be used for reading recording data.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   214
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   215
     * @see Recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   216
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   217
    public long takeSnapshot();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   218
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   219
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   220
     * Creates a copy of an existing recording, useful for extracting parts of a
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   221
     * recording.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   222
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   223
     * The cloned recording contains the same recording data as the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   224
     * original, but it has a new ID and a name prefixed with
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   225
     * {@code "Clone of recording"}. If the original recording is running, then
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   226
     * the clone is also running.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   227
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   228
     * @param recordingId the recording ID of the recording to create a clone
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   229
     *        from
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   230
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   231
     * @param stop if the newly created clone is stopped before
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   232
     *        returning.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   233
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   234
     * @return a unique ID that can be used to start, stop,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   235
     *         close and configure the recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   236
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   237
     * @throws IllegalArgumentException if a recording with the specified ID
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   238
     *         doesn't exist
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   239
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   240
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   241
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   242
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   243
     * @see Recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   244
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   245
    long cloneRecording(long recordingId, boolean stop) throws IllegalArgumentException, SecurityException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   246
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   247
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   248
     * Starts the recording with the specified ID.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   249
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   250
     * A recording that is stopped can't be restarted.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   251
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   252
     * @param recordingId ID of the recording to start
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   253
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   254
     * @throws IllegalArgumentException if a recording with the specified ID
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   255
     *         doesn't exist
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   256
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   257
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   258
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   259
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   260
     * @see Recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   261
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   262
    void startRecording(long recordingId) throws IllegalStateException, SecurityException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   263
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   264
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   265
     * Stops the running recording with the specified ID.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   266
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   267
     * @param recordingId the ID of the recording to stop
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   268
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   269
     * @return {@code true} if the recording is stopped, {@code false}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   270
     *         otherwise
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   271
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   272
     * @throws IllegalArgumentException if a recording with the specified ID
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   273
     *         doesn't exist
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   274
     * @throws IllegalStateException if the recording is not running
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   275
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   276
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   277
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   278
     * @see #newRecording()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   279
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   280
    boolean stopRecording(long recordingId) throws IllegalArgumentException, IllegalStateException, SecurityException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   281
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   282
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   283
     * Closes the recording with the specified ID and releases any system
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   284
     * resources that are associated with the recording.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   285
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   286
     * If the recording is already closed, invoking this method has no effect.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   287
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   288
     * @param recordingId the ID of the recording to close
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   289
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   290
     * @throws IllegalArgumentException if a recording with the specified ID
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   291
     *         doesn't exist
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   292
     * @throws IOException if an I/O error occurs
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   293
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   294
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   295
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   296
     * @see #newRecording()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   297
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   298
    void closeRecording(long recordingId) throws IOException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   299
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   300
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   301
     * Opens a data stream for the recording with the specified ID, or {@code 0}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   302
     * to get data irrespective of recording.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   303
     * <table class="striped">
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   304
     * <caption>Recording stream options</caption>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   305
     * <thead>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   306
     * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   307
     * <th scope="col">Name</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   308
     * <th scope="col">Descripion</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   309
     * <th scope="col">Default value</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   310
     * <th scope="col">Format</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   311
     * <th scope="col">Example values</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   312
     * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   313
     * </thead>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   314
     * <tbody>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   315
     * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   316
     * <th scope="row">{@code startTime}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   317
     * <td>Specifies the point in time to start a recording stream. Due to
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   318
     * how data is stored, some events that start or end prior to the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   319
     * start time may be included.</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   320
     * <td>{@code Instant.MIN_VALUE.toString()}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   321
     * <td>ISO-8601. See {@link Instant#toString}<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   322
     * or milliseconds since epoch</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   323
     * <td>{@code "2015-11-03T00:00"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   324
     * {@code "1446508800000"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   325
     * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   326
     * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   327
     * <th scope="row">{@code endTime}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   328
     * <td>Specifies the point in time to end a recording stream. Due to how
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   329
     * data is stored, some events that start or end after the end time may
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   330
     * be included.</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   331
     * <td>{@code Instant.MAX_VALUE.toString()}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   332
     * <td>ISO-8601. See {@link Instant#toString} <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   333
     * or milliseconds since epoch</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   334
     * <td>{@code "2015-11-03T01:00"}, <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   335
     * {@code "1446512400000"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   336
     * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   337
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   338
     * <tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   339
     * <th scope="row">{@code blockSize}</th>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   340
     * <td>Specifies the maximum number of bytes to read with a call to {@code readStream}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   341
     * </td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   342
     * <td>{@code "50000"}</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   343
     * <td>A positive {@code long} value. <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   344
     * <br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   345
     * Setting {@code blockSize} to a very high value may result in
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   346
     * {@link OutOfMemoryError} or an {@link IllegalArgumentException}, if the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   347
     * Java Virtual Machine (JVM) deems the value too large to handle.</td>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   348
     * <td>{@code "50000"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   349
     * {@code "1000000"},<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   350
     * </tr>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   351
     * </tbody>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   352
     * </table>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   353
     * If an option is omitted from the map the default value is used.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   354
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   355
     * The recording with the specified ID must be stopped before a stream can
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   356
     * be opened. This restriction might be lifted in future releases.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   357
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   358
     * @param recordingId ID of the recording to open the stream for
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   359
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   360
     * @param streamOptions a map that contains the options that controls the amount of data
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   361
     *        and how it is read, or {@code null} to get all data for the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   362
     *        recording with the default block size
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   363
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   364
     * @return a unique ID for the stream.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   365
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   366
     * @throws IllegalArgumentException if a recording with the iD doesn't
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   367
     *         exist, or if {@code options} contains invalid values
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   368
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   369
     * @throws IOException if the recording is closed, an I/O error occurs, or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   370
     *         no data is available for the specified recording or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   371
     *         interval
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   372
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   373
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   374
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   375
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   376
    long openStream(long recordingId, Map<String, String> streamOptions) throws IOException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   377
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   378
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   379
     * Closes the recording stream with the specified ID and releases any system
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   380
     * resources that are associated with the stream.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   381
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   382
     * If the stream is already closed, invoking this method has no effect.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   383
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   384
     * @param streamId the ID of the stream
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   385
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   386
     * @throws IllegalArgumentException if a stream with the specified ID doesn't
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   387
     *         exist
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   388
     * @throws IOException if an I/O error occurs while trying to close the stream
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   389
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   390
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   391
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   392
     * @see #openStream(long, Map)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   393
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   394
    void closeStream(long streamId) throws IOException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   395
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   396
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   397
     * Reads a portion of data from the stream with the specified ID, or returns
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   398
     * {@code null} if no more data is available.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   399
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   400
     * To read all data for a recording, invoke this method repeatedly until
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   401
     * {@code null} is returned.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   402
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   403
     * @param streamId the ID of the stream
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   404
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   405
     * @return byte array that contains recording data, or {@code null} when no more
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   406
     *         data is available
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   407
     * @throws IOException if the stream is closed, or an I/O error occurred while
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   408
     *         trying to read the stream
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   409
     * @throws IllegalArgumentException if no recording with the stream ID exists
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   410
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   411
     *         caller does not have {@code ManagementPermission("monitor")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   412
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   413
    byte[] readStream(long streamId) throws IOException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   414
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   415
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   416
     * Returns a map that contains the options for the recording with the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   417
     * specified ID (for example, the destination file or time span to keep
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   418
     * recorded data).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   419
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   420
     * See {@link FlightRecorderMXBean} for available option names.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   421
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   422
     * @param recordingId the ID of the recording to get options for
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   423
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   424
     * @return a map describing the recording options, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   425
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   426
     * @throws IllegalArgumentException if no recording with the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   427
     *         specified ID exists
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   428
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   429
     *         caller does not have {@code ManagementPermission("monitor")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   430
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   431
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   432
    Map<String, String> getRecordingOptions(long recordingId) throws IllegalArgumentException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   433
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   434
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   435
     * Returns a {@code Map} that contains the settings for the recording with the specified ID,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   436
     * (for example, the event thresholds)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   437
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   438
     * If multiple recordings are running at the same time, more data could be
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   439
     * recorded than what is specified in the {@code Map} object.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   440
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   441
     * The name in the {@code Map} is the event name and the setting name separated by
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   442
     * {@code "#"} (for example, {@code "jdk.VMInfo#period"}). The value
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   443
     * is a textual representation of the settings value (for example,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   444
     * {@code "60 s"}).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   445
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   446
     * @param recordingId the ID of the recordings to get settings for
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   447
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   448
     * @return a map that describes the recording settings, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   449
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   450
     * @throws IllegalArgumentException if no recording with the specified ID exists
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   451
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   452
     *         caller does not have {@code ManagementPermission("monitor")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   453
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   454
    Map<String, String> getRecordingSettings(long recordingId) throws IllegalArgumentException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   455
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   456
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   457
     * Sets a configuration as a string representation for the recording with the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   458
     * specified ID.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   459
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   460
     * @param recordingId ID of the recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   461
     * @param contents a string representation of the configuration file to use,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   462
     *        not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   463
     * @throws IllegalArgumentException if no recording with the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   464
     *         specified ID exists or if the configuration could not be parsed.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   465
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   466
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   467
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   468
     * @see Configuration#getContents()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   469
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   470
    void setConfiguration(long recordingId, String contents) throws IllegalArgumentException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   471
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   472
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   473
     * Sets a predefined configuration for the recording with the specified ID.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   474
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   475
     * @param recordingId ID of the recording to set the configuration for
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   476
     * @param configurationName the name of the configuration (for example,
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   477
     *        {@code "profile"} or {@code "default"}), not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   478
     * @throws IllegalArgumentException if no recording with the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   479
     *         specified ID exists
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   480
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   481
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   482
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   483
     * @see #getConfigurations()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   484
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   485
    void setPredefinedConfiguration(long recordingId, String configurationName) throws IllegalArgumentException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   486
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   487
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   488
     * Sets and replaces all previous settings for the specified recording.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   489
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   490
     * A setting consists of a name/value pair, where <em>name</em> specifies the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   491
     * event and setting to configure, and the <em>value</em> specifies what to set
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   492
     * it to.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   493
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   494
     * The name can be formed in the following ways:
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   495
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   496
     * {@code
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   497
     *   <event-name> + "#" + <setting-name>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   498
     * }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   499
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   500
     * or
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   501
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   502
     * {@code
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   503
     *   <event-id> + "#" + <setting-name>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   504
     * }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   505
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   506
     * For example, to set the sample interval of the CPU Load event to once every
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   507
     * second, use the name {@code "jdk.CPULoad#period"} and the value
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   508
     * {@code "1 s"}. If multiple events use the same name, for example if an event
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   509
     * class is loaded in multiple class loaders, and differentiation is needed
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   510
     * between them, then the name is {@code "56#period"}. The ID for an event is
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   511
     * obtained by invoking {@link jdk.jfr.EventType#getId()} method and is valid
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   512
     * for the Java Virtual Machine (JVM) instance that the event is registered in.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   513
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   514
     * A list of available event names is retrieved by invoking
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   515
     * {@link jdk.jfr.FlightRecorder#getEventTypes()} and
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   516
     * {@link jdk.jfr.EventType#getName()}. A list of available settings for an
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   517
     * event type is obtained by invoking
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   518
     * {@link jdk.jfr.EventType#getSettingDescriptors()} and
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   519
     * {@link jdk.jfr.ValueDescriptor#getName()}.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   520
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   521
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   522
     * @param recordingId ID of the recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   523
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   524
     * @param settings name value map of the settings to set, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   525
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   526
     * @throws IllegalArgumentException if no recording with the specified ID exists
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   527
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   528
     *         caller does not have {@code ManagementPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   529
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   530
     * @see Recording#getId()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   531
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   532
    void setRecordingSettings(long recordingId, Map<String, String> settings) throws IllegalArgumentException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   533
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   534
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   535
     * Configures the recording options (for example, destination file and time span
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   536
     * to keep data).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   537
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   538
     * See {@link FlightRecorderMXBean} for a description of the options and values
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   539
     * that can be used. Setting a value to {@code null} restores the value to the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   540
     * default value.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   541
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   542
     * @param recordingId the ID of the recording to set options for
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   543
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   544
     * @param options name/value map of the settings to set, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   545
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   546
     * @throws IllegalArgumentException if no recording with the specified ID exists
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   547
     * @throws java.lang.SecurityException if a security manager exists, and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   548
     *         caller does not have {@code ManagementPermission("control")} or an
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   549
     *         option contains a file that the caller does not have permission to
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   550
     *         operate on.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   551
     * @see Recording#getId()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   552
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   553
    void setRecordingOptions(long recordingId, Map<String, String> options) throws IllegalArgumentException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   554
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   555
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   556
     * Returns the list of the available recordings, not necessarily running.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   557
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   558
     * <b>MBeanServer access</b>:<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   559
     * The mapped type of {@code RecordingInfo} is {@code CompositeData} with
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   560
     * attributes as specified in the {@link RecordingInfo#from
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   561
     * RecordingInfo.from} method.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   562
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   563
     * @return list of recordings, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   564
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   565
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   566
     *         caller does not have {@code  ManagementPermission("monitor")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   567
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   568
     * @see RecordingInfo
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   569
     * @see Recording
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   570
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   571
    List<RecordingInfo> getRecordings();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   572
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   573
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   574
     * Returns the list of predefined configurations for this Java Virtual Machine (JVM).
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   575
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   576
     * <b>MBeanServer access</b>:<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   577
     * The mapped type of {@code ConfigurationInfo} is {@code CompositeData}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   578
     * with attributes as specified in the {@link ConfigurationInfo#from
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   579
     * ConfigurationInfo.from} method.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   580
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   581
     * @return the list of predefined configurations, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   582
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   583
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   584
     *         caller does not have {@code ManagementPermission("monitor")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   585
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   586
     * @see ConfigurationInfo
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   587
     * @see Configuration
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   588
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   589
    List<ConfigurationInfo> getConfigurations();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   590
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   591
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   592
     * Returns the list of currently registered event types.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   593
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   594
     * <b>MBeanServer access</b>:<br>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   595
     * The mapped type of {@code EventTypeInfo} is {@code CompositeData} with
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   596
     * attributes as specified in the {@link EventTypeInfo#from
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   597
     * EventTypeInfo.from} method.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   598
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   599
     * @return the list of registered event types, not {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   600
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   601
     * @throws java.lang.SecurityException if a security manager exists and the
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   602
     *         caller does not have {@code ManagementPermission("monitor")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   603
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   604
     * @see EventTypeInfo
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   605
     * @see EventType
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   606
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   607
    List<EventTypeInfo> getEventTypes();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   608
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   609
    /**
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   610
     * Writes recording data to the specified file.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   611
     * <p>
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   612
     * If this method is invoked remotely from another process, the data is written
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   613
     * to a file named {@code outputFile} on the machine where the target Java
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   614
     * Virtual Machine (JVM) is running. If the file location is a relative path, it
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   615
     * is relative to the working directory where the target JVM was started.
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   616
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   617
     * @param recordingId the ID of the recording to dump data for
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   618
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   619
     * @param outputFile the system-dependent file name where data is written, not
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   620
     *        {@code null}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   621
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   622
     * @throws IOException if the recording can't be dumped due to an I/O error (for
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   623
     *         example, an invalid path)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   624
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   625
     * @throws IllegalArgumentException if a recording with the specified ID doesn't
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   626
     *         exist
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   627
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   628
     * @throws IllegalStateException if the recording is not yet started or if it is
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   629
     *         already closed
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   630
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   631
     * @throws SecurityException if a security manager exists and its
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   632
     *         {@code SecurityManager.checkWrite(java.lang.String)} method denies
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   633
     *         write access to the named file or the caller does not have
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   634
     *         {@code ManagmentPermission("control")}
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   635
     *
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   636
     * @see java.nio.file.Path#toString()
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   637
     * @see Recording#dump(java.nio.file.Path)
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   638
     */
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   639
    void copyTo(long recordingId, String outputFile) throws IOException, SecurityException;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents:
diff changeset
   640
}