HBase 完全分布式安装(新)

第1关:HBase 完全分布式安装

1.主机映射配置
输入命令 vi /etc/hosts进行主机 ip 的映射设置,添加如下配置:

复制代码
#master、slave1、slave2
172.16.248.174    master
172.16.251.34    slave1
172.16.240.174    slave2

2.免密登录

在各节点服务器生成秘钥:

复制代码
#master、slave1、slave2
ssh-keygen -t rsa

在 master 复制 master、slave1、slave2 的公钥。

复制代码
cat ~/.ssh/id_rsa.pub>> ~/.ssh/authorized_keys
ssh slave1 cat ~/.ssh/id_rsa.pub>> ~/.ssh/authorized_keys
ssh slave2 cat ~/.ssh/id_rsa.pub>> ~/.ssh/authorized_keys

在 slave1 复制 master 的 authorized_keys 文件。

复制代码
ssh master cat ~/.ssh/authorized_keys>> ~/.ssh/authorized_keys

在 slave2 复制 master 的 authorized_keys 文件。

复制代码
ssh master cat ~/.ssh/authorized_keys>> ~/.ssh/authorized_keys

3.安装 Zookeeper

复制代码
cd /opt
tar -zxvf zookeeper-3.4.6.tar.gz
mv zookeeper-3.4.6 /app
vim /etc/profile
# 添加配置
export ZOOKEEPER_HOME=/app/zookeeper-3.4.6
export PATH=$ZOOKEEPER_HOME/bin:$PATH
# 保存退出
source /etc/profile
cd /app/zookeeper-3.4.6/conf
mv zoo_sample.cfg zoo.cfg
vim zoo.cfg
# 修改添加配置
dataDir=/app/zookeeper-3.4.6/zkData
server.1=master:2888:3888
server.2=slave1:2888:3888
server.3=slave2:2888:3888
mkdir /app/zookeeper-3.4.6/zkData
vim /app/zookeeper-3.4.6/zkData/myid

在 myid 文件中输入数字 1 ,保存退出

分发 Zookeeper

将解压好的 Zookeeper 与配置文件通过 scp 命令发送至 slave1、slave2 中

复制代码
#发送 Zookeeper
scp -r /app/zookeeper-3.4.6 root@slave1:/app
scp -r /app/zookeeper-3.4.6 root@slave2:/app
# 修改 slave1、slave2 中的 myid
# slave1:
vim /app/zookeeper-3.4.6/zkData/myid
# 删除所有内容,输入数字 2 ,保存退出
# slave2:
vim /app/zookeeper-3.4.6/zkData/myid
# 删除所有内容,输入数字 3 ,保存退出
#master
#发送配置文件
scp  /etc/profile root@slave1:/etc/
scp  /etc/profile root@slave2:/etc/

在各节点上分别执行source /etc/profile,使配置文件生效。

启动 Zookeeper

分别在三台节点上执行命令启动 Zookeeper

复制代码
# master
zkServer.sh start
# slave1
zkServer.sh start
# slave2
zkServer.sh start

4.Hadoop 伪分布式安装

复制代码
cd /opt
tar -zxvf hadoop-3.1.3.tar.gz -C /app/
vim /etc/profile
# 添加配置
export HADOOP_HOME=/app/hadoop-3.1.3
export PATH=$HADOOP_HOME/bin:$HADOOP_HOME/sbin:$PATH
# 保存退出
source /etc/profile
cd /app/hadoop-3.1.3/etc/hadoop
# 编辑文件
vi hadoop-env.sh
# 在文件末尾添加如下代码
export JAVA_HOME=/usr/lib/jvm/jdk1.8.0_111
export HDFS_NAMENODE_USER=root
export HDFS_DATANODE_USER=root
export HDFS_SECONDARYNAMENODE_USER=root
export YARN_RESOURCEMANAGER_USER=root
export YARN_NODEMANAGER_USER=root
# 编辑文件
vim core-site.xml
# 在文件末尾的 configuration 标签中添加代码如下
    <!--指定Hadoop运行时产生文件的存储目录-->
    <property>
        <name>hadoop.tmp.dir</name>
        <value>/app/hadoop-3.1.3/data/hadoop/tmp</value>
    </property>
    <!--指定HDFS中NameNode的地址-->
    <property>
        <name>fs.defaultFS</name>
        <value>hdfs://master:9000</value>
    </property>
#编辑文件
vim hdfs-site.xml
# 在文件末尾的 configuration 标签中添加代码如下
    <property>
        <name>dfs.replication</name>
        <value>1</value>
    </property>
# 格式化 NameNode
hadoop namenode -format
# 启动 HDFS
start-dfs.sh

5.HBase 完全分布式搭建

复制代码
cd /opt
tar -zxvf hbase-2.2.3-bin.tar.gz -C /app/
vim /etc/profile
# 添加配置
export HBASE_HOME=/app/hbase-2.2.3
export PATH=$HBASE_HOME/bin:$PATH
# 保存退出
source /etc/profile
cd /app/hbase-2.2.3/conf
vi hbase-env.sh
# 添加配置
export JAVA_HOME=/usr/lib/jvm/jdk1.8.0_111
export HBASE_MANAGES_ZK=false
vim hbase-site.xml
# 添加配置
<property>
          <name>hbase.rootdir</name>
          <value>hdfs://master:9000/hbase</value>
      </property> 
      <property>
          <name>hbase.cluster.distributed</name>
          <value>true</value>
      </property>
      <property>
          <name>hbase.unsafe.stream.capability.enforce</name>
          <value>false</value>
      </property>
           <property>
            <name>hbase.zookeeper.quorum</name>
          <value>master,slave1,slave2</value>
      </property>
      <property>
          <name>hbase.zookeeper.property.dataDir</name>
          <value>/app/zookeeper-3.4.6/zkData</value>
      </property>
vim regionservers
# 添加配置
master
slave1
slave2
# 分发
scp -r /app/hbase-2.2.3 root@slave1:/app
scp -r /app/hbase-2.2.3 root@slave2:/app
scp  /etc/profile root@slave1:/etc/
scp  /etc/profile root@slave2:/etc/
# 在各节点上分别执行 source /etc/profile,使配置文件生效。
# master 上启动 HBase
start-hbase.sh
相关推荐
大尚来也1 小时前
主键、外键、索引,一篇讲透
java·数据库·oracle
j7~1 小时前
【MYSQL】表的内外连接--详解(重点)
数据库·mysql·内连接·左外连接·右外连接
水木流年追梦2 小时前
大模型入门-大模型优化方法3
人工智能·分布式·python·深度学习·机器学习
147API2 小时前
Claude Opus 4.8 接口与工程落地分析:长任务调用链应该怎么设计
java·前端·数据库
绝知此事2 小时前
Redis 从入门到精通:Spring Boot 实战三部曲(一)—— 基础核心与快速上手
数据库·redis·缓存
鸽芷咕2 小时前
金仓数据库标量子查询消除:一条SQL从32秒优化到24毫秒
数据库·sql
朝阳5812 小时前
MySQL 主从复制 — 双服务器灾备方案(原生安装)
服务器·数据库·mysql
是狐狸吖2 小时前
Redis分布式锁进阶第十六篇
数据库·redis·分布式
闪电悠米2 小时前
黑马点评-优惠券秒杀-04_one_user_one_order
服务器·网络·数据库