You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@reef.apache.org by ju...@apache.org on 2015/07/02 04:42:06 UTC

incubator-reef git commit: [REEF-438]:Add a Java example for demonstrating TcpProvider with YARN environment.

Repository: incubator-reef
Updated Branches:
  refs/heads/master 6bbc775fb -> 26156627e


[REEF-438]:Add a Java example for demonstrating TcpProvider with YARN environment.

This addressed the issue by adding an example for demonstrating
TcpProvider usage with YARN environment.

JIRA: [REEF-438](https://issues.apache.org/jira/browse/REEF-438)

This closes #268

Author:    Beysim Sezgin <be...@microsoft.com>


Project: http://git-wip-us.apache.org/repos/asf/incubator-reef/repo
Commit: http://git-wip-us.apache.org/repos/asf/incubator-reef/commit/26156627
Tree: http://git-wip-us.apache.org/repos/asf/incubator-reef/tree/26156627
Diff: http://git-wip-us.apache.org/repos/asf/incubator-reef/diff/26156627

Branch: refs/heads/master
Commit: 26156627ed29abeb522085e41fafbaf75edb97de
Parents: 6bbc775
Author: Beysim Sezgin <be...@microsoft.com>
Authored: Wed Jul 1 14:28:46 2015 -0700
Committer: Julia Wang <jw...@yahoo.com>
Committed: Wed Jul 1 19:34:57 2015 -0700

----------------------------------------------------------------------
 .../reef/examples/hello/HelloReefYarnTcp.java   | 94 ++++++++++++++++++++
 1 file changed, 94 insertions(+)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/incubator-reef/blob/26156627/lang/java/reef-examples/src/main/java/org/apache/reef/examples/hello/HelloReefYarnTcp.java
----------------------------------------------------------------------
diff --git a/lang/java/reef-examples/src/main/java/org/apache/reef/examples/hello/HelloReefYarnTcp.java b/lang/java/reef-examples/src/main/java/org/apache/reef/examples/hello/HelloReefYarnTcp.java
new file mode 100644
index 0000000..fa6c46a
--- /dev/null
+++ b/lang/java/reef-examples/src/main/java/org/apache/reef/examples/hello/HelloReefYarnTcp.java
@@ -0,0 +1,94 @@
+/*
+ * 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.reef.examples.hello;
+
+import org.apache.reef.client.DriverConfiguration;
+import org.apache.reef.client.DriverLauncher;
+import org.apache.reef.client.LauncherStatus;
+import org.apache.reef.client.parameters.DriverConfigurationProviders;
+import org.apache.reef.io.TcpPortConfigurationProvider;
+import org.apache.reef.runtime.yarn.client.YarnClientConfiguration;
+import org.apache.reef.tang.Configuration;
+import org.apache.reef.tang.Tang;
+import org.apache.reef.tang.exceptions.InjectionException;
+import org.apache.reef.wake.remote.ports.parameters.TcpPortRangeBegin;
+import org.apache.reef.wake.remote.ports.parameters.TcpPortRangeCount;
+import org.apache.reef.wake.remote.ports.parameters.TcpPortRangeTryCount;
+
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+/**
+ * The Client for Hello REEF example.
+ */
+public final class HelloReefYarnTcp {
+
+  private static final Logger LOG = Logger.getLogger(HelloReefYarnTcp.class.getName());
+
+  /**
+   * Number of milliseconds to wait for the job to complete.
+   */
+  private static final int JOB_TIMEOUT = 150000; // 30 sec.
+
+  private HelloReefYarnTcp(){}
+  /**
+   * @return the configuration of the HelloREEF driver.
+   */
+  private static Configuration getDriverConfiguration() {
+    return DriverConfiguration.CONF
+        .set(DriverConfiguration.GLOBAL_LIBRARIES, HelloReefYarnTcp.class.getProtectionDomain().getCodeSource().getLocation().getFile())
+        .set(DriverConfiguration.DRIVER_IDENTIFIER, "HelloREEF")
+        .set(DriverConfiguration.ON_DRIVER_STARTED, HelloDriver.StartHandler.class)
+        .set(DriverConfiguration.ON_EVALUATOR_ALLOCATED, HelloDriver.EvaluatorAllocatedHandler.class)
+        .build();
+  }
+
+  private static Configuration getRuntimeConfiguration(
+      int tcpBeginPort,
+      int tcpRangeCount,
+      int tcpTryCount) {
+
+    return Tang.Factory.getTang().newConfigurationBuilder(YarnClientConfiguration.CONF.build())
+        .bindSetEntry(DriverConfigurationProviders.class, TcpPortConfigurationProvider.class)
+        .bindNamedParameter(TcpPortRangeBegin.class, Integer.toString(tcpBeginPort))
+        .bindNamedParameter(TcpPortRangeCount.class, Integer.toString(tcpRangeCount))
+        .bindNamedParameter(TcpPortRangeTryCount.class, Integer.toString(tcpTryCount))
+        .build();
+  }
+
+  /**
+   * Start Hello REEF job. Runs method runHelloReef().
+   * @param args command line parameters.
+   * @throws org.apache.reef.tang.exceptions.BindException      configuration error.
+   * @throws org.apache.reef.tang.exceptions.InjectionException configuration error.
+   */
+  public static final int defaultTcpBeginPort = 8900;
+  public static final int defaultTcpRangeCount = 10;
+  public static final int defaultTcpRangeTryCount = 1111;
+  public static void main(final String[] args) throws InjectionException {
+    final int tcpBeginPort = args.length > 0 ? Integer.valueOf(args[0]) : defaultTcpBeginPort;
+    final int tcpRangeCount = args.length > 1 ? Integer.valueOf(args[1]) : defaultTcpRangeCount;
+    final int tcpTryCount = args.length > 2 ? Integer.valueOf(args[2]) : defaultTcpRangeTryCount;
+    Configuration runtimeConfiguration = getRuntimeConfiguration(tcpBeginPort, tcpRangeCount, tcpTryCount);
+    final LauncherStatus status = DriverLauncher
+        .getLauncher(runtimeConfiguration)
+        .run(getDriverConfiguration(), JOB_TIMEOUT);
+    LOG.log(Level.INFO, "REEF job completed: {0}", status);
+  }
+}