adding profiling for 55k servers

This commit is contained in:
Dhruv Parthasarathy 2013-08-01 23:38:44 -07:00
parent 9f17e8fc43
commit 6f6a335a40
2 changed files with 96 additions and 22 deletions

View File

@ -132,6 +132,7 @@ public class DruidMasterBalancerTest
EasyMock.verify(druidServer4); EasyMock.verify(druidServer4);
} }
@Test @Test
public void testMoveToEmptyServerBalancer() public void testMoveToEmptyServerBalancer()
{ {

View File

@ -16,15 +16,17 @@ import com.metamx.druid.master.LoadQueuePeon;
import com.metamx.druid.master.LoadQueuePeonTester; import com.metamx.druid.master.LoadQueuePeonTester;
import com.metamx.druid.master.ServerHolder; import com.metamx.druid.master.ServerHolder;
import com.metamx.druid.shard.NoneShardSpec; import com.metamx.druid.shard.NoneShardSpec;
import com.metamx.emitter.EmittingLogger;
import com.metamx.emitter.service.ServiceEmitter;
import org.easymock.EasyMock; import org.easymock.EasyMock;
import org.joda.time.DateTime; import org.joda.time.DateTime;
import org.joda.time.Interval; import org.joda.time.Interval;
import org.junit.After;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import java.util.Arrays; import java.util.Arrays;
import java.util.HashMap; import java.util.HashMap;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -37,39 +39,110 @@ public class DruidMasterBalancerProfiler
Map<String, DataSegment> segments = Maps.newHashMap(); Map<String, DataSegment> segments = Maps.newHashMap();
DateTime start1 = new DateTime("2012-01-01"); DateTime start1 = new DateTime("2012-01-01");
DateTime version = new DateTime("2012-03-01"); DateTime version = new DateTime("2012-03-01");
ServiceEmitter emitter;
@Before @Before
public void setUp() throws Exception public void setUp() throws Exception
{ {
master = EasyMock.createMock(DruidMaster.class); master = EasyMock.createMock(DruidMaster.class);
druidServer1 = EasyMock.createMock(DruidServer.class); druidServer1 = EasyMock.createMock(DruidServer.class);
druidServer2 = EasyMock.createMock(DruidServer.class); druidServer2 = EasyMock.createMock(DruidServer.class);
for (int i=0; i<55000;i++) emitter = EasyMock.createMock(ServiceEmitter.class);
{ EmittingLogger.registerEmitter(emitter);
DataSegment segment = new DataSegment(
"datasource1",
new Interval(start1, start1.plusHours(1)),
version.toString(),
Maps.<String, Object>newHashMap(),
Lists.<String>newArrayList(),
Lists.<String>newArrayList(),
new NoneShardSpec(),
0,
11L
);
segments.put("datasource"+i+"_2012-01-01T00:00:00.000Z_2012-01-01T01:00:00.000Z_2012-03-01T00:00:00.000Z",segment);
}
} }
@After @Test
public void tearDown() throws Exception public void bigProfiler()
{ {
EasyMock.verify(master); Stopwatch watch = new Stopwatch();
EasyMock.verify(druidServer1); int numServers = 1000;
EasyMock.verify(druidServer2); master.moveSegment(
EasyMock.<String>anyObject(),
EasyMock.<String>anyObject(),
EasyMock.<String>anyObject(),
EasyMock.<LoadPeonCallback>anyObject()
);
EasyMock.expectLastCall().anyTimes();
EasyMock.replay(master);
List<DruidServer> serverList = Lists.newArrayList();
Map<String, LoadQueuePeon> peonMap = Maps.newHashMap();
List<ServerHolder> serverHolderList = Lists.newArrayList();
Map<String,DataSegment> segmentMap = Maps.newHashMap();
for (int i=0;i<numServers;i++)
{
segmentMap.put(
"segment" + i,
new DataSegment(
"datasource" + i,
new Interval(new DateTime("2012-01-01"), (new DateTime("2012-01-01")).plusHours(1)),
(new DateTime("2012-03-01")).toString(),
Maps.<String, Object>newHashMap(),
Lists.<String>newArrayList(),
Lists.<String>newArrayList(),
new NoneShardSpec(),
0,
4L
)
);
}
for (int i=0;i<numServers;i++)
{
DruidServer server =EasyMock.createMock(DruidServer.class);
EasyMock.expect(server.getMetadata()).andReturn(null).anyTimes();
EasyMock.expect(server.getCurrSize()).andReturn(30L).atLeastOnce();
EasyMock.expect(server.getMaxSize()).andReturn(100L).atLeastOnce();
EasyMock.expect(server.getName()).andReturn(Integer.toString(i)).atLeastOnce();
if (i==0)
{
EasyMock.expect(server.getSegments()).andReturn(segmentMap).anyTimes();
}
else
{
EasyMock.expect(server.getSegments()).andReturn(new HashMap<String, DataSegment>()).anyTimes();
}
EasyMock.expect(server.getSegment(EasyMock.<String>anyObject())).andReturn(null).anyTimes();
EasyMock.replay(server);
LoadQueuePeon peon = new LoadQueuePeonTester();
peonMap.put(Integer.toString(i),peon);
serverHolderList.add(new ServerHolder(server, peon));
}
DruidMasterRuntimeParams params =
DruidMasterRuntimeParams.newBuilder()
.withDruidCluster(
new DruidCluster(
ImmutableMap.<String, MinMaxPriorityQueue<ServerHolder>>of(
"normal",
MinMaxPriorityQueue.orderedBy(DruidMasterBalancerTester.percentUsedComparator)
.create(
serverHolderList
)
)
)
)
.withLoadManagementPeons(
peonMap
)
.withAvailableSegments(segmentMap.values())
.withMaxSegmentsToMove(MAX_SEGMENTS_TO_MOVE)
.withBalancerReferenceTimestamp(new DateTime("2013-01-01"))
.withEmitter(emitter)
.build();
DruidMasterBalancerTester tester = new DruidMasterBalancerTester(master);
watch.start();
for (int i=0;i<numServers;i++)
{
params = tester.run(params);
}
System.out.println(watch.stop());
} }
@Test @Test
public void profileRun(){ public void profileRun(){
Stopwatch stopwatch = new Stopwatch(); Stopwatch stopwatch = new Stopwatch();