Haproxy+Keepalived+Jboss集群实施架构一例

Haproxy+Keepalived+Jboss集群实施架构一例,第1张

Haproxy+Keepalived+Jboss集群实施架构一例 一、基础环境


两个IBMx3650M3, *** 作系统CentOS5.9x64,连接到一个IBMDS3400存储。系统底层采用GFS文件系统实现文件共享,数据库是另一个独立的oraclerac集群。这种架构不需要考虑数据库。
GFS文件系统及相关配置请参考上一篇文章中的IBMx3650M3+GFS+IPMIfence生产环境配置示例。这篇文章是上一篇文章的延伸。两台服务器的主机名分别是节点01和节点02。由于应用架构简单,服务器资源有限,通过两台服务器实现双机备份模式的高可用架构。本文来自:http://koumm.blog.51cto.com/

IBMx3650m3+GFS+http://koumm.blog.51cto.com/703525/1544971IPMI围栏生产环境配置示例

该架构如下所示:

1.网络环境及IP地址准备,CentOS5.9x64 1)节点1主机名:node01

注意:IBMserver需要将专用的IMM2端口或标有系统MGMT的网络端口连接到交换机,与本地IP地址在同一个网段。

IPMI:10.10.10.85/24
eth1:192.168.233.83/24
eth1:0

2)节点2主机名:node02

IPMI:10.10.10.86/24
eth1:192.168.233.84/24
eth1:0

3)node01,node02hosts文件配置

#卡特彼勒/etc/主机

192.168.233.83node01
192.168.233.84node02
192.168.233.90VIP
10.10.10.85node01_IPMI
10.10.10.86node02_IPMI

二、双机Keepalived配置

为了实现VIP的出现,作为例子使用的VIP地址是192.168.233.90。

1.安装keepalived软件

注意:keepalive-1.2.12安装后没有问题。

(1)下载软件包并在node01,node02两个节点上安装 wget http://www.keepalived.org/software/keepalived-1.2.12.tar.gz  tar zxvf keepalived-1.2.12.tar.gz  cd keepalived-1.2.12  ./configure --prefix=/usr/local/keepalived  make && make install cp /usr/local/keepalived/sbin/keepalived /usr/sbin/  cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/  cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/  mkdir /etc/keepalived

2.创建keepalived配置文件 1)在node01节点一上配置文件

修改配置文件,绑定网卡为eth1

注意:从机的优先级与原生IP不同,但其他都是一样的。

# vi /etc/keepalived/keepalived.conf   ! Configuration File for keepalived global_defs {    notification_email {      xxx@126.com    }    notification_email_from service@abc.com    smtp_server 127.0.0.1    smtp_connect_timeout 30    router_id LVS_DEVEL } vrrp_instance VI_1 {     state MASTER          interface eth1     virtual_router_id 51     mcast_src_ip 192.168.233.83        priority 100           advert_int 1     authentication {         auth_type PASS         auth_pass 876543     }     virtual_ipaddress {         192.168.233.90         } } 2)在node02节点二上配置文件 # vi /etc/keepalived/keepalived.conf   ! Configuration File for keepalived global_defs {    notification_email {      xxx@126.com    }    notification_email_from service@abc.com    smtp_server 127.0.0.1    smtp_connect_timeout 30    router_id LVS_DEVEL } vrrp_instance VI_1 {     state MASTER          interface eth1     virtual_router_id 51     mcast_src_ip 192.168.233.84     priority 99       advert_int 1     authentication {         auth_type PASS         auth_pass 876543     }     virtual_ipaddress {         192.168.233.90       } } 3.在node01,node02两节点上启动与创建keepalived服务 1)启动服务并加为开机启动: service keepalived start  chkconfig --add keepalived  chkconfig keepalived on

2)测试并观察VIP漂移情况 (1)VIP地址观察

主持人:观察VIP地址如下:

[root@node01 /]# service keepalived start  Starting keepalived: [ OK ][root@node01 /]# ip a  1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue  link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00  inet 127.0.0.1/8 scope host lo  2: eth0: <BROADCAST,MULTICAST> mtu 1500 qdisc noop qlen 1000  link/ether e4:1f:13:65:0e:a0 brd ff:ff:ff:ff:ff:ff  3: eth1: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000  link/ether e4:1f:13:65:0e:a2 brd ff:ff:ff:ff:ff:ff  inet 192.168.233.83/24 brd 192.168.230.255 scope global eth1  inet 10.10.10.87/24 brd 10.10.10.255 scope global eth1:0  inet 192.168.233.85/32 scope global eth1  4: usb0: <BROADCAST,MULTICAST> mtu 1500 qdisc pfifo_fast qlen 1000  link/ether e6:1f:13:57:0e:a3 brd ff:ff:ff:ff:ff:ff  [root@node01 /]#

注意:您可以关闭keepalived服务,并通过cat/var/log/messages观察VIP动向。

三、HAproxy反向代理配置

node01、node02配置的 *** 作

1.添加非本机IP邦定支持 # vi /etc/sysctl.conf  net.ipv4.ip_nonlocal_bind = 1 # sysctl –p

2.安装haproxy软件 # tar zxvf haproxy-1.4.25.tar.gz  # cd haproxy-1.4.25  # make TARGET=linux26 PREFIX=/usr/local/haproxy  # make install PREFIX=/usr/local/haproxy  # cd /usr/local/haproxy  # mkdir conf

3.安装socat工具 # wget http://www.dest-unreach.org/socat/download/socat-2.0.0-b5.tar.gz  # tar zxvf socat-2.0.0-b5.tar.gz  # ./configure --disable-fips  # make && make install

4.创建配置文件 1)node01上创建配置文件 # vi /usr/local/haproxy/conf/haproxy.cfg global  log 127.0.0.1 local0  maxconn 65535  chroot /usr/local/haproxy  uid 99  gid 99  stats socket /usr/local/haproxy/HaproxSocket level admin  daemon  nbproc 1  pidfile /usr/local/haproxy/haproxy.pid  #debug defaults  log 127.0.0.1 local3  mode http  option httplog  option httpclose  option dontlognull  option forwardfor  option redispatch  retries 2  maxconn 2000  balance source  #balance roundrobin  stats uri /haproxy-stats  contimeout 5000  clitimeout 50000  srvtimeout 50000 listen web_proxy 0.0.0.0:80  mode http  option httpchk GET /test.html HTTP/1.0\r\nHost:192.168.233.90  server node01 192.168.233.83:8000 weight 3 check inter 2000 rise 2 fall 1  server node02 192.168.233.84:8000 weight 3 backup check inter 2000 rise 2 fall 1 listen stats_auth 0.0.0.0:91  mode http  stats enable  stats uri /admin  stats realm "Admin console"  stats auth admin:123456  stats hide-version  stats refresh 10s  stats admin if TRUE

2)node02上创建配置文件 # vi /usr/local/haproxy/conf/haproxy.cfg global  log 127.0.0.1 local0  maxconn 65535  chroot /usr/local/haproxy  uid 99  gid 99  stats socket /usr/local/haproxy/HaproxSocket level admin  daemon  nbproc 1  pidfile /usr/local/haproxy/haproxy.pid  #debug defaults  log 127.0.0.1 local3  mode http  option httplog  option httpclose  option dontlognull  option forwardfor  option redispatch  retries 2  maxconn 2000  balance source  #balance roundrobin  stats uri /haproxy-stats  contimeout 5000  clitimeout 50000  srvtimeout 50000 listen web_proxy 0.0.0.0:80  mode http  option httpchk GET /test.html HTTP/1.0\r\nHost:192.168.233.90  server node01 192.168.233.83:8000 weight 3 backup check inter 2000 rise 2 fall 1  server node02 192.168.233.84:8000 weight 3 check inter 2000 rise 2 fall 1 listen stats_auth 0.0.0.0:91  mode http  stats enable  stats uri /admin  stats realm "Admin_console"  stats auth admin:123456  stats hide-version  stats refresh 10s  stats admin if TRUE

注意:这两个节点是活动和备用模式,它们都被优化为使用本地节点作为活动节点,这也可以是负载平衡模式。

5.node01,node02上配置HAproxy日志文件 1)Haproxy日志配置 # vi /etc/syslog.conf  local3.* /var/log/haproxy.log  local0.* /var/log/haproxy.log  *.info;mail.none;authpriv.none;cron.none;local3.none /var/log/messages

注意:第三行删除了/var/log/message中记录haproxy.log日志的功能。

# vi /etc/sysconfig/syslog  SYSLOGD_OPTIONS="-r -m 0"

直接手动执行

service syslog restart  touch /var/log/haproxy.log  chown nobody:nobody /var/log/haproxy.log 注:99默认是nobody用户  chmod u+x /var/log/haproxy.log

2)haproxy日志切割 # vi /root/system/cut_log.sh  #!/bin/bash  # author: koumm  # desc:  # date: 2014-08-28  # version: v1.0  # modify: # cut haproxy log  if [ -e /var/log/haproxy.log ]; then  mv /var/log/haproxy.log /var/log/haproxy.log.bak  fi if [ -e /var/log/haproxy.log.bak ]; then  logrotate -f /etc/logrotate.conf  chown nobody:nobody /var/log/haproxy.log  chmod +x /var/log/haproxy.log  fi sleep 1 if [ -e /var/log/haproxy.log ]; then  rm -rf /var/log/haproxy.log.bak  fi

注意:root权限执行脚本。
#crontab-e
5923***su-root-c'/root/system/cut_log.sh'

6.配置HAproxy启动服务 # vi /etc/init.d/haproxy #!/bin/sh  # chkconfig: 345 85 15  # description: HAProxy is a TCP/HTTP reverse proxy which is particularly suited for high availability environments. # Source function library.  if [ -f /etc/init.d/functions ]; then  . /etc/init.d/functions  elif [ -f /etc/rc.d/init.d/functions ] ; then  . /etc/rc.d/init.d/functions  else  exit 0  fi # Source networking configuration.  . /etc/sysconfig/network # Check that networking is up.  [ ${NETWORKING} = "no" ] && exit 0  [ -f /usr/local/haproxy/conf/haproxy.cfg ] || exit 1 RETVAL=0 start() {  /usr/local/haproxy/sbin/haproxy -c -q -f /usr/local/haproxy/conf/haproxy.cfg if [ $? -ne 0 ]; then  echo "Errors found in configuration file."  return 1  fi echo -n "Starting HAproxy: "  daemon /usr/local/haproxy/sbin/haproxy -D -f /usr/local/haproxy/conf/haproxy.cfg -p /var/run/haproxy.pid  RETVAL=$? echo  [ $RETVAL -eq 0 ] && touch /var/lock/subsys/haproxy  return $RETVAL  } stop() {  echo -n "Shutting down HAproxy: "  killproc haproxy -USR1  RETVAL=$?  echo  [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/haproxy  [ $RETVAL -eq 0 ] && rm -f /var/run/haproxy.pid  return $RETVAL  } restart() {  /usr/local/haproxy/sbin/haproxy -c -q -f /usr/local/haproxy/conf/haproxy.cfg  if [ $? -ne 0 ]; then  echo "Errors found in configuration file, check it with 'haproxy check'."  return 1  fi  stop  start  } check() {  /usr/local/haproxy/sbin/haproxy -c -q -V -f /usr/local/haproxy/conf/haproxy.cfg  } rhstatus() {  status haproxy  } condrestart() {  [ -e /var/lock/subsys/haproxy ] && restart || :  } # See how we were called. case "$1" in  start)  start  ;;  stop)  stop  ;;  restart)  restart  ;;  reload)  restart  ;;  condrestart)  condrestart  ;;  status)  rhstatus  ;;  check)  check  ;;  *)  echo $"Usage: haproxy {start|stop|restart|reload|condrestart|status|check}"  RETVAL=1  esac exit $RETVAL

(2)node01,node02上创建service服务 chmod +x /etc/init.d/haproxy  chkconfig --add haproxy  chkconfig haproxy on  service haproxy start

(3)测试监控

http://192.168.233.85:91/admin
http://192.168.233.83:91/admin
http://192.168.233.84:

四、Jboss-EAP-4.3集群配置 配置要点: 1)Jboss及java基础环境配置略,Jboss会话复制是本例的重点。 2)Jboss及应用程序代码部署在GFS集群文件系统目录上,两节点能够访问同一个内容。 3)延伸可以部署监控脚本监控jboss应用,如果进程死掉或无法访问,重启应用,本文略过该内容。

1.添加JBoss会话复制功能

在应用程序中配置会话复制

#VI/cluster/zhzxxt/deploy/app.war/web-INF/WEB.XML

<!DOCTYPE web-app  PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"  "http://java.sun.com/dtd/web-app_2_3.dtd">  <web-app>  <distributable/>

2.修改集群标识 1)修改集群标识

#VI/cluster/JBoss4/server/node01/deploy/JBoss-weB-cluster.sar/META-INF/JBoss-service.XML
#VI/cluster/JBoss4/server/node02/deploy/jboss-web-cluster.sar/META-INF/jboss-service.xml
<;attributename="clustername">;Tomcat-APP-Cluster<;/attribute>;

2)采用TCP方式实现会话复制通讯,注释掉原UDP多播配置文件,因多播绑定端口到本机最后一个IP地址上,会造成多网段两台服务器绑定IP网段不一样,复制进程无法通讯,改为TCP模式问题解决。 <config>  <TCP bind_addr="192.168.233.83" start_port="7810" loopback="true"  tcp_nodelay="true"  recv_buf_size="20000000"  send_buf_size="640000"  discard_incompatible_packets="true"  enable_bundling="true"  max_bundle_size="64000"  max_bundle_timeout="30"  use_incoming_packet_handler="true"  use_outgoing_packet_handler="false"  down_thread="false" up_thread="false"  use_send_queues="false"  sock_conn_timeout="300"  skip_suspected_members="true"/>  <TCPPING initial_hosts="192.168.233.83[7810],192.168.233.84[7810]" port_range="3"  timeout="3000"  down_thread="true" up_thread="true"  num_initial_members="3"/>  <MERGE2 max_interval="100000"  down_thread="true" up_thread="true" min_interval="20000"/>  <FD_SOCK down_thread="true" up_thread="true"/>  <FD timeout="10000" max_tries="5" down_thread="true" up_thread="true" shun="true"/>  <VERIFY_SUSPECT timeout="1500" down_thread="true" up_thread="true"/>  <pbcast.NAKACK max_xmit_size="60000"  use_mcast_xmit="false" gc_lag="0"  retransmit_timeout="300,600,1200,2400,4800"  down_thread="true" up_thread="true"  discard_delivered_msgs="true"/>  <pbcast.STABLE stability_delay="1000" desired_avg_gossip="50000"  down_thread="false" up_thread="false"  <pbcast.GMS print_local_addr="true" join_timeout="3000"  down_thread="true" up_thread="true"  join_retry_timeout="2000" shun="true"  view_bundling="true"/>  <FC max_credits="2000000" down_thread="true" up_thread="true"  min_threshold="0.10"/>  <FRAG2 frag_size="60000" down_thread="true" up_thread="true"/>  <pbcast.STATE_TRANSFER down_thread="true" up_thread="true" use_flush="false"/>  </config>

整个架构配置完成,在测试过程中稳定可靠。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/784364.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-04
下一篇 2022-05-04

发表评论

登录后才能评论

评论列表(0条)

保存