Ambari大数据平台集群利器的探索与实践

一、简介

Ambari是 Apache Software Foundation 中的一个顶级项目,它是用来创建、管理、监视Hadoop整个生态圈的工具。 Ambari是分布式架构,主要由Ambari Server和Ambari Agent组成。

HDP是hortonworks的软件栈,里面包含了hadoop生态系统的所有软件项目,其实就是软件包合集。

HDP-UTILS是工具类库。各软件版本对照表:

https://supportmatrix.hortonworks.com/

hadoop生态圈示图:

二、环境准备

2.1 资源要求

2.2 软件要求

2.3 软件下载地址

1
2
3
[root@ambari-server01 ~]# wget http://public-repo-1.hortonworks.com/ambari/centos7/2.x/updates/2.7.1.0/ambari-2.7.1.0-centos7.tar.gz
[root@ambari-server01 ~]# wget http://public-repo-1.hortonworks.com/HDP/centos7/3.x/updates/3.0.1.0/HDP-3.0.1.0-centos7-rpm.tar.gz
[root@ambari-server01 ~]# wget http://public-repo-1.hortonworks.com/HDP-UTILS-1.1.0.22/repos/centos7/HDP-UTILS-1.1.0.22-centos7.tar.gz

2.4 系统初始化,执行以下脚本(所有节点)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#!/bin/bash
#
#服务器初始化脚本

# 关闭防火墙
systemctl stop firewalld
systemctl disable firewalld

# 关闭 SeLinux
setenforce 0
sed -i "s/SELINUX=enforcing/SELINUX=disabled/g" /etc/selinux/config

# 关闭 swap
swapoff -a
sed -i 's/.*swap.*/#&/' /etc/fstab
# echo "1" >/proc/sys/net/bridge/bridge-nf-call-iptables

# 安装必要的调试程序
yum install -y vim lrzsz telnet net-tools tar wget
yum install -y java-1.8.0-openjdk*

# 安装配置时间同步服务
yum install -y ntp
systemctl start ntpd.service
systemctl enable ntpd.service

# 设置进程文件最大打开数量
echo "* soft nofile 65535" >> /etc/security/limits.conf
echo "* hard nofile 65535" >> /etc/security/limits.conf

# 设置系统总限制文件最大打开数量
echo 6553560 > /proc/sys/fs/file-max
echo "fs.file-max = 6553560" >> /etc/sysctl.conf

2.5 设置主机名(所有节点)

1
2
3
4
5
6
7
8
9
10
11
# 三台主机分别设置hostname
[root@ambari-server01 ~]# hostnamectl set-hostname ambari-server01.test.com
[root@ambari-node01 ~]# hostnamectl set-hostname ambari-node01.test.com
[root@ambari-node02 ~]# hostnamectl set-hostname ambari-node02.test.com

# 添加hosts解析(所有节点)
[root@ambari-server01 ~]# cat >> /etc/hosts << EOF
192.168.2.111 ambari-server01.test.com
192.168.2.112 ambari-node01.test.com
192.168.2.113 ambari-node02.test.com
EOF

2.6 设置免密登陆(ambari-server01节点)

1
2
3
4
5
6
7
# 在192.168.2.111节点执行:
[root@ambari-server01 ~]# ssh-keygen
[root@ambari-server01 ~]# ssh-copy-id ambari-server01.test.com
[root@ambari-server01 ~]# ssh-copy-id ambari-node01.test.com
[root@ambari-server01 ~]# ssh-copy-id ambari-node02.test.com
[root@ambari-server01 ~]# scp -r .ssh/ ambari-node01.test.com:/root
[root@ambari-server01 ~]# scp -r .ssh/ ambari-node02.test.com:/root

三、安装mysql相关(ambari-server01节点)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
# 下载并安装mysql
[root@ambari-server01 ~]# wget -i -c http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
[root@ambari-server01 ~]# yum -y install mysql-community-release-el7-5.noarch.rpm
[root@ambari-server01 ~]# yum -y install mysql-community-server

# 启动mysql
[root@ambari-server01 ~]# systemctl start mysqld.service # 启动mysql
[root@ambari-server01 ~]# systemctl status mysqld.service # 查看mysql状态
[root@ambari-server01 ~]# systemctl enable mysqld.service # 开机自启

# 设置mysql密码
> set password for root@localhost = password('root123'); # 方法一,需要登陆mysql执行

# 创建ambari数据库及用户名和密码
mysql> create database ambari character set utf8;
mysql> CREATE USER 'ambari'@'%'IDENTIFIED BY 'Ambari123';
mysql> GRANT ALL PRIVILEGES ON ambari.* TO 'ambari'@'%';
mysql> GRANT ALL PRIVILEGES ON ambari.* TO 'ambari'@'ambari-server01.test.com'IDENTIFIED BY 'Ambari123';
mysql> FLUSH PRIVILEGES;

# 创建hive数据库及用户名和密码(如果不需要安装hive服务,则不需要配置以下数据库)
mysql> create database hive character set utf8;
mysql> CREATE USER 'hive'@'%'IDENTIFIED BY 'Hive123';
mysql> GRANT ALL PRIVILEGES ON hive.* TO 'hive'@'%';
mysql> GRANT ALL PRIVILEGES ON hive.* TO 'ambari'@'ambari-server01.test.com'IDENTIFIED BY 'Hive123';
mysql> FLUSH PRIVILEGES;

# 如果需要安装oozie、ranger服务,创建数据库方法同上。

# 下载 mysql-connector-java-5.1.46-bin.jar包
# 复制到/var/lib/ambari-server/resources/mysql-connector-java-5.1.46-bin.jar目录;
# 再复制到/usr/share/java/mysql-connector-java-5.1.46-bin.jar到这个目录一份。

四、利用httpd创建本地yum的repo源(ambari-server01节点)

1
2
3
4
5
6
7
8
9
10
11
12
13
# 安装软件
[root@ambari-server01 ~]# yum -y install yum-utils createrepo httpd
# 创建目录
[root@ambari-server01 ~]# mkdir -p /var/www/html/ambari/
[root@ambari-server01 ~]# mkdir -p /var/www/html/hdp/
[root@ambari-server01 ~]# mkdir -p /var/www/html/hdp/HDP-UTILS/
# 解压tar包
[root@ambari-server01 ~]# tar -zxvf ambari-2.7.1.0-centos7.tar.gz -C /var/www/html/ambari/
[root@ambari-server01 ~]# tar -zxvf HDP-3.0.1.0-centos7-rpm.tar.gz -C /var/www/html/hdp/
[root@ambari-server01 ~]# tar -zxvf HDP-UTILS-1.1.0.22-centos7.tar.gz -C /var/www/html/hdp/HDP-UTILS/
# 启动httpd
[root@ambari-server01 ~]# systemctl start httpd
[root@ambari-server01 ~]# systemctl enable httpd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
**浏览器查看,如下即为正常**

![](https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/6eda665d14c04ee9bb69a5dbbe28b23a~tplv-k3u1fbpfcp-zoom-1.image)

# 配置本地repo
[root@ambari-server01 ~]# wget -O /etc/yum.repos.d/ambari.repo http://public-repo-1.hortonworks.com/ambari/centos7/2.x/updates/2.7.1.0/ambari.repo

# 将下载的repo修改内容为如下
[root@ambari-server01 ~]# vim /etc/yum.repos.d/ambari.repo
#VERSION_NUMBER=2.7.1.0-139
[ambari-2.7.1.0]
#json.url = http://public-repo-1.hortonworks.com/HDP/hdp_urlinfo.json
name=ambari Version - ambari-2.7.1.0
baseurl=http://192.168.2.111/ambari/ambari/centos7/2.7.1.0-169
gpgcheck=1
gpgkey=http://192.168.2.111/ambari/ambari/centos7/2.7.1.0-169/RPM-GPG-KEY/RPM-GPG-KEY-Jenkins
enabled=1
priority=1

# 配置HDP和HDP-UTILS的repo
[root@ambari-server01 ~]# vim /etc/yum.repos.d/HDP.repo
#VERSION_NUMBER=3.0.1.0-187
[HDP-3.0.1.0]
name=HDP Version - HDP-3.0.1.0
baseurl=http://192.168.2.111/hdp/HDP/centos7
gpgcheck=1
gpgkey=http://192.168.2.111/hdp/HDP/centos7/3.0.1.0-187/RPM-GPG-KEY/RPM-GPG-KEY-Jenkins
enabled=1
priority=1
[HDP-UTILS-1.1.0.22]
name=HDP-UTILS Version - HDP-UTILS-1.1.0.22
baseurl=http://192.168.2.111/hdp/HDP-UTILS/centos7/1.1.0.22
gpgcheck=1
gpgkey=http://192.168.2.111/hdp/HDP-UTILS/centos7/1.1.0.22/RPM-GPG-KEY/RPM-GPG-KEY-Jenkins
enabled=1
priority=1

# 将repo拷贝到其他节点
[root@ambari-server01 ~]# cd /etc/yum.repos.d/
[root@ambari-server01 ~]# scp ambari.repo HDP.repo root@192.168.2.112:/etc/yum.repos.d/
[root@ambari-server01 ~]# scp ambari.repo HDP.repo root@192.168.2.113:/etc/yum.repos.d/

# 生成本地源
[root@ambari-server01 ~]# createrepo /var/www/html/hdp/HDP/centos7/
[root@ambari-server01 ~]# createrepo /var/www/html/hdp/HDP-UTILS/

五、安装ambari集群

5.1 安装ambari-server(ambari-server01节点)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58

[root@ambari-server01 ~]# yum -y install ambari-server
[root@ambari-server01 ~]# ambari-server setup
Using python /usr/bin/python
Setup ambari-server
Checking SELinux...
SELinux status is 'disabled'
Customize user account for ambari-server daemon [y/n] (n)? y
Enter user account for ambari-server daemon (root):root # 用户
Adjusting ambari-server permissions and ownership...
Checking firewall status...
Checking JDK...
[1] Oracle JDK 1.8 + Java Cryptography Extension (JCE) Policy Files 8
[2] Custom JDK
==============================================================================
Enter choice (1): 2 # 选择自定义jdk
WARNING: JDK must be installed on all hosts and JAVA_HOME must be valid on all hosts.
WARNING: JCE Policy files are required for configuring Kerberos security. If you plan to use Kerberos,please make sure JCE Unlimited Strength Jurisdiction Policy Files are valid on all hosts.
Path to JAVA_HOME: /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.262.b10-0.el7_8.x86_64/ #jdk安装路径
Validating JDK on Ambari Server...done.
Check JDK version for Ambari Server...
JDK version found: 8
Minimum JDK version is 8 for Ambari. Skipping to setup different JDK for Ambari Server.
Checking GPL software agreement...
GPL License for LZO: https://www.gnu.org/licenses/old-licenses/gpl-2.0.en.html
Enable Ambari Server to download and install GPL Licensed LZO packages [y/n] (n)? y
Completing setup...
Configuring database...
Enter advanced database configuration [y/n] (n)? y
Configuring database...
==============================================================================
Choose one of the following options:
[1] - PostgreSQL (Embedded)
[2] - Oracle
[3] - MySQL / MariaDB
[4] - PostgreSQL
[5] - Microsoft SQL Server (Tech Preview)
[6] - SQL Anywhere
[7] - BDB
==============================================================================
Enter choice (1): 3 # 选择安装的mysql
Hostname (localhost): ambari-server01.test.com # 配置hostname
Port (3306): # 默认
Database name (ambari): # 默认
Username (ambari): # 默认
Enter Database Password (bigdata): # 输入密码
Re-enter password:
Configuring ambari database...
Should ambari use existing default jdbc /usr/share/java/mysql-connector-java.jar [y/n] (y)? y
Configuring remote database connection properties...
WARNING: Before starting Ambari Server, you must run the following DDL directly from the database shell to create the schema: /var/lib/ambari-server/resources/Ambari-DDL-MySQL-CREATE.sql # 此处需注意,启动ambari之前需要执行此句
Proceed with configuring remote database connection properties [y/n] (y)? y
Extracting system views...
ambari-admin-2.7.3.0.139.jar
....
Ambari repo file contains latest json url http://public-repo-1.hortonworks.com/HDP/hdp_urlinfo.json, updating stacks repoinfos with it...
Adjusting ambari-server permissions and ownership...
Ambari Server 'setup' completed successfully. # 安装成功

5.2 使用ambari用户登陆mysql

1
2
3
[root@ambari-server01 ~]# mysql -u ambari -pAmbari123 -h ambari-server01.test.com
mysql> source /var/lib/ambari-server/resources/Ambari-DDL-MySQL-CREATE.sql;
mysql> show tables;

5.3 启动ambari-Server

1
[root@ambari-server01 ~]# ambari-server start

5.4 安装ambari-agent(ambari-node01、ambari-node02节点)

1
[root@ambari-node01 ~]# yum -y install ambari-agent

六、Ambari web页面配置

1
2
3
访问地址:http://192.168.2.111:8080/
默认账号:admin
默认密码:admin

进行web页面配置时没有截图,以下截图为网上下载,仅供参考

6.1 选择版本

6.2 配置节点、密钥

6.3 主机确认

6.4 选择要安装的组件

6.5 节点分配

6.6 分配从属和客户端

6.7 定制服务


1
2
# 执行以下命令(ambari-server01节点)
[root@ambari-server01 ~]# ambari-server setup --jdbc-db=mysql --jdbc-driver=/usr/share/java/mysql-connector-java-5.1.46-bin.jar

6.8 设置存储路径等



6.9 集群情况预览并部署




等待启动完毕,不用担心警告,后期可以调整,搭建完成,可以在展示页面进行查看集群状态

可以查看监控界面,可以看到大数据组件中出现错误,单个组件点开处理

6.10 监控面板

6.10.1 监控面板-主机状态

6.10.2 监控面板-配置历史(可针对单个服务调整配置)

6.11 新部署其他服务

6.12 添加node节点

6.13 配置邮件报警

6.14 ambari会自动安装grafana作为监控面板


至此,搭建完成!