YARN-9037. [CSI] Ignore volume resource in resource calculators based on tags. Contributed by Sunil Govindan.
This commit is contained in:
parent
4297e20c8b
commit
0921b706f7
@ -60,6 +60,7 @@ public class ResourceUtils {
|
|||||||
public static final String TAGS = ".tags";
|
public static final String TAGS = ".tags";
|
||||||
public static final String MINIMUM_ALLOCATION = ".minimum-allocation";
|
public static final String MINIMUM_ALLOCATION = ".minimum-allocation";
|
||||||
public static final String MAXIMUM_ALLOCATION = ".maximum-allocation";
|
public static final String MAXIMUM_ALLOCATION = ".maximum-allocation";
|
||||||
|
public static final String EXTERNAL_VOLUME_RESOURCE_TAG = "system:csi-volume";
|
||||||
|
|
||||||
private static final String MEMORY = ResourceInformation.MEMORY_MB.getName();
|
private static final String MEMORY = ResourceInformation.MEMORY_MB.getName();
|
||||||
private static final String VCORES = ResourceInformation.VCORES.getName();
|
private static final String VCORES = ResourceInformation.VCORES.getName();
|
||||||
@ -74,10 +75,12 @@ public class ResourceUtils {
|
|||||||
private static final Map<String, Integer> RESOURCE_NAME_TO_INDEX =
|
private static final Map<String, Integer> RESOURCE_NAME_TO_INDEX =
|
||||||
new ConcurrentHashMap<String, Integer>();
|
new ConcurrentHashMap<String, Integer>();
|
||||||
private static volatile Map<String, ResourceInformation> resourceTypes;
|
private static volatile Map<String, ResourceInformation> resourceTypes;
|
||||||
|
private static volatile Map<String, ResourceInformation> nonCountableResourceTypes;
|
||||||
private static volatile ResourceInformation[] resourceTypesArray;
|
private static volatile ResourceInformation[] resourceTypesArray;
|
||||||
private static volatile boolean initializedNodeResources = false;
|
private static volatile boolean initializedNodeResources = false;
|
||||||
private static volatile Map<String, ResourceInformation> readOnlyNodeResources;
|
private static volatile Map<String, ResourceInformation> readOnlyNodeResources;
|
||||||
private static volatile int numKnownResourceTypes = -1;
|
private static volatile int numKnownResourceTypes = -1;
|
||||||
|
private static volatile int numNonCountableResourceTypes = -1;
|
||||||
|
|
||||||
static final Logger LOG = LoggerFactory.getLogger(ResourceUtils.class);
|
static final Logger LOG = LoggerFactory.getLogger(ResourceUtils.class);
|
||||||
|
|
||||||
@ -290,15 +293,18 @@ static void initializeResourcesMap(Configuration conf) {
|
|||||||
public static void initializeResourcesFromResourceInformationMap(
|
public static void initializeResourcesFromResourceInformationMap(
|
||||||
Map<String, ResourceInformation> resourceInformationMap) {
|
Map<String, ResourceInformation> resourceInformationMap) {
|
||||||
resourceTypes = Collections.unmodifiableMap(resourceInformationMap);
|
resourceTypes = Collections.unmodifiableMap(resourceInformationMap);
|
||||||
|
nonCountableResourceTypes = new HashMap<>();
|
||||||
updateKnownResources();
|
updateKnownResources();
|
||||||
updateResourceTypeIndex();
|
updateResourceTypeIndex();
|
||||||
initializedResources = true;
|
initializedResources = true;
|
||||||
numKnownResourceTypes = resourceTypes.size();
|
numKnownResourceTypes = resourceTypes.size();
|
||||||
|
numNonCountableResourceTypes = nonCountableResourceTypes.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void updateKnownResources() {
|
private static void updateKnownResources() {
|
||||||
// Update resource names.
|
// Update resource names.
|
||||||
resourceTypesArray = new ResourceInformation[resourceTypes.size()];
|
resourceTypesArray = new ResourceInformation[resourceTypes.size()];
|
||||||
|
List<ResourceInformation> nonCountableResources = new ArrayList<>();
|
||||||
|
|
||||||
int index = 2;
|
int index = 2;
|
||||||
for (ResourceInformation resInfo : resourceTypes.values()) {
|
for (ResourceInformation resInfo : resourceTypes.values()) {
|
||||||
@ -309,10 +315,22 @@ private static void updateKnownResources() {
|
|||||||
resourceTypesArray[1] = ResourceInformation
|
resourceTypesArray[1] = ResourceInformation
|
||||||
.newInstance(resourceTypes.get(VCORES));
|
.newInstance(resourceTypes.get(VCORES));
|
||||||
} else {
|
} else {
|
||||||
|
if (resInfo.getTags() != null && resInfo.getTags()
|
||||||
|
.contains(EXTERNAL_VOLUME_RESOURCE_TAG)) {
|
||||||
|
nonCountableResources.add(resInfo);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
resourceTypesArray[index] = ResourceInformation.newInstance(resInfo);
|
resourceTypesArray[index] = ResourceInformation.newInstance(resInfo);
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add all non-countable resource types to the end of the resource array.
|
||||||
|
for(ResourceInformation resInfo: nonCountableResources) {
|
||||||
|
resourceTypesArray[index] = ResourceInformation.newInstance(resInfo);
|
||||||
|
nonCountableResourceTypes.put(resInfo.getName(), resInfo);
|
||||||
|
index++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void updateResourceTypeIndex() {
|
private static void updateResourceTypeIndex() {
|
||||||
@ -355,6 +373,13 @@ public static int getNumberOfKnownResourceTypes() {
|
|||||||
return numKnownResourceTypes;
|
return numKnownResourceTypes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static int getNumberOfCountableResourceTypes() {
|
||||||
|
if (numKnownResourceTypes < 0) {
|
||||||
|
initializeResourceTypesIfNeeded();
|
||||||
|
}
|
||||||
|
return numKnownResourceTypes - numNonCountableResourceTypes;
|
||||||
|
}
|
||||||
|
|
||||||
private static Map<String, ResourceInformation> getResourceTypes(
|
private static Map<String, ResourceInformation> getResourceTypes(
|
||||||
Configuration conf) {
|
Configuration conf) {
|
||||||
return getResourceTypes(conf,
|
return getResourceTypes(conf,
|
||||||
@ -383,6 +408,7 @@ private static void initializeResourceTypesIfNeeded(Configuration conf,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
numKnownResourceTypes = resourceTypes.size();
|
numKnownResourceTypes = resourceTypes.size();
|
||||||
|
numNonCountableResourceTypes = nonCountableResourceTypes.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Map<String, ResourceInformation> getResourceTypes(
|
private static Map<String, ResourceInformation> getResourceTypes(
|
||||||
|
@ -72,7 +72,7 @@ private int compare(Resource lhs, Resource rhs) {
|
|||||||
boolean rhsGreater = false;
|
boolean rhsGreater = false;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation lhsResourceInformation = lhs
|
ResourceInformation lhsResourceInformation = lhs
|
||||||
.getResourceInformation(i);
|
.getResourceInformation(i);
|
||||||
@ -110,7 +110,7 @@ public int compare(Resource clusterResource, Resource lhs, Resource rhs,
|
|||||||
// resources and then look for which resource has the biggest
|
// resources and then look for which resource has the biggest
|
||||||
// share overall.
|
// share overall.
|
||||||
ResourceInformation[] clusterRes = clusterResource.getResources();
|
ResourceInformation[] clusterRes = clusterResource.getResources();
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
|
|
||||||
// If array creation shows up as a time sink, these arrays could be cached
|
// If array creation shows up as a time sink, these arrays could be cached
|
||||||
// because they're always the same length.
|
// because they're always the same length.
|
||||||
@ -183,7 +183,7 @@ private void calculateShares(ResourceInformation[] clusterRes, Resource first,
|
|||||||
ResourceInformation[] firstRes = first.getResources();
|
ResourceInformation[] firstRes = first.getResources();
|
||||||
ResourceInformation[] secondRes = second.getResources();
|
ResourceInformation[] secondRes = second.getResources();
|
||||||
|
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
firstShares[i] = calculateShare(clusterRes[i], firstRes[i]);
|
firstShares[i] = calculateShare(clusterRes[i], firstRes[i]);
|
||||||
secondShares[i] = calculateShare(clusterRes[i], secondRes[i]);
|
secondShares[i] = calculateShare(clusterRes[i], secondRes[i]);
|
||||||
@ -274,7 +274,7 @@ private void calculateShares(ResourceInformation[] clusterRes, Resource first,
|
|||||||
max[0] = 0.0;
|
max[0] = 0.0;
|
||||||
max[1] = 0.0;
|
max[1] = 0.0;
|
||||||
|
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
firstShares[i] = calculateShare(clusterRes[i], firstRes[i]);
|
firstShares[i] = calculateShare(clusterRes[i], firstRes[i]);
|
||||||
secondShares[i] = calculateShare(clusterRes[i], secondRes[i]);
|
secondShares[i] = calculateShare(clusterRes[i], secondRes[i]);
|
||||||
@ -330,7 +330,7 @@ private double compareShares(double[] lhsShares, double[] rhsShares) {
|
|||||||
public long computeAvailableContainers(Resource available,
|
public long computeAvailableContainers(Resource available,
|
||||||
Resource required) {
|
Resource required) {
|
||||||
long min = Long.MAX_VALUE;
|
long min = Long.MAX_VALUE;
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation availableResource = available
|
ResourceInformation availableResource = available
|
||||||
.getResourceInformation(i);
|
.getResourceInformation(i);
|
||||||
@ -346,7 +346,7 @@ public long computeAvailableContainers(Resource available,
|
|||||||
@Override
|
@Override
|
||||||
public float divide(Resource clusterResource,
|
public float divide(Resource clusterResource,
|
||||||
Resource numerator, Resource denominator) {
|
Resource numerator, Resource denominator) {
|
||||||
int nKnownResourceTypes = ResourceUtils.getNumberOfKnownResourceTypes();
|
int nKnownResourceTypes = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
ResourceInformation[] clusterRes = clusterResource.getResources();
|
ResourceInformation[] clusterRes = clusterResource.getResources();
|
||||||
// We have to provide the calculateShares() method with somewhere to store
|
// We have to provide the calculateShares() method with somewhere to store
|
||||||
// the shares. We don't actually need these shares afterwards.
|
// the shares. We don't actually need these shares afterwards.
|
||||||
@ -375,7 +375,7 @@ public boolean isInvalidDivisor(Resource r) {
|
|||||||
@Override
|
@Override
|
||||||
public float ratio(Resource a, Resource b) {
|
public float ratio(Resource a, Resource b) {
|
||||||
float ratio = 0.0f;
|
float ratio = 0.0f;
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation aResourceInformation = a.getResourceInformation(i);
|
ResourceInformation aResourceInformation = a.getResourceInformation(i);
|
||||||
ResourceInformation bResourceInformation = b.getResourceInformation(i);
|
ResourceInformation bResourceInformation = b.getResourceInformation(i);
|
||||||
@ -393,7 +393,7 @@ public Resource divideAndCeil(Resource numerator, int denominator) {
|
|||||||
|
|
||||||
public Resource divideAndCeil(Resource numerator, long denominator) {
|
public Resource divideAndCeil(Resource numerator, long denominator) {
|
||||||
Resource ret = Resource.newInstance(numerator);
|
Resource ret = Resource.newInstance(numerator);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation resourceInformation = ret.getResourceInformation(i);
|
ResourceInformation resourceInformation = ret.getResourceInformation(i);
|
||||||
resourceInformation
|
resourceInformation
|
||||||
@ -414,7 +414,7 @@ public Resource divideAndCeil(Resource numerator, float denominator) {
|
|||||||
public Resource normalize(Resource r, Resource minimumResource,
|
public Resource normalize(Resource r, Resource minimumResource,
|
||||||
Resource maximumResource, Resource stepFactor) {
|
Resource maximumResource, Resource stepFactor) {
|
||||||
Resource ret = Resource.newInstance(r);
|
Resource ret = Resource.newInstance(r);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
||||||
ResourceInformation minimumResourceInformation = minimumResource
|
ResourceInformation minimumResourceInformation = minimumResource
|
||||||
@ -448,7 +448,7 @@ public Resource roundDown(Resource r, Resource stepFactor) {
|
|||||||
|
|
||||||
private Resource rounding(Resource r, Resource stepFactor, boolean roundUp) {
|
private Resource rounding(Resource r, Resource stepFactor, boolean roundUp) {
|
||||||
Resource ret = Resource.newInstance(r);
|
Resource ret = Resource.newInstance(r);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
||||||
ResourceInformation stepFactorResourceInformation = stepFactor
|
ResourceInformation stepFactorResourceInformation = stepFactor
|
||||||
@ -473,7 +473,7 @@ private Resource rounding(Resource r, Resource stepFactor, boolean roundUp) {
|
|||||||
public Resource multiplyAndNormalizeUp(Resource r, double[] by,
|
public Resource multiplyAndNormalizeUp(Resource r, double[] by,
|
||||||
Resource stepFactor) {
|
Resource stepFactor) {
|
||||||
Resource ret = Resource.newInstance(r);
|
Resource ret = Resource.newInstance(r);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
||||||
ResourceInformation stepFactorResourceInformation = stepFactor
|
ResourceInformation stepFactorResourceInformation = stepFactor
|
||||||
@ -502,7 +502,7 @@ public Resource multiplyAndNormalizeDown(Resource r, double by,
|
|||||||
private Resource multiplyAndNormalize(Resource r, double by,
|
private Resource multiplyAndNormalize(Resource r, double by,
|
||||||
Resource stepFactor, boolean roundUp) {
|
Resource stepFactor, boolean roundUp) {
|
||||||
Resource ret = Resource.newInstance(r);
|
Resource ret = Resource.newInstance(r);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
||||||
ResourceInformation stepFactorResourceInformation = stepFactor
|
ResourceInformation stepFactorResourceInformation = stepFactor
|
||||||
@ -528,7 +528,7 @@ private Resource multiplyAndNormalize(Resource r, double by,
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean fitsIn(Resource smaller, Resource bigger) {
|
public boolean fitsIn(Resource smaller, Resource bigger) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation sResourceInformation = smaller
|
ResourceInformation sResourceInformation = smaller
|
||||||
.getResourceInformation(i);
|
.getResourceInformation(i);
|
||||||
@ -544,7 +544,7 @@ public boolean fitsIn(Resource smaller, Resource bigger) {
|
|||||||
@Override
|
@Override
|
||||||
public Resource normalizeDown(Resource r, Resource stepFactor) {
|
public Resource normalizeDown(Resource r, Resource stepFactor) {
|
||||||
Resource ret = Resource.newInstance(r);
|
Resource ret = Resource.newInstance(r);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
ResourceInformation rResourceInformation = r.getResourceInformation(i);
|
||||||
ResourceInformation stepFactorResourceInformation = stepFactor
|
ResourceInformation stepFactorResourceInformation = stepFactor
|
||||||
@ -564,7 +564,7 @@ public Resource normalizeDown(Resource r, Resource stepFactor) {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAnyMajorResourceZeroOrNegative(Resource resource) {
|
public boolean isAnyMajorResourceZeroOrNegative(Resource resource) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation resourceInformation = resource.getResourceInformation(
|
ResourceInformation resourceInformation = resource.getResourceInformation(
|
||||||
i);
|
i);
|
||||||
@ -577,7 +577,7 @@ public boolean isAnyMajorResourceZeroOrNegative(Resource resource) {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAnyMajorResourceAboveZero(Resource resource) {
|
public boolean isAnyMajorResourceAboveZero(Resource resource) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation resourceInformation = resource.getResourceInformation(
|
ResourceInformation resourceInformation = resource.getResourceInformation(
|
||||||
i);
|
i);
|
||||||
|
@ -251,7 +251,7 @@ public static Resource clone(Resource res) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static Resource addTo(Resource lhs, Resource rhs) {
|
public static Resource addTo(Resource lhs, Resource rhs) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
try {
|
try {
|
||||||
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
||||||
@ -270,7 +270,7 @@ public static Resource add(Resource lhs, Resource rhs) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static Resource subtractFrom(Resource lhs, Resource rhs) {
|
public static Resource subtractFrom(Resource lhs, Resource rhs) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
try {
|
try {
|
||||||
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
||||||
@ -325,7 +325,7 @@ public static Resource negate(Resource resource) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static Resource multiplyTo(Resource lhs, double by) {
|
public static Resource multiplyTo(Resource lhs, double by) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
try {
|
try {
|
||||||
ResourceInformation lhsValue = lhs.getResourceInformation(i);
|
ResourceInformation lhsValue = lhs.getResourceInformation(i);
|
||||||
@ -348,7 +348,7 @@ public static Resource multiply(Resource lhs, double by) {
|
|||||||
*/
|
*/
|
||||||
public static Resource multiplyAndAddTo(
|
public static Resource multiplyAndAddTo(
|
||||||
Resource lhs, Resource rhs, double by) {
|
Resource lhs, Resource rhs, double by) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
try {
|
try {
|
||||||
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
||||||
@ -381,7 +381,7 @@ public static Resource multiplyAndNormalizeDown(
|
|||||||
|
|
||||||
public static Resource multiplyAndRoundDown(Resource lhs, double by) {
|
public static Resource multiplyAndRoundDown(Resource lhs, double by) {
|
||||||
Resource out = clone(lhs);
|
Resource out = clone(lhs);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
try {
|
try {
|
||||||
ResourceInformation lhsValue = lhs.getResourceInformation(i);
|
ResourceInformation lhsValue = lhs.getResourceInformation(i);
|
||||||
@ -490,7 +490,7 @@ public static Resource max(
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static boolean fitsIn(Resource smaller, Resource bigger) {
|
public static boolean fitsIn(Resource smaller, Resource bigger) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
try {
|
try {
|
||||||
ResourceInformation rhsValue = bigger.getResourceInformation(i);
|
ResourceInformation rhsValue = bigger.getResourceInformation(i);
|
||||||
@ -513,7 +513,7 @@ public static boolean fitsIn(ResourceCalculator rc,
|
|||||||
|
|
||||||
public static Resource componentwiseMin(Resource lhs, Resource rhs) {
|
public static Resource componentwiseMin(Resource lhs, Resource rhs) {
|
||||||
Resource ret = createResource(0);
|
Resource ret = createResource(0);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
try {
|
try {
|
||||||
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
||||||
@ -532,7 +532,7 @@ public static Resource componentwiseMin(Resource lhs, Resource rhs) {
|
|||||||
|
|
||||||
public static Resource componentwiseMax(Resource lhs, Resource rhs) {
|
public static Resource componentwiseMax(Resource lhs, Resource rhs) {
|
||||||
Resource ret = createResource(0);
|
Resource ret = createResource(0);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
try {
|
try {
|
||||||
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
ResourceInformation rhsValue = rhs.getResourceInformation(i);
|
||||||
|
@ -400,4 +400,57 @@ public static String setupResourceTypes(Configuration conf, String filename)
|
|||||||
ResourceUtils.getResourceTypes();
|
ResourceUtils.getResourceTypes();
|
||||||
return dest.getAbsolutePath();
|
return dest.getAbsolutePath();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testMultipleOpsForResourcesWithTags() throws Exception {
|
||||||
|
|
||||||
|
Configuration conf = new YarnConfiguration();
|
||||||
|
setupResourceTypes(conf, "resource-types-6.xml");
|
||||||
|
Resource resourceA = Resource.newInstance(2, 4);
|
||||||
|
Resource resourceB = Resource.newInstance(3, 6);
|
||||||
|
|
||||||
|
resourceA.setResourceInformation("resource1",
|
||||||
|
ResourceInformation.newInstance("resource1", "T", 5L));
|
||||||
|
|
||||||
|
resourceA.setResourceInformation("resource2",
|
||||||
|
ResourceInformation.newInstance("resource2", "M", 2L));
|
||||||
|
resourceA.setResourceInformation("yarn.io/gpu",
|
||||||
|
ResourceInformation.newInstance("yarn.io/gpu", "", 1));
|
||||||
|
resourceA.setResourceInformation("yarn.io/test-volume",
|
||||||
|
ResourceInformation.newInstance("yarn.io/test-volume", "", 2));
|
||||||
|
|
||||||
|
resourceB.setResourceInformation("resource1",
|
||||||
|
ResourceInformation.newInstance("resource1", "T", 3L));
|
||||||
|
|
||||||
|
resourceB.setResourceInformation("resource2",
|
||||||
|
ResourceInformation.newInstance("resource2", "M", 4L));
|
||||||
|
resourceB.setResourceInformation("yarn.io/gpu",
|
||||||
|
ResourceInformation.newInstance("yarn.io/gpu", "", 2));
|
||||||
|
resourceB.setResourceInformation("yarn.io/test-volume",
|
||||||
|
ResourceInformation.newInstance("yarn.io/test-volume", "", 3));
|
||||||
|
|
||||||
|
Resource addedResource = Resources.add(resourceA, resourceB);
|
||||||
|
Assert.assertEquals(addedResource.getMemorySize(), 5);
|
||||||
|
Assert.assertEquals(addedResource.getVirtualCores(), 10);
|
||||||
|
Assert.assertEquals(
|
||||||
|
addedResource.getResourceInformation("resource1").getValue(), 8);
|
||||||
|
|
||||||
|
// Verify that value of resourceA and resourceB is not added up for
|
||||||
|
// "yarn.io/test-volume".
|
||||||
|
Assert.assertEquals(
|
||||||
|
addedResource.getResourceInformation("yarn.io/test-volume").getValue(),
|
||||||
|
2);
|
||||||
|
|
||||||
|
Resource mulResource = Resources.multiplyAndRoundDown(resourceA, 3);
|
||||||
|
Assert.assertEquals(mulResource.getMemorySize(), 6);
|
||||||
|
Assert.assertEquals(mulResource.getVirtualCores(), 12);
|
||||||
|
Assert.assertEquals(
|
||||||
|
mulResource.getResourceInformation("resource1").getValue(), 15);
|
||||||
|
|
||||||
|
// Verify that value of resourceA is not multiplied up for
|
||||||
|
// "yarn.io/test-volume".
|
||||||
|
Assert.assertEquals(
|
||||||
|
mulResource.getResourceInformation("yarn.io/test-volume").getValue(),
|
||||||
|
2);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,58 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<?xml-stylesheet type="text/xsl" href="configuration.xsl"?>
|
||||||
|
<!--
|
||||||
|
Licensed 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. See accompanying LICENSE file.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<configuration>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>yarn.resource-types</name>
|
||||||
|
<value>resource1,resource2,resource3,yarn.io/gpu,yarn.io/test-volume</value>
|
||||||
|
</property>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>yarn.resource-types.resource1.units</name>
|
||||||
|
<value>G</value>
|
||||||
|
</property>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>yarn.resource-types.resource2.units</name>
|
||||||
|
<value>m</value>
|
||||||
|
</property>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>yarn.resource-types.resource3.units</name>
|
||||||
|
<value>G</value>
|
||||||
|
</property>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>yarn.resource-types.resource3.tags</name>
|
||||||
|
<value>resource3_tag_1,resource3_tag_2</value>
|
||||||
|
</property>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>yarn.resource-types.yarn.io/gpu.units</name>
|
||||||
|
<value></value>
|
||||||
|
</property>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>yarn.resource-types.yarn.io/test-volume.units</name>
|
||||||
|
<value>G</value>
|
||||||
|
</property>
|
||||||
|
|
||||||
|
<property>
|
||||||
|
<name>yarn.resource-types.yarn.io/test-volume.tags</name>
|
||||||
|
<value>system:csi-volume</value>
|
||||||
|
</property>
|
||||||
|
</configuration>
|
@ -28,6 +28,7 @@
|
|||||||
import org.apache.hadoop.yarn.exceptions.YarnException;
|
import org.apache.hadoop.yarn.exceptions.YarnException;
|
||||||
import org.apache.hadoop.yarn.server.nodemanager.containermanager.container.Container;
|
import org.apache.hadoop.yarn.server.nodemanager.containermanager.container.Container;
|
||||||
import org.apache.hadoop.yarn.server.nodemanager.containermanager.linux.runtime.DockerLinuxContainerRuntime;
|
import org.apache.hadoop.yarn.server.nodemanager.containermanager.linux.runtime.DockerLinuxContainerRuntime;
|
||||||
|
import org.apache.hadoop.yarn.server.volume.csi.CsiConstants;
|
||||||
import org.apache.hadoop.yarn.server.volume.csi.VolumeMetaData;
|
import org.apache.hadoop.yarn.server.volume.csi.VolumeMetaData;
|
||||||
import org.apache.hadoop.yarn.server.volume.csi.exception.InvalidVolumeException;
|
import org.apache.hadoop.yarn.server.volume.csi.exception.InvalidVolumeException;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
@ -120,7 +121,8 @@ private List<VolumeMetaData> getVolumes() throws InvalidVolumeException {
|
|||||||
if (containerResource != null) {
|
if (containerResource != null) {
|
||||||
for (ResourceInformation resourceInformation :
|
for (ResourceInformation resourceInformation :
|
||||||
containerResource.getAllResourcesListCopy()) {
|
containerResource.getAllResourcesListCopy()) {
|
||||||
if (resourceInformation.getTags().contains("system:csi-volume")) {
|
if (resourceInformation.getTags()
|
||||||
|
.contains(CsiConstants.CSI_VOLUME_RESOURCE_TAG)) {
|
||||||
volumes.addAll(VolumeMetaData.fromResource(resourceInformation));
|
volumes.addAll(VolumeMetaData.fromResource(resourceInformation));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -262,7 +262,7 @@ protected void initIdealAssignment(Resource totGuarant,
|
|||||||
private void resetCapacity(Resource clusterResource,
|
private void resetCapacity(Resource clusterResource,
|
||||||
Collection<TempQueuePerPartition> queues, boolean ignoreGuar) {
|
Collection<TempQueuePerPartition> queues, boolean ignoreGuar) {
|
||||||
Resource activeCap = Resource.newInstance(0, 0);
|
Resource activeCap = Resource.newInstance(0, 0);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
|
|
||||||
if (ignoreGuar) {
|
if (ignoreGuar) {
|
||||||
for (TempQueuePerPartition q : queues) {
|
for (TempQueuePerPartition q : queues) {
|
||||||
|
@ -98,7 +98,7 @@ public TempQueuePerPartition(String queueName, Resource current,
|
|||||||
}
|
}
|
||||||
|
|
||||||
this.normalizedGuarantee = new double[ResourceUtils
|
this.normalizedGuarantee = new double[ResourceUtils
|
||||||
.getNumberOfKnownResourceTypes()];
|
.getNumberOfCountableResourceTypes()];
|
||||||
this.children = new ArrayList<>();
|
this.children = new ArrayList<>();
|
||||||
this.apps = new ArrayList<>();
|
this.apps = new ArrayList<>();
|
||||||
this.untouchableExtra = Resource.newInstance(0, 0);
|
this.untouchableExtra = Resource.newInstance(0, 0);
|
||||||
|
@ -73,7 +73,7 @@ public class ClusterNodeTracker<N extends SchedulerNode> {
|
|||||||
private boolean reportedMaxAllocation = false;
|
private boolean reportedMaxAllocation = false;
|
||||||
|
|
||||||
public ClusterNodeTracker() {
|
public ClusterNodeTracker() {
|
||||||
maxAllocation = new long[ResourceUtils.getNumberOfKnownResourceTypes()];
|
maxAllocation = new long[ResourceUtils.getNumberOfCountableResourceTypes()];
|
||||||
Arrays.fill(maxAllocation, -1);
|
Arrays.fill(maxAllocation, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -355,7 +355,7 @@ private static void validateResourceRequest(ResourceRequest resReq,
|
|||||||
private static Map<String, ResourceInformation> getZeroResources(
|
private static Map<String, ResourceInformation> getZeroResources(
|
||||||
Resource resource) {
|
Resource resource) {
|
||||||
Map<String, ResourceInformation> resourceInformations = Maps.newHashMap();
|
Map<String, ResourceInformation> resourceInformations = Maps.newHashMap();
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
|
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation resourceInformation =
|
ResourceInformation resourceInformation =
|
||||||
@ -372,7 +372,7 @@ private static Map<String, ResourceInformation> getZeroResources(
|
|||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
static void checkResourceRequestAgainstAvailableResource(Resource reqResource,
|
static void checkResourceRequestAgainstAvailableResource(Resource reqResource,
|
||||||
Resource availableResource) throws InvalidResourceRequestException {
|
Resource availableResource) throws InvalidResourceRequestException {
|
||||||
for (int i = 0; i < ResourceUtils.getNumberOfKnownResourceTypes(); i++) {
|
for (int i = 0; i < ResourceUtils.getNumberOfCountableResourceTypes(); i++) {
|
||||||
final ResourceInformation requestedRI =
|
final ResourceInformation requestedRI =
|
||||||
reqResource.getResourceInformation(i);
|
reqResource.getResourceInformation(i);
|
||||||
final String reqResourceName = requestedRI.getName();
|
final String reqResourceName = requestedRI.getName();
|
||||||
@ -404,7 +404,7 @@ static void checkResourceRequestAgainstAvailableResource(Resource reqResource,
|
|||||||
}
|
}
|
||||||
|
|
||||||
List<ResourceInformation> invalidResources = Lists.newArrayList();
|
List<ResourceInformation> invalidResources = Lists.newArrayList();
|
||||||
for (int i = 0; i < ResourceUtils.getNumberOfKnownResourceTypes(); i++) {
|
for (int i = 0; i < ResourceUtils.getNumberOfCountableResourceTypes(); i++) {
|
||||||
final ResourceInformation requestedRI =
|
final ResourceInformation requestedRI =
|
||||||
reqResource.getResourceInformation(i);
|
reqResource.getResourceInformation(i);
|
||||||
final String reqResourceName = requestedRI.getName();
|
final String reqResourceName = requestedRI.getName();
|
||||||
|
@ -1031,7 +1031,7 @@ private void calculateEffectiveResourcesAndCapacity(String label,
|
|||||||
private Resource getMinResourceNormalized(String name, Map<String, Float> effectiveMinRatio,
|
private Resource getMinResourceNormalized(String name, Map<String, Float> effectiveMinRatio,
|
||||||
Resource minResource) {
|
Resource minResource) {
|
||||||
Resource ret = Resource.newInstance(minResource);
|
Resource ret = Resource.newInstance(minResource);
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation nResourceInformation = minResource
|
ResourceInformation nResourceInformation = minResource
|
||||||
.getResourceInformation(i);
|
.getResourceInformation(i);
|
||||||
@ -1055,7 +1055,7 @@ private Map<String, Float> getEffectiveMinRatioPerResource(
|
|||||||
Resource configuredMinResources, Resource numeratorForMinRatio) {
|
Resource configuredMinResources, Resource numeratorForMinRatio) {
|
||||||
Map<String, Float> effectiveMinRatioPerResource = new HashMap<>();
|
Map<String, Float> effectiveMinRatioPerResource = new HashMap<>();
|
||||||
if (numeratorForMinRatio != null) {
|
if (numeratorForMinRatio != null) {
|
||||||
int maxLength = ResourceUtils.getNumberOfKnownResourceTypes();
|
int maxLength = ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
for (int i = 0; i < maxLength; i++) {
|
for (int i = 0; i < maxLength; i++) {
|
||||||
ResourceInformation nResourceInformation = numeratorForMinRatio
|
ResourceInformation nResourceInformation = numeratorForMinRatio
|
||||||
.getResourceInformation(i);
|
.getResourceInformation(i);
|
||||||
|
@ -63,7 +63,7 @@ public ConfigurableResource(Resource resource) {
|
|||||||
|
|
||||||
private static double[] getOneHundredPercentArray() {
|
private static double[] getOneHundredPercentArray() {
|
||||||
double[] resourcePercentages =
|
double[] resourcePercentages =
|
||||||
new double[ResourceUtils.getNumberOfKnownResourceTypes()];
|
new double[ResourceUtils.getNumberOfCountableResourceTypes()];
|
||||||
Arrays.fill(resourcePercentages, 1.0);
|
Arrays.fill(resourcePercentages, 1.0);
|
||||||
|
|
||||||
return resourcePercentages;
|
return resourcePercentages;
|
||||||
|
@ -599,7 +599,7 @@ private static int parseOldStyleResourceVcores(String lCaseValue)
|
|||||||
private static double[] getResourcePercentage(
|
private static double[] getResourcePercentage(
|
||||||
String val) throws AllocationConfigurationException {
|
String val) throws AllocationConfigurationException {
|
||||||
int numberOfKnownResourceTypes = ResourceUtils
|
int numberOfKnownResourceTypes = ResourceUtils
|
||||||
.getNumberOfKnownResourceTypes();
|
.getNumberOfCountableResourceTypes();
|
||||||
double[] resourcePercentage = new double[numberOfKnownResourceTypes];
|
double[] resourcePercentage = new double[numberOfKnownResourceTypes];
|
||||||
String[] strings = val.split(",");
|
String[] strings = val.split(",");
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@ public class DominantResourceFairnessPolicy extends SchedulingPolicy {
|
|||||||
public static final String NAME = "DRF";
|
public static final String NAME = "DRF";
|
||||||
|
|
||||||
private static final int NUM_RESOURCES =
|
private static final int NUM_RESOURCES =
|
||||||
ResourceUtils.getNumberOfKnownResourceTypes();
|
ResourceUtils.getNumberOfCountableResourceTypes();
|
||||||
private static final DominantResourceFairnessComparator COMPARATORN =
|
private static final DominantResourceFairnessComparator COMPARATORN =
|
||||||
new DominantResourceFairnessComparatorN();
|
new DominantResourceFairnessComparatorN();
|
||||||
private static final DominantResourceFairnessComparator COMPARATOR2 =
|
private static final DominantResourceFairnessComparator COMPARATOR2 =
|
||||||
|
@ -17,14 +17,17 @@
|
|||||||
*/
|
*/
|
||||||
package org.apache.hadoop.yarn.server.resourcemanager.volume.csi;
|
package org.apache.hadoop.yarn.server.resourcemanager.volume.csi;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableList;
|
||||||
import com.google.common.collect.ImmutableMap;
|
import com.google.common.collect.ImmutableMap;
|
||||||
import com.google.common.collect.ImmutableSet;
|
import com.google.common.collect.ImmutableSet;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.yarn.api.CsiAdaptorProtocol;
|
import org.apache.hadoop.yarn.api.CsiAdaptorProtocol;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.AllocateRequest;
|
import org.apache.hadoop.yarn.api.protocolrecords.AllocateRequest;
|
||||||
|
import org.apache.hadoop.yarn.api.protocolrecords.AllocateResponse;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.ResourceTypes;
|
import org.apache.hadoop.yarn.api.protocolrecords.ResourceTypes;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.ValidateVolumeCapabilitiesRequest;
|
import org.apache.hadoop.yarn.api.protocolrecords.ValidateVolumeCapabilitiesRequest;
|
||||||
import org.apache.hadoop.yarn.api.protocolrecords.ValidateVolumeCapabilitiesResponse;
|
import org.apache.hadoop.yarn.api.protocolrecords.ValidateVolumeCapabilitiesResponse;
|
||||||
|
import org.apache.hadoop.yarn.api.records.Container;
|
||||||
import org.apache.hadoop.yarn.api.records.Resource;
|
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.ResourceSizing;
|
import org.apache.hadoop.yarn.api.records.ResourceSizing;
|
||||||
@ -57,7 +60,9 @@
|
|||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileWriter;
|
import java.io.FileWriter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
@ -132,6 +137,9 @@ private void writeTmpResourceTypesFile(File tmpFile) throws IOException {
|
|||||||
yarnConf.set(YarnConfiguration.RESOURCE_TYPES, VOLUME_RESOURCE_NAME);
|
yarnConf.set(YarnConfiguration.RESOURCE_TYPES, VOLUME_RESOURCE_NAME);
|
||||||
yarnConf.set("yarn.resource-types."
|
yarnConf.set("yarn.resource-types."
|
||||||
+ VOLUME_RESOURCE_NAME + ".units", "Mi");
|
+ VOLUME_RESOURCE_NAME + ".units", "Mi");
|
||||||
|
yarnConf.set("yarn.resource-types."
|
||||||
|
+ VOLUME_RESOURCE_NAME + ".tags",
|
||||||
|
CsiConstants.CSI_VOLUME_RESOURCE_TAG);
|
||||||
yarnConf.writeXml(fw);
|
yarnConf.writeXml(fw);
|
||||||
} finally {
|
} finally {
|
||||||
fw.close();
|
fw.close();
|
||||||
@ -267,4 +275,57 @@ public void testProvisioningFailures() throws Exception {
|
|||||||
}
|
}
|
||||||
rm.stop();
|
rm.stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test (timeout = 10000L)
|
||||||
|
public void testVolumeResourceAllocate() throws Exception {
|
||||||
|
RMApp app1 = rm.submitApp(1 * GB, "app", "user", null, "default");
|
||||||
|
MockAM am1 = MockRM.launchAndRegisterAM(app1, rm, mockNMS[0]);
|
||||||
|
Resource resource = Resource.newInstance(1024, 1);
|
||||||
|
ResourceInformation volumeResource = ResourceInformation
|
||||||
|
.newInstance(VOLUME_RESOURCE_NAME, "Mi", 1024,
|
||||||
|
ResourceTypes.COUNTABLE, 0, Long.MAX_VALUE,
|
||||||
|
ImmutableSet.of(CsiConstants.CSI_VOLUME_RESOURCE_TAG),
|
||||||
|
ImmutableMap.of(
|
||||||
|
CsiConstants.CSI_VOLUME_ID, "test-vol-000001",
|
||||||
|
CsiConstants.CSI_DRIVER_NAME, "hostpath",
|
||||||
|
CsiConstants.CSI_VOLUME_MOUNT, "/mnt/data"
|
||||||
|
)
|
||||||
|
);
|
||||||
|
resource.setResourceInformation(VOLUME_RESOURCE_NAME, volumeResource);
|
||||||
|
SchedulingRequest sc = SchedulingRequest
|
||||||
|
.newBuilder().allocationRequestId(0L)
|
||||||
|
.resourceSizing(ResourceSizing.newInstance(1, resource))
|
||||||
|
.build();
|
||||||
|
|
||||||
|
// inject adaptor client for testing
|
||||||
|
CsiAdaptorProtocol mockedClient = Mockito
|
||||||
|
.mock(CsiAdaptorProtocol.class);
|
||||||
|
rm.getRMContext().getVolumeManager()
|
||||||
|
.registerCsiDriverAdaptor("hostpath", mockedClient);
|
||||||
|
|
||||||
|
// simulate validation succeed
|
||||||
|
doReturn(ValidateVolumeCapabilitiesResponse.newInstance(true, ""))
|
||||||
|
.when(mockedClient)
|
||||||
|
.validateVolumeCapacity(any(ValidateVolumeCapabilitiesRequest.class));
|
||||||
|
|
||||||
|
am1.addSchedulingRequest(ImmutableList.of(sc));
|
||||||
|
List<Container> allocated = new ArrayList<>();
|
||||||
|
while (allocated.size() != 1) {
|
||||||
|
AllocateResponse response = am1.schedule();
|
||||||
|
mockNMS[0].nodeHeartbeat(true);
|
||||||
|
allocated.addAll(response.getAllocatedContainers());
|
||||||
|
Thread.sleep(500);
|
||||||
|
}
|
||||||
|
|
||||||
|
Assert.assertEquals(1, allocated.size());
|
||||||
|
Container alloc = allocated.get(0);
|
||||||
|
Assert.assertEquals(alloc.getResource().getMemorySize(), 1024);
|
||||||
|
Assert.assertEquals(alloc.getResource().getVirtualCores(), 1);
|
||||||
|
ResourceInformation allocatedVolume =
|
||||||
|
alloc.getResource().getResourceInformation(VOLUME_RESOURCE_NAME);
|
||||||
|
Assert.assertNotNull(allocatedVolume);
|
||||||
|
Assert.assertEquals(allocatedVolume.getValue(), 1024);
|
||||||
|
Assert.assertEquals(allocatedVolume.getUnits(), "Mi");
|
||||||
|
rm.stop();
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user