本文整理匯總了Java中org.apache.bookkeeper.util.ReflectionUtils類的典型用法代碼示例。如果您正苦於以下問題:Java ReflectionUtils類的具體用法?Java ReflectionUtils怎麽用?Java ReflectionUtils使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
ReflectionUtils類屬於org.apache.bookkeeper.util包,在下文中一共展示了ReflectionUtils類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: main
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
public static void main(String args[]) {
int rc = -1;
if (args.length <= 0) {
System.err.println("No tool to run.");
System.err.println("");
System.err.println("Usage : Tool <tool_class_name> <options>");
System.exit(-1);
}
String toolClass = args[0];
try {
Tool tool = ReflectionUtils.newInstance(toolClass, Tool.class);
String[] newArgs = new String[args.length - 1];
System.arraycopy(args, 1, newArgs, 0, newArgs.length);
rc = tool.run(newArgs);
} catch (Throwable t) {
System.err.println("Fail to run tool " + toolClass + " : ");
t.printStackTrace();
}
System.exit(rc);
}
示例2: createService
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
private DistributedLogServiceImpl createService(
ServerConfiguration serverConf,
DistributedLogConfiguration dlConf,
CountDownLatch latch) throws Exception {
// Build the stream partition converter
StreamPartitionConverter converter;
try {
converter = ReflectionUtils.newInstance(serverConf.getStreamPartitionConverterClass());
} catch (ConfigurationException e) {
logger.warn("Failed to load configured stream-to-partition converter. Fallback to use {}",
IdentityStreamPartitionConverter.class.getName());
converter = new IdentityStreamPartitionConverter();
}
return new DistributedLogServiceImpl(
serverConf,
dlConf,
ConfUtils.getConstDynConf(dlConf),
new NullStreamConfigProvider(),
uri,
converter,
NullStatsLogger.INSTANCE,
NullStatsLogger.INSTANCE,
latch);
}
示例3: getEnsemblePlacementDnsResolverClass
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
/**
* Get the DNS resolver class for bookkeeper ensemble placement.
* <p>By default, {@link DNSResolverForRacks} will be used if
* {@link #getRowAwareEnsemblePlacementEnabled()} is disabled and
* {@link DNSResolverForRows} will be used if {@link #getRowAwareEnsemblePlacementEnabled()}
* is enabled.
*
* @return dns resolver class for bookkeeper ensemble placement.
* @throws ConfigurationException
* @see #getRowAwareEnsemblePlacementEnabled()
*/
public Class<? extends DNSToSwitchMapping> getEnsemblePlacementDnsResolverClass()
throws ConfigurationException {
Class<? extends DNSToSwitchMapping> defaultResolverCls;
if (getRowAwareEnsemblePlacementEnabled()) {
defaultResolverCls = DNSResolverForRows.class;
} else {
defaultResolverCls = DNSResolverForRacks.class;
}
return ReflectionUtils.getClass(this, BKDL_ENSEMBLE_PLACEMENT_DNS_RESOLVER_CLASS,
defaultResolverCls, DNSToSwitchMapping.class, defaultLoader);
}
示例4: runTool
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
private static int runTool(String[] args) throws Exception {
Tool tool = ReflectionUtils.newInstance(args[0], Tool.class);
String[] newArgs = new String[args.length - 1];
System.arraycopy(args, 1, newArgs, 0, newArgs.length);
int rc = tool.run(newArgs);
assertTrue(0 == rc);
return rc;
}
示例5: getStreamPartitionConverterClass
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
/**
* Get the stream partition converter class.
*
* @return the stream partition converter class.
* @throws ConfigurationException
*/
public Class<? extends StreamPartitionConverter> getStreamPartitionConverterClass()
throws ConfigurationException {
return ReflectionUtils.getClass(
this,
SERVER_STREAM_PARTITION_CONVERTER_CLASS,
IdentityStreamPartitionConverter.class,
StreamPartitionConverter.class,
defaultLoader);
}
示例6: runCmd
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
void runCmd(CommandLine cmdline) throws IOException {
StatsProvider statsProvider = new NullStatsProvider();
if (cmdline.hasOption("p")) {
String providerClass = cmdline.getOptionValue("p");
statsProvider = ReflectionUtils.newInstance(providerClass, StatsProvider.class);
}
StatsReceiver statsReceiver = NullStatsReceiver.get();
final MonitorService monitorService = new MonitorService(
getOptionalStringArg(cmdline, "u"),
getOptionalStringArg(cmdline, "c"),
getOptionalStringArg(cmdline, "s"),
getOptionalIntegerArg(cmdline, "i"),
getOptionalIntegerArg(cmdline, "d"),
getOptionalStringArg(cmdline, "f"),
getOptionalIntegerArg(cmdline, "n"),
getOptionalIntegerArg(cmdline, "t"),
getOptionalIntegerArg(cmdline, "hck"),
getOptionalBooleanArg(cmdline, "hsci"),
getOptionalBooleanArg(cmdline, "w"),
statsReceiver,
statsProvider);
monitorService.runServer();
Runtime.getRuntime().addShutdownHook(new Thread() {
@Override
public void run() {
logger.info("Closing monitor service.");
monitorService.close();
logger.info("Closed monitor service.");
}
});
try {
monitorService.join();
} catch (InterruptedException ie) {
logger.warn("Interrupted when waiting monitor service to be finished : ", ie);
}
}
示例7: parseCommandLine
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
protected void parseCommandLine(String[] args)
throws Exception {
BasicParser parser = new BasicParser();
CommandLine cmdline = parser.parse(options, args);
if (cmdline.hasOption("h")) {
printUsage();
System.exit(0);
}
if (cmdline.hasOption("u")) {
this.uri = URI.create(cmdline.getOptionValue("u"));
} else {
printUsage();
System.exit(0);
}
this.conf = new DistributedLogConfiguration();
if (cmdline.hasOption("c")) {
String configFile = cmdline.getOptionValue("c");
this.conf.loadConf(new File(configFile).toURI().toURL());
}
if (cmdline.hasOption("p")) {
statsProvider = ReflectionUtils.newInstance(cmdline.getOptionValue("p"), StatsProvider.class);
} else {
statsProvider = new NullStatsProvider();
}
if (cmdline.hasOption("s")) {
this.streamName = cmdline.getOptionValue("s");
} else {
printUsage();
System.exit(0);
}
parseCommandLine(cmdline);
}
示例8: main
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
public static void main(String[] args) throws Exception {
if (args.length <= 0) {
System.err.println(USAGE);
return;
}
String benchmarkClassName = args[0];
StreamBenchmark benchmark = ReflectionUtils.newInstance(
benchmarkClassName, StreamBenchmark.class);
benchmark.run(args);
}
示例9: BrokerStarter
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
BrokerStarter(String[] args) throws Exception{
StarterArguments starterArguments = new StarterArguments();
JCommander jcommander = new JCommander(starterArguments);
jcommander.setProgramName("PulsarBrokerStarter");
// parse args by JCommander
jcommander.parse(args);
if (starterArguments.help) {
jcommander.usage();
System.exit(-1);
}
// init broker config and pulsar service
if (isBlank(starterArguments.brokerConfigFile)) {
jcommander.usage();
throw new IllegalArgumentException("Need to specify a configuration file for broker");
} else {
brokerConfig = loadConfig(starterArguments.brokerConfigFile);
pulsarService = new PulsarService(brokerConfig);
}
// if no argument to run bookie in cmd line, read from pulsar config
if (!argsContains(args, "-rb") && !argsContains(args, "--run-bookie")) {
checkState(starterArguments.runBookie == false,
"runBookie should be false if has no argument specified");
starterArguments.runBookie = brokerConfig.isEnableRunBookieTogether();
}
if (!argsContains(args, "-ra") && !argsContains(args, "--run-bookie-autorecovery")) {
checkState(starterArguments.runBookieAutoRecovery == false,
"runBookieAutoRecovery should be false if has no argument specified");
starterArguments.runBookieAutoRecovery = brokerConfig.isEnableRunBookieAutoRecoveryTogether();
}
if ((starterArguments.runBookie || starterArguments.runBookieAutoRecovery)
&& isBlank(starterArguments.bookieConfigFile)) {
jcommander.usage();
throw new IllegalArgumentException("No configuration file for Bookie");
}
// init stats provider
if (starterArguments.runBookie || starterArguments.runBookieAutoRecovery) {
checkState(isNotBlank(starterArguments.bookieConfigFile),
"No configuration file for Bookie");
bookieConfig = readBookieConfFile(starterArguments.bookieConfigFile);
Class<? extends StatsProvider> statsProviderClass = bookieConfig.getStatsProviderClass();
bookieStatsProvider = ReflectionUtils.newInstance(statsProviderClass);
} else {
bookieConfig = null;
bookieStatsProvider = null;
}
// init bookie server
if (starterArguments.runBookie) {
checkNotNull(bookieConfig, "No ServerConfiguration for Bookie");
checkNotNull(bookieStatsProvider, "No Stats Provider for Bookie");
bookieServer = new BookieServer(bookieConfig, bookieStatsProvider.getStatsLogger(""));
} else {
bookieServer = null;
}
// init bookie AutorecoveryMain
if (starterArguments.runBookieAutoRecovery) {
checkNotNull(bookieConfig, "No ServerConfiguration for Bookie Autorecovery");
autoRecoveryMain = new AutoRecoveryMain(bookieConfig);
} else {
autoRecoveryMain = null;
}
}
示例10: getFeatureProviderClass
import org.apache.bookkeeper.util.ReflectionUtils; //導入依賴的package包/類
/**
* Get feature provider class.
*
* @return feature provider class.
* @throws ConfigurationException
*/
public Class<? extends FeatureProvider> getFeatureProviderClass()
throws ConfigurationException {
return ReflectionUtils.getClass(this, BKDL_FEATURE_PROVIDER_CLASS, DefaultFeatureProvider.class,
FeatureProvider.class, FeatureProvider.class.getClassLoader());
}