simplified console code. Added Builder. Fixed urls

This commit is contained in:
Dhruv Parthasarathy 2013-08-01 14:06:22 -07:00
parent dd689ca828
commit 9b340d9f6c
10 changed files with 133 additions and 173 deletions

View File

@ -121,7 +121,7 @@ public class InfoResource
this.serverInventoryView = serverInventoryView; this.serverInventoryView = serverInventoryView;
this.databaseSegmentManager = databaseSegmentManager; this.databaseSegmentManager = databaseSegmentManager;
this.databaseRuleManager = databaseRuleManager; this.databaseRuleManager = databaseRuleManager;
this.configManager=configManager; this.configManager = configManager;
this.indexingServiceClient = indexingServiceClient; this.indexingServiceClient = indexingServiceClient;
} }
@ -136,11 +136,17 @@ public class InfoResource
} }
@GET @GET
@Path("/master/dynamicConfigs") @Path("/master/config")
@Produces("application/json") @Produces("application/json")
public Response getDynamicConfigs() public Response getDynamicConfigs()
{ {
Response.ResponseBuilder builder = Response.status(Response.Status.OK).entity(configManager.watch(DynamicConfigs.CONFIG_KEY,DynamicConfigs.class).get()); Response.ResponseBuilder builder = Response.status(Response.Status.OK)
.entity(
configManager.watch(
DynamicConfigs.CONFIG_KEY,
DynamicConfigs.class
).get()
);
return builder.build(); return builder.build();
} }
@ -389,13 +395,13 @@ public class InfoResource
} }
@POST @POST
@Path("master/dynamicConfigs") @Path("master/config")
@Consumes("application/json") @Consumes("application/json")
public Response setDynamicConfigs( public Response setDynamicConfigs(
final DynamicConfigs dynamicConfigs) final DynamicConfigs dynamicConfigs
)
{ {
if (!configManager.set(DynamicConfigs.CONFIG_KEY, dynamicConfigs)) if (!configManager.set(DynamicConfigs.CONFIG_KEY, dynamicConfigs)) {
{
return Response.status(Response.Status.BAD_REQUEST).build(); return Response.status(Response.Status.BAD_REQUEST).build();
} }
return Response.status(Response.Status.OK).build(); return Response.status(Response.Status.OK).build();

View File

@ -80,7 +80,6 @@ public class DruidMaster
private volatile boolean started = false; private volatile boolean started = false;
private volatile boolean master = false; private volatile boolean master = false;
private volatile boolean defaultConfigsSet=false;
private final DruidMasterConfig config; private final DruidMasterConfig config;
private final ZkPathsConfig zkPaths; private final ZkPathsConfig zkPaths;
@ -466,12 +465,8 @@ public class DruidMaster
serverInventoryView.start(); serverInventoryView.start();
final List<Pair<? extends MasterRunnable, Duration>> masterRunnables = Lists.newArrayList(); final List<Pair<? extends MasterRunnable, Duration>> masterRunnables = Lists.newArrayList();
if (!defaultConfigsSet)
{
configManager.watch(DynamicConfigs.CONFIG_KEY, DynamicConfigs.class); configManager.watch(DynamicConfigs.CONFIG_KEY, DynamicConfigs.class);
configManager.set(DynamicConfigs.CONFIG_KEY, new DynamicConfigs(null,null,null,null)); configManager.set(DynamicConfigs.CONFIG_KEY, (new DynamicConfigs.Builder()).build());
defaultConfigsSet=true;
}
masterRunnables.add(Pair.of(new MasterComputeManagerRunnable(), config.getMasterPeriod())); masterRunnables.add(Pair.of(new MasterComputeManagerRunnable(), config.getMasterPeriod()));
if (indexingServiceClient != null) { if (indexingServiceClient != null) {

View File

@ -214,7 +214,7 @@ public class DruidMasterRuntimeParams
this.replicationManager = null; this.replicationManager = null;
this.emitter = null; this.emitter = null;
this.stats = new MasterStats(); this.stats = new MasterStats();
this.dynamicConfigs = new DynamicConfigs(null,null,null,null); this.dynamicConfigs = new DynamicConfigs.Builder().build();
this.balancerReferenceTimestamp = null; this.balancerReferenceTimestamp = null;
} }

View File

@ -30,31 +30,18 @@ public class DynamicConfigs
private int maxSegmentsToMove = 5; private int maxSegmentsToMove = 5;
@JsonCreator @JsonCreator
public DynamicConfigs(@JsonProperty("millisToWaitBeforeDeleting") Integer millisToWaitBeforeDeleting, public DynamicConfigs(@JsonProperty("millisToWaitBeforeDeleting") Long millisToWaitBeforeDeleting,
@JsonProperty("mergeBytesLimit") Long mergeBytesLimit, @JsonProperty("mergeBytesLimit") Long mergeBytesLimit,
@JsonProperty("mergeSegmentsLimit") Integer mergeSegmentsLimit, @JsonProperty("mergeSegmentsLimit") Integer mergeSegmentsLimit,
@JsonProperty("maxSegmentsToMove") Integer maxSegmentsToMove @JsonProperty("maxSegmentsToMove") Integer maxSegmentsToMove
) )
{ {
if (maxSegmentsToMove!=null)
{
this.maxSegmentsToMove=maxSegmentsToMove; this.maxSegmentsToMove=maxSegmentsToMove;
}
if (millisToWaitBeforeDeleting!=null)
{
this.millisToWaitBeforeDeleting=millisToWaitBeforeDeleting; this.millisToWaitBeforeDeleting=millisToWaitBeforeDeleting;
}
if (mergeSegmentsLimit!=null)
{
this.mergeSegmentsLimit=mergeSegmentsLimit; this.mergeSegmentsLimit=mergeSegmentsLimit;
}
if (mergeBytesLimit!=null)
{
this.mergeBytesLimit=mergeBytesLimit; this.mergeBytesLimit=mergeBytesLimit;
}
} }
public static String getConfigKey() public static String getConfigKey()
{ {
return CONFIG_KEY; return CONFIG_KEY;
@ -83,4 +70,59 @@ public class DynamicConfigs
{ {
return maxSegmentsToMove; return maxSegmentsToMove;
} }
public static class Builder
{
public static final String CONFIG_KEY = "master.dynamicConfigs";
private long millisToWaitBeforeDeleting;
private long mergeBytesLimit;
private int mergeSegmentsLimit;
private int maxSegmentsToMove;
public Builder()
{
this.millisToWaitBeforeDeleting=15 * 60 * 1000L;
this.mergeBytesLimit= 100000000L;
this.mergeSegmentsLimit= Integer.MAX_VALUE;
this.maxSegmentsToMove = 5;
}
public Builder(long millisToWaitBeforeDeleting, long mergeBytesLimit, int mergeSegmentsLimit, int maxSegmentsToMove)
{
this.millisToWaitBeforeDeleting = millisToWaitBeforeDeleting;
this.mergeBytesLimit = mergeBytesLimit;
this.mergeSegmentsLimit = mergeSegmentsLimit;
this.maxSegmentsToMove = maxSegmentsToMove;
}
public Builder withMillisToWaitBeforeDeleting(long millisToWaitBeforeDeleting)
{
this.millisToWaitBeforeDeleting=millisToWaitBeforeDeleting;
return this;
}
public Builder withMergeBytesLimit(long mergeBytesLimit)
{
this.mergeBytesLimit=mergeBytesLimit;
return this;
}
public Builder withMergeSegmentsLimit(int mergeSegmentsLimit)
{
this.mergeSegmentsLimit=mergeSegmentsLimit;
return this;
}
public Builder withMaxSegmentsToMove(int maxSegmentsToMove)
{
this.maxSegmentsToMove=maxSegmentsToMove;
return this;
}
public DynamicConfigs build()
{
return new DynamicConfigs(millisToWaitBeforeDeleting,mergeBytesLimit,mergeSegmentsLimit,maxSegmentsToMove);
}
}
} }

View File

@ -2,33 +2,22 @@
<html> <html>
<head> <head>
<title>Configure Dynamic Master Parameters</title> <title>Configure Dynamic Master Parameters</title>
<link rel="stylesheet" href="js/SlickGrid-master/slick.grid.css" type="text/css"/>
<link rel="stylesheet" href="js/SlickGrid-master/css/smoothness/jquery-ui-1.8.16.custom.css" type="text/css"/>
<link rel="stylesheet" href="js/SlickGrid-master/examples/examples.css" type="text/css"/>
</head> </head>
<body> <body>
<table width="100%"> <form action="process_config.html" autocomplete="on" id ="configs">
<tr> millisToWaitBeforeDeleting:<input type="text" name="millisToWaitBeforeDeleting" id="millis">
<td valign="top" width="50%"> <br>
<div id="myGrid" style="width:600px;height:500px;"></div> mergeBytesLimit: <input type="text" name="mergeBytesLimit" id="mergeBytes">
</td> <br>
</tr> mergeSegmentsLimit: <input type="text" name = "mergeSegmentsLimit" id="mergeSegments">
</table> <br>
maxSegmentsToMove: <input type= "text" name ="maxSegmentsToMove" id ="maxSegments">
<script src="js/SlickGrid-master/lib/firebugx.js"></script> <br>
<button type="button" id="submit"> Submit </button>
<script src="js/SlickGrid-master/lib/jquery-1.7.min.js"></script> </form>
<script src="js/SlickGrid-master/lib/jquery-ui-1.8.16.custom.min.js"></script>
<script src="js/SlickGrid-master/lib/jquery.event.drag-2.2.js"></script>
<script src="js/SlickGrid-master/slick.core.js"></script>
<script src="js/SlickGrid-master/plugins/slick.cellrangedecorator.js"></script>
<script src="js/SlickGrid-master/plugins/slick.cellrangeselector.js"></script>
<script src="js/SlickGrid-master/plugins/slick.cellselectionmodel.js"></script>
<script src="js/SlickGrid-master/slick.formatters.js"></script>
<script src="js/SlickGrid-master/slick.editors.js"></script>
<script src="js/SlickGrid-master/slick.grid.js"></script>
<script src="js/createDynamicParamsGrid.js"></script>
</body> </body>
<script type="text/javascript" src="js/jquery-1.8.3.js"></script>
<script type="text/javascript" src="js/dynamicConfigs.js"></script>
</script>
</html> </html>

View File

@ -1,33 +0,0 @@
var grid;
var columns = [
{id: "millisToWaitBeforeDeleting", name: "millisToWaitBeforeDeleting", field: "millisToWaitBeforeDeleting",editor: Slick.Editors.LongText},
{id: "mergeBytesLimit", name: "mergeBytesLimit", field: "mergeBytesLimit",editor: Slick.Editors.LongText},
{id: "mergeSegmentsLimit", name: "mergeSegmentsLimit", field: "mergeSegmentsLimit",editor: Slick.Editors.LongText},
{id: "maxSegmentsToMove", name: "maxSegmentsToMove", field: "maxSegmentsToMove",editor: Slick.Editors.LongText}
];
var options = {
enableCellNavigation: true,
enableColumnReorder: false,
editable: true,
autoEdit: false,
fullWidthRows: true
};
$(function () {
$.get('../info/master/dynamicConfigs', function (data) {
var rowData = [];
rowData[0]=data;
grid = new Slick.Grid("#myGrid", rowData, columns, options);
grid.onCellChange.subscribe(function (e) {
var paramJson = JSON.stringify(grid.getData()[0]);
$.ajax({
url:'../info/master/dynamicConfigs',
type:"POST",
data:paramJson,
contentType:"application/json; charset=utf-8",
dataType:"json"
});
});
});
});

View File

@ -0,0 +1,25 @@
$(function () {
$.get('../info/master/config', function (data) {
document.getElementById("millis").value=data["millisToWaitBeforeDeleting"];
document.getElementById("mergeBytes").value = data["mergeBytesLimit"];
document.getElementById("mergeSegments").value = data["mergeSegmentsLimit"];
document.getElementById("maxSegments").value = data["maxSegmentsToMove"];
});
$("#submit").click( function ()
{
values = {};
list = $('form').serializeArray();
for (var i=0;i< list.length;i++)
{
values[list[i]["name"]]=list[i]["value"];
}
$.ajax({
url:'../info/master/config',
type:"POST",
data: JSON.stringify(values),
contentType:"application/json; charset=utf-8",
dataType:"json"
});
});
});

View File

@ -193,14 +193,7 @@ public class DruidMasterBalancerTest
) )
.withAvailableSegments(segments.values()) .withAvailableSegments(segments.values())
.withDynamicConfigs( .withDynamicConfigs(
new DynamicConfigs(null,null,null,null) new DynamicConfigs.Builder().withMaxSegmentsToMove(MAX_SEGMENTS_TO_MOVE).build()
{
@Override
public int getMaxSegmentsToMove()
{
return MAX_SEGMENTS_TO_MOVE;
}
}
) )
.withBalancerReferenceTimestamp(new DateTime("2013-01-01")) .withBalancerReferenceTimestamp(new DateTime("2013-01-01"))
.build(); .build();
@ -277,16 +270,20 @@ public class DruidMasterBalancerTest
) )
) )
) )
.withLoadManagementPeons(ImmutableMap.<String, LoadQueuePeon>of("1", peon1, "2", peon2, "3", peon3, "4", peon4)) .withLoadManagementPeons(
ImmutableMap.<String, LoadQueuePeon>of(
"1",
peon1,
"2",
peon2,
"3",
peon3,
"4",
peon4
)
)
.withAvailableSegments(segments.values()) .withAvailableSegments(segments.values())
.withDynamicConfigs(new DynamicConfigs(null,null,null,null) .withDynamicConfigs(new DynamicConfigs.Builder().withMaxSegmentsToMove(MAX_SEGMENTS_TO_MOVE).build())
{
@Override
public int getMaxSegmentsToMove()
{
return MAX_SEGMENTS_TO_MOVE;
}
})
.withBalancerReferenceTimestamp(new DateTime("2013-01-01")) .withBalancerReferenceTimestamp(new DateTime("2013-01-01"))
.build(); .build();

View File

@ -177,15 +177,7 @@ public class DruidMasterRuleRunnerTest
.withAvailableSegments(availableSegments) .withAvailableSegments(availableSegments)
.withDatabaseRuleManager(databaseRuleManager) .withDatabaseRuleManager(databaseRuleManager)
.withSegmentReplicantLookup(SegmentReplicantLookup.make(new DruidCluster())) .withSegmentReplicantLookup(SegmentReplicantLookup.make(new DruidCluster()))
.withDynamicConfigs(new DynamicConfigs(null,null,null,null) .withDynamicConfigs(new DynamicConfigs.Builder().withMaxSegmentsToMove(5).build())
{
@Override
public int getMaxSegmentsToMove()
{
return 5;
}
})
.withBalancerReferenceTimestamp(new DateTime("2013-01-01"))
.build(); .build();
DruidMasterRuntimeParams afterParams = ruleRunner.run(params); DruidMasterRuntimeParams afterParams = ruleRunner.run(params);
@ -530,14 +522,7 @@ public class DruidMasterRuleRunnerTest
DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder() DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder()
.withDruidCluster(druidCluster) .withDruidCluster(druidCluster)
.withDynamicConfigs( new DynamicConfigs(null,null,null,null) .withDynamicConfigs(new DynamicConfigs.Builder().withMillisToWaitBeforeDeleting(0L).build())
{
@Override
public long getMillisToWaitBeforeDeleting()
{
return 0L;
}
})
.withAvailableSegments(availableSegments) .withAvailableSegments(availableSegments)
.withDatabaseRuleManager(databaseRuleManager) .withDatabaseRuleManager(databaseRuleManager)
.withSegmentReplicantLookup(segmentReplicantLookup) .withSegmentReplicantLookup(segmentReplicantLookup)
@ -611,14 +596,7 @@ public class DruidMasterRuleRunnerTest
DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder() DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder()
.withDruidCluster(druidCluster) .withDruidCluster(druidCluster)
.withDynamicConfigs( new DynamicConfigs(null,null,null,null) .withDynamicConfigs(new DynamicConfigs.Builder().withMillisToWaitBeforeDeleting(0L).build())
{
@Override
public long getMillisToWaitBeforeDeleting()
{
return 0L;
}
})
.withAvailableSegments(availableSegments) .withAvailableSegments(availableSegments)
.withDatabaseRuleManager(databaseRuleManager) .withDatabaseRuleManager(databaseRuleManager)
.withSegmentReplicantLookup(segmentReplicantLookup) .withSegmentReplicantLookup(segmentReplicantLookup)
@ -699,14 +677,7 @@ public class DruidMasterRuleRunnerTest
DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder() DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder()
.withDruidCluster(druidCluster) .withDruidCluster(druidCluster)
.withDynamicConfigs( new DynamicConfigs(null,null,null,null) .withDynamicConfigs(new DynamicConfigs.Builder().withMillisToWaitBeforeDeleting(0L).build())
{
@Override
public long getMillisToWaitBeforeDeleting()
{
return 0L;
}
})
.withAvailableSegments(availableSegments) .withAvailableSegments(availableSegments)
.withDatabaseRuleManager(databaseRuleManager) .withDatabaseRuleManager(databaseRuleManager)
.withSegmentReplicantLookup(segmentReplicantLookup) .withSegmentReplicantLookup(segmentReplicantLookup)
@ -783,14 +754,7 @@ public class DruidMasterRuleRunnerTest
DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder() DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder()
.withDruidCluster(druidCluster) .withDruidCluster(druidCluster)
.withDynamicConfigs( new DynamicConfigs(null,null,null,null) .withDynamicConfigs(new DynamicConfigs.Builder().withMillisToWaitBeforeDeleting(0L).build())
{
@Override
public long getMillisToWaitBeforeDeleting()
{
return 0L;
}
})
.withAvailableSegments(availableSegments) .withAvailableSegments(availableSegments)
.withDatabaseRuleManager(databaseRuleManager) .withDatabaseRuleManager(databaseRuleManager)
.withSegmentReplicantLookup(segmentReplicantLookup) .withSegmentReplicantLookup(segmentReplicantLookup)
@ -879,14 +843,7 @@ public class DruidMasterRuleRunnerTest
DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder() DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder()
.withDruidCluster(druidCluster) .withDruidCluster(druidCluster)
.withDynamicConfigs( new DynamicConfigs(null,null,null,null) .withDynamicConfigs(new DynamicConfigs.Builder().withMillisToWaitBeforeDeleting(0L).build())
{
@Override
public long getMillisToWaitBeforeDeleting()
{
return 0L;
}
})
.withAvailableSegments(availableSegments) .withAvailableSegments(availableSegments)
.withDatabaseRuleManager(databaseRuleManager) .withDatabaseRuleManager(databaseRuleManager)
.withSegmentReplicantLookup(segmentReplicantLookup) .withSegmentReplicantLookup(segmentReplicantLookup)
@ -1072,14 +1029,7 @@ public class DruidMasterRuleRunnerTest
DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder() DruidMasterRuntimeParams params = new DruidMasterRuntimeParams.Builder()
.withDruidCluster(druidCluster) .withDruidCluster(druidCluster)
.withDynamicConfigs( new DynamicConfigs(null,null,null,null) .withDynamicConfigs(new DynamicConfigs.Builder().withMillisToWaitBeforeDeleting(0L).build())
{
@Override
public long getMillisToWaitBeforeDeleting()
{
return 0L;
}
})
.withAvailableSegments(longerAvailableSegments) .withAvailableSegments(longerAvailableSegments)
.withDatabaseRuleManager(databaseRuleManager) .withDatabaseRuleManager(databaseRuleManager)
.withSegmentReplicantLookup(segmentReplicantLookup) .withSegmentReplicantLookup(segmentReplicantLookup)

View File

@ -422,19 +422,8 @@ public class DruidMasterSegmentMergerTest
final DruidMasterRuntimeParams params = DruidMasterRuntimeParams.newBuilder() final DruidMasterRuntimeParams params = DruidMasterRuntimeParams.newBuilder()
.withAvailableSegments(ImmutableSet.copyOf(segments)) .withAvailableSegments(ImmutableSet.copyOf(segments))
.withDynamicConfigs( .withDynamicConfigs(
new DynamicConfigs(null,null,null,null) new DynamicConfigs.Builder().withMergeBytesLimit(mergeBytesLimit).withMergeSegmentsLimit(mergeSegmentsLimit).build())
{
@Override
public long getMergeBytesLimit(){
return mergeBytesLimit;
}
@Override
public int getMergeSegmentsLimit(){
return mergeSegmentsLimit;
}
})
.build(); .build();
merger.run(params); merger.run(params);
return retVal; return retVal;
} }