YARN-8223. Improved yarn auxiliary service to load jar file from HDFS.

Contributed by Zian Chen
This commit is contained in:
Eric Yang 2018-05-04 12:36:31 -04:00
parent 6795f8072f
commit 8cdb032aff
2 changed files with 61 additions and 2 deletions

View File

@ -67,6 +67,50 @@ The collector class configuration may specify a comma-separated list of collecto
|:---- |:---- |:---- | |:---- |:---- |:---- |
| `yarn.nodemanager.aux-services` | `...,mapreduce_shuffle` | The auxiliary service name | | `yarn.nodemanager.aux-services` | `...,mapreduce_shuffle` | The auxiliary service name |
| `yarn.nodemanager.aux-services.mapreduce_shuffle.class` | `org.apache.hadoop.mapred.ShuffleHandler` | The auxiliary service class to use | | `yarn.nodemanager.aux-services.mapreduce_shuffle.class` | `org.apache.hadoop.mapred.ShuffleHandler` | The auxiliary service class to use |
| `yarn.nodemanager.aux-services.%s.classpath` | NONE | local directory which includes the related jar file as well as all the dependencies jar file. We could specify the single jar file or use /dep/* to load all jars under the dep directory. |
| `yarn.nodemanager.aux-services.%s.remote-classpath` | NONE | The remote absolute or relative path to jar file |
#### Example of loading jar file from HDFS:
```xml
<configuration>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle,AuxServiceFromHDFS</value>
</property>
<property>
<name>yarn.nodemanager.aux-services.AuxServiceFromHDFS.remote-classpath</name>
<value>/aux/test/aux-service-hdfs.jar</value>
</property>
<property>
<name>yarn.nodemanager.aux-services.AuxServiceFromHDFS.class&lt;/name>
<value>org.apache.auxtest.AuxServiceFromHDFS2</value>
</property>
</configuration>
```
#### Example of loading jar file from local file system:
```xml
<configuration>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle,AuxServiceFromHDFS</value>
</property>
<property>
<name>yarn.nodemanager.aux-services.AuxServiceFromHDFS.classpath</name>
<value>/aux/test/aux-service-hdfs.jar</value>
</property>
<property>
<name>yarn.nodemanager.aux-services.AuxServiceFromHDFS.class&lt;/name>
<value>org.apache.auxtest.AuxServiceFromHDFS2</value>
</property>
</configuration>
```
**IMPORTANT:** If setting an auxiliary service in addition the default **IMPORTANT:** If setting an auxiliary service in addition the default
`mapreduce_shuffle` service, then a new service key should be added to the `mapreduce_shuffle` service, then a new service key should be added to the

View File

@ -230,15 +230,30 @@ public class AuxServices extends AbstractService
} }
} }
if (reDownload) { if (reDownload) {
LocalResourceType srcType = null;
String lowerDst = StringUtils.toLowerCase(src.toString());
if (lowerDst.endsWith(".jar")) {
srcType = LocalResourceType.FILE;
} else if (lowerDst.endsWith(".zip") ||
lowerDst.endsWith(".tar.gz") || lowerDst.endsWith(".tgz")
|| lowerDst.endsWith(".tar")) {
srcType = LocalResourceType.ARCHIVE;
} else {
throw new YarnRuntimeException(
"Can not unpack file from remote-file-path:" + src
+ "for aux-service:" + ".\n");
}
LocalResource scRsrc = LocalResource.newInstance( LocalResource scRsrc = LocalResource.newInstance(
URL.fromURI(src.toUri()), URL.fromURI(src.toUri()),
LocalResourceType.ARCHIVE, LocalResourceVisibility.PRIVATE, srcType, LocalResourceVisibility.PRIVATE,
scFileStatus.getLen(), scFileStatus.getModificationTime()); scFileStatus.getLen(), scFileStatus.getModificationTime());
FSDownload download = new FSDownload(localLFS, null, conf, FSDownload download = new FSDownload(localLFS, null, conf,
downloadDest, scRsrc, null); downloadDest, scRsrc, null);
try { try {
Path downloaded = download.call(); Path downloaded = download.call();
dest = new Path(downloaded + Path.SEPARATOR + "*"); // don't need to convert downloaded path into a dir
// since its already a jar path.
dest = downloaded;
} catch (Exception ex) { } catch (Exception ex) {
throw new YarnRuntimeException( throw new YarnRuntimeException(
"Exception happend while downloading files " "Exception happend while downloading files "