ResourceGroupSpecBuilder.java
/*
* 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.facebook.presto.resourceGroups.db;
import com.facebook.presto.resourceGroups.ResourceGroupNameTemplate;
import com.facebook.presto.resourceGroups.ResourceGroupSpec;
import com.facebook.presto.spi.resourceGroups.ResourceGroupQueryLimits;
import com.google.common.collect.ImmutableList;
import io.airlift.units.DataSize;
import io.airlift.units.Duration;
import org.jdbi.v3.core.mapper.RowMapper;
import org.jdbi.v3.core.statement.StatementContext;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Optional;
import static java.util.Objects.requireNonNull;
public class ResourceGroupSpecBuilder
{
private final long id;
private final ResourceGroupNameTemplate nameTemplate;
private final String softMemoryLimit;
private final int maxQueued;
private final Optional<Integer> softConcurrencyLimit;
private final int hardConcurrencyLimit;
private final Optional<Integer> workersPerQueryLimit;
private final Optional<String> schedulingPolicy;
private final Optional<Integer> schedulingWeight;
private final Optional<Boolean> jmxExport;
private final Optional<Duration> softCpuLimit;
private final Optional<Duration> hardCpuLimit;
private final Optional<ResourceGroupQueryLimits> perQueryLimits;
private final Optional<Long> parentId;
private final ImmutableList.Builder<ResourceGroupSpec> subGroups = ImmutableList.builder();
ResourceGroupSpecBuilder(
long id,
ResourceGroupNameTemplate nameTemplate,
String softMemoryLimit,
int maxQueued,
Optional<Integer> softConcurrencyLimit,
int hardConcurrencyLimit,
Optional<String> schedulingPolicy,
Optional<Integer> schedulingWeight,
Optional<Boolean> jmxExport,
Optional<String> softCpuLimit,
Optional<String> hardCpuLimit,
Optional<String> perQueryExecutionTimeLimit,
Optional<String> perQueryTotalMemoryLimit,
Optional<String> perQueryCpuTimeLimit,
Optional<Integer> workersPerQueryLimit,
Optional<Long> parentId)
{
this.id = id;
this.nameTemplate = nameTemplate;
this.softMemoryLimit = requireNonNull(softMemoryLimit, "softMemoryLimit is null");
this.maxQueued = maxQueued;
this.softConcurrencyLimit = requireNonNull(softConcurrencyLimit, "softConcurrencyLimit is null");
this.hardConcurrencyLimit = hardConcurrencyLimit;
this.workersPerQueryLimit = workersPerQueryLimit;
this.schedulingPolicy = requireNonNull(schedulingPolicy, "schedulingPolicy is null");
this.schedulingWeight = schedulingWeight;
this.jmxExport = requireNonNull(jmxExport, "jmxExport is null");
this.softCpuLimit = requireNonNull(softCpuLimit, "softCpuLimit is null").map(Duration::valueOf);
this.hardCpuLimit = requireNonNull(hardCpuLimit, "hardCpuLimit is null").map(Duration::valueOf);
Optional<Duration> executionTimeLimit = requireNonNull(perQueryExecutionTimeLimit, "perQueryExecutionTimeLimit is null").map(Duration::valueOf);
Optional<DataSize> totalMemoryLimit = requireNonNull(perQueryTotalMemoryLimit, "perQueryTotalMemoryLimit is null").map(DataSize::valueOf);
Optional<Duration> cpuTimeLimit = requireNonNull(perQueryCpuTimeLimit, "perQueryCpuTimeLimit is null").map(Duration::valueOf);
this.perQueryLimits = Optional.of(new ResourceGroupQueryLimits(executionTimeLimit, totalMemoryLimit, cpuTimeLimit));
this.parentId = parentId;
}
public long getId()
{
return id;
}
public ResourceGroupNameTemplate getNameTemplate()
{
return nameTemplate;
}
public Optional<Duration> getSoftCpuLimit()
{
return softCpuLimit;
}
public Optional<Duration> getHardCpuLimit()
{
return hardCpuLimit;
}
public Optional<Long> getParentId()
{
return parentId;
}
public void addSubGroup(ResourceGroupSpec subGroup)
{
subGroups.add(subGroup);
}
public ResourceGroupSpec build()
{
return new ResourceGroupSpec(
nameTemplate,
softMemoryLimit,
maxQueued,
softConcurrencyLimit,
Optional.of(hardConcurrencyLimit),
Optional.empty(),
schedulingPolicy,
schedulingWeight,
Optional.of(subGroups.build()),
jmxExport,
softCpuLimit,
hardCpuLimit,
perQueryLimits,
workersPerQueryLimit);
}
public static class Mapper
implements RowMapper<ResourceGroupSpecBuilder>
{
@Override
public ResourceGroupSpecBuilder map(ResultSet resultSet, StatementContext context)
throws SQLException
{
long id = resultSet.getLong("resource_group_id");
ResourceGroupNameTemplate nameTemplate = new ResourceGroupNameTemplate(resultSet.getString("name"));
String softMemoryLimit = resultSet.getString("soft_memory_limit");
int maxQueued = resultSet.getInt("max_queued");
Optional<Integer> softConcurrencyLimit = Optional.of(resultSet.getInt("soft_concurrency_limit"));
if (resultSet.wasNull()) {
softConcurrencyLimit = Optional.empty();
}
int hardConcurrencyLimit = resultSet.getInt("hard_concurrency_limit");
Optional<String> schedulingPolicy = Optional.ofNullable(resultSet.getString("scheduling_policy"));
Optional<Integer> schedulingWeight = Optional.of(resultSet.getInt("scheduling_weight"));
if (resultSet.wasNull()) {
schedulingWeight = Optional.empty();
}
Optional<Integer> workersPerQueryLimit = Optional.of(resultSet.getInt("workers_per_query_limit"));
if (resultSet.wasNull()) {
workersPerQueryLimit = Optional.empty();
}
Optional<Boolean> jmxExport = Optional.of(resultSet.getBoolean("jmx_export"));
if (resultSet.wasNull()) {
jmxExport = Optional.empty();
}
Optional<String> softCpuLimit = Optional.ofNullable(resultSet.getString("soft_cpu_limit"));
Optional<String> hardCpuLimit = Optional.ofNullable(resultSet.getString("hard_cpu_limit"));
Optional<String> perQueryExecutionTimeLimit = Optional.ofNullable(resultSet.getString("per_query_execution_time_limit"));
Optional<String> perQueryTotalMemoryLimit = Optional.ofNullable(resultSet.getString("per_query_total_memory_limit"));
Optional<String> perQueryCpuTimeLimit = Optional.ofNullable(resultSet.getString("per_query_cpu_time_limit"));
Optional<Long> parentId = Optional.of(resultSet.getLong("parent"));
if (resultSet.wasNull()) {
parentId = Optional.empty();
}
return new ResourceGroupSpecBuilder(
id,
nameTemplate,
softMemoryLimit,
maxQueued,
softConcurrencyLimit,
hardConcurrencyLimit,
schedulingPolicy,
schedulingWeight,
jmxExport,
softCpuLimit,
hardCpuLimit,
perQueryExecutionTimeLimit,
perQueryTotalMemoryLimit,
perQueryCpuTimeLimit,
workersPerQueryLimit,
parentId);
}
}
}