es.davy.ai

Preguntas y respuestas de programación confiables

¿Tienes una pregunta?

Si tienes alguna pregunta, puedes hacerla a continuación o ingresar lo que estás buscando.

Hive no se está iniciando

Estoy tratando de iniciar Hive en mi sistema Linux. Da el siguiente error:

Excepción en el subproceso "main" java.lang.ExceptionInInitializerError
    at org.apache.hadoop.hive.ql.plan.TableDesc.setProperties(TableDesc.java:133)
    at org.apache.hadoop.hive.ql.plan.TableDesc.<init>(TableDesc.java:71)
    at org.apache.hadoop.hive.ql.plan.PlanUtils.getDefaultTableDesc(PlanUtils.java:458)
    at org.apache.hadoop.hive.ql.exec.Utilities.<clinit>(Utilities.java:681)
    at org.apache.hadoop.hive.ql.session.SessionState.createRootHDFSDir(SessionState.java:709)
    at org.apache.hadoop.hive.ql.session.SessionState.createSessionDirs(SessionState.java:654)
    at org.apache.hadoop.hive.ql.session.SessionState.start(SessionState.java:586)
    at org.apache.hadoop.hive.ql.session.SessionState.beginStart(SessionState.java:553)
    at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:750)
    at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:686)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:77)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:568)
    at org.apache.hadoop.util.RunJar.run(RunJar.java:323)
    at org.apache.hadoop.util.RunJar.main(RunJar.java:236)
Caused by: java.lang.reflect.InaccessibleObjectException: No se puede hacer que el campo privado volátil java.lang.String java.net.URI.string sea accesible: el módulo java.base no abre java.net a un módulo sin nombre @3e849b9e
    at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:354)
    at java.base/java.lang.reflect.AccessibleObject.checkCanSetAccessible(AccessibleObject.java:297)
    at java.base/java.lang.reflect.Field.checkCanSetAccessible(Field.java:178)
    at java.base/java.lang.reflect.Field.setAccessible(Field.java:172)
    at org.apache.hadoop.hive.common.StringInternUtils.<clinit>(StringInternUtils.java:57)
    ... 16 more

No puedo entender por qué está ocurriendo esto. Incluso cambié la versión de JAVA a 8 en mi sistema, pero el error persiste.

Tags:  ,

Answer

  1. Avatar for davy.ai

    Parece que el error es causado por un campo inaccesible en el módulo java.net.URI.string. Para solucionar este problema, puedes intentar los siguientes pasos:

    1. Verifica si has configurado las variables de entorno correctas para Hadoop y Hive.
    2. Verifica si has configurado la variable HADOOP_HOME. Si no lo has hecho, ajústala para que apunte a la carpeta raíz que contiene la instalación de Hadoop.

    3. Verifica si has configurado la variable HIVE_HOME. Si no lo has hecho, ajústala para que apunte a la carpeta raíz que contiene la instalación de Hive.

    4. Verifica si el classpath está configurado para incluir las librerías de Hadoop y Hive. Agrega las siguientes líneas a tu archivo .bashrc o .bash_profile:

    export HADOOP_CLASSPATH=$HADOOP_CLASSPATH:$HIVE_HOME/lib/*

    export HADOOP_USER_CLASSPATH_FIRST=true

    1. Verifica si tienes la versión correcta de Java instalada. Se recomienda usar Java 8 para Hive.
  2. Verifica si existen otras versiones de Java conflictivas en tu sistema. Elimina cualquier versión conflictiva de Java y configura la versión correcta como la versión predeterminada.

  3. Verifica si los permisos están configurados correctamente para las carpetas de Hadoop y Hive. Asegúrate de tener permisos de lectura y escritura para las carpetas.

  4. Intenta reinstalar Hive y Hadoop, y sigue cuidadosamente las instrucciones de instalación.

  5. Si ninguna de estas soluciones funciona, puedes intentar buscar otras soluciones en línea o consultar a un experto en Hadoop o Hive.

Comments are closed.