hive的启动和停止

一、启动后台运行

打出日志便于差错,如不需要可省略。
[hadoop ~]# nohup hive --service metastore >> ~/metastore.log 2>&1 &        ##hivemetastore
[hadoop ~]# nohup  hive --service hiveserver2 >> ~/hiveserver2.log 2>&1 &   ##hiveserver2,jdbc连接需要
建议指定日志路径,方便查找问题。否则都会存到nohup.out文件中。
~/hiveserver2.log

 

二、停止后台进程

1、先查看端口信息

[hadoop ~]# vi ../hive/conf/hive-site.xml
  <property>
    <name>hive.metastore.port</name>
    <value>9083</value>
    <description>Hive metastore listener port</description>
  </property>
  <property>
    <name>hive.server2.thrift.port</name>
    <value>10000</value>
    <description>Port number of HiveServer2 Thrift interface when hive.server2.transport.mode is 'binary'.</description>
  </property>

2、查看进程

1) 方法一、使用netstat查找端口号的进程

[hadoop ~]# netstat  -lnp|grep 9083
tcp    LISTEN     0      50        *:9083                  *:*                   users:(("java",pid=33253,fd=546))
[hadoop ~]# netstat  -lnp|grep 10000
tcp    LISTEN     0      50        *:10000                 *:*                   users:(("java",pid=33322,fd=572))

2) 方法二、centos 中,使用ss命令代替netstat查找端口号的进程

[hadoop ~]# ss -lnp|grep 9083
tcp    LISTEN     0      50        *:9083                  *:*                   users:(("java",pid=33253,fd=546))
[hadoop ~]# ss -lnp|grep 10000
tcp    LISTEN     0      50        *:10000                 *:*                   users:(("java",pid=33322fd=572))

3) 方法三、查看hive进程

[hadoop ~]# ps -aux|grep hive

hadoop 33253 0.4 14.9 2330148 357316 pts/2 Sl 04:38 1:22 /usr/local/jdk1.8.0_161/bin/java -Xmx512m -Djava.net.preferIPv4Stack=true -Dhadoop.log.dir=/usr/local/hadoop/logs -Dhadoop.log.file=hadoop.log -Dhadoop.home.dir=/usr/local/hadoop -Dhadoop.id.str=hadoop -Dhadoop.root.logger=INFO,console -Djava.library.path=/usr/local/hadoop/lib/native -Dhadoop.policy.file=hadoop-policy.xml -Djava.net.preferIPv4Stack=true -Xmx512m -Dlog4j.configurationFile=hive-log4j2.properties -Djava.util.logging.config.file=/usr/local/hive2/conf/parquet-logging.properties -Dhadoop.security.logger=INFO,NullAppender org.apache.hadoop.util.RunJar /usr/local/hive2/lib/hive-metastore-2.2.0.jar org.apache.hadoop.hive.metastore.HiveMetaStore

hadoop 33322 1.1 17.1 2331028 407888 pts/2 Sl 04:38 3:23 /usr/local/jdk1.8.0_161/bin/java -Xmx512m -Djava.net.preferIPv4Stack=true -Dhadoop.log.dir=/usr/local/hadoop/logs -Dhadoop.log.file=hadoop.log -Dhadoop.home.dir=/usr/local/hadoop -Dhadoop.id.str=hadoop -Dhadoop.root.logger=INFO,console -Djava.library.path=/usr/local/hadoop/lib/native -Dhadoop.policy.file=hadoop-policy.xml -Djava.net.preferIPv4Stack=true -Xmx512m -Dlog4j.configurationFile=hive-log4j2.properties -Djava.util.logging.config.file=/usr/local/hive2/conf/parquet-logging.properties -Dhadoop.security.logger=INFO,NullAppender org.apache.hadoop.util.RunJar /usr/local/hive2/lib/hive-service-2.2.0.jar org.apache.hive.service.server.HiveServer2

3、根据方法1、2、3的pid,杀死进程

[hadoop ~]# kill -9 33253
[hadoop ~]# kill -9 33322

### Hive 服务启动方法及常见问题解决 Hive启动主要包括两个主要服务:`metastore` `hiveserver2`。以下是具体的启动方法以及可能遇到的启动问题的解决方案。 #### 启动 Hive 服务 1. **启动 Metastore 服务** 在 Hive 安装目录下,可以通过以下命令启动 Metastore 服务: ```bash bin/hive --service metastore ``` 如果需要以后台模式运行,可以使用 `nohup` 命令: ```bash nohup bin/hive --service metastore & ``` 2. **启动 Hiveserver2 服务** Hiveserver2 是用于客户端连接 Hive 的服务。同样,在 Hive 安装目录下执行以下命令以启动 Hiveserver2: ```bash bin/hive --service hiveserver2 ``` 或者以后台模式运行: ```bash nohup bin/hive --service hiveserver2 & ``` #### 解决 Hive 启动问题 在某些情况下,Hive 可能会因为依赖的服务未正确启动或配置问题而无法正常启动。以下是常见的启动问题及其解决方法: 1. **HDFS 高可用(HA)相关问题** 如果 Hive 启动时遇到与 HDFS 高可用相关的错误,可能是由于 ZooKeeper(ZK) HDFS 的状态不一致导致的。例如,自动选择 Active Namenode 的功能可能导致手动切换失败[^2]。 - 解决方案: 先停止 ZK HDFS 服务,然后重新启动所有相关服务,并检查 Namenode 的状态。具体操作如下: ```bash # 停止 ZK HDFS zkStop-all.sh stop-dfs.sh # 启动 ZK HDFS zkStart-all.sh start-dfs.sh # 检查 Namenode 状态 hdfs haadmin -getServiceState nn1 ``` 2. **Hadoop 服务未启动** 如果 Hadoop 的核心服务(如 Namenode、Datanode、ResourceManager 等)未正确启动Hive 将无法访问存储在 HDFS 上的数据[^3]。 - 解决方案: 使用以下命令确保 Hadoop 的所有服务已启动: ```bash start-dfs.sh start-yarn.sh # 检查服务状态 jps ``` 3. **Hive 命令冲突** 在某些环境中,Hive启动命令可能会与系统中的其他命令发生冲突。 - 解决方案: 确保环境变量中正确配置了 Hive 的路径,并避免与其他工具的命令冲突。 4. **Metastore 数据库连接问题** 如果 Metastore 无法连接到数据库(如 MySQL 或 Derby),可能会导致 Hive 启动失败。 - 解决方案: 检查 Hive 的配置文件 `hive-site.xml` 中的数据库连接信息是否正确。例如: ```xml <property> <name>javax.jdo.option.ConnectionURL</name> <value>jdbc:mysql://localhost:3306/hive_metastore</value> </property> <property> <name>javax.jdo.option.ConnectionDriverName</name> <value>com.mysql.cj.jdbc.Driver</value> </property> ``` #### 示例代码 以下是一个完整的 Hive 启动脚本示例: ```bash #!/bin/bash # 启动 Hadoop 服务 start-dfs.sh start-yarn.sh # 启动 Hive Metastore Hiveserver2 nohup bin/hive --service metastore & nohup bin/hive --service hiveserver2 & ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值