use of io.fabric8.api.FabricRequirements in project fabric8 by jboss-fuse.
the class SshAutoScalerTest method assertProfilesUseSeparateHost.
/**
* lets assert that no host has more than its maximum number of containers
*/
public static void assertProfilesUseSeparateHost(FabricRequirements requirements, Map<String, CountingMap> hostToProfileCounts) {
for (Map.Entry<String, CountingMap> entry : hostToProfileCounts.entrySet()) {
String hostName = entry.getKey();
CountingMap counts = entry.getValue();
Set<String> keys = counts.keySet();
for (String profileId : keys) {
int count = counts.count(profileId);
// lets see if we have a maximum number of profile count
ProfileRequirements profileRequirement = requirements.getOrCreateProfileRequirement(profileId);
Integer maximum = profileRequirement.getMaximumInstancesPerHost();
if (maximum != null) {
assertTrue("Host " + hostName + " has " + count + " instances of " + profileId + " but this is configured to have a maximium of " + maximum + " per host", count <= maximum);
}
}
}
}
use of io.fabric8.api.FabricRequirements in project fabric8 by jboss-fuse.
the class FabricManager method requirementsJson.
@Override
public void requirementsJson(String json) throws IOException {
ObjectMapper mapper = new ObjectMapper();
mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
mapper.configure(DeserializationFeature.ACCEPT_SINGLE_VALUE_AS_ARRAY, true);
Object value = mapper.reader(FabricRequirements.class).readValue(json);
if (value instanceof FabricRequirements) {
requirements((FabricRequirements) value);
} else {
throw new IOException("Failed to parse FabricRequirements from JSON. Got " + value + ". JSON: " + json);
}
}
use of io.fabric8.api.FabricRequirements in project fabric8 by jboss-fuse.
the class SshAutoScaler method chooseHostContainerOptions.
/**
* This method is public for easier testing
*/
public static CreateSshContainerOptions.Builder chooseHostContainerOptions(AutoScaleRequest request, HostProfileCounter hostProfileCounter) {
CreateSshContainerOptions.Builder builder = CreateSshContainerOptions.builder();
FabricRequirements requirements = request.getFabricRequirements();
ProfileRequirements profileRequirements = request.getProfileRequirements();
SshScalingRequirements sshScalingRequirements = profileRequirements.getSshScalingRequirements();
List<SshHostConfiguration> hosts = requirements.getSshHosts();
SortedSet<LoadSortedHostConfiguration<SshHostConfiguration>> sortedHostConfigurations = AutoScalers.filterHosts(profileRequirements, sshScalingRequirements, hostProfileCounter, hosts);
SshHostConfiguration sshHostConfig = null;
if (!sortedHostConfigurations.isEmpty()) {
LoadSortedHostConfiguration<SshHostConfiguration> first = sortedHostConfigurations.first();
sshHostConfig = first.getConfiguration();
}
if (sshHostConfig == null) {
LOG.warn("Could not create version " + request.getVersion() + " profile " + request.getProfile() + " as no matching hosts could be found for " + sshScalingRequirements);
request.getProfileAutoScaleStatus().noSuitableHost("" + sshScalingRequirements);
return null;
}
builder.configure(sshHostConfig, requirements, profileRequirements);
return builder;
}
use of io.fabric8.api.FabricRequirements in project fabric8 by jboss-fuse.
the class SshAutoScaler method createContainers.
@Override
public void createContainers(AutoScaleRequest request) throws Exception {
int count = request.getDelta();
String profile = request.getProfile();
String version = request.getVersion();
FabricService fabricService = request.getFabricService();
Container[] containers = fabricService.getContainers();
FabricRequirements requirements = request.getFabricRequirements();
List<? extends HostConfiguration> hostConfigurations = requirements.getSshHosts();
HostProfileCounter hostProfileCounter = new HostProfileCounter();
AutoScalers.createHostToProfileScaleMap(hostProfileCounter, hostConfigurations, containers);
for (int i = 0; i < count; i++) {
CreateSshContainerOptions.Builder builder = null;
NameValidator nameValidator = Containers.createNameValidator(containers);
String name = Containers.createAutoScaleContainerName(containers, profile, containerProvider.getScheme(), nameValidator);
if (fabricService != null) {
builder = createAutoScaleOptions(request, fabricService, hostProfileCounter);
}
if (builder != null) {
final CreateSshContainerOptions.Builder configuredBuilder = builder.number(1).version(version).profiles(profile);
CreateSshContainerOptions options = configuredBuilder.name(name).build();
LOG.info("Creating container name " + name + " version " + version + " profile " + profile + " " + count + " container(s)");
fabricService.createContainers(options);
}
}
}
Aggregations