/**
* Copyright (c) 2009-2011 VMware, Inc. All Rights Reserved.
*
* 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.
*/
package com.springsource.insight.plugin.hadoop;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import com.springsource.insight.intercept.operation.Operation;
import com.springsource.insight.intercept.topology.AbstractExternalResourceAnalyzer;
import com.springsource.insight.intercept.topology.ExternalResourceDescriptor;
import com.springsource.insight.intercept.topology.ExternalResourceType;
import com.springsource.insight.intercept.topology.MD5NameGenerator;
import com.springsource.insight.intercept.trace.Frame;
import com.springsource.insight.intercept.trace.Trace;
import com.springsource.insight.util.ListUtil;
public class HadoopExternalResourceAnalyzer extends AbstractExternalResourceAnalyzer {
private static final HadoopExternalResourceAnalyzer INSTANCE = new HadoopExternalResourceAnalyzer();
private HadoopExternalResourceAnalyzer() {
super(OperationCollectionTypes.MAP_TYPE.type);
}
public static final HadoopExternalResourceAnalyzer getInstance() {
return INSTANCE;
}
public Collection<ExternalResourceDescriptor> locateExternalResourceName(Trace trace, Collection<Frame> frames) {
if (ListUtil.size(frames) <= 0) {
return Collections.emptyList();
}
List<ExternalResourceDescriptor> queueDescriptors = new ArrayList<ExternalResourceDescriptor>(frames.size());
for (Frame cacheFrame : frames) {
Operation op = cacheFrame.getOperation();
String host = op.get("host", String.class, null);
if (host != null) {
String hashString = MD5NameGenerator.getName(host);
String color = colorManager.getColor(op);
ExternalResourceDescriptor descriptor =
new ExternalResourceDescriptor(cacheFrame, "server:" + hashString, host,
ExternalResourceType.OTHER.name(), "HadoopMapper",
host, 0, color, false);
queueDescriptors.add(descriptor);
}
}
return queueDescriptors;
}
}