CDH5.x配置spark错误解决

 

通过cloudera manager 5.x添加spark服务,在创建服务过程中,发现spark服务创建失败,可以通过控制台错误输出看到如下日志信息:

+ perl -pi -e 's#{{CMF_CONF_DIR}}#/etc/spark/conf.cloudera.spark_on_yarn/yarn-conf#g' /opt/cm-5.9.2/run/cloudera-scm-agent/process/ccdeploy_spark-conf_etcsparkconf.cloudera.spark_on_yarn_1615663591259519890/spark-conf/yarn-conf/yarn-site.xml

++ get_default_fs /opt/cm-5.9.2/run/cloudera-scm-agent/process/ccdeploy_spark-conf_etcsparkconf.cloudera.spark_on_yarn_1615663591259519890/spark-conf/yarn-conf

++ get_hadoop_conf /opt/cm-5.9.2/run/cloudera-scm-agent/process/ccdeploy_spark-conf_etcsparkconf.cloudera.spark_on_yarn_1615663591259519890/spark-conf/yarn-conf fs.defaultFS

++ local conf=/opt/cm-5.9.2/run/cloudera-scm-agent/process/ccdeploy_spark-conf_etcsparkconf.cloudera.spark_on_yarn_1615663591259519890/spark-conf/yarn-conf

++ local key=fs.defaultFS

++ '[' 1 == 1 ']'

++ /opt/cloudera/parcels/CDH-5.9.2-1.cdh5.9.2.p0.3/lib/hadoop/../../bin/hdfs --config /opt/cm-5.9.2/run/cloudera-scm-agent/process/ccdeploy_spark-conf_etcsparkconf.cloudera.spark_on_yarn_1615663591259519890/spark-conf/yarn-conf getconf -confKey fs.defaultFS

Exception in thread "main" java.lang.UnsupportedClassVersionError: org/apache/hadoop/hdfs/tools/GetConf : Unsupported major.minor version 51.0

at java.lang.ClassLoader.defineClass1(Native Method)

at java.lang.ClassLoader.defineClass(ClassLoader.java:643)

at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)

at java.net.URLClassLoader.defineClass(URLClassLoader.java:277)

at java.net.URLClassLoader.access$000(URLClassLoader.java:73)

at java.net.URLClassLoader$1.run(URLClassLoader.java:212)

at java.security.AccessController.doPrivileged(Native Method)

at java.net.URLClassLoader.findClass(URLClassLoader.java:205)

at java.lang.ClassLoader.loadClass(ClassLoader.java:323)

at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)

at java.lang.ClassLoader.loadClass(ClassLoader.java:268)

Could not find the main class: org.apache.hadoop.hdfs.tools.GetConf. Program will exit.

+ DEFAULT_FS=

根据输出日志信息大致可以判断这是因为jdk版本导致的添加spark服务失败。因为这是我全权安装的环境,所以印象中jdk版本是满足cm5安装要求的,我这里使用的是jdk1.7.0_67,如下:

# java -version

java version "1.7.0_67"

Java(TM) SE Runtime Environment (build 1.7.0_67-b01)

Java HotSpot(TM) 64-Bit Server VM (build 24.65-b04, mixed mode)

You have new mail in /var/spool/mail/root

针对于目前java版本并没有问题,满足当前安装的cm5版本要求。所以判断可能是因为我是通过tar包方式安装的java的原因,正常通过rpm包安装应该没有这个问题。下面验证自己的猜测:

这里使用alternatives命令,alternatives命令通常用来管理服务器上的相同软件多版本问题。

--查看服务器java版本,发现jdk1.7.0_67没有再服务器管理之下:

[root@db01 ~]# alternatives --config java

There are 2 programs which provide 'java'.

  Selection    Command

-----------------------------------------------

   1           /usr/lib/jvm/jre-1.5.0-gcj/bin/java

*+ 2           /usr/lib/jvm/jre-1.6.0-openjdk.x86_64/bin/java

Enter to keep the current selection[+], or type selection number:

--将jdk1.7.0_67添加到服务器管理中:

[root@db01 ~]# alternatives --install /usr/bin/java java /opt/java/jdk1.7.0_67/bin/java 3

--再次查看服务器java版本信息,并且调整优先级最高的为jdk1.7.0_67:

[root@db01 ~]# alternatives --config java

There are 3 programs which provide 'java'.

  Selection    Command

-----------------------------------------------

   1           /usr/lib/jvm/jre-1.5.0-gcj/bin/java

*+ 2           /usr/lib/jvm/jre-1.6.0-openjdk.x86_64/bin/java

   3           /opt/java/jdk1.7.0_67/bin/java

Enter to keep the current selection[+], or type selection number: 3

[root@db01 ~]# alternatives --config java

There are 3 programs which provide 'java'.

  Selection    Command

-----------------------------------------------

   1           /usr/lib/jvm/jre-1.5.0-gcj/bin/java

*  2           /usr/lib/jvm/jre-1.6.0-openjdk.x86_64/bin/java

+ 3           /opt/java/jdk1.7.0_67/bin/java

Enter to keep the current selection[+], or type selection number:

调整java版本信息后,再次添加spark服务,成功。

或者卸载原生的java版本,如:

# rpm -e java-1.5.0-gcj-1.5.0.0-29.1.el6.x86_64 java-1.6.0-openjdk-1.6.0.0-1.66.1.13.0.el6.x86_64 tzdata-java-2013g-1.el6.noarch java_cup-0.10k-5.el6.x86_64 java-1.6.0-openjdk-devel-1.6.0.0-1.66.1.13.0.el6.x86_64 gcc-java-4.4.7-4.el6.x86_64 --nodeps

 

如果以上方法不可用,采用以下方法,直接指定环境变量:

find / -type f -name "*cc.sh"
定位到/opt/program/cm-5.9.0/lib64/cmf/service/client/deploy-cc.sh

直接在上面加上

JAVA_HOME=/opt/java
export JAVA_HOME=/opt/java

 

===========================

ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/avro-tools /etc/alternatives/avro-tools
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/beeline /etc/alternatives/beeline
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/bigtop-detect-javahome /etc/alternatives/bigtop-detect-javahome
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/catalogd /etc/alternatives/catalogd
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/cli_mt /etc/alternatives/cli_mt
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/cli_st /etc/alternatives/cli_st
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/flume-ng /etc/alternatives/flume-ng
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hadoop /etc/alternatives/hadoop
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hadoop-0.20 /etc/alternatives/hadoop-0.20
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hadoop-fuse-dfs /etc/alternatives/hadoop-fuse-dfs
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hbase /etc/alternatives/hbase
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hbase-indexer /etc/alternatives/hbase-indexer
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hcat /etc/alternatives/hcat
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hdfs /etc/alternatives/hdfs
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hive /etc/alternatives/hive
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/hiveserver2 /etc/alternatives/hiveserver2
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/impala-collect-minidumps /etc/alternatives/impala-collect-minidumps
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/impalad /etc/alternatives/impalad
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/impala-shell /etc/alternatives/impala-shell
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/kite-dataset /etc/alternatives/kite-dataset
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/llama /etc/alternatives/llama
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/llamaadmin /etc/alternatives/llamaadmin
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/load_gen /etc/alternatives/load_gen
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/mahout /etc/alternatives/mahout
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/mapred /etc/alternatives/mapred
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/oozie /etc/alternatives/oozie
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/parquet-tools /etc/alternatives/parquet-tools
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/pig /etc/alternatives/pig
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/pyspark /etc/alternatives/pyspark
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sentry /etc/alternatives/sentry
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/solrctl /etc/alternatives/solrctl
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/spark-shell /etc/alternatives/spark-shell
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/spark-submit /etc/alternatives/spark-submit
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop /etc/alternatives/sqoop
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop2 /etc/alternatives/sqoop2
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-codegen /etc/alternatives/sqoop-codegen
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-create-hive-table /etc/alternatives/sqoop-create-hive-table
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-eval /etc/alternatives/sqoop-eval
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-export /etc/alternatives/sqoop-export
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-help /etc/alternatives/sqoop-help
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-import /etc/alternatives/sqoop-import
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-import-all-tables /etc/alternatives/sqoop-import-all-tables
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-job /etc/alternatives/sqoop-job
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-list-databases /etc/alternatives/sqoop-list-databases
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-list-tables /etc/alternatives/sqoop-list-tables
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-merge /etc/alternatives/sqoop-merge
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-metastore /etc/alternatives/sqoop-metastore
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/sqoop-version /etc/alternatives/sqoop-version
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/statestored /etc/alternatives/statestored
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/whirr /etc/alternatives/whirr
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/yarn /etc/alternatives/yarn
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/zookeeper-client /etc/alternatives/zookeeper-client
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/zookeeper-server /etc/alternatives/zookeeper-server
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/zookeeper-server-cleanup /etc/alternatives/zookeeper-server-cleanup
ln -s /opt/cloudera/parcels/CDH-5.14.0-1.cdh5.14.0.p0.24/bin/zookeeper-server-initialize /etc/alternatives/zookeeper-server-initialize


#!/bin/bash

for a in `find . -type l`
do
stat -L $a >/dev/null 2>/dev/null
if [ $? -gt 0 ]
then
rm $a
fi
done

posted @ 2018-07-11 15:51  highyeyeye  阅读(1254)  评论(0编辑  收藏  举报