YARN-7039. Fix javac and javadoc errors in YARN-3926 branch. (Sunil G via wangda)
Change-Id: I442bf6d838b3aba83f1f6779cf9dcf8596a2102d
(cherry picked from commit e490602e9b
)
This commit is contained in:
parent
5dd008ca2e
commit
57bbdbeb80
File diff suppressed because it is too large
Load Diff
|
@ -1,283 +0,0 @@
|
||||||
This product includes software developed by The Apache Software
|
|
||||||
Foundation (http://www.apache.org/).
|
|
||||||
|
|
||||||
The binary distribution of this product bundles binaries of
|
|
||||||
org.iq80.leveldb:leveldb-api (https://github.com/dain/leveldb), which has the
|
|
||||||
following notices:
|
|
||||||
* Copyright 2011 Dain Sundstrom <dain@iq80.com>
|
|
||||||
* Copyright 2011 FuseSource Corp. http://fusesource.com
|
|
||||||
|
|
||||||
The binary distribution of this product bundles binaries of
|
|
||||||
org.fusesource.hawtjni:hawtjni-runtime (https://github.com/fusesource/hawtjni),
|
|
||||||
which has the following notices:
|
|
||||||
* This product includes software developed by FuseSource Corp.
|
|
||||||
http://fusesource.com
|
|
||||||
* This product includes software developed at
|
|
||||||
Progress Software Corporation and/or its subsidiaries or affiliates.
|
|
||||||
* This product includes software developed by IBM Corporation and others.
|
|
||||||
|
|
||||||
The binary distribution of this product bundles binaries of
|
|
||||||
AWS Java SDK 1.10.6,
|
|
||||||
which has the following notices:
|
|
||||||
* This software includes third party software subject to the following
|
|
||||||
copyrights: - XML parsing and utility functions from JetS3t - Copyright
|
|
||||||
2006-2009 James Murty. - JSON parsing and utility functions from JSON.org -
|
|
||||||
Copyright 2002 JSON.org. - PKCS#1 PEM encoded private key parsing and utility
|
|
||||||
functions from oauth.googlecode.com - Copyright 1998-2010 AOL Inc.
|
|
||||||
|
|
||||||
The binary distribution of this product bundles binaries of
|
|
||||||
Gson 2.2.4,
|
|
||||||
which has the following notices:
|
|
||||||
|
|
||||||
The Netty Project
|
|
||||||
=================
|
|
||||||
|
|
||||||
Please visit the Netty web site for more information:
|
|
||||||
|
|
||||||
* http://netty.io/
|
|
||||||
|
|
||||||
Copyright 2014 The Netty Project
|
|
||||||
|
|
||||||
The Netty Project licenses this file to you under the Apache License,
|
|
||||||
version 2.0 (the "License"); you may not use this file except in compliance
|
|
||||||
with the License. You may obtain a copy of the License at:
|
|
||||||
|
|
||||||
http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
|
||||||
Unless required by applicable law or agreed to in writing, software
|
|
||||||
distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
||||||
WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
||||||
License for the specific language governing permissions and limitations
|
|
||||||
under the License.
|
|
||||||
|
|
||||||
Also, please refer to each LICENSE.<component>.txt file, which is located in
|
|
||||||
the 'license' directory of the distribution file, for the license terms of the
|
|
||||||
components that this product depends on.
|
|
||||||
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
This product contains the extensions to Java Collections Framework which has
|
|
||||||
been derived from the works by JSR-166 EG, Doug Lea, and Jason T. Greene:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.jsr166y.txt (Public Domain)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://gee.cs.oswego.edu/cgi-bin/viewcvs.cgi/jsr166/
|
|
||||||
* http://viewvc.jboss.org/cgi-bin/viewvc.cgi/jbosscache/experimental/jsr166/
|
|
||||||
|
|
||||||
This product contains a modified version of Robert Harder's Public Domain
|
|
||||||
Base64 Encoder and Decoder, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.base64.txt (Public Domain)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://iharder.sourceforge.net/current/java/base64/
|
|
||||||
|
|
||||||
This product contains a modified portion of 'Webbit', an event based
|
|
||||||
WebSocket and HTTP server, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.webbit.txt (BSD License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://github.com/joewalnes/webbit
|
|
||||||
|
|
||||||
This product contains a modified portion of 'SLF4J', a simple logging
|
|
||||||
facade for Java, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.slf4j.txt (MIT License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://www.slf4j.org/
|
|
||||||
|
|
||||||
This product contains a modified portion of 'ArrayDeque', written by Josh
|
|
||||||
Bloch of Google, Inc:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.deque.txt (Public Domain)
|
|
||||||
|
|
||||||
This product contains a modified portion of 'Apache Harmony', an open source
|
|
||||||
Java SE, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.harmony.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://archive.apache.org/dist/harmony/
|
|
||||||
|
|
||||||
This product contains a modified version of Roland Kuhn's ASL2
|
|
||||||
AbstractNodeQueue, which is based on Dmitriy Vyukov's non-intrusive MPSC queue.
|
|
||||||
It can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.abstractnodequeue.txt (Public Domain)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://github.com/akka/akka/blob/wip-2.2.3-for-scala-2.11/akka-actor/src/main/java/akka/dispatch/AbstractNodeQueue.java
|
|
||||||
|
|
||||||
This product contains a modified portion of 'jbzip2', a Java bzip2 compression
|
|
||||||
and decompression library written by Matthew J. Francis. It can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.jbzip2.txt (MIT License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://code.google.com/p/jbzip2/
|
|
||||||
|
|
||||||
This product contains a modified portion of 'libdivsufsort', a C API library to construct
|
|
||||||
the suffix array and the Burrows-Wheeler transformed string for any input string of
|
|
||||||
a constant-size alphabet written by Yuta Mori. It can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.libdivsufsort.txt (MIT License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://code.google.com/p/libdivsufsort/
|
|
||||||
|
|
||||||
This product contains a modified portion of Nitsan Wakart's 'JCTools', Java Concurrency Tools for the JVM,
|
|
||||||
which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.jctools.txt (ASL2 License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://github.com/JCTools/JCTools
|
|
||||||
|
|
||||||
This product optionally depends on 'JZlib', a re-implementation of zlib in
|
|
||||||
pure Java, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.jzlib.txt (BSD style License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://www.jcraft.com/jzlib/
|
|
||||||
|
|
||||||
This product optionally depends on 'Compress-LZF', a Java library for encoding and
|
|
||||||
decoding data in LZF format, written by Tatu Saloranta. It can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.compress-lzf.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://github.com/ning/compress
|
|
||||||
|
|
||||||
This product optionally depends on 'lz4', a LZ4 Java compression
|
|
||||||
and decompression library written by Adrien Grand. It can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.lz4.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://github.com/jpountz/lz4-java
|
|
||||||
|
|
||||||
This product optionally depends on 'lzma-java', a LZMA Java compression
|
|
||||||
and decompression library, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.lzma-java.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://github.com/jponge/lzma-java
|
|
||||||
|
|
||||||
This product contains a modified portion of 'jfastlz', a Java port of FastLZ compression
|
|
||||||
and decompression library written by William Kinney. It can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.jfastlz.txt (MIT License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://code.google.com/p/jfastlz/
|
|
||||||
|
|
||||||
This product contains a modified portion of and optionally depends on 'Protocol Buffers', Google's data
|
|
||||||
interchange format, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.protobuf.txt (New BSD License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://code.google.com/p/protobuf/
|
|
||||||
|
|
||||||
This product optionally depends on 'Bouncy Castle Crypto APIs' to generate
|
|
||||||
a temporary self-signed X.509 certificate when the JVM does not provide the
|
|
||||||
equivalent functionality. It can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.bouncycastle.txt (MIT License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://www.bouncycastle.org/
|
|
||||||
|
|
||||||
This product optionally depends on 'Snappy', a compression library produced
|
|
||||||
by Google Inc, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.snappy.txt (New BSD License)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://code.google.com/p/snappy/
|
|
||||||
|
|
||||||
This product optionally depends on 'JBoss Marshalling', an alternative Java
|
|
||||||
serialization API, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.jboss-marshalling.txt (GNU LGPL 2.1)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://www.jboss.org/jbossmarshalling
|
|
||||||
|
|
||||||
This product optionally depends on 'Caliper', Google's micro-
|
|
||||||
benchmarking framework, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.caliper.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://code.google.com/p/caliper/
|
|
||||||
|
|
||||||
This product optionally depends on 'Apache Commons Logging', a logging
|
|
||||||
framework, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.commons-logging.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://commons.apache.org/logging/
|
|
||||||
|
|
||||||
This product optionally depends on 'Apache Log4J', a logging framework, which
|
|
||||||
can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.log4j.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://logging.apache.org/log4j/
|
|
||||||
|
|
||||||
This product optionally depends on 'Aalto XML', an ultra-high performance
|
|
||||||
non-blocking XML processor, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.aalto-xml.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* http://wiki.fasterxml.com/AaltoHome
|
|
||||||
|
|
||||||
This product contains a modified version of 'HPACK', a Java implementation of
|
|
||||||
the HTTP/2 HPACK algorithm written by Twitter. It can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.hpack.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://github.com/twitter/hpack
|
|
||||||
|
|
||||||
This product contains a modified portion of 'Apache Commons Lang', a Java library
|
|
||||||
provides utilities for the java.lang API, which can be obtained at:
|
|
||||||
|
|
||||||
* LICENSE:
|
|
||||||
* license/LICENSE.commons-lang.txt (Apache License 2.0)
|
|
||||||
* HOMEPAGE:
|
|
||||||
* https://commons.apache.org/proper/commons-lang/
|
|
||||||
|
|
||||||
The binary distribution of this product bundles binaries of
|
|
||||||
Commons Codec 1.4,
|
|
||||||
which has the following notices:
|
|
||||||
* src/test/org/apache/commons/codec/language/DoubleMetaphoneTest.javacontains test data from http://aspell.net/test/orig/batch0.tab.Copyright (C) 2002 Kevin Atkinson (kevina@gnu.org)
|
|
||||||
===============================================================================
|
|
||||||
The content of package org.apache.commons.codec.language.bm has been translated
|
|
||||||
from the original php source code available at http://stevemorse.org/phoneticinfo.htm
|
|
||||||
with permission from the original authors.
|
|
||||||
Original source copyright:Copyright (c) 2008 Alexander Beider & Stephen P. Morse.
|
|
||||||
|
|
||||||
The binary distribution of this product bundles binaries of
|
|
||||||
Commons Lang 2.6,
|
|
||||||
which has the following notices:
|
|
||||||
* This product includes software from the Spring Framework,under the Apache License 2.0 (see: StringUtils.containsWhitespace())
|
|
||||||
|
|
||||||
The binary distribution of this product bundles binaries of
|
|
||||||
Apache Log4j 1.2.17,
|
|
||||||
which has the following notices:
|
|
||||||
* ResolverUtil.java
|
|
||||||
Copyright 2005-2006 Tim Fennell
|
|
||||||
Dumbster SMTP test server
|
|
||||||
Copyright 2004 Jason Paul Kitchen
|
|
||||||
TypeUtil.java
|
|
||||||
Copyright 2002-2012 Ramnivas Laddad, Juergen Hoeller, Chris Beams
|
|
|
@ -24,7 +24,6 @@ import org.apache.hadoop.classification.InterfaceStability.Stable;
|
||||||
import org.apache.hadoop.classification.InterfaceStability.Unstable;
|
import org.apache.hadoop.classification.InterfaceStability.Unstable;
|
||||||
import org.apache.hadoop.yarn.util.Records;
|
import org.apache.hadoop.yarn.util.Records;
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -19,9 +19,7 @@
|
||||||
package org.apache.hadoop.yarn.api.records;
|
package org.apache.hadoop.yarn.api.records;
|
||||||
|
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.classification.InterfaceAudience.Public;
|
|
||||||
import org.apache.hadoop.classification.InterfaceStability;
|
import org.apache.hadoop.classification.InterfaceStability;
|
||||||
import org.apache.hadoop.classification.InterfaceStability.Evolving;
|
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.ResourceTypes;
|
import org.apache.hadoop.yarn.api.protocolrecords.ResourceTypes;
|
||||||
import org.apache.hadoop.yarn.util.Records;
|
import org.apache.hadoop.yarn.util.Records;
|
||||||
|
|
||||||
|
@ -111,7 +109,7 @@ public abstract class ResourceTypeInfo implements Comparable<ResourceTypeInfo> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new instance of ResourceTypeInfo from name, units
|
* Create a new instance of ResourceTypeInfo from name, units.
|
||||||
*
|
*
|
||||||
* @param name name of resource type
|
* @param name name of resource type
|
||||||
* @param units units of resource type
|
* @param units units of resource type
|
||||||
|
@ -124,7 +122,7 @@ public abstract class ResourceTypeInfo implements Comparable<ResourceTypeInfo> {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new instance of ResourceTypeInfo from name
|
* Create a new instance of ResourceTypeInfo from name.
|
||||||
*
|
*
|
||||||
* @param name name of resource type
|
* @param name name of resource type
|
||||||
* @return the new ResourceTypeInfo object
|
* @return the new ResourceTypeInfo object
|
||||||
|
|
|
@ -15,6 +15,10 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
/**
|
||||||
|
* Package org.apache.hadoop.yarn.api.records.impl contains classes
|
||||||
|
* which define basic resources.
|
||||||
|
*/
|
||||||
@InterfaceAudience.Public
|
@InterfaceAudience.Public
|
||||||
@InterfaceStability.Unstable
|
@InterfaceStability.Unstable
|
||||||
package org.apache.hadoop.yarn.api.records.impl;
|
package org.apache.hadoop.yarn.api.records.impl;
|
||||||
|
|
|
@ -45,9 +45,8 @@ public class UnitsConversionUtil {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final String[] UNITS =
|
private static final String[] UNITS = {"p", "n", "u", "m", "", "k", "M", "G",
|
||||||
{ "p", "n", "u", "m", "", "k", "M", "G", "T", "P", "Ki", "Mi", "Gi", "Ti",
|
"T", "P", "Ki", "Mi", "Gi", "Ti", "Pi"};
|
||||||
"Pi" };
|
|
||||||
private static final List<String> SORTED_UNITS = Arrays.asList(UNITS);
|
private static final List<String> SORTED_UNITS = Arrays.asList(UNITS);
|
||||||
public static final Set<String> KNOWN_UNITS = createKnownUnitsSet();
|
public static final Set<String> KNOWN_UNITS = createKnownUnitsSet();
|
||||||
private static final Converter PICO =
|
private static final Converter PICO =
|
||||||
|
|
|
@ -466,8 +466,8 @@ public class ResourceUtils {
|
||||||
return readOnlyNodeResources;
|
return readOnlyNodeResources;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Map<String, ResourceInformation>
|
private static Map<String, ResourceInformation> initializeNodeResourceInformation(
|
||||||
initializeNodeResourceInformation(Configuration conf) {
|
Configuration conf) {
|
||||||
Map<String, ResourceInformation> nodeResources = new HashMap<>();
|
Map<String, ResourceInformation> nodeResources = new HashMap<>();
|
||||||
try {
|
try {
|
||||||
addResourcesFileToConf(
|
addResourcesFileToConf(
|
||||||
|
|
|
@ -15,6 +15,10 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
/**
|
||||||
|
* Package org.apache.hadoop.yarn.util.resource contains classes
|
||||||
|
* which is used as utility class for resource profile computations.
|
||||||
|
*/
|
||||||
@InterfaceAudience.Public
|
@InterfaceAudience.Public
|
||||||
@InterfaceStability.Unstable
|
@InterfaceStability.Unstable
|
||||||
package org.apache.hadoop.yarn.util.resource;
|
package org.apache.hadoop.yarn.util.resource;
|
||||||
|
|
|
@ -22,6 +22,9 @@ import org.apache.hadoop.yarn.api.records.ResourceInformation;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test class to verify various resource informations in a given resource.
|
||||||
|
*/
|
||||||
public class TestResourceInformation {
|
public class TestResourceInformation {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -21,6 +21,10 @@ package org.apache.hadoop.yarn.util;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test class to handle all test cases needed to verify basic unit conversion
|
||||||
|
* scenarios.
|
||||||
|
*/
|
||||||
public class TestUnitsConversionUtil {
|
public class TestUnitsConversionUtil {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -87,13 +91,13 @@ public class TestUnitsConversionUtil {
|
||||||
UnitsConversionUtil.convert("P", "p", test);
|
UnitsConversionUtil.convert("P", "p", test);
|
||||||
Assert.fail("this operation should result in an overflow");
|
Assert.fail("this operation should result in an overflow");
|
||||||
} catch (IllegalArgumentException ie) {
|
} catch (IllegalArgumentException ie) {
|
||||||
; // do nothing
|
// do nothing
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
UnitsConversionUtil.convert("m", "p", Long.MAX_VALUE - 1);
|
UnitsConversionUtil.convert("m", "p", Long.MAX_VALUE - 1);
|
||||||
Assert.fail("this operation should result in an overflow");
|
Assert.fail("this operation should result in an overflow");
|
||||||
} catch (IllegalArgumentException ie) {
|
} catch (IllegalArgumentException ie) {
|
||||||
; // do nothing
|
// do nothing
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -77,6 +77,7 @@ import org.apache.hadoop.yarn.client.api.YarnClient;
|
||||||
import org.apache.hadoop.yarn.client.api.YarnClientApplication;
|
import org.apache.hadoop.yarn.client.api.YarnClientApplication;
|
||||||
import org.apache.hadoop.yarn.client.util.YarnClientUtils;
|
import org.apache.hadoop.yarn.client.util.YarnClientUtils;
|
||||||
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
||||||
|
import org.apache.hadoop.yarn.exceptions.YARNFeatureNotEnabledException;
|
||||||
import org.apache.hadoop.yarn.exceptions.YarnException;
|
import org.apache.hadoop.yarn.exceptions.YarnException;
|
||||||
import org.apache.hadoop.yarn.util.timeline.TimelineUtils;
|
import org.apache.hadoop.yarn.util.timeline.TimelineUtils;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
|
|
@ -60,8 +60,9 @@ public class GetAllResourceTypeInfoRequestPBImpl
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean equals(Object other) {
|
public boolean equals(Object other) {
|
||||||
if (other == null)
|
if (other == null) {
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
if (other.getClass().isAssignableFrom(this.getClass())) {
|
if (other.getClass().isAssignableFrom(this.getClass())) {
|
||||||
return this.getProto().equals(this.getClass().cast(other).getProto());
|
return this.getProto().equals(this.getClass().cast(other).getProto());
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,6 @@ import org.apache.hadoop.yarn.proto.YarnProtos.ResourceProto;
|
||||||
|
|
||||||
import com.google.protobuf.TextFormat;
|
import com.google.protobuf.TextFormat;
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
@Private
|
@Private
|
||||||
|
|
|
@ -26,8 +26,6 @@ import org.apache.hadoop.yarn.proto.YarnProtos;
|
||||||
import org.apache.hadoop.yarn.proto.YarnProtos.ResourceTypeInfoProto;
|
import org.apache.hadoop.yarn.proto.YarnProtos.ResourceTypeInfoProto;
|
||||||
import org.apache.hadoop.yarn.proto.YarnProtos.ResourceTypesProto;
|
import org.apache.hadoop.yarn.proto.YarnProtos.ResourceTypesProto;
|
||||||
|
|
||||||
import com.google.common.base.Preconditions;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@code ResourceTypeInfoPBImpl} which implements the
|
* {@code ResourceTypeInfoPBImpl} which implements the
|
||||||
* {@link ResourceTypeInfo} class which represents different resource types
|
* {@link ResourceTypeInfo} class which represents different resource types
|
||||||
|
|
|
@ -30,6 +30,10 @@ import org.apache.hadoop.yarn.util.UnitsConversionUtil;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resources is a computation class which provides a set of apis to do
|
||||||
|
* mathematical operations on Resource object.
|
||||||
|
*/
|
||||||
@InterfaceAudience.LimitedPrivate({ "YARN", "MapReduce" })
|
@InterfaceAudience.LimitedPrivate({ "YARN", "MapReduce" })
|
||||||
@Unstable
|
@Unstable
|
||||||
public class Resources {
|
public class Resources {
|
||||||
|
@ -47,7 +51,7 @@ public class Resources {
|
||||||
private String name;
|
private String name;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor for a fixed value resource
|
* Constructor for a fixed value resource.
|
||||||
* @param rName the name of the resource
|
* @param rName the name of the resource
|
||||||
* @param value the fixed value to be returned for all resource types
|
* @param value the fixed value to be returned for all resource types
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -29,8 +29,6 @@ import org.apache.hadoop.security.proto.SecurityProtos.TokenProto;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.CommitResponse;
|
import org.apache.hadoop.yarn.api.protocolrecords.CommitResponse;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.ContainerUpdateRequest;
|
import org.apache.hadoop.yarn.api.protocolrecords.ContainerUpdateRequest;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.ContainerUpdateResponse;
|
import org.apache.hadoop.yarn.api.protocolrecords.ContainerUpdateResponse;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.GetAllResourceTypeInfoRequest;
|
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.GetAllResourceTypeInfoResponse;
|
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.IncreaseContainersResourceRequest;
|
import org.apache.hadoop.yarn.api.protocolrecords.IncreaseContainersResourceRequest;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.IncreaseContainersResourceResponse;
|
import org.apache.hadoop.yarn.api.protocolrecords.IncreaseContainersResourceResponse;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.ReInitializeContainerRequest;
|
import org.apache.hadoop.yarn.api.protocolrecords.ReInitializeContainerRequest;
|
||||||
|
@ -143,7 +141,6 @@ import org.apache.hadoop.yarn.api.records.ReservationRequest;
|
||||||
import org.apache.hadoop.yarn.api.records.ReservationRequests;
|
import org.apache.hadoop.yarn.api.records.ReservationRequests;
|
||||||
import org.apache.hadoop.yarn.api.records.Resource;
|
import org.apache.hadoop.yarn.api.records.Resource;
|
||||||
import org.apache.hadoop.yarn.api.records.ResourceAllocationRequest;
|
import org.apache.hadoop.yarn.api.records.ResourceAllocationRequest;
|
||||||
import org.apache.hadoop.yarn.api.records.Resource;
|
|
||||||
import org.apache.hadoop.yarn.api.records.ResourceInformation;
|
import org.apache.hadoop.yarn.api.records.ResourceInformation;
|
||||||
import org.apache.hadoop.yarn.api.records.ResourceBlacklistRequest;
|
import org.apache.hadoop.yarn.api.records.ResourceBlacklistRequest;
|
||||||
import org.apache.hadoop.yarn.api.records.ResourceOption;
|
import org.apache.hadoop.yarn.api.records.ResourceOption;
|
||||||
|
@ -341,7 +338,6 @@ import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
import com.google.common.collect.ImmutableSet;
|
import com.google.common.collect.ImmutableSet;
|
||||||
import java.io.IOException;
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -33,6 +33,9 @@ import java.io.File;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test class to verify all resource utility methods.
|
||||||
|
*/
|
||||||
public class TestResourceUtils {
|
public class TestResourceUtils {
|
||||||
|
|
||||||
static class ResourceFileInformation {
|
static class ResourceFileInformation {
|
||||||
|
@ -106,8 +109,8 @@ public class TestResourceUtils {
|
||||||
testFile4.resourceNameUnitsMap.put("resource1", "G");
|
testFile4.resourceNameUnitsMap.put("resource1", "G");
|
||||||
testFile4.resourceNameUnitsMap.put("resource2", "m");
|
testFile4.resourceNameUnitsMap.put("resource2", "m");
|
||||||
|
|
||||||
ResourceFileInformation[] tests =
|
ResourceFileInformation[] tests = {testFile1, testFile2, testFile3,
|
||||||
{ testFile1, testFile2, testFile3, testFile4 };
|
testFile4};
|
||||||
Map<String, ResourceInformation> res;
|
Map<String, ResourceInformation> res;
|
||||||
for (ResourceFileInformation testInformation : tests) {
|
for (ResourceFileInformation testInformation : tests) {
|
||||||
ResourceUtils.resetResourceTypes();
|
ResourceUtils.resetResourceTypes();
|
||||||
|
@ -134,9 +137,9 @@ public class TestResourceUtils {
|
||||||
public void testGetResourceTypesConfigErrors() throws Exception {
|
public void testGetResourceTypesConfigErrors() throws Exception {
|
||||||
Configuration conf = new YarnConfiguration();
|
Configuration conf = new YarnConfiguration();
|
||||||
|
|
||||||
String[] resourceFiles =
|
String[] resourceFiles = {"resource-types-error-1.xml",
|
||||||
{ "resource-types-error-1.xml", "resource-types-error-2.xml",
|
"resource-types-error-2.xml", "resource-types-error-3.xml",
|
||||||
"resource-types-error-3.xml", "resource-types-error-4.xml" };
|
"resource-types-error-4.xml"};
|
||||||
for (String resourceFile : resourceFiles) {
|
for (String resourceFile : resourceFiles) {
|
||||||
ResourceUtils.resetResourceTypes();
|
ResourceUtils.resetResourceTypes();
|
||||||
File dest = null;
|
File dest = null;
|
||||||
|
@ -159,15 +162,15 @@ public class TestResourceUtils {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInitializeResourcesMap() throws Exception {
|
public void testInitializeResourcesMap() throws Exception {
|
||||||
String[] empty = { "", "" };
|
String[] empty = {"", ""};
|
||||||
String[] res1 = { "resource1", "m" };
|
String[] res1 = {"resource1", "m"};
|
||||||
String[] res2 = { "resource2", "G" };
|
String[] res2 = {"resource2", "G"};
|
||||||
String[][] test1 = { empty };
|
String[][] test1 = {empty};
|
||||||
String[][] test2 = { res1 };
|
String[][] test2 = {res1};
|
||||||
String[][] test3 = { res2 };
|
String[][] test3 = {res2};
|
||||||
String[][] test4 = { res1, res2 };
|
String[][] test4 = {res1, res2};
|
||||||
|
|
||||||
String[][][] allTests = { test1, test2, test3, test4 };
|
String[][][] allTests = {test1, test2, test3, test4};
|
||||||
|
|
||||||
for (String[][] test : allTests) {
|
for (String[][] test : allTests) {
|
||||||
|
|
||||||
|
@ -221,19 +224,19 @@ public class TestResourceUtils {
|
||||||
@Test
|
@Test
|
||||||
public void testInitializeResourcesMapErrors() throws Exception {
|
public void testInitializeResourcesMapErrors() throws Exception {
|
||||||
|
|
||||||
String[] mem1 = { "memory-mb", "" };
|
String[] mem1 = {"memory-mb", ""};
|
||||||
String[] vcores1 = { "vcores", "M" };
|
String[] vcores1 = {"vcores", "M"};
|
||||||
|
|
||||||
String[] mem2 = { "memory-mb", "m" };
|
String[] mem2 = {"memory-mb", "m"};
|
||||||
String[] vcores2 = { "vcores", "G" };
|
String[] vcores2 = {"vcores", "G"};
|
||||||
|
|
||||||
String[] mem3 = { "memory", "" };
|
String[] mem3 = {"memory", ""};
|
||||||
|
|
||||||
String[][] test1 = { mem1, vcores1 };
|
String[][] test1 = {mem1, vcores1};
|
||||||
String[][] test2 = { mem2, vcores2 };
|
String[][] test2 = {mem2, vcores2};
|
||||||
String[][] test3 = { mem3 };
|
String[][] test3 = {mem3};
|
||||||
|
|
||||||
String[][][] allTests = { test1, test2, test3 };
|
String[][][] allTests = {test1, test2, test3};
|
||||||
|
|
||||||
for (String[][] test : allTests) {
|
for (String[][] test : allTests) {
|
||||||
|
|
||||||
|
|
|
@ -175,12 +175,12 @@ public class NodeStatusUpdaterImpl extends AbstractService implements
|
||||||
@Override
|
@Override
|
||||||
protected void serviceInit(Configuration conf) throws Exception {
|
protected void serviceInit(Configuration conf) throws Exception {
|
||||||
this.totalResource = NodeManagerHardwareUtils.getNodeResources(conf);
|
this.totalResource = NodeManagerHardwareUtils.getNodeResources(conf);
|
||||||
int memoryMb = totalResource.getMemory();
|
long memoryMb = totalResource.getMemorySize();
|
||||||
float vMemToPMem =
|
float vMemToPMem =
|
||||||
conf.getFloat(
|
conf.getFloat(
|
||||||
YarnConfiguration.NM_VMEM_PMEM_RATIO,
|
YarnConfiguration.NM_VMEM_PMEM_RATIO,
|
||||||
YarnConfiguration.DEFAULT_NM_VMEM_PMEM_RATIO);
|
YarnConfiguration.DEFAULT_NM_VMEM_PMEM_RATIO);
|
||||||
int virtualMemoryMb = (int)Math.ceil(memoryMb * vMemToPMem);
|
long virtualMemoryMb = (long)Math.ceil(memoryMb * vMemToPMem);
|
||||||
|
|
||||||
int virtualCores = totalResource.getVirtualCores();
|
int virtualCores = totalResource.getVirtualCores();
|
||||||
LOG.info("Nodemanager resources: memory set to " + memoryMb + "MB.");
|
LOG.info("Nodemanager resources: memory set to " + memoryMb + "MB.");
|
||||||
|
@ -190,12 +190,12 @@ public class NodeStatusUpdaterImpl extends AbstractService implements
|
||||||
metrics.addResource(totalResource);
|
metrics.addResource(totalResource);
|
||||||
|
|
||||||
// Get actual node physical resources
|
// Get actual node physical resources
|
||||||
int physicalMemoryMb = memoryMb;
|
long physicalMemoryMb = memoryMb;
|
||||||
int physicalCores = virtualCores;
|
int physicalCores = virtualCores;
|
||||||
ResourceCalculatorPlugin rcp =
|
ResourceCalculatorPlugin rcp =
|
||||||
ResourceCalculatorPlugin.getNodeResourceMonitorPlugin(conf);
|
ResourceCalculatorPlugin.getNodeResourceMonitorPlugin(conf);
|
||||||
if (rcp != null) {
|
if (rcp != null) {
|
||||||
physicalMemoryMb = (int) (rcp.getPhysicalMemorySize() / (1024 * 1024));
|
physicalMemoryMb = rcp.getPhysicalMemorySize() / (1024 * 1024);
|
||||||
physicalCores = rcp.getNumProcessors();
|
physicalCores = rcp.getNumProcessors();
|
||||||
}
|
}
|
||||||
this.physicalResource =
|
this.physicalResource =
|
||||||
|
|
|
@ -246,8 +246,8 @@ public class NodeManagerHardwareUtils {
|
||||||
return cores;
|
return cores;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int getConfiguredMemoryMB(Configuration conf) {
|
private static long getConfiguredMemoryMB(Configuration conf) {
|
||||||
int memoryMb = conf.getInt(YarnConfiguration.NM_PMEM_MB,
|
long memoryMb = conf.getLong(YarnConfiguration.NM_PMEM_MB,
|
||||||
YarnConfiguration.DEFAULT_NM_PMEM_MB);
|
YarnConfiguration.DEFAULT_NM_PMEM_MB);
|
||||||
if (memoryMb == -1) {
|
if (memoryMb == -1) {
|
||||||
memoryMb = YarnConfiguration.DEFAULT_NM_PMEM_MB;
|
memoryMb = YarnConfiguration.DEFAULT_NM_PMEM_MB;
|
||||||
|
@ -270,7 +270,7 @@ public class NodeManagerHardwareUtils {
|
||||||
* - the configuration for the NodeManager
|
* - the configuration for the NodeManager
|
||||||
* @return the amount of memory that will be used for YARN containers in MB.
|
* @return the amount of memory that will be used for YARN containers in MB.
|
||||||
*/
|
*/
|
||||||
public static int getContainerMemoryMB(Configuration conf) {
|
public static long getContainerMemoryMB(Configuration conf) {
|
||||||
if (!isHardwareDetectionEnabled(conf)) {
|
if (!isHardwareDetectionEnabled(conf)) {
|
||||||
return getConfiguredMemoryMB(conf);
|
return getConfiguredMemoryMB(conf);
|
||||||
}
|
}
|
||||||
|
@ -299,7 +299,7 @@ public class NodeManagerHardwareUtils {
|
||||||
* - the configuration for the NodeManager
|
* - the configuration for the NodeManager
|
||||||
* @return the amount of memory that will be used for YARN containers in MB.
|
* @return the amount of memory that will be used for YARN containers in MB.
|
||||||
*/
|
*/
|
||||||
public static int getContainerMemoryMB(ResourceCalculatorPlugin plugin,
|
public static long getContainerMemoryMB(ResourceCalculatorPlugin plugin,
|
||||||
Configuration conf) {
|
Configuration conf) {
|
||||||
if (!isHardwareDetectionEnabled(conf) || plugin == null) {
|
if (!isHardwareDetectionEnabled(conf) || plugin == null) {
|
||||||
return getConfiguredMemoryMB(conf);
|
return getConfiguredMemoryMB(conf);
|
||||||
|
@ -307,26 +307,24 @@ public class NodeManagerHardwareUtils {
|
||||||
return getContainerMemoryMBInternal(plugin, conf);
|
return getContainerMemoryMBInternal(plugin, conf);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static int getContainerMemoryMBInternal(ResourceCalculatorPlugin plugin,
|
private static long getContainerMemoryMBInternal(ResourceCalculatorPlugin plugin,
|
||||||
Configuration conf) {
|
Configuration conf) {
|
||||||
int memoryMb = conf.getInt(YarnConfiguration.NM_PMEM_MB, -1);
|
long memoryMb = conf.getInt(YarnConfiguration.NM_PMEM_MB, -1);
|
||||||
if (memoryMb == -1) {
|
if (memoryMb == -1) {
|
||||||
int physicalMemoryMB =
|
long physicalMemoryMB = (plugin.getPhysicalMemorySize() / (1024 * 1024));
|
||||||
(int) (plugin.getPhysicalMemorySize() / (1024 * 1024));
|
long hadoopHeapSizeMB = (Runtime.getRuntime().maxMemory()
|
||||||
int hadoopHeapSizeMB =
|
/ (1024 * 1024));
|
||||||
(int) (Runtime.getRuntime().maxMemory() / (1024 * 1024));
|
long containerPhysicalMemoryMB = (long) (0.8f
|
||||||
int containerPhysicalMemoryMB =
|
* (physicalMemoryMB - (2 * hadoopHeapSizeMB)));
|
||||||
(int) (0.8f * (physicalMemoryMB - (2 * hadoopHeapSizeMB)));
|
long reservedMemoryMB = conf
|
||||||
int reservedMemoryMB =
|
.getInt(YarnConfiguration.NM_SYSTEM_RESERVED_PMEM_MB, -1);
|
||||||
conf.getInt(YarnConfiguration.NM_SYSTEM_RESERVED_PMEM_MB, -1);
|
|
||||||
if (reservedMemoryMB != -1) {
|
if (reservedMemoryMB != -1) {
|
||||||
containerPhysicalMemoryMB = physicalMemoryMB - reservedMemoryMB;
|
containerPhysicalMemoryMB = physicalMemoryMB - reservedMemoryMB;
|
||||||
}
|
}
|
||||||
if(containerPhysicalMemoryMB <= 0) {
|
if (containerPhysicalMemoryMB <= 0) {
|
||||||
LOG.error("Calculated memory for YARN containers is too low."
|
LOG.error("Calculated memory for YARN containers is too low."
|
||||||
+ " Node memory is " + physicalMemoryMB
|
+ " Node memory is " + physicalMemoryMB
|
||||||
+ " MB, system reserved memory is "
|
+ " MB, system reserved memory is " + reservedMemoryMB + " MB.");
|
||||||
+ reservedMemoryMB + " MB.");
|
|
||||||
}
|
}
|
||||||
containerPhysicalMemoryMB = Math.max(containerPhysicalMemoryMB, 0);
|
containerPhysicalMemoryMB = Math.max(containerPhysicalMemoryMB, 0);
|
||||||
memoryMb = containerPhysicalMemoryMB;
|
memoryMb = containerPhysicalMemoryMB;
|
||||||
|
@ -365,8 +363,8 @@ public class NodeManagerHardwareUtils {
|
||||||
}
|
}
|
||||||
ResourceInformation memResInfo = resourceInformation.get(memory);
|
ResourceInformation memResInfo = resourceInformation.get(memory);
|
||||||
if(memResInfo.getValue() == 0) {
|
if(memResInfo.getValue() == 0) {
|
||||||
ret.setMemory(getContainerMemoryMB(conf));
|
ret.setMemorySize(getContainerMemoryMB(conf));
|
||||||
LOG.debug("Set memory to " + ret.getMemory());
|
LOG.debug("Set memory to " + ret.getMemorySize());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (resourceInformation.containsKey(vcores)) {
|
if (resourceInformation.containsKey(vcores)) {
|
||||||
|
|
|
@ -172,7 +172,7 @@ public class TestNodeManagerHardwareUtils {
|
||||||
YarnConfiguration conf = new YarnConfiguration();
|
YarnConfiguration conf = new YarnConfiguration();
|
||||||
conf.setBoolean(YarnConfiguration.NM_ENABLE_HARDWARE_CAPABILITY_DETECTION,
|
conf.setBoolean(YarnConfiguration.NM_ENABLE_HARDWARE_CAPABILITY_DETECTION,
|
||||||
true);
|
true);
|
||||||
int mem = NodeManagerHardwareUtils.getContainerMemoryMB(null, conf);
|
long mem = NodeManagerHardwareUtils.getContainerMemoryMB(null, conf);
|
||||||
Assert.assertEquals(YarnConfiguration.DEFAULT_NM_PMEM_MB, mem);
|
Assert.assertEquals(YarnConfiguration.DEFAULT_NM_PMEM_MB, mem);
|
||||||
|
|
||||||
mem = NodeManagerHardwareUtils.getContainerMemoryMB(plugin, conf);
|
mem = NodeManagerHardwareUtils.getContainerMemoryMB(plugin, conf);
|
||||||
|
|
Loading…
Reference in New Issue