2015-05-12 6 views
5

Ich benutze Maven für mein Projekt. Wenn ich ein Programm ausführe, erhalte ich diesen Fehler, und deshalb kann ich den Fortschritt meiner Programmausführung nicht sehen, obwohl das Programm erwartete Ausgaben erzeugt.Log4j Es konnten keine Appender für den Logger gefunden werden (org.apache.hadoop.util.shell)

[email protected]:~/CCHD&CCHA/mangoes$ mvn exec:java -q -Dexec.mainClass=bananas.MapReduceColorCount -Dexec.args="hdfs://localhost:9000/users.avrofile hdfs://localhost:9000/pleaseatleastnow6" 
log4j:WARN No appenders could be found for logger (org.apache.hadoop.util.Shell). 
log4j:WARN Please initialize the log4j system properly. 
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info. 
[email protected]:~/CCHD&CCHA/mangoes$ 

Hier ist meine pom.xml

<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>fruits</groupId> 
    <artifactId>mangoes</artifactId> 
    <version>0.0.1-SNAPSHOT</version> 
    <name>Hadoop</name> 
    <description>Hadoop 
Hadoop</description> 
<dependencies> 
<dependency> 
    <groupId>org.apache.avro</groupId> 
    <artifactId>avro</artifactId> 
    <version>1.7.6</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.avro</groupId> 
    <artifactId>avro-mapred</artifactId> 
    <version>1.7.6</version> 
    <classifier>hadoop2</classifier> 
</dependency> 
<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-yarn-api</artifactId> 
    <version>2.6.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-common</artifactId> 
    <version>2.6.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-hdfs</artifactId> 
    <version>2.6.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-mapreduce-client-app</artifactId> 
    <version>2.6.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-mapreduce-client-common</artifactId> 
    <version>2.6.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-yarn-client</artifactId> 
    <version>2.6.0</version> 
</dependency> 

<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-client</artifactId> 
    <version>2.6.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-mapreduce-client-core</artifactId> 
    <version>2.6.0</version> 
</dependency> 
<dependency> 
    <groupId>org.apache.hadoop</groupId> 
    <artifactId>hadoop-yarn-common</artifactId> 
    <version>2.6.0</version> 
</dependency> 
</dependencies> 

<build> 
<pluginManagement> 
    <plugins> 
     <plugin> 
     <groupId>org.apache.maven.plugins</groupId> 
     <artifactId>maven-compiler-plugin</artifactId> 
     <version>3.3</version> 
     <configuration> 
      <source>1.7</source> 
      <target>1.7</target> 
     </configuration> 
     </plugin> 
     <plugin> 
    <groupId>org.apache.avro</groupId> 
    <artifactId>avro-maven-plugin</artifactId> 
    <version>1.7.6</version> 
    <executions> 
    <execution> 
     <phase>generate-sources</phase> 
     <goals> 
     <goal>schema</goal> 
     </goals> 
     <configuration> 
     <sourceDirectory>${project.basedir}/../</sourceDirectory> 
     <outputDirectory>${project.basedir}/target/generated-sources/</outputDirectory> 
     </configuration> 
    </execution> 
    </executions> 
</plugin> 
    </plugins> 
    </pluginManagement> 
    </build> 

</project> 

bin ich eine Abhängigkeit fehlt? Wie/Wo konfiguriere ich log4j richtig? Danke im Voraus. Ich würde etwas Hilfe schätzen.

+0

Zuerst ist es kein Fehler, sondern nur eine Warnung; Trotzdem eine wichtige Warnung. –

+0

Ok. Aber ich möchte den Fortschritt der Ausführung sehen. Wie entferne ich diese Warnung? –

+0

@SrimanthDuggineni, stellen Sie sicher, dass Sie die Datei log4j.properties im Klassenpfad platziert haben. – sureshsiva

Antwort

5

Für Maven Sie in main/resources Ordner mit den log4j.properties oder log4j.xml Datei setzen müssen. das ist es. nichts weiter zu tun. Erstellen Sie eine eigene Eigenschaftendatei. Etwas wie das.

log4j.rootLogger=DEBUG, CA 

log4j.appender.CA=org.apache.log4j.ConsoleAppender 

log4j.appender.CA.layout=org.apache.log4j.PatternLayout 
log4j.appender.CA.layout.ConversionPattern=%-4r [%t] %-5p %c %x - %m%n 

Sie geben INFO, ERROR, WARNING, FATAL und DEBUG auf die log4j.rootLogger Eigenschaft. Ersetzen Sie das Debug mit dem Protokoll, das für Ihre Anforderungen am besten geeignet ist.

+0

Ich gab DEBUG der Eigenschaft log4j.rootLogger, legte die Datei in main/resources und dann das Projekt erfüllt. Jetzt kann ich alle DEBUG-Nachrichten :) Es funktionierte wie Charme –

1

Folgen Sie der in der Warnung angegebenen URL. Es wird einige Leitinformationen gegeben.

http://logging.apache.org/log4j/1.2/faq.html#noconfig 

Von der Website:

Dies geschieht, wenn die Standard-Konfigurationsdateien log4j.properties und log4j.xml nicht gefunden werden kann und die Anwendung führt keine explizite Konfiguration. log4j verwendet Thread.getContextClassLoader(). getResource() , um die Standardkonfigurationsdateien zu finden, und überprüft das Dateisystem nicht direkt auf . Wenn Sie den entsprechenden Speicherort für log4j.properties oder log4j.xml kennen, müssen Sie die Suchstrategie des verwendeten Klassenladeprogramms kennen. log4j bietet keine Standardkonfiguration , da die Ausgabe auf die Konsole oder das Dateisystem in einigen Umgebungen möglicherweise verboten ist.

Sie benötigen entweder ein log4j.properties oder log4j.xml. Konstruieren Sie entweder das, was am besten zu Ihnen passt. Lesen Sie die Log4J manua l geben Ihnen einige Kenntnisse, um die Konfigurationsdatei zu konstruieren