hive的嵌入模式报错

配置conf/hive-site.xml

原来的内容:

 

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
            <?xml-stylesheet type="text/xsl" href="configuration.xsl"?>
            <configuration>             
                    <property>
                    <name>javax.jdo.option.ConnectionURL</name>
                    <value>jdbc:derby:;databaseName=metastore_db;create=true</value>
                    </property>    

                    <property>
                    <name>javax.jdo.option.ConnectionDriverName</name>
                    <value>org.apache.derby.jdbc.EmbeddedDriver</value>
                    </property>    

                    <property>
                    <name>hive.metastore.local</name>
                    <value>true</value>
                    </property>    

                    <property>
                    <name>hive.metastore.warehouse.dir</name>
                    <value>file:///root/training/apache-hive-2.3.0-bin/warehouse</value>
                    </property>        
            </configuration>    

 

[Fatal Error] hive-site.xml:2:6: The processing instruction target matching "[xX][mM][lL]" is not allowed.
Exception in thread "main" java.lang.RuntimeException: org.xml.sax.SAXParseException; systemId: file:/root/training/apache-hive-2.3.0-bin/conf/hive-site.xml; lineNumber: 2; columnNumber: 6; The processing instruction target matching "[xX][mM][lL]" is not allowed.
        at org.apache.hadoop.conf.Configuration.loadResource(Configuration.java:2348)
        at org.apache.hadoop.conf.Configuration.loadResources(Configuration.java:2205)
        at org.apache.hadoop.conf.Configuration.getProps(Configuration.java:2112)
        at org.apache.hadoop.conf.Configuration.get(Configuration.java:1078)
        at org.apache.hadoop.hive.conf.HiveConf.getVar(HiveConf.java:3901)
        at org.apache.hadoop.hive.conf.HiveConf.getVar(HiveConf.java:3970)
        at org.apache.hadoop.hive.conf.HiveConf.initialize(HiveConf.java:4057)
        at org.apache.hadoop.hive.conf.HiveConf.<init>(HiveConf.java:4005)
        at org.apache.hive.beeline.HiveSchemaTool.<init>(HiveSchemaTool.java:82)
        at org.apache.hive.beeline.HiveSchemaTool.main(HiveSchemaTool.java:1117)
        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.main(RunJar.java:212)
Caused by: org.xml.sax.SAXParseException; systemId: file:/root/training/apache-hive-2.3.0-bin/conf/hive-site.xml; lineNumber: 2; columnNumber: 6; The processing instruction target matching "[xX][mM][lL]" is not allowed.
        at org.apache.xerces.parsers.DOMParser.parse(Unknown Source)
        at org.apache.xerces.jaxp.DocumentBuilderImpl.parse(Unknown Source)
        at javax.xml.parsers.DocumentBuilder.parse(DocumentBuilder.java:150)
        at org.apache.hadoop.conf.Configuration.parse(Configuration.java:2183)
        at org.apache.hadoop.conf.Configuration.parse(Configuration.java:2171)
        at org.apache.hadoop.conf.Configuration.loadResource(Configuration.java:2239)
        ... 14 more
 

 

 

 

解决办法:修改conf/hive-site.xml为(即去掉头2行):

<configuration>             
                    <property>
                    <name>javax.jdo.option.ConnectionURL</name>
                    <value>jdbc:derby:;databaseName=metastore_db;create=true</value>
                    </property>    

                    <property>
                    <name>javax.jdo.option.ConnectionDriverName</name>
                    <value>org.apache.derby.jdbc.EmbeddedDriver</value>
                    </property>    

                    <property>
                    <name>hive.metastore.local</name>
                    <value>true</value>
                    </property>    

                    <property>
                    <name>hive.metastore.warehouse.dir</name>
                    <value>file:///root/training/apache-hive-2.3.0-bin/warehouse</value>
                    </property>        
            </configuration>    
 

Hive Metastore Canary报错时,这可能是由于以下几个原因造成的。 首先,检查Hive Metastore服务是否正常运行。可以通过查看日志文件或运行命令(如`systemctl status hive-metastore`或`service hive-metastore status`)来确定服务是否启动。如果服务未启动,可以尝试重新启动它并观察是否解决了问题。 其次,检查Hive Metastore配置文件是否正确。Hive Metastore的配置文件通常位于`/etc/hive/conf/hive-site.xml`路径下。确保配置文件中的所有属性和值都是正确的,并且与其他相关组件(如Hadoop)的配置相匹配。 另外,检查Hive Metastore连接的数据库是否可用。Hive Metastore使用数据库来存储元数据信息,例如表、分区和列等。确保数据库服务已启动,并且Metastore配置文件中的数据库连接属性正确设置。 此外,还要考虑Hive Metastore版本与其他组件的兼容性。如果使用的Hive Metastore版本与其他组件(如Hadoop、Spark等)不兼容,可能会导致Canary报错。在这种情况下,可以尝试升级或降级Hive Metastore版本,以与其他组件保持兼容性。 最后,如果以上方法都没有解决问题,可以尝试重启整个Hive集群。有时候,重启可以解决一些不明原因的故障。 综上所述,当Hive Metastore Canary报错时,我们可以通过检查Hive Metastore服务、配置文件、数据库连接以及版本兼容性来解决问题。如果以上方法都无效,我们可以尝试重启整个Hive集群。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值