热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

42.Impala负载均衡实现—HAProxy

42.1操作演示HAProxy安装及启停在集群中选择一个节点,使用yum方式安装HAProxy服务[rootip-172-31-9-33~]#yum-yinst

42.1 操作演示

HAProxy安装及启停

  • 在集群中选择一个节点,使用yum方式安装HAProxy服务

[root@ip-172-31-9-33 ~]# yum -y install haproxy

  • 启动与停止HAProxy服务,并将服务添加到自启动列表

[root@ip-172-31-9-33 ~]# service haproxy start
[root@ip-172-31-9-33 ~]# service haproxy stop
[root@ip-172-31-9-33 ~]# chkconfig haproxy on

HAProxy配置Impala负载均衡

  • 将/etc/haproxy目录下的haproxy.cfg文件备份,新建haproxy.cfg文件,添加如下配置
    • 主要配置了HAProxy的http状态管理界面、impalashell和impalajdbc的负载均衡。

#---------------------------------------------------------------------
# Example configuration for a possible web application. See the
# full configuration options online.
#
# http://haproxy.1wt.eu/download/1.4/doc/configuration.txt
#
#---------------------------------------------------------------------#---------------------------------------------------------------------
# Global settings
#---------------------------------------------------------------------
globallog 127.0.0.1 local2chroot /var/lib/haproxypidfile /var/run/haproxy.pidmaxconn 4000user haproxygroup haproxydaemon# turn on stats unix socketstats socket /var/lib/haproxy/stats#---------------------------------------------------------------------
# common defaults that all the 'listen' and 'backend' sections will
# use if not designated in their block
#---------------------------------------------------------------------
defaultsmode httplog globaloption httplogoption dontlognull#option http-server-close#option forwardfor except 127.0.0.0/8option redispatchretries 3timeout http-request 10stimeout queue 1mtimeout connect 10stimeout client 1mtimeout server 1mtimeout http-keep-alive 10stimeout check 10smaxconn 3000listen statsbind 0.0.0.0:1080mode httpoption httplogmaxconn 5000stats refresh 30sstats uri /stats listen impalashellbind 0.0.0.0:25003mode tcpoption tcplogbalance leastconnserver ip-172-31-9-33.fayson.com ip-172-31-9-33.fayson.com:21000 checkserver ip-172-31-5-190.fayson.com ip-172-31-5-190.fayson.com:21000 checkserver ip-172-31-10-118.fayson.com ip-172-31-10-118.fayson.com:21000 checklisten impalajdbcbind 0.0.0.0:25004mode tcpoption tcplogbalance leastconnserver ip-172-31-9-33.fayson.com ip-172-31-9-33.fayson.com:21050 checkserver ip-172-31-5-190.fayson.com ip-172-31-5-190.fayson.com:21050 checkserver ip-172-31-10-118.fayson.com ip-172-31-10-118.fayson.com:21050 check

  • 重启HAProxy服务

[root@ip-172-31-9-33 haproxy]# service haproxy restart

  • 浏览器访问http://{hostname}:1080/stats,查看Impala服务的负载均衡是否配置成功

Impala Shell测试

  • 使用多个终端同时访问,并执行SQL语句,查看是否会通过HAProxy服务自动负载到其它Impala Daemon节点
  • 使用Impala shell访问HAProxy服务的25003端口,命令如下

[root@ip-172-31-6-148 ~]# impala-shell -i ip-172-31-9-33.fayson.com:25003

  • 打开第一个终端访问并执行SQL

[root@ip-172-31-6-148 ~]# impala-shell -i ip-172-31-9-33.fayson.com:25003
...
[ip-172-31-9-33.fayson.com:25003] > select * from my_first_table;
...
+----+------+
| id | name |
+----+------+
| 1 | john |
| 2 | tom |
| 3 | jim |
+----+------+
Fetched 3 row(s) in 7.20s
[ip-172-31-9-33.fayson.com:25003] >

  • 同时打开第二个终端访问并执行SQL

[root@ip-172-31-6-148 ~]# impala-shell -i ip-172-31-9-33.fayson.com:25003
...
[ip-172-31-9-33.fayson.com:25003] > select * from my_first_table;
...
+----+------+
| id | name |
+----+------+
| 2 | tom |
| 3 | jim |
| 1 | john |
+----+------+
Fetched 3 row(s) in 1.81s
[ip-172-31-9-33.fayson.com:25003] >

  • 通过以上测试可以看到,两个终端执行的SQL不在同一个Impala Daemon,这样就实现了Impala Daemon服务的负载均衡。

大数据视频推荐:
CSDN


推荐阅读
author-avatar
被遗忘的孩子1995
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有