由于nginx默认仅支持http应用层协议的端口,对四层tcp端口支持不好,需要安装额外的nginx_tcp_proxy_module模块,因此在不方便重新编译nginx模块时,可以用HAProxy代理activemq的tcp端口,只需要6个步骤就可以完成(以Ubuntu为例,CentOS大同小异)。
步骤1:安装HAProxy
apt-get install haproxy
步骤2:配置HAProxy配置文件
vim编辑/etc/haproxy/haproxy.cfg,将defaults段中的mode http和option httplog注释掉,添加一个tcp代理,如下文所示:
global log /dev/log local0 log /dev/log local1 notice chroot /var/lib/haproxy user haproxy group haproxy daemon defaults log global #mode http #option httplog option dontlognull contimeout 5000 clitimeout 50000 srvtimeout 50000 errorfile 400 /etc/haproxy/errors/400.http errorfile 403 /etc/haproxy/errors/403.http errorfile 408 /etc/haproxy/errors/408.http errorfile 500 /etc/haproxy/errors/500.http errorfile 502 /etc/haproxy/errors/502.http errorfile 503 /etc/haproxy/errors/503.http errorfile 504 /etc/haproxy/errors/504.http listen activemq_cluster 0.0.0.0:61616 mode tcp balance source option tcpka option tcplog server activemqnode1 192.168.100.81:61616 check inter 2000 rise 2 fall 3
步骤3:测试HAProxy配置文件是否正确
/usr/sbin/haproxy -c -f /etc/haproxy/haproxy.cfg
步骤4:启用HAProxy,允许init脚本启动HAProxy,如/etc/init.d/haproxy start或service haproxy start等
# /etc/default/haproxy ,ENABLED=1sed -i 's/ENABLED=0/ENABLED=1/g' /etc/default/haproxycat /etc/default/haproxy# Set ENABLED to 1 if you want the init script to start haproxy. ENABLED=1 # Add extra flags here. #EXTRAOPTS="-de -m 16"
步骤5:启动HAProxy并检查运行结果
/etc/init.d/haproxy start或service haproxy start/etc/init.d/haproxy status或service haproxy statusnetstat –anop | grep haproxy或ps –ef | grep haproxy | grep –v grep
步骤6:允许防火墙通过设定的tcp端口
ufw allow 61616/tcp
接下来就可以测试和使用activemq了。
--end--