Skip to content

Commit

Permalink
8176055: JMX diagnostic improvements
Browse files Browse the repository at this point in the history
Reviewed-by: dfuchs, mchung, ahgross, rhalade, jwilhelm
  • Loading branch information
Harsha Wardhana B committed May 12, 2017
1 parent 0dadd76 commit fb87831
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 4 deletions.
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2005, 2014, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2005, 2017, 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
Expand Down Expand Up @@ -61,9 +61,10 @@ public interface HotSpotDiagnosticMXBean extends PlatformManagedObject {
* @param outputFile the system-dependent filename
* @param live if {@code true} dump only <i>live</i> objects
* i.e. objects that are reachable from others
* @throws IOException if the {@code outputFile}
* @throws IOException if the {@code outputFile} already exists,
* cannot be created, opened, or written to.
* @throws UnsupportedOperationException if this operation is not supported.
* @throws IllegalArgumentException if {@code outputFile} does not end with ".hprof" suffix.
* @throws NullPointerException if {@code outputFile} is {@code null}.
* @throws SecurityException
* If a security manager exists and its {@link
Expand Down
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2005, 2017, 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
Expand All @@ -22,7 +22,6 @@
* or visit www.oracle.com if you need additional information or have any
* questions.
*/

package com.sun.management.internal;

import java.io.IOException;
Expand All @@ -32,6 +31,8 @@

import com.sun.management.HotSpotDiagnosticMXBean;
import com.sun.management.VMOption;
import java.security.AccessController;
import java.security.PrivilegedAction;
import sun.management.Util;

/**
Expand All @@ -43,6 +44,14 @@ public HotSpotDiagnostic() {

@Override
public void dumpHeap(String outputFile, boolean live) throws IOException {

String propertyName = "jdk.management.heapdump.allowAnyFileSuffix";
PrivilegedAction<Boolean> pa = () -> Boolean.parseBoolean(System.getProperty(propertyName, "false"));
boolean allowAnyFileSuffix = AccessController.doPrivileged(pa);
if (!allowAnyFileSuffix && !outputFile.endsWith(".hprof")) {
throw new IllegalArgumentException("heapdump file must have .hprof extention");
}

SecurityManager security = System.getSecurityManager();
if (security != null) {
security.checkWrite(outputFile);
Expand Down

0 comments on commit fb87831

Please sign in to comment.