进去root权限(su)
1.从https://mirrors.tuna.tsinghua.edu.cn/apache/hive/hive-1.2.2/apache-hive-1.2.2-bin.tar.gz获取镜像地址选择版本下载(此处使用清华开源的Apache-hive1.2.2版本)
wget 下载地址
2.解压安装hive
tar -xzvf apache-hive-1.2.2-bin.tar.gz
3.设置hive环境变量
vim /etc/profile
加入(根据自己安装的路径来写)
export HIVE_HOME=/usr/local/hive
export PATH=$PATH:$HIVE_HOME/bin
4.配置Hive
# cd $HIVE_HOME/conf(进入hive目录下)
此处为:
cd /usr/local/hive/conf
cp hive-env.sh.template hive-env.sh cp hive-default.xml.template hive-default.xml cp hive-log4j2.properties.template hive-log4j2.properties cp hive-exec-log4j2.properties.template hive-exec-log4j2.properties
5.创建HDFS目录(开启hadoop:start-all.sh)
hdfs dfs -mkdir -p /usr/hive/warehouse(此处的-p指直接创建多级目录,一次创建成功) hdfs dfs -mkdir -p /usr/hive/tmp hdfs dfs -mkdir -p /usr/hive/log hdfs dfs -chmod g+w /usr/hive/warehouse(设置权限) hdfs dfs -chmod g+w /usr/hive/tmp hdfs dfs -chmod g+w /usr/hive/log
6.修改 hive-env.sh(位于$HIVE_HOME/bin)
vim hive-env.sh
(以下修改自己对应的路径,以下仅供参考)
export JAVA_HOME=/home/xiaolanlin/jdk1.8.0_201 export HIVE_HOME=/usr/local/hive export HADOOP_HOME=/usr/local/hadoop-2.7.6 export HIVE_CONF_DIR=/usr/local/hive/conf
7.修改 hive-site.xml(位于$HIVE_HOME/conf)
vim hive-site.xml
替换以下参数
<property> <name>javax.jdo.option.ConnectionURL</name> <value>jdbc:mysql://localhost:3306/hive</value> <description>JDBC connect string for a JDBC metastore</description> </property> <property> <name>javax.jdo.option.ConnectionDriverName</name> <value>com.mysql.jdbc.Driver</value> <description>Driver class name for a JDBC metastore</description> </property> <property> <name>javax.jdo.option.ConnectionUserName</name> <value>xiaolanLin</value>#数据库用户名 <description>Username to use against metastore database</description> </property> <property> <name>javax.jdo.option.ConnectionPassword</name> <value>linxiaolan</value>#数据库密码 <description>password to use against metastore database</description> </property>
下面的部分如果不配置会产生错误
<property> <name>hive.exec.local.scratchdir</name> <value>/usr/local/hive</value> <description>Local scratch space for Hive jobs</description> </property> <property> <name>hive.downloaded.resources.dir</name> <value>/usr/local/hive/hive-downloaded-addDir/</value>#自定义目录 <description>Temporary local directory for added resources in the remote file system.</description> </property> <property> <name>hive.querylog.location</name> <value>/usr/local/hive/querylog-location-addDir/</value>#自定义目录 <description>Location of Hive run time structured log file</description> </property> <property> <name>hive.server2.logging.operation.log.location</name> <value>/usr/local/hive/hive-logging-operation-log-addDir/</value>#自定义目录 <description>Top level directory where operation logs are stored if logging functionality is enabled</description> </property>
8.修改hive-log4j.properties
vim hive-log4j.properties
hive.log.dir=自定义目录
9.删除hive-site.xml.swp
rm -rf ./conf/.hive-site.xml.swp(文件修改过程中退出出现的错误,会产生缓存文件,将其删除)
10.创建数据库和用户
linux(Ubuntu16.04)安装mysql参考教程https://www.cnblogs.com/luengmingbiao/p/10864249.html
mysql -uroot -p(输入密码后进入mysql)
hive> create database hive default charser utf8 COLLATE utf8_general_ci; hive> show databases; hive> grant all on hive.* to 'hive'@'%' identified by 'hive';(将所有数据库的所有表的所有权限赋给hive用户,后面的hive是配置hive-site.xml中配置的连接密码) hive> flush privileges;(刷新mysql系统权限关系表) hive> exit;(quit;)
11.数据库的初始化
schematool -initSchema -dbType mysql
12.启动hive
hive --service metastore
hive
遇到的问题:
1.还未安装jdbc
wget http://central.maven.org/maven2/mysql/mysql-connector-java/6.0.6/mysql-connector-java-6.0.6.jar(此版本不是目前最新)
2.解决了上面这个问题后,接下来依然报错
于是我决定将版本升级为目前最新版本
wget http://central.maven.org/maven2/mysql/mysql-connector-java/8.0.15/mysql-connector-java-8.0.15.jar(此版本为目前最新)
3.于是出现了新的报错(坑越踩越多,还是继续加油吧^~^)
报错说它不是最新版本……
我开始怀疑人生……
决定检查一下我是不是有什么还没做
噢,数据库还没创建!!!~~~~~~~~