针对Web服务器容灾的自动切换方案测试

简介:

我们网站的XX服务随着业务的增长我们需要配置跨IDC容灾情况,为了处理突发事件,避免影响网站的正常访问

自己在网上看了很多处理方法,结合自己的实际情况,我自己也在在局域网的测试服务器上演练了一把。

测试结果表现良好,现在把我在局域网中的部署整理如下:

思路:
当服务器A 发生故障,服务器B可以迅速接管服务器A的任务,不影响用户的正常访问。
当服务器A 故障恢复,服务器A可以马上接管服务器B的任务,服务器B恢复备机状态。

做法:
两台服务器上配置一个虚拟IP地址,主服务器先绑定虚拟ip地址,当发生故障时,备机自动接管虚拟ip地址

刷新网关路由地址。当主机恢复后,备机释放虚拟ip地址,主机再次主动接管虚拟ip地址,刷新网关路由地址

结构图:

wKiom1lM3piiFMnHAAE-8fryLOM266.png-wh_50

主服务器:ip 192.168.190.199
备服务器: ip 192.168.190.208

vip:192.168.190.88
gateWay=192.168.190.254
netMask=255.255.255.0
bcast=192.168.190.255

步骤:

1、配置虚拟ip:192.168.190.88 到 www.test.com 绑定虚拟ip

/sbin/ifconfig eth0:1 192.168.190.88 broadcast 192.168.190.255    

netmask 255.255.255.0  up  

/sbin/route add -host 192.168.190.88 dev eth0:1  

2、刷新网关路由

/sbin/arping -i eth0 -s 192.168.190.88  192.168.190.254 > /dev/null 2>&1  


3、当发生故障时,主机192.168.190.199 ,释放虚拟ip192.168.190.88,备机192.168.190.208接管 虚拟ip192.168.190.88

/sbin/ifconfig eth0:1 192.168.190.88  broadcast  192.168.190.255   netmask 255.255.255.0 down          

/sbin/arping -i eth0 -s 192.168.190.88  192.168.190.254 > /dev/null 2>&1  


4、这时 www.test.com 解析到了备机服务器192.168.190.208

5、重启备机web服务器

6、若主机192.168.190.199服务恢复正常,备机192.168.190.208

释放虚拟IP,主机,绑定虚拟IP 192.168.190.88 备机释放虚拟ip:


/sbin/ifconfig eth0:1 192.168.190.88  broadcast  192.168.190.255   netmask 255.255.255.0 down          

/sbin/arping -i eth0 -s 192.168.190.88  192.168.190.254 > /dev/null 2>&1  


7、重启启动主备机web服务

主机192.168.190.199
autoSwitchMain.sh切换脚本


    #!/bin/sh  
    #############################################################  
    #desc:服务器宕机自动切换服务  
    #author:gaozhonghui  
    #mail:toptreegzh@163.com  
    #date:20121101  
    #############################################################  
      
    vip=192.168.190.88  
    gateWay=192.168.190.254  
    netMask=255.255.255.0  
    bcast=192.168.190.255  
      
    function_bind_vip1(){  
    /sbin/ifconfig eth0:1 ${vip} broadcast ${bcast}  netmask ${netMask} up  
    /sbin/route add -host ${vip} dev eth0:1  
    }  
      
    function_remove_vip1(){  
    /sbin/ifconfig eth0:1 ${vip} broadcast ${bcast}  netmask ${netMask down  
    }  
      
    function_vip_arping1(){  
    /sbin/arping -i eth0 -s ${vip} ${gateWay} > /dev/null 2>&1  
    }  
      
    function_restart_nginx(){  
    /web/webserver/nginx/sbin/nginx -s reload  
    }  
      
    bind_time_vip="N"  
      
    while true  
    do  
        httpCode_rip1=`/usr/bin/curl -o /dev/null -s -w %{http_code} http://192.168.190.199`  
          
        if [ x${httpCode_rip1} == "x200" ];  
        then  
            if [ ${bind_time_vip} == "N" ];  
            then  
                function_bind_vip1  
                function_vip_arping1  
                bind_time_vip="Y"  
            fi  
            function_vip_arping1  
        else  
            if [ ${bind_time_vip} == "Y" ]  
            then  
                function_remove_vip1  
                bind_time_vip="N"  
            fi  
        fi  
        sleep 10  
    done  


然后linux 启动守候进程
/usr/bin/nohup /bin/sh  /home/Gzh/shell/ autoSwitchMain.sh   2>&1 > /dev/null &

备机192.168.190.208:
autoSwitchSlave.sh


    #!/bin/sh  
    #############################################################  
    #desc:服务器宕机自动切换服务  
    #author:gaozhonghui  
    #mail:toptreegzh@163.com  
    #date:20121101  
    #############################################################  
      
    vip=192.168.190.88  
    gateWay=192.168.190.254  
    netMask=255.255.255.0  
    bcast=192.168.190.255  
      
    function_bind_vip1(){  
    /sbin/ifconfig eth0:1 ${vip} broadcast ${bcast}  netmask ${netMask} up  
    /sbin/route add -host ${vip} dev eth0:1  
    }  
      
    function_remove_vip1(){  
    /sbin/ifconfig eth0:1 ${vip} broadcast ${bcast}  netmask ${netMask} down  
    }  
      
    function_vip_arping1(){  
    /sbin/arping -i eth0 -s ${vip} ${gateWay} > /dev/null 2>&1  
    }  
      
    function_restart_nginx(){  
    /web/webserver/nginx/sbin/nginx -s reload  
    }  
      
    bind_time_vip="N"  
      
    while true  
    do  
            httpCode_rip1=`/usr/bin/curl -o /dev/null -s -w %{http_code} http://192.168.190.199`  
      
            if [ x${httpCode_rip1} == "x200" ];  
            then  
                    if [ ${bind_time_vip} == "Y" ];  
                    then  
                            function_remove_vip1  
                            bind_time_vip="N"  
                    fi  
                    function_vip_arping1  
            else  
                    if [ ${bind_time_vip} == "N" ]  
                    then  
                            function_bind_vip1  
                            function_vip_arping1  
                            bind_time_vip="Y"  
                    fi  
            fi  
      
            sleep 10  
    done  


启动守候进程
/usr/bin/nohup /bin/sh  /home/Gzh/shell/autoSwitchSlave.sh   2>&1 > /dev/null &



本文转自 2012hjtwyf 51CTO博客,原文链接:http://blog.51cto.com/hujiangtao/1944292,如需转载请自行联系原作者

相关文章
|
1天前
|
Web App开发 移动开发 前端开发
web端实现rtsp实时推流视频播放可行性方案
总之,要在Web端实现RTSP实时推流视频播放,需要使用适当的前端技术(如HTML5 Video或WebRTC),以及媒体服务器或流转换器来处理RTSP流。这需要一些开发和配置工作,但是可以实现实时视频流的播放。具体的实现方案可能会根据您的需求和技术栈而有所不同,所以需要仔细评估和选择适合您的解决方案。
8 0
|
1天前
|
JSON 监控 安全
LabVIEW测试和调试Web服务
LabVIEW测试和调试Web服务
|
1天前
|
NoSQL 关系型数据库 MySQL
涉及rocketMQ,jemeter等性能测试服务器的安装记录
涉及rocketMQ,jemeter等性能测试服务器的安装记录
12 1
|
1天前
|
JSON 应用服务中间件 Linux
skywalking内部测试服务器安装记录
skywalking内部测试服务器安装记录
|
2天前
|
监控 测试技术 Apache
如何测试服务器性能?
通过以上步骤,您可以全面评估服务器的性能,找出潜在问题,并采取措施来提高服务器的性能和稳定性。这对于确保服务器在实际生产环境中能够高效运行非常重要。
12 1
|
5天前
|
缓存 负载均衡 安全
深入探索Nginx高性能Web服务器配置与优化
【5月更文挑战第7天】本文深入探讨了Nginx的配置与优化,重点介绍了基础配置参数如`worker_processes`、`worker_connections`和`keepalive_timeout`,以及优化策略,包括使用epoll事件驱动模型、开启gzip压缩、启用缓存、负载均衡和安全配置。此外,还提到了性能调优工具,如ab、nginx-stats和nmon,以助于提升Nginx的性能和稳定性。
|
5天前
|
SQL 安全 数据处理
Web 测试神器:HackBar 保姆级教程
Web 测试神器:HackBar 保姆级教程
|
12天前
|
编解码 前端开发 JavaScript
【Web 前端】移动端适配方案有哪些?
【4月更文挑战第22天】【Web 前端】移动端适配方案有哪些?
|
13天前
|
中间件 Go API
Golang深入浅出之-Go语言标准库net/http:构建Web服务器
【4月更文挑战第25天】Go语言的`net/http`包是构建高性能Web服务器的核心,提供创建服务器和发起请求的功能。本文讨论了使用中的常见问题和解决方案,包括:使用第三方路由库改进路由设计、引入中间件处理通用逻辑、设置合适的超时和连接管理以防止资源泄露。通过基础服务器和中间件的代码示例,展示了如何有效运用`net/http`包。掌握这些最佳实践,有助于开发出高效、易维护的Web服务。
28 1
|
16天前
|
机器学习/深度学习 数据挖掘 Python
使用Python实现简单的Web服务器
使用Python内置的http.server模块,本文演示了创建基本Web服务器的步骤。通过编写简单的代码,实现响应GET请求并返回“Hello, World!”。此外,还展示了如何扩展服务器功能,处理不同URL路径,如根路径和/about路径,并实现404错误页面。这个基础教程为理解HTTP服务器原理和Python网络编程入门提供了帮助。对于复杂Web应用,建议使用Flask或Django等高级框架。