2017-05-04 69 views
0

我在Mac OS上安裝了hadoop和配置單元。我能夠毫無問題地推出hadoop和紗線。我可以運行hadoop fs相關命令來操作hdfs上的文件。但是我沒有啓動配置單元進程,並且出現錯誤。無法啓動配置單元

$ hive 
SLF4J: Class path contains multiple SLF4J bindings. 
SLF4J: Found binding in [jar:file:/usr/local/Cellar/hive/2.1.0/libexec/lib/log4j-slf4j-impl-2.4.1.jar!/org/slf4j/impl/StaticLoggerBinder.class] 
SLF4J: Found binding in [jar:file:/usr/local/Cellar/hadoop/2.8.0/libexec/share/hadoop/common/lib/slf4j-log4j12-1.7.10.jar!/org/slf4j/impl/StaticLoggerBinder.class] 
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation. 
SLF4J: Actual binding is of type [org.apache.logging.slf4j.Log4jLoggerFactory] 

Logging initialized using configuration in jar:file:/usr/local/Cellar/hive/2.1.0/libexec/lib/hive-common-2.1.0.jar!/hive-log4j2.properties Async: true 
Exception in thread "main" java.lang.IllegalArgumentException: java.net.URISyntaxException: Relative path in absolute URI: ${system:java.io.tmpdir%7D/$%7Bhive.session.id%7D_resources 
    at org.apache.hadoop.fs.Path.initialize(Path.java:254) 
    at org.apache.hadoop.fs.Path.<init>(Path.java:212) 
    at org.apache.hadoop.hive.ql.session.SessionState.createSessionDirs(SessionState.java:634) 
    at org.apache.hadoop.hive.ql.session.SessionState.start(SessionState.java:550) 
    at org.apache.hadoop.hive.ql.session.SessionState.beginStart(SessionState.java:518) 
    at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:705) 
    at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:641) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at org.apache.hadoop.util.RunJar.run(RunJar.java:234) 
    at org.apache.hadoop.util.RunJar.main(RunJar.java:148) 
Caused by: java.net.URISyntaxException: Relative path in absolute URI: ${system:java.io.tmpdir%7D/$%7Bhive.session.id%7D_resources 
    at java.net.URI.checkPath(URI.java:1823) 
    at java.net.URI.<init>(URI.java:745) 
    at org.apache.hadoop.fs.Path.initialize(Path.java:251) 
    ... 12 more 

我是hive的新手,不確定我該在哪看。我如何解決上述問題?

回答

0

你可以嘗試在你的hive-site.xml

<property> 
    <name>system:java.io.tmpdir</name> 
    <value>/tmp/hive/java</value> 
</property> 

頂級目錄添加此或改變一些/tmp/mydir及其在Configuring Hive

告訴