Make supervisor API similar to submit task API (#8810)

* accept spec or dataSchema, tuningConfig, ioConfig while submitting task json

* fix test

* update docs

* lgtm warning

* Add original constructor back to IndexTask to minimize changes

* fix indentation in docs

* Allow spec to be specified in supervisor schema

* undo IndexTask spec changes

* update docs

* Add Nullable and deprecated annotations

* remove deprecated configs from SeekableStreamSupervisorSpec

* remove nullable annotation
This commit is contained in:
Surekha 2019-11-20 10:04:41 -08:00 committed by Jihoon Son
parent ee8f048381
commit d628bebbd7
15 changed files with 541 additions and 187 deletions

View File

@ -180,6 +180,7 @@ Paste in this spec and click `Submit`.
```json
{
"type": "kafka",
"spec" : {
"dataSchema": {
"dataSource": "wikipedia",
"parser": {
@ -237,6 +238,7 @@ Paste in this spec and click `Submit`.
}
}
}
}
```
This will start the supervisor that will in turn spawn some tasks that will start listening for incoming data.

View File

@ -1,5 +1,6 @@
{
"type": "kafka",
"spec" : {
"dataSchema": {
"dataSource": "wikipedia",
"parser": {
@ -28,9 +29,18 @@
"regionIsoCode",
"regionName",
"user",
{ "name": "added", "type": "long" },
{ "name": "deleted", "type": "long" },
{ "name": "delta", "type": "long" }
{
"name": "added",
"type": "long"
},
{
"name": "deleted",
"type": "long"
},
{
"name": "delta",
"type": "long"
}
]
}
}
@ -57,3 +67,4 @@
}
}
}
}

View File

@ -0,0 +1,66 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.druid.indexing.kafka.supervisor;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import org.apache.druid.indexing.seekablestream.supervisor.SeekableStreamSupervisorIngestionSpec;
import org.apache.druid.segment.indexing.DataSchema;
public class KafkaSupervisorIngestionSpec extends SeekableStreamSupervisorIngestionSpec
{
private final DataSchema dataSchema;
private final KafkaSupervisorIOConfig ioConfig;
private final KafkaSupervisorTuningConfig tuningConfig;
@JsonCreator
public KafkaSupervisorIngestionSpec(
@JsonProperty("dataSchema") DataSchema dataSchema,
@JsonProperty("ioConfig") KafkaSupervisorIOConfig ioConfig,
@JsonProperty("tuningConfig") KafkaSupervisorTuningConfig tuningConfig
)
{
super(dataSchema, ioConfig, tuningConfig);
this.dataSchema = dataSchema;
this.ioConfig = ioConfig;
this.tuningConfig = tuningConfig == null ? KafkaSupervisorTuningConfig.defaultConfig() : tuningConfig;
}
@Override
@JsonProperty("dataSchema")
public DataSchema getDataSchema()
{
return dataSchema;
}
@Override
@JsonProperty("ioConfig")
public KafkaSupervisorIOConfig getIOConfig()
{
return ioConfig;
}
@Override
@JsonProperty("tuningConfig")
public KafkaSupervisorTuningConfig getTuningConfig()
{
return tuningConfig;
}
}

View File

@ -36,6 +36,7 @@ import org.apache.druid.java.util.emitter.service.ServiceEmitter;
import org.apache.druid.segment.indexing.DataSchema;
import org.apache.druid.server.metrics.DruidMonitorSchedulerConfig;
import javax.annotation.Nullable;
import java.util.Map;
public class KafkaSupervisorSpec extends SeekableStreamSupervisorSpec
@ -44,9 +45,10 @@ public class KafkaSupervisorSpec extends SeekableStreamSupervisorSpec
@JsonCreator
public KafkaSupervisorSpec(
@JsonProperty("dataSchema") DataSchema dataSchema,
@JsonProperty("tuningConfig") KafkaSupervisorTuningConfig tuningConfig,
@JsonProperty("ioConfig") KafkaSupervisorIOConfig ioConfig,
@JsonProperty("spec") @Nullable KafkaSupervisorIngestionSpec ingestionSchema,
@JsonProperty("dataSchema") @Nullable DataSchema dataSchema,
@JsonProperty("tuningConfig") @Nullable KafkaSupervisorTuningConfig tuningConfig,
@JsonProperty("ioConfig") @Nullable KafkaSupervisorIOConfig ioConfig,
@JsonProperty("context") Map<String, Object> context,
@JsonProperty("suspended") Boolean suspended,
@JacksonInject TaskStorage taskStorage,
@ -61,36 +63,15 @@ public class KafkaSupervisorSpec extends SeekableStreamSupervisorSpec
)
{
super(
ingestionSchema != null
? ingestionSchema
: new KafkaSupervisorIngestionSpec(
dataSchema,
ioConfig,
tuningConfig != null
? tuningConfig
: new KafkaSupervisorTuningConfig(
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null
: KafkaSupervisorTuningConfig.defaultConfig()
),
ioConfig,
context,
suspended,
taskStorage,
@ -132,6 +113,7 @@ public class KafkaSupervisorSpec extends SeekableStreamSupervisorSpec
}
@Override
@Deprecated
@JsonProperty
public KafkaSupervisorTuningConfig getTuningConfig()
{
@ -139,16 +121,25 @@ public class KafkaSupervisorSpec extends SeekableStreamSupervisorSpec
}
@Override
@Deprecated
@JsonProperty
public KafkaSupervisorIOConfig getIoConfig()
{
return (KafkaSupervisorIOConfig) super.getIoConfig();
}
@Override
@JsonProperty
public KafkaSupervisorIngestionSpec getSpec()
{
return (KafkaSupervisorIngestionSpec) super.getSpec();
}
@Override
protected KafkaSupervisorSpec toggleSuspend(boolean suspend)
{
return new KafkaSupervisorSpec(
getSpec(),
getDataSchema(),
getTuningConfig(),
getIoConfig(),

View File

@ -43,6 +43,36 @@ public class KafkaSupervisorTuningConfig extends KafkaIndexTaskTuningConfig
private final Duration shutdownTimeout;
private final Duration offsetFetchPeriod;
public static KafkaSupervisorTuningConfig defaultConfig()
{
return new KafkaSupervisorTuningConfig(
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null
);
}
public KafkaSupervisorTuningConfig(
@JsonProperty("maxRowsInMemory") Integer maxRowsInMemory,
@JsonProperty("maxBytesInMemory") Long maxBytesInMemory,

View File

@ -137,6 +137,7 @@ public class KafkaSamplerSpecTest extends InitializedNullHandlingTest
insertData(generateRecords(TOPIC));
KafkaSupervisorSpec supervisorSpec = new KafkaSupervisorSpec(
null,
DATA_SCHEMA,
null,
new KafkaSupervisorIOConfig(

View File

@ -146,6 +146,91 @@ public class KafkaSupervisorSpecTest
Assert.assertEquals(serialized, stable);
}
@Test
public void testSerdeWithSpec() throws IOException
{
String json = "{\n"
+ " \"type\": \"kafka\",\n"
+ " \"spec\": {\n"
+ " \"dataSchema\": {\n"
+ " \"dataSource\": \"metrics-kafka\",\n"
+ " \"parser\": {\n"
+ " \"type\": \"string\",\n"
+ " \"parseSpec\": {\n"
+ " \"format\": \"json\",\n"
+ " \"timestampSpec\": {\n"
+ " \"column\": \"timestamp\",\n"
+ " \"format\": \"auto\"\n"
+ " },\n"
+ " \"dimensionsSpec\": {\n"
+ " \"dimensions\": [],\n"
+ " \"dimensionExclusions\": [\n"
+ " \"timestamp\",\n"
+ " \"value\"\n"
+ " ]\n"
+ " }\n"
+ " }\n"
+ " },\n"
+ " \"metricsSpec\": [\n"
+ " {\n"
+ " \"name\": \"count\",\n"
+ " \"type\": \"count\"\n"
+ " },\n"
+ " {\n"
+ " \"name\": \"value_sum\",\n"
+ " \"fieldName\": \"value\",\n"
+ " \"type\": \"doubleSum\"\n"
+ " },\n"
+ " {\n"
+ " \"name\": \"value_min\",\n"
+ " \"fieldName\": \"value\",\n"
+ " \"type\": \"doubleMin\"\n"
+ " },\n"
+ " {\n"
+ " \"name\": \"value_max\",\n"
+ " \"fieldName\": \"value\",\n"
+ " \"type\": \"doubleMax\"\n"
+ " }\n"
+ " ],\n"
+ " \"granularitySpec\": {\n"
+ " \"type\": \"uniform\",\n"
+ " \"segmentGranularity\": \"HOUR\",\n"
+ " \"queryGranularity\": \"NONE\"\n"
+ " }\n"
+ " },\n"
+ " \"ioConfig\": {\n"
+ " \"topic\": \"metrics\",\n"
+ " \"consumerProperties\": {\n"
+ " \"bootstrap.servers\": \"localhost:9092\"\n"
+ " },\n"
+ " \"taskCount\": 1\n"
+ " }\n"
+ " }\n"
+ "}";
KafkaSupervisorSpec spec = mapper.readValue(json, KafkaSupervisorSpec.class);
Assert.assertNotNull(spec);
Assert.assertNotNull(spec.getDataSchema());
Assert.assertEquals(4, spec.getDataSchema().getAggregators().length);
Assert.assertNotNull(spec.getIoConfig());
Assert.assertEquals("metrics", spec.getIoConfig().getTopic());
Assert.assertNotNull(spec.getTuningConfig());
Assert.assertNull(spec.getContext());
Assert.assertFalse(spec.isSuspended());
String serialized = mapper.writeValueAsString(spec);
// expect default values populated in reserialized string
Assert.assertTrue(serialized.contains("\"tuningConfig\":{"));
Assert.assertTrue(serialized.contains("\"indexSpec\":{"));
Assert.assertTrue(serialized.contains("\"suspended\":false"));
KafkaSupervisorSpec spec2 = mapper.readValue(serialized, KafkaSupervisorSpec.class);
String stable = mapper.writeValueAsString(spec2);
Assert.assertEquals(serialized, stable);
}
@Test
public void testSuspendResume() throws IOException
{

View File

@ -3453,6 +3453,7 @@ public class KafkaSupervisorTest extends EasyMockSupport
taskClientFactory,
OBJECT_MAPPER,
new KafkaSupervisorSpec(
null,
dataSchema,
tuningConfig,
kafkaSupervisorIOConfig,
@ -3561,6 +3562,7 @@ public class KafkaSupervisorTest extends EasyMockSupport
taskClientFactory,
OBJECT_MAPPER,
new KafkaSupervisorSpec(
null,
dataSchema,
tuningConfig,
kafkaSupervisorIOConfig,
@ -3646,6 +3648,7 @@ public class KafkaSupervisorTest extends EasyMockSupport
taskClientFactory,
OBJECT_MAPPER,
new KafkaSupervisorSpec(
null,
dataSchema,
tuningConfig,
kafkaSupervisorIOConfig,

View File

@ -0,0 +1,67 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.druid.indexing.kinesis.supervisor;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import org.apache.druid.indexing.seekablestream.supervisor.SeekableStreamSupervisorIngestionSpec;
import org.apache.druid.segment.indexing.DataSchema;
public class KinesisSupervisorIngestionSpec extends SeekableStreamSupervisorIngestionSpec
{
private final DataSchema dataSchema;
private final KinesisSupervisorIOConfig ioConfig;
private final KinesisSupervisorTuningConfig tuningConfig;
@JsonCreator
public KinesisSupervisorIngestionSpec(
@JsonProperty("dataSchema") DataSchema dataSchema,
@JsonProperty("ioConfig") KinesisSupervisorIOConfig ioConfig,
@JsonProperty("tuningConfig") KinesisSupervisorTuningConfig tuningConfig
)
{
super(dataSchema, ioConfig, tuningConfig);
this.dataSchema = dataSchema;
this.ioConfig = ioConfig;
this.tuningConfig = tuningConfig == null ? KinesisSupervisorTuningConfig.defaultConfig() : tuningConfig;
}
@Override
@JsonProperty("dataSchema")
public DataSchema getDataSchema()
{
return dataSchema;
}
@Override
@JsonProperty("ioConfig")
public KinesisSupervisorIOConfig getIOConfig()
{
return ioConfig;
}
@Override
@JsonProperty("tuningConfig")
public KinesisSupervisorTuningConfig getTuningConfig()
{
return tuningConfig;
}
}

View File

@ -38,6 +38,7 @@ import org.apache.druid.java.util.emitter.service.ServiceEmitter;
import org.apache.druid.segment.indexing.DataSchema;
import org.apache.druid.server.metrics.DruidMonitorSchedulerConfig;
import javax.annotation.Nullable;
import java.util.Map;
public class KinesisSupervisorSpec extends SeekableStreamSupervisorSpec
@ -47,9 +48,10 @@ public class KinesisSupervisorSpec extends SeekableStreamSupervisorSpec
@JsonCreator
public KinesisSupervisorSpec(
@JsonProperty("dataSchema") DataSchema dataSchema,
@JsonProperty("tuningConfig") KinesisSupervisorTuningConfig tuningConfig,
@JsonProperty("ioConfig") KinesisSupervisorIOConfig ioConfig,
@JsonProperty("spec") @Nullable KinesisSupervisorIngestionSpec ingestionSchema,
@JsonProperty("dataSchema") @Nullable DataSchema dataSchema,
@JsonProperty("tuningConfig") @Nullable KinesisSupervisorTuningConfig tuningConfig,
@JsonProperty("ioConfig") @Nullable KinesisSupervisorIOConfig ioConfig,
@JsonProperty("context") Map<String, Object> context,
@JsonProperty("suspended") Boolean suspended,
@JacksonInject TaskStorage taskStorage,
@ -65,43 +67,15 @@ public class KinesisSupervisorSpec extends SeekableStreamSupervisorSpec
)
{
super(
ingestionSchema != null
? ingestionSchema
: new KinesisSupervisorIngestionSpec(
dataSchema,
ioConfig,
tuningConfig != null
? tuningConfig
: new KinesisSupervisorTuningConfig(
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null
: KinesisSupervisorTuningConfig.defaultConfig()
),
ioConfig,
context,
suspended,
taskStorage,
@ -158,6 +132,7 @@ public class KinesisSupervisorSpec extends SeekableStreamSupervisorSpec
}
@Override
@Deprecated
@JsonProperty
public KinesisSupervisorTuningConfig getTuningConfig()
{
@ -165,16 +140,25 @@ public class KinesisSupervisorSpec extends SeekableStreamSupervisorSpec
}
@Override
@Deprecated
@JsonProperty
public KinesisSupervisorIOConfig getIoConfig()
{
return (KinesisSupervisorIOConfig) super.getIoConfig();
}
@Override
@JsonProperty
public KinesisSupervisorIngestionSpec getSpec()
{
return (KinesisSupervisorIngestionSpec) super.getSpec();
}
@Override
protected KinesisSupervisorSpec toggleSuspend(boolean suspend)
{
return new KinesisSupervisorSpec(
getSpec(),
getDataSchema(),
getTuningConfig(),
getIoConfig(),

View File

@ -40,6 +40,43 @@ public class KinesisSupervisorTuningConfig extends KinesisIndexTaskTuningConfig
private final Duration shutdownTimeout;
private final Duration repartitionTransitionDuration;
public static KinesisSupervisorTuningConfig defaultConfig()
{
return new KinesisSupervisorTuningConfig(
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null,
null
);
}
public KinesisSupervisorTuningConfig(
@JsonProperty("maxRowsInMemory") Integer maxRowsInMemory,
@JsonProperty("maxBytesInMemory") Long maxBytesInMemory,

View File

@ -151,6 +151,7 @@ public class KinesisSamplerSpecTest extends EasyMockSupport
replayAll();
KinesisSupervisorSpec supervisorSpec = new KinesisSupervisorSpec(
null,
DATA_SCHEMA,
null,
new KinesisSupervisorIOConfig(

View File

@ -4677,6 +4677,7 @@ public class KinesisSupervisorTest extends EasyMockSupport
taskClientFactory,
OBJECT_MAPPER,
new KinesisSupervisorSpec(
null,
dataSchema,
tuningConfig,
kinesisSupervisorIOConfig,
@ -4780,6 +4781,7 @@ public class KinesisSupervisorTest extends EasyMockSupport
taskClientFactory,
OBJECT_MAPPER,
new KinesisSupervisorSpec(
null,
dataSchema,
tuningConfig,
kinesisSupervisorIOConfig,
@ -4865,6 +4867,7 @@ public class KinesisSupervisorTest extends EasyMockSupport
taskClientFactory,
OBJECT_MAPPER,
new KinesisSupervisorSpec(
null,
dataSchema,
tuningConfig,
kinesisSupervisorIOConfig,
@ -4952,6 +4955,7 @@ public class KinesisSupervisorTest extends EasyMockSupport
taskClientFactory,
OBJECT_MAPPER,
new KinesisSupervisorSpec(
null,
dataSchema,
tuningConfig,
kinesisSupervisorIOConfig,

View File

@ -0,0 +1,61 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.druid.indexing.seekablestream.supervisor;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import org.apache.druid.segment.indexing.DataSchema;
public abstract class SeekableStreamSupervisorIngestionSpec
{
private final DataSchema dataSchema;
private final SeekableStreamSupervisorIOConfig ioConfig;
private final SeekableStreamSupervisorTuningConfig tuningConfig;
@JsonCreator
public SeekableStreamSupervisorIngestionSpec(
@JsonProperty("dataSchema") DataSchema dataSchema,
@JsonProperty("ioConfig") SeekableStreamSupervisorIOConfig ioConfig,
@JsonProperty("tuningConfig") SeekableStreamSupervisorTuningConfig tuningConfig
)
{
this.dataSchema = dataSchema;
this.ioConfig = ioConfig;
this.tuningConfig = tuningConfig;
}
@JsonProperty("dataSchema")
public DataSchema getDataSchema()
{
return dataSchema;
}
@JsonProperty("ioConfig")
public SeekableStreamSupervisorIOConfig getIOConfig()
{
return ioConfig;
}
@JsonProperty("tuningConfig")
public SeekableStreamSupervisorTuningConfig getTuningConfig()
{
return tuningConfig;
}
}

View File

@ -44,15 +44,24 @@ import java.util.Map;
public abstract class SeekableStreamSupervisorSpec implements SupervisorSpec
{
private static SeekableStreamSupervisorIngestionSpec checkIngestionSchema(
SeekableStreamSupervisorIngestionSpec ingestionSchema
)
{
Preconditions.checkNotNull(ingestionSchema, "ingestionSchema");
Preconditions.checkNotNull(ingestionSchema.getDataSchema(), "dataSchema");
Preconditions.checkNotNull(ingestionSchema.getIOConfig(), "ioConfig");
return ingestionSchema;
}
protected final TaskStorage taskStorage;
protected final TaskMaster taskMaster;
protected final IndexerMetadataStorageCoordinator indexerMetadataStorageCoordinator;
protected final SeekableStreamIndexTaskClientFactory indexTaskClientFactory;
protected final ObjectMapper mapper;
protected final RowIngestionMetersFactory rowIngestionMetersFactory;
private final DataSchema dataSchema;
private final SeekableStreamSupervisorTuningConfig tuningConfig;
private final SeekableStreamSupervisorIOConfig ioConfig;
private final SeekableStreamSupervisorIngestionSpec ingestionSchema;
@Nullable
private final Map<String, Object> context;
protected final ServiceEmitter emitter;
@ -62,9 +71,7 @@ public abstract class SeekableStreamSupervisorSpec implements SupervisorSpec
@JsonCreator
public SeekableStreamSupervisorSpec(
@JsonProperty("dataSchema") DataSchema dataSchema,
@JsonProperty("tuningConfig") SeekableStreamSupervisorTuningConfig tuningConfig,
@JsonProperty("ioConfig") SeekableStreamSupervisorIOConfig ioConfig,
@JsonProperty("spec") final SeekableStreamSupervisorIngestionSpec ingestionSchema,
@JsonProperty("context") @Nullable Map<String, Object> context,
@JsonProperty("suspended") Boolean suspended,
@JacksonInject TaskStorage taskStorage,
@ -78,9 +85,7 @@ public abstract class SeekableStreamSupervisorSpec implements SupervisorSpec
@JacksonInject SupervisorStateManagerConfig supervisorStateManagerConfig
)
{
this.dataSchema = Preconditions.checkNotNull(dataSchema, "dataSchema");
this.tuningConfig = tuningConfig; // null check done in concrete class
this.ioConfig = Preconditions.checkNotNull(ioConfig, "ioConfig");
this.ingestionSchema = checkIngestionSchema(ingestionSchema);
this.context = context;
this.taskStorage = taskStorage;
@ -95,22 +100,29 @@ public abstract class SeekableStreamSupervisorSpec implements SupervisorSpec
this.supervisorStateManagerConfig = supervisorStateManagerConfig;
}
@JsonProperty
public SeekableStreamSupervisorIngestionSpec getSpec()
{
return ingestionSchema;
}
@Deprecated
@JsonProperty
public DataSchema getDataSchema()
{
return dataSchema;
return ingestionSchema.getDataSchema();
}
@JsonProperty
public SeekableStreamSupervisorTuningConfig getTuningConfig()
{
return tuningConfig;
return ingestionSchema.getTuningConfig();
}
@JsonProperty
public SeekableStreamSupervisorIOConfig getIoConfig()
{
return ioConfig;
return ingestionSchema.getIOConfig();
}
@Nullable
@ -128,7 +140,7 @@ public abstract class SeekableStreamSupervisorSpec implements SupervisorSpec
@Override
public String getId()
{
return dataSchema.getDataSource();
return ingestionSchema.getDataSchema().getDataSource();
}
public DruidMonitorSchedulerConfig getMonitorSchedulerConfig()
@ -171,5 +183,4 @@ public abstract class SeekableStreamSupervisorSpec implements SupervisorSpec
protected abstract SeekableStreamSupervisorSpec toggleSuspend(boolean suspend);
}