you need to package hdfs-site.xml and core-site.xml  from your hadoop
cluster as part of your topology jar.
http://docs.hortonworks.com/HDPDocuments/HDP2/HDP-2.3.0/bk_storm-user-guide/content/storm-connectors-secure.html

-Harsha


On Thu, Dec 24, 2015, at 08:48 PM, Raja.Aravapalli wrote:
>
>
>
Hi,
>
>
I am getting below exception when i am trying to write tuples into HDFS
which is in a secured Hadoop cluster. Can someone pls share your
thoughts and help me fix the issue
>
> *Exception: *


> *---------------*


> java.lang.RuntimeException: Error preparing HdfsBolt:
> java.net.UnknownHostException: <HOSTNAME> at
 org.apache.storm.hdfs.bolt.AbstractHdfsBolt.prepare(AbstractHdfsBolt.j-
 ava:111) at backtype.storm.daemon.executor$fn__5265$fn__5278.invoke(ex-
 ecutor.clj:732) at
 backtype.storm.util$async_loop$fn__551.invoke(util.clj:463) at
 clojure.lang.AFn.run(AFn.java:24) at
 java.lang.Thread.run(Thread.java:744) Caused by:
 java.lang.IllegalArgumentException: java.net.UnknownHostException:
 <HOSTNAME> at org.apache.hadoop.security.SecurityUtil.buildTokenServic-
 e(SecurityUtil.java:374) at org.apache.hadoop.hdfs.NameNodeProxies.cre-
 ateNonHAProxy(NameNodeProxies.java:312) at org.apache.hadoop.hdfs.Name-
 NodeProxies.createProxy(NameNodeProxies.java:178) at
 org.apache.hadoop.hdfs.DFSClient.<init>(DFSClient.java:665) at
 org.apache.hadoop.hdfs.DFSClient.<init>(DFSClient.java:601) at org.apa-
 che.hadoop.hdfs.DistributedFileSystem.initialize(DistributedFileSystem-
 .java:148) at
 org.apache.hadoop.fs.FileSystem.createFileSystem(FileSystem.java:2619)
 at org.apache.hadoop.fs.FileSystem.access$200(FileSystem.java:91) at
 org.apache.hadoop.fs.FileSystem$Cache.getInternal(FileSystem.java:2653)
 at org.apache.hadoop.fs.FileSystem$Cache.get(FileSystem.java:2635) at
 org.apache.hadoop.fs.FileSystem.get(FileSystem.java:370) at
 org.apache.storm.hdfs.bolt.HdfsBolt.doPrepare(HdfsBolt.java:87) at org-
 .apache.storm.hdfs.bolt.AbstractHdfsBolt.prepare(AbstractHdfsBolt.java-
 :107) ... 4 more Caused by: java.net.UnknownHostException: <HOSTNAME>
 ... 17 more


>


>


> *Code* *-------* HdfsBolt hdfsbolt = *new *HdfsBolt()
>
.withFsUrl(*"hdfs://NAMENODESERVICEID"*)
>
.withFileNameFormat(fileNameFormat)
>
.withRecordFormat(format)
>
.withRotationPolicy(rotationPolicy)
>
.withSyncPolicy(syncPolicy)
>
.withConfigKey(*"hdfs.config**”*);
>
> Map<String, Object> map = new HashMap<String, Object>();
> map.put("hdfs.keytab.file", “PATH_TO_KEYTAB");
> map.put("hdfs.kerberos.principal", “PRINCIPAL");
>
> Config config = new Config(); config.setDebug(true);
> config.put(HdfsSecurityUtil.STORM_KEYTAB_FILE_KEY, “PATH_TO_KEYTAB");
> config.put(HdfsSecurityUtil.STORM_USER_NAME_KEY, "PRINCIPAL");
> config.put("hdfs.config", map);
>
> StormTopology topology = builder.createTopology();
> StormSubmitter.submitTopology(“<TOPOLOGY_NAME>", config, topology);
>
> *POM.xml* *——————*
>
> <?xml version="1.0" encoding="UTF-8"?> <project xmlns="
> http://maven.apache.org/POM/4.0.0"         xmlns:xsi="
> http://www.w3.org/2001/XMLSchema-instance"         xsi:schemaLocation="
> http://maven.apache.org/POM/4.0.0
> http://maven.apache.org/xsd/maven-4.0.0.xsd";>
> <modelVersion>4.0.0</modelVersion>
>
> <groupId>GROUPID</groupId>    <artifactId>ARTIFACTID</artifactId>
> <version>1.0-SNAPSHOT</version>
>
> <properties>        <storm.version>0.9.3.2.2.4.0-2633</storm.version>
> <hadoop.version>2.6.0.2.2.4.12-2</hadoop.version>    </properties>
>
> <dependencies>        <dependency>
> <groupId>org.apache.storm</groupId>            <artifactId>storm-
> core</artifactId>            <version>${storm.version}</version>
> <scope>provided</scope>        </dependency>
>
> <dependency>            <groupId>org.apache.storm</groupId>
> <artifactId>storm-hdfs</artifactId>
> <version>${storm.version}</version>            <scope>compile</scope>
> <exclusions>                <exclusion>
> <groupId>org.apache.hadoop</groupId>                    <artifactId>hadoop-
> client</artifactId>                </exclusion>
> <exclusion>                    <groupId>org.apache.hadoop</groupId>
> <artifactId>hadoop-hdfs</artifactId>                </exclusion>
> <exclusion>                    <groupId>log4j</groupId>
> <artifactId>log4j</artifactId>                </exclusion>
> <exclusion>                    <groupId>org.slf4j</groupId>
> <artifactId>slf4j-log4j12</artifactId>                </exclusion>
> </exclusions>        </dependency>
>
> <dependency>            <groupId>org.apache.hadoop</groupId>
> <artifactId>hadoop-hdfs</artifactId>
> <version>${hadoop.version}</version>            <scope>compile</scope>
> <exclusions>                <exclusion>
> <groupId>log4j</groupId>
> <artifactId>log4j</artifactId>                </exclusion>
> <exclusion>                    <groupId>org.slf4j</groupId>
> <artifactId>slf4j-log4j12</artifactId>                </exclusion>
> </exclusions>        </dependency>
>
> <dependency>            <groupId>org.apache.hadoop</groupId>
> <artifactId>hadoop-client</artifactId>
> <version>${hadoop.version}</version>            <scope>compile</scope>
> <exclusions>                <exclusion>
> <groupId>log4j</groupId>
> <artifactId>log4j</artifactId>                </exclusion>
> <exclusion>                    <groupId>org.slf4j</groupId>
> <artifactId>slf4j-log4j12</artifactId>                </exclusion>
> </exclusions>        </dependency>
>
> </dependencies>
>
> <repositories>        <repository>            <id>HDPReleases</id>
> <name>HDP Releases</name>            <url>
> http://repo.hortonworks.com/content/repositories/releases/</url>
> <layout>default</layout>        </repository>        <repository>
> <id>HDP Jetty Hadoop</id>            <name>HDP Jetty Hadoop</name>
> <url>
> http://repo.hortonworks.com/content/repositories/jetty-hadoop/</url>
> <layout>default</layout>        </repository>        <repository>
> <id>confluent</id>            <url>
> http://packages.confluent.io/maven</url>        </repository>
> </repositories>
>
> <build>        <plugins>            <plugin>
> <groupId>org.apache.maven.plugins</groupId>                
> <artifactId>maven-compiler-
> plugin</artifactId>                <version>2.5.1</version>
> <configuration>                    <source>1.7</source>
> <target>1.7</target>                </configuration>
> </plugin>            <plugin>
> <groupId>org.apache.maven.plugins</groupId>                
> <artifactId>maven-shade-
> plugin</artifactId>                <version>2.4.2</version>
> <configuration>                    <createDependencyReducedPom>true</-
> createDependencyReducedPom>                </configuration>
> <executions>                    <execution>
> <phase>package</phase>                        <goals>
> <goal>shade</goal>                        </goals>
> <configuration>                            <transformers>
> <transformer implementation="org.apache.maven.plugins.shade.resource.-
> ServicesResourceTransformer" />
> <transformer implementation="org.apache.maven.plugins.shade.resource.-
> ManifestResourceTransformer">
> <mainClass>xml</mainClass>
> </transformer>                            </transformers>
> <filters>                                <filter>
> <artifact>*:*</artifact>                                    <excludes>
> <exclude>META-INF/*.SF</exclude>
> <exclude>META-INF/*.DSA</exclude>
> <exclude>META-INF/*.RSA</exclude>
> </excludes>                                </filter>
> </filters>                        </configuration>
> </execution>                </executions>            </plugin>
> </plugins>    </build> </project>
>
>
> --Raja.
>

Reply via email to