如何实现双机热备

简介:

最近项目需要实现双机热备,大体情况是这样的

1、2台监控主机一个做主机一个做备机

2、系统是window server 2008 环境.net4.0

3、2台监控主机上面都有同一款监控软件(c#开发),但只有一个软件在运行,另一个软件不启动

4、我想要实现的是主机的监控软件关闭后,备机可以自动检测然后判断主机监控软件已经关闭,备机监控软件启动运行

5、同样备机监控软件启动后,主机的监控软件也可以自动检测,主备机可以相互切换

6、存储数据保存是以文件的形式保存,如何互相备份

我在网上找了很久,发现很多window下面的双机热备软件都需要钱买,倒是liunx下面有开源的软件,

window下面双机热备软件有开源的可以留个言啊。。。

既然不想花钱买又要实现这个功能,下面我谈谈我自己的思路,还请各位批评指正:

1、既然要实现主备机相互检测是否软件在运行,那么必须要用的socket,我的想法是在window上面建立一个

window服务程序,不停的在发心跳包检测对方电脑上的软件是否启动

2、设置3个IP地址,主机一个IP备机一个IP还需要一个公共IP地址,当2台主机切换到备机的时候,清除主机公共IP

(虚拟IP)在备机新建公共IP(虚拟IP),这样不影响通信

3、监控软件和window服务程序进行交互

4、2台电脑存储的数据如何相互备份?

以上是我的想法,请各位大侠给支个招。。。。

非常感谢!!!

 

第一步创建window服务程序代码如下

  protected override void OnStart(string[] args)
        {
            timer1 = new System.Timers.Timer();
            timer1.Interval = 3000;  //设置计时器事件间隔执行时间
            timer1.Elapsed += new System.Timers.ElapsedEventHandler(timer1_Elapsed);
            timer1.Enabled = true;
        }

        protected override void OnStop()
        {
            this.timer1.Enabled = false;
        }
        public static System.Threading.Thread m_NetSendThread;//数据发送线程

        private void timer1_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
        {           
            //打开数据发送线程
            m_NetSendThread = new System.Threading.Thread(new System.Threading.ThreadStart(NetSendThread));
            m_NetSendThread.Priority = ThreadPriority.Lowest;
            m_NetSendThread.Start();
        }
        //双击监测发送线程
        private static void NetSendThread()
        {
            int port=23701;
            string ip="172.16.62.34", localIP="172.16.62.34";
            bool bsjrb, bzbj, bstart;//双击热备,主备机
            int tick = System.Environment.TickCount;
            byte[] sendbuf = new byte[4];
            UdpClient udpsend; //发送端udp
            
            sendbuf[0] = 0x7e;
            try
            {
                bsjrb = true;            

                udpsend = new UdpClient(new IPEndPoint(IPAddress.Parse(localIP), port));
                IPEndPoint groupEP = new IPEndPoint(IPAddress.Parse(ip), port);
                while (true)
                {
                    try
                    {                        
                        #region 使用双击热备,向外发送运行状态广播
                        if (bsjrb)
                        {
                            sendbuf[2] = 0x1;
                            try
                            {
                                udpsend.Send(sendbuf, sendbuf.Length, groupEP);
                            }
                            catch (System.Exception ex)
                            {
                            }
                        }
                        #endregion

                    }
                    catch (System.Exception ex1)
                    {
                    }

                    Thread.Sleep(1000);
                }
            }
            catch (System.Exception ex)
            {
            }
        }

 安装window服务程序

安装成功点击电脑右键查看服务--winservice1存在并已经启动服务

 

说明安装成功。

第二步监控软件接收window服务程序数据判断是否断开

    listener = new UdpClient(new IPEndPoint(IPAddress.Parse(localIP), port));//本地监听主机IP及通讯端口
    IPEndPoint groupEP = new IPEndPoint(IPAddress.Parse(srcip), port);//远端主机IP及通讯端口

   if (bZbj)
lb_title.Text = "主机监控中心站已关闭,备机中心站即将启动.....";

实现主机监控软件断开备机监控软件自动打开

下一步继续实现备机监控软件断开主机监控软件自动打开

第三步主备机存储的数据相互备份还没思路求解!



本文转自夜&枫博客园博客,原文链接:http://www.cnblogs.com/newstart/archive/2012/08/30/2663994.html,如需转载请自行联系原作者

相关文章
|
8月前
|
监控 NoSQL 算法
Redis集群模式:高可用性与性能的完美结合!
小米探讨Redis集群模式,通过一致性哈希分散负载,主从节点确保高可用性。节点间健康检测、主备切换、数据复制与同步、分区策略和Majority选举机制保证服务可靠性。适合高可用性及性能需求场景,哨兵模式则适用于简单需求。一起学习技术的乐趣!关注小米微信公众号“软件求生”获取更多内容。
358 11
Redis集群模式:高可用性与性能的完美结合!
|
运维 Kubernetes 调度
k8s 自身原理之高可用
k8s 自身原理之高可用
113 0
|
负载均衡 关系型数据库 PostgreSQL
Pgpool-II实现高可用+读写分离+负载均衡(八)---- 维护工具
Pgpool提供了一些维护工具,用于日常观察Pgpool运行状态、上线、下线节点等操作。主要有:pcp_stop_pgpool,pcp_node_count,pcp_node_info,pcp_health_check_stats,pcp_proc_count,pcp_proc_info,pcp_detach_node,pcp_attach_node,pcp_recovery_node,pcp_promote_node,pcp_pool_status,pcp_watchdog_info,pcp_reload_config
|
存储 缓存 NoSQL
redis集群模式工作原理
redis集群模式工作原理
131 0
|
弹性计算 安全 物联网
使用场景和主备链路|学习笔记
快速学习使用场景和主备链路
使用场景和主备链路|学习笔记
|
存储 缓存 运维
【高并发/高可用/哨兵机制/集群模式/高可用与主备切换/主从复制/断点续传】
【高并发/高可用/哨兵机制/集群模式/高可用与主备切换/主从复制/断点续传】
200 0
【高并发/高可用/哨兵机制/集群模式/高可用与主备切换/主从复制/断点续传】
【系统概念】容错、高可用和灾备
容错,高可用、灾备这三个词的使用环境极易被混淆。很多时候以为这三个词的意思是相同的。
315 0
【系统概念】容错、高可用和灾备
|
关系型数据库 MySQL Linux
Mysql主从复制与高可用主备切换搭建完整详细版
Mysql主从复制与高可用主备切换搭建完整详细版
|
存储
beegfs高可用模式探讨
beegfs高可用模式探讨
559 0
beegfs高可用模式探讨
|
缓存 监控 NoSQL
超全面分布式缓存高可用方案:哨兵机制
开发工作中对于分布式缓存高可用方案(搭建Redis缓存高可用方案),Redis主从架构下是如何保证高可用的呢? 我们知道是应用了哨兵机制来实现。那Redis 服务部署的哨兵模式主要是什么,又解决了什么问题呢,于是利用周末时间整理了下,相信看完这篇文章,你也可以去给别人做技术分享了。O(∩_∩)O哈哈~
超全面分布式缓存高可用方案:哨兵机制