博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Setting up Oozie high availability
阅读量:6615 次
发布时间:2019-06-25

本文共 3455 字,大约阅读时间需要 11 分钟。

本文介绍如何搭建四节点的Oracle Linux 7集群以及oozie的High Availability。环境如下图:

Setting up Oozie high availability
一、创建HA集群
1、安装集群软件包
分别在4个节点上安装,如下:

[root@hdp01 ~]#  yum install pcs fence-agents-all -y[root@hdp02 ~]#  yum install pcs fence-agents-all -y[root@hdp03 ~]#  yum install pcs fence-agents-all -y[root@hdp04 ~]#  yum install pcs fence-agents-all -y

2、设置集群用户密码

集群软件包安装完成后,会在系统中创建一个hacluster用户,默认是没有密码的,需要单独设置,否则后续节点认证会失败。

[root@hdp01 ~]# for id in {1..4};do ssh hdp0$id "echo redhat|passwd --stdin hacluster";doneChanging password for user hacluster.passwd: all authentication tokens updated successfully.Changing password for user hacluster.passwd: all authentication tokens updated successfully.Changing password for user hacluster.passwd: all authentication tokens updated successfully.Changing password for user hacluster.passwd: all authentication tokens updated successfully.

3、启用集群服务

安装完成后,集群服务默认是禁用状态,使用下面的命令启用:

[root@hdp01 ~]# for id in {1..4};do ssh hdp0$id "systemctl enable pcsd.service;systemctl start pcsd.service";doneCreated symlink from /etc/systemd/system/multi-user.target.wants/pcsd.service to /usr/lib/systemd/system/pcsd.service.Created symlink from /etc/systemd/system/multi-user.target.wants/pcsd.service to /usr/lib/systemd/system/pcsd.service.Created symlink from /etc/systemd/system/multi-user.target.wants/pcsd.service to /usr/lib/systemd/system/pcsd.service.Created symlink from /etc/systemd/system/multi-user.target.wants/pcsd.service to /usr/lib/systemd/system/pcsd.service.[root@hdp01 ~]# for id in {1..4};do ssh hdp0$id "systemctl status pcsd.service";done

4、集群节点认证

通过下面的命令进行集群节点认证:

[root@hdp01 ~]# pcs cluster auth hdp01 hdp02 hdp03 hdp04

Setting up Oozie high availability

5、创建集群

[root@hdp01 ~]# pcs cluster setup --start --name hcluster hdp01 hdp02 hdp03 hdp04

Setting up Oozie high availability

6、配置集群服务自启动

[root@hdp01 ~]# pcs cluster enable --all

7、验证集群状态

[root@hdp01 ~]# pcs cluster status

Setting up Oozie high availability

8、禁用fence服务
这里的4个几点都是虚拟机,所以不需要启用fence服务,但如果是物理机就需要启用,具体参考官方文档。

[root@hdp01 ~]# pcs property set stonith-enabled=false[root@hdp01 ~]# pcs property set no-quorum-policy=ignore[root@hdp01 ~]# pcs resource defaults migration-threshold=1

9、创建资源组

这里只针对hadoop提供虚拟IP服务,所以只创建一个虚拟IP的资源,如下:

[root@hdp01 ~]# pcs resource create vip_res IPaddr2 ip=192.168.120.101 cidr_netmask=24 nic=eth0 op monitor interval=30s --group hadoopAssumed agent name 'ocf:heartbeat:IPaddr2' (deduced from 'IPaddr2')[root@hdp01 ~]# pcs status

Setting up Oozie high availability

10、启用资源组

[root@hdp01 ~]# pcs cluster start --all && pcs status

Setting up Oozie high availability

二、配置Oozie HA
4个节点上都运行oozie服务,而且使用的是同一个mysql作为metastore database。对外服务的IP是一个虚拟IP。(这里先在hdp01上做完所有配置,然后再拷贝到其他机器)。在做以下配置之前,确保每个节点的oozie服务未运行。
1、编辑oozie-site.xml文件
加入以下内容:

oozie.services.ext=org.apache.oozie.service.ZKLocksService,org.apache.oozie.service.ZKXLogStreamingService,org.apache.oozie.service.ZKJobsConcurrencyService,org.apache.oozie.service.ZKUUIDService--如果zookeeper是多个服务器则之间使用逗号隔开oozie.zookeeper.connection.string=hdp01:2181,hdp02:2181,hdp03:2181,hdp04:2181oozie.zookeeper.namespac=oozieoozie.base.url=http://192.168.120.101:11000/oozie--其他节点的instance.id改成对应的主机名即可oozie.instance.id=hdp01

Setting up Oozie high availability

2、同步oozie至其他节点

[hadoop@hdp01 ~]$ for i in {2..4};do scp -r /u01/oozie hdp0$i:/u01;done

注意:

同步完成后,将oozie存放pid文件夹下的pid文件删除,另外还需要更改oozie-site.xml的instance.id为本机主机名。
3、启动每个节点的oozie服务

[hadoop@hdp01 ~]$ for i in {1..4};do ssh hdp0$i "source .bash_profile;oozied.sh start";done--在任意一台节点通过虚拟IP测试是否可以访问[hadoop@hdp03 ~]$ oozie admin -oozie http://192.168.120.101:11000/oozie -statusSystem mode: NORMAL

4、Zookeeper检查是否已注册oozie服务

Setting up Oozie high availability

参考文献:

1、
2、

转载于:https://blog.51cto.com/candon123/2050967

你可能感兴趣的文章
[LeetCode] Contains Duplicate III
查看>>
经济周期
查看>>
启动新进程
查看>>
KubeCon + CloudNativeCon论坛2019上海
查看>>
【总结整理】已读功能---摘自《馒头商学院》
查看>>
非抢占式系统优点
查看>>
TPYBoard V102:能跑Python的stm32开发板
查看>>
在阿里云域名https配置(nginx为例)
查看>>
TP5.0中的小知识总结
查看>>
【SSH网上商城项目实战27】域名空间的申请和项目的部署及发布
查看>>
RabbitMQ-从基础到实战(2)— 防止消息丢失
查看>>
5.1、Android Studio用Logcat编写和查看日志
查看>>
【译】ExtJS 4.1会带来什么
查看>>
正则表达式基础知识
查看>>
【ShaderToy】开篇
查看>>
wp7 城市天气预报查询
查看>>
重要的话
查看>>
银联参数
查看>>
QRegExp正则表达式用法
查看>>
a 标签的伪类的正确顺序,以及原因
查看>>