如何实现双机热备

简介:

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

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,如需转载请自行联系原作者

相关文章
|
11月前
|
缓存 负载均衡 关系型数据库
Pgpool-II实现高可用+读写分离+负载均衡(一)---- 规划及安装
Pgpool-II是一款工作在PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件。提供了连接池、复制、负载均衡、限制过多连接、看门狗、查询缓存等功能。
|
1月前
|
负载均衡 算法 关系型数据库
MySQL集群如何实现负载均衡?
【8月更文挑战第16天】MySQL集群如何实现负载均衡?
62 6
|
4月前
|
监控 NoSQL 算法
Redis集群模式:高可用性与性能的完美结合!
小米探讨Redis集群模式,通过一致性哈希分散负载,主从节点确保高可用性。节点间健康检测、主备切换、数据复制与同步、分区策略和Majority选举机制保证服务可靠性。适合高可用性及性能需求场景,哨兵模式则适用于简单需求。一起学习技术的乐趣!关注小米微信公众号“软件求生”获取更多内容。
258 11
Redis集群模式:高可用性与性能的完美结合!
|
9月前
|
运维 Kubernetes 调度
k8s 自身原理之高可用
k8s 自身原理之高可用
|
10月前
|
负载均衡 关系型数据库 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
|
12月前
|
存储 缓存 NoSQL
redis集群模式工作原理
redis集群模式工作原理
102 0
|
存储 缓存 运维
【Redis集群原理专题】介绍一下常用的Redis集群机制方案的介绍和分析
【Redis集群原理专题】介绍一下常用的Redis集群机制方案的介绍和分析
170 0
【Redis集群原理专题】介绍一下常用的Redis集群机制方案的介绍和分析
|
消息中间件 监控 算法
高可用怎么设计呢
《高可用》系列
164 0
高可用怎么设计呢
|
负载均衡 容灾 NoSQL
【服务器系列】高可用方案
高可用的一些解决方案冷备双机热备同城双活异地双活异地多活。
401 0
【服务器系列】高可用方案
|
SQL 缓存 网络协议
深入理解MySQL主从复制原理以及集群部署流程
主从复制是指将主数据库的 DDL 和 DML 操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数据保持同步。 MySQL支持一台主库同时向多台从库进行复制, 从库同时也可以作为其他从服务器的主库,实现链状复制。
509 0