Linux系统 CentOS 7怎么搭建集群

Linux系统 CentOS 7怎么搭建集群,第1张

CentOS 7下怎么搭建高可用集群。高可用集群是指以减少服务中断时间为目的的服务器集群技术。它通过保护用户的业务程序对外不间断提供的服务,把因软件/硬件/人为造成的故障对业务的影响降低到最小程度。那么新的centos下怎么来搭建高可用集群。

  环境:本文以两台机器实现双集热备高可用集群,主机名node1的IP为192168122168 ,主机名node2的IP为192168122169 。

  一、安装集群软件必须软件pcs,pacemaker,corosync,fence-agents-all,如果需要配置相关服务,也要安装对应的软件

  二、配置防火墙

  1、禁止防火墙和selinux

  修改/etc/sysconfig/selinux确保SELINUX=disabled,然后执行setenforce 0或者reboot服务器以生效

  2、设置防火墙规则

  三、各节点之间主机名互相解析分别修改2台主机名分别为node1和node2,在centos 7中直接修改/etc/hostname加入本机主机名和主机表,然后重启网络服务即可。

  配置2台主机的主机表,在/etc/hosts中加入

  四、各节点之间时间同步在node1和node2分别进行时间同步,可以使用ntp实现。

  五、各节点之间配置ssh的无密码密钥访问。下面的操作需要在各个节点上操作。

  两台主机都要互相可以通信,所以两台主机都得互相生成密钥和复制公钥,相互的节点上的hosts文件是都要解析对方的主机名, 192168122168 node1 192168122169 node2

  六、通过pacemaker来管理高可用集群

  1、创建集群用户

市面上存在两种数据库负载均衡的思路:1

基于数据库连接的负载均衡:例如总共有100个数据库连接,50个连接登录到数据库机器A,另外50个连接登录到数据库机器B,这样每个连接中接下来的所有请求全都是发往同一台数据库机器的

这种数据库负载均衡的思路模拟了WEB上的负载均衡方法,但是由于WEB连接是短时间连接(连接建立后,获取需要的HTML等资源后,连接马上被关闭),而数据库连接是长时间连接(连接建立后,可长时间保持,客户可不停向数据库发送SQL请求,数据库做出回答,如此不断循环直到连接被人为或因错而断开为止),因此这种数据库负载均衡思路存在着明显的缺点:有可能会发生绝大部分的请求压力都集中到某台数据库机器上去,从而使得负载均衡效果失效

2

基于批处理请求的负载均衡:在建立数据库连接的时候,会同时与每台数据库服务器建立连接,之后针对客户端的每次请求,都会根据负载均衡算法,独立地选出某个数据库节点来执行这个请求

此种思路符合数据库长时间连接的特征,不存在上面所述的基于连接的负载均衡方法的缺点

市面上的负载均衡厂商,既有基于连接的,也有基于批处理请求的,用户需仔细辨别才能找到自己想要的合适产品

在实际应用中,如果网站的访问量很大,为了提高访问速度,可以与多个Tomcat服务器与Apache服务器集成,让他们共同运行servlet/jsp组件的任务,多个Tomcat服务器构成了一个集群(Cluster)系统,共同为客户提供服务。集群系统具有以下优点:

高可靠性(HA):利用集群管理软件,当主服务器故障时,备份服务器能够自动接管主服务器的工作,并及时切换过去,以实现对用户的不间断服务。  

高性能计算(HP):即充分利用集群中的每一台计算机的资源,实现复杂运算的并行处理,通常用于科学计算领域,比如基因分析,化学分析等。  

负载平衡:即把负载压力根据某种算法合理分配到集群中的每一台计算机上,以减轻主服务器的压力,降低对主服务器的硬件和软件要求。  

原理:JK插件的负载均衡器根据在workerproperties中配置的lbfactor(负载平衡因数),负责为集群系统中的Tomcat服务器分配工作负荷,以实现负载平衡。每个Tomcat服务器间用集群管理器(SimpleTcpCluster)进行通信,以实现HTTP回话的复制,比如Session。

下面我们在一台机器上配置一个Apache和两个Tomcat服务器集群:

2安装Apache,安装两个Tomcat,并把一个测试项目放到两个Tomcat的webapps目录下以便以后测试。

3把mod_jkso复制到<apache_home>/modules下。

4在<apache_home>/conf目录下创建:workersproperties文件:

"pln">worker "pun"> "pln">list "pun">= "pln"> worker1 "pun">, "pln">worker2 "pun">, "pln">loadbalancer         "com">#apache把Tomcat看成是工人,loadbalancer是负载均衡器

 

workerworker1host=localhost        #Tomcat worker1服务器

workerworker1port=8009            #Tomcat端口

workerworker1type=ajp13            #协议

workerworker1lbfactor=100            #负载平衡因数

 

workerworker2host=localhost        #Tomcat worker2服务器

workerworker2port=8009            #因为在一台机器上所以端口不能一样

workerworker2type=ajp13            #协议

workerworker2lbfactor=100            #设为一样代表两台机器的负载相同

 

workerloadbalancertype=1b

workerloadbalancerbalanced_workers=worker1,worker2

workerloadbalancersticky_seesion=false

workerloadbalancersticky_session_force=false

说明:1workerloadbalancersticky_seesion如果设为true则说明会话具有“粘性”,也就是如果一个用户在一个Tomcat中建立了会话后则此后这个用户的所有操做都由这个Tomcat服务器承担。集群系统不会进行会话复制。如果设为false则下面的 sticky_session_force无意义。

2sticky_session_force:假设sticky_session设为true,用户会话具有了粘性,当当前Tomcat服务器停止服务后,如果sticky_session_force为true也就是强制会话与当前Tomcat关联,那么会报500错误,如果设为false则会转到另外的Tomcat服务器。

 

5修改<apache_home>/conf/httpdconf文件,在文件后面加上:

"com">#Tomcat集群配置

"com">LoadModule jk_module modules/mod_jkso

JkWorkersFile conf/workersproperties

#我的工人们

JkLogFile logs/mod_jklog            

#日志文件

JkLogLevel debug                     

#tomcat运行模式

JkMount /jsp loadbalancer          

#收到jsp结尾的文件交给负载均衡器处理

JkMount /helloapp/ loadbalancer     

#收到helloapp/路径交给负载均衡器处理

6修改两个Tomcat的conf/servicexml文件。

61首先要修改AJP端口,确保他们与workersproperties中配置的一样

例如按我们上面的配置,只需要把Tomcat2中的AJP端口该为8109即可。

62此外在使用了loadbalancer后,要求worker的名字与Tomcat的servicexml中的Engine元素的jvmRoute属性一致,

例如worker1修改为: <Engine name="Catalina" defaultHost="localhost" jvmRoute="worker1">

63另外,如果两台Tomcat服务器装在一台机器上,必须确保他们的端口没有冲突,Tomcat中一共配置了三个端口:

<Server port="8005" shutdown="SHUTDOWN">

<Connector port="8080" />

<Connector port="8109" protocol="AJP/13" redirectPort="8443" />

把其中一个该了让它们不一样就行了。

 

完成了以上步骤我们的集群算是基本完成了,打开Apache和两个Tomcat 浏览器进入:localhost/demo/ 能够正确访问。

为了测试,我们写一个jsp文件:testjsp

"tag"><html>

<head>

<title>test</title>

</head>

<body>

    <%

        Systemoutprintfln("call testjsp");

    %>

    session:<%=sessiongetId() %>

</body></html>

把它放到两个Tomcat中的demo项目中,浏览器访问这个页面,每次访问只在一个Tomcat控制台打印语句。

然而页面中的Session Id是会变的。这种情况下如果一个用户正在访问时,如果跳到另一个Tomcat服务器,那么他的session就没有了,可能导致错误。

 

7配置集群管理器

如果读者对HttpSession有了解应该知道,用户的会话状态保存在session中,一个浏览器访问多个网页它们的请求始终处于一个会话范围中,因此SessionID应该是不变的。

以上我们看到的浏览器中的SessionID不同,因为转到另一个Tomcat后当前会话就结束了,又在另一个服务器上开启了一个新的会话。那么怎么让多个Tomcat服务器共享一个会话呢

为了解决上述问题,我们启用Tomcat的集群管理器(SimpleTcpCluster):

71修改Tomcat1和Tomcat2的servletxml文件,在Engine元素中加入以下Cluster元素

"tag"><Cluster "pln">  "atn">className "pun">= "atv">"orgapachecatalinahatcpSimpleTcpCluster"

            channelSendOptions="8">

 

        <Manager className="orgapachecatalinahasessionDeltaManager"

        expireSessionsOnShutdown="false"

        notifyListenersOnReplication="true"/>

 

        <Channel className="orgapachecatalinatribesgroupGroupChannel">

            <Membership className="orgapachecatalinatribesmembershipMcastService"

                        bind="127001"

                        address="228004"

                        port="45564"

                        frequency="500"

                        dropTime="3000"/>    

            <Receiver className="orgapachecatalinatribestransportnioNioReceiver"

                      address="auto"

                      port="4000"

                      autoBind="100"

                      selectorTimeout="5000"

                      maxThreads="6"/>

            <Sender className="orgapachecatalinatribestransportReplicationTransmitter">

                <Transport className="orgapachecatalinatribestransportnioPooledParallelSender"/>

            </Sender>

            <Interceptor className="orgapachecatalinatribesgroupinterceptorsTcpFailureDetector"/>

            <Interceptor className="orgapachecatalinatribesgroupinterceptorsMessageDispatch15Interceptor"/>

        </Channel>

 

        <Valve className="orgapachecatalinahatcpReplicationValve" filter=""/>

        <Valve className="orgapachecatalinahasessionJvmRouteBinderValve"/>

 

        <Deployer className="orgapachecatalinahadeployFarmWarDeployer"

                    tempDir="/tmp/war-temp/"

                    deployDir="/tmp/war-deploy/"

                    watchDir="/tmp/war-listen/"

                    watchEnabled="false"/>

        <ClusterListener className="orgapachecatalinahasessionJvmRouteSessionIDBinderListener"/>

        <ClusterListener className="orgapachecatalinahasessionClusterSessionListener"/>

        </Cluster> 

关于Cluster的相关介绍参照:<tomcat-home>\webapps\docs\cluster-howtohtml  <tomcat-home>\webapps\docs\config\clusterhtml

72分别修改Tomcat1和Tomcat2 demo项目的webxml文件,在后面加入<distributable>元素

"tag"><web-app>

"pln">

"tag"><distributable/>

</web-app>

如果一个web项目的webxml文件中指定了<distributable/>元素那么Tomcat服务器启动这个Web应用时,会为它创建由<Cluster>元素指定的会话管理器,这里我们用的是DeltaManager,他们把会话从一个Tomcat服务器复制到集群中另一个Tomcat服务器。

73重新启动两个Tomcat,发现Tomcat控制台还是依次打印出Call testjsp 页面中的SessionID却不变了。测试完成。

重要说明:(1)如果项目要发布到集群上,那么与会话有关的类需要实现javaioSerializable序列化接口。

(2)集群中Tomcat间用组播方式进行通信,如果机器上有多个网卡则可能导致组播失败,解决的办法是<Cluster>元素的<Membership>元素配置bind属性,它用于明确知道组播地址:

<Membership className="orgapachecatalinatribesmembershipMcastService" bind="127001"/>

(3)如果集群较小,可以采用DeltaManager会话管理器,如果多的话建议使用BackupManager

(4)<Membership>的address设为"228004",运行时须确保机器联网能访问到该地址,否则可能运行失败。

有两种常用的服务器集群方法,一种是将备份服务器连接在主服务器上,当主服务器发生故障时,备份服务器才投入运行,把主服务器上所有任务接管过来。另一种方法是将多台服务器连接,这些服务器一起分担同样的应用和数据库计算任务,改善关键大型应用的响应时间。同时,每台服务器还承担一些容错任务,一旦某台服务器出现故障时,系统可以在系统软件的支持下,将这台服务器与系统隔离,并通过各服务器的负载转嫁机制完成新的负载分配。PC服务器中较为常见的是两台服务器的集群,UNIX系统可支持8台服务器的集群系统,康柏的专用系统OpenVMS可支持多达96台服务器的集群系统。

不难,硬件用路由器,软件嘛,操作系统用WIN2003 server enterprise 企业版,推荐一并安装R2升级包,所有机器组局域网,用一台千兆网卡做域控,架设流媒体服务器,其他机做为域成员加入进来,内网IP各用各的,外网用端口映射到一个IP,用域控做网络流量负载平衡,域控机器配置要强,如果你网络流量大,建议用专业级服务器,至强+2Gb+SCSI硬盘之类,看你环境要求了,如果必要可以上双至强,再用一台512mb内存的p4 20G以上机做备份域控,这样主域控上下线或重启或出故障不影响域内成员正常工作,备份域控凑合就可以了,按我上面的要求就行,当然,有钱可以用好的

如果你安全性要求高,建议路由前端用普通P4+512Mb内存机器架ISA2004 server组防火墙,配置的好效果比一般的硬件防火墙要好,完全不影响网络环境运行,域内成员可以裸奔不怕毒和黑

至于域内成员机,如果仅全力供应片源,当前主流家用机型就够用了

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » Linux系统 CentOS 7怎么搭建集群

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情