Search in sources :

Example 1 with MemoryTrackingContext

use of com.facebook.presto.memory.context.MemoryTrackingContext in project presto by prestodb.

the class TestingOperatorContext method create.

public static OperatorContext create(ScheduledExecutorService scheduledExecutor) {
    Executor executor = MoreExecutors.directExecutor();
    TaskContext taskContext = TestingTaskContext.createTaskContext(executor, scheduledExecutor, TestingSession.testSessionBuilder().build());
    MemoryTrackingContext pipelineMemoryContext = new MemoryTrackingContext(newSimpleAggregatedMemoryContext(), newSimpleAggregatedMemoryContext(), newSimpleAggregatedMemoryContext());
    PipelineContext pipelineContext = new PipelineContext(1, taskContext, executor, scheduledExecutor, pipelineMemoryContext, false, false, false);
    DriverContext driverContext = new DriverContext(pipelineContext, executor, scheduledExecutor, pipelineMemoryContext, Lifespan.taskWide(), Optional.empty(), 0L);
    OperatorContext operatorContext = driverContext.addOperatorContext(1, new PlanNodeId("test"), "operator type");
    return operatorContext;
}
Also used : PlanNodeId(com.facebook.presto.spi.plan.PlanNodeId) Executor(java.util.concurrent.Executor) TestingTaskContext(com.facebook.presto.testing.TestingTaskContext) MemoryTrackingContext(com.facebook.presto.memory.context.MemoryTrackingContext)

Example 2 with MemoryTrackingContext

use of com.facebook.presto.memory.context.MemoryTrackingContext in project presto by prestodb.

the class TestTableWriterOperator method assertMemoryIsReleased.

private void assertMemoryIsReleased(TableWriterOperator tableWriterOperator) {
    OperatorContext tableWriterOperatorOperatorContext = tableWriterOperator.getOperatorContext();
    MemoryTrackingContext tableWriterMemoryContext = tableWriterOperatorOperatorContext.getOperatorMemoryContext();
    assertEquals(tableWriterMemoryContext.getSystemMemory(), 0);
    assertEquals(tableWriterMemoryContext.getUserMemory(), 0);
    assertEquals(tableWriterMemoryContext.getRevocableMemory(), 0);
    Operator statisticAggregationOperator = tableWriterOperator.getStatisticAggregationOperator();
    assertTrue(statisticAggregationOperator instanceof AggregationOperator);
    AggregationOperator aggregationOperator = (AggregationOperator) statisticAggregationOperator;
    OperatorContext aggregationOperatorOperatorContext = aggregationOperator.getOperatorContext();
    MemoryTrackingContext aggregationOperatorMemoryContext = aggregationOperatorOperatorContext.getOperatorMemoryContext();
    assertEquals(aggregationOperatorMemoryContext.getSystemMemory(), 0);
    assertEquals(aggregationOperatorMemoryContext.getUserMemory(), 0);
    assertEquals(aggregationOperatorMemoryContext.getRevocableMemory(), 0);
}
Also used : MemoryTrackingContext(com.facebook.presto.memory.context.MemoryTrackingContext)

Example 3 with MemoryTrackingContext

use of com.facebook.presto.memory.context.MemoryTrackingContext in project presto by prestodb.

the class TestMemoryTracking method testOperatorAllocations.

@Test
public void testOperatorAllocations() {
    MemoryTrackingContext operatorMemoryContext = operatorContext.getOperatorMemoryContext();
    LocalMemoryContext systemMemory = operatorContext.newLocalSystemMemoryContext("test");
    LocalMemoryContext userMemory = operatorContext.localUserMemoryContext();
    LocalMemoryContext revocableMemory = operatorContext.localRevocableMemoryContext();
    userMemory.setBytes(100);
    assertOperatorMemoryAllocations(operatorMemoryContext, 100, 0, 0);
    systemMemory.setBytes(1_000_000);
    assertOperatorMemoryAllocations(operatorMemoryContext, 100, 1_000_000, 0);
    systemMemory.setBytes(2_000_000);
    assertOperatorMemoryAllocations(operatorMemoryContext, 100, 2_000_000, 0);
    userMemory.setBytes(500);
    assertOperatorMemoryAllocations(operatorMemoryContext, 500, 2_000_000, 0);
    userMemory.setBytes(userMemory.getBytes() - 500);
    assertOperatorMemoryAllocations(operatorMemoryContext, 0, 2_000_000, 0);
    revocableMemory.setBytes(300);
    assertOperatorMemoryAllocations(operatorMemoryContext, 0, 2_000_000, 300);
    assertAllocationFails((ignored) -> userMemory.setBytes(userMemory.getBytes() - 500), "bytes cannot be negative");
    operatorContext.destroy();
    assertOperatorMemoryAllocations(operatorMemoryContext, 0, 0, 0);
}
Also used : LocalMemoryContext(com.facebook.presto.memory.context.LocalMemoryContext) MemoryTrackingContext(com.facebook.presto.memory.context.MemoryTrackingContext) Test(org.testng.annotations.Test)

Aggregations

MemoryTrackingContext (com.facebook.presto.memory.context.MemoryTrackingContext)3 LocalMemoryContext (com.facebook.presto.memory.context.LocalMemoryContext)1 PlanNodeId (com.facebook.presto.spi.plan.PlanNodeId)1 TestingTaskContext (com.facebook.presto.testing.TestingTaskContext)1 Executor (java.util.concurrent.Executor)1 Test (org.testng.annotations.Test)1