精华内容
下载资源
问答
  • 双机热备是应用于服务器的一种解决方案,其构造思想是主机和从机通过TCP/IP网络连接,正常情况下主机处于工作状态,从机处于监视状态,一旦从机发现主机异常,从机将会在很短的时间之内代替主机,完全实现主机的功能...

    792c48d27c5d6be71a60d4ae91a2567d.png

    双机热备是应用于服务器的一种解决方案,其构造思想是主机和从机通过TCP/IP网络连接,正常情况下主机处于工作状态,从机处于监视状态,一旦从机发现主机异常,从机将会在很短的时间之内代替主机,完全实现主机的功能。MySQL数据库提供了一种主从备份的机制,其实就是把主数据库的所有的数据同时写到备份的数据库中,实现MySQL数据库的热备份,从而实现MySQL双机热备。

    9a2712f2194da3fba9d71d1ea26d3b8f.png

    要想实现双机热备,首先要了解主从数据库服务器的版本的需求。要实现热备MySQL的版本都高于3.2。还有一个基本的原则就是作为从数据库的数据版本可以高于主服务器数据库的版本,但是不可以低于主服务器的数据库版本。

    当然要实现MySQL双机热备,除了MySQL本身自带的REPLICATION功能可以实现外,也可以用Heartbeat这个开源软件来实现。主从复制的根本操作就是把从主服务器上所执行过的SQL在从机上再执行一遍,只要两个机器的数据库初态(数据库结构,数据,配置)是一样的,那么我们开启主从复制之后就能保证他们一直都是一样的状态。这些都是mysql自己实现的,我们就配置一下就可以了。

    双机热备主要是实时数据、报警信息和变量历史记录的热备。主从机都正常工作时,主机从设备采集数据,并产生报警和事件信息。从机通过网络从主机获取实时数据和报警信息,而不会从设备读取或自己产生报警信息,主从机都各自记录变量历史数据。同时,从机通过网络监听主机,从机与主机之间的监听采取请求与应答的方式,从机以一定的时间间隔(冗余机心跳检测时间)向主机发出请求,主机应答表示工作正常,主机如果没有作出应答,从机将切断与主机的网络数据传输,转入活动状态,改由下位设备获取数据,并产生报警和事件信息。此后,从机还会定时监听主机状态,一旦主机恢复,就切换到热备状态,通过这种方式实现了热备。

    当主机正常运行,从机后启动时,主机先将实时数据和当前报警缓冲区中的报警和事件信息发送到从机上,完成实时数据的热备份。然后主从机同步,暂停变量历史数据记录,从机从主机上将所缺的历史记录文件通过网络拷贝到本地,完成历史数据的热备份。这时可以在主从机组态王信息窗中看到提示信息“开始备份历史数据”和“停止备份历史数据”。

    历史数据文件备份完成后,主从机转入正常工作状态。

    当从机正常运行、主机后启动时,从机先将实时数据和当前报警缓冲区中的报警和事件信息发送到主机上,完成实时数据的热备份。然后主从机同步,暂停变量历史数据记录,主机从从机上将所缺的历史记录文件通过网络拷贝到本地,完成历史数据的热备份。这时也可以在主从机的组态王信息窗中看到提示信息“开始备份历史数据”和“停止备份历史数据”。历史数据文件备份完成后,主从机转入正常工作状态。

    MySQL双机热备针对的是MySQL服务器的故障,服务器的故障可能由各种原因引起,如设备故障、操作系统故障、软件系统故障,等等。对于一些重要系统而言,用户是很难忍受这样长时间的服务中断的。因此,就需要通过双机热备,来避免长时间的服务中断,保证系统长期、可靠的服务。想要了解MySQL双机热备是如何在MySQL数据库中具体实现的,可以观看本站的MySQL教程,里面有很生动形象的图文讲解,帮助我们理解透彻MySQL双机热备的实现。

    展开全文
  • 双机热备概念原理实现步骤

    万次阅读 2019-04-03 10:59:50
    1.双机热备 对于双机热备这一概念,我搜索了很多资料,最后,还是按照大多数资料所讲分成广义与狭义两种意义来说。 从广义上讲,就是对于重要的服务,使用两台服务器,互相备份,共同执行同一服务。当一台服务器...

    1.双机热备

    对于双机热备这一概念,我搜索了很多资料,最后,还是按照大多数资料所讲分成广义与狭义两种意义来说。

    从广义上讲,就是对于重要的服务,使用两台服务器,互相备份,共同执行同一服务。当一台服务器出现故障时,可以由另一台服务器承担服务任务,从而在不需要人工干预的情况下,自动保证系统能持续提供服务。

    从狭义上讲,双机热备就是使用互为备份的两台服务器共同执行同一服务,其中一台主机为工作机(Primary Server),另一台主机为备份主机(Standby Server)。在系统正常情况下,工作机为应用系统提供服务,备份机监视工作机的运行情况(一般是通过心跳诊断,工作机同时也在检测备份机是否正常),当工作机出现异常,不能支持应用系统运营时,备份机主动接管工作机的工作,继续支持关键应用服务,保证系统不间断的运行。双机热备针对的是IT核心服务器、存储、网络路由交换的故障的高可用性解决方案。

    2.为什么要进行双机热备?

    双机热备服务针对的是服务器的故障。服务器的故障可能由各种原因引起,如设备故障、操作系统故障、软件系统故障等等。一般地讲,在技术人员在现场的情况下,恢复服务器正常可能需要10分钟、几小时甚至几天。从实际经验上看,除非是简单地重启服务器(可能隐患仍然存在),否则往往需要几个小时以上。而如果技术人员不在现场,则恢复服务的时间就更长了。

    而对于一些重要系统而言,用户是很难忍受这样长时间的服务中断的。因此,就需要通过双机热备服务,来避免长时间的服务中断,保证系统长期、可靠的服务。

    当然,决定是否使用双机热备,正确的方法是要分析一下系统的重要性以及对服务中断的容忍程度,以些决定是否使用双机热备。换句话说,就是你的用户能容忍多长时间恢复服务,如果服务不能恢复会造成多大的影响。

    在考虑双机热备时,需要注意,一般意义上的双机热备都会有一个切换过程,这个切换过程可能是一分钟左右。在切换过程中,服务是有可能短时间中断的。但是,当切换完成后,服务将正常恢复。因此,双机热备不是无缝、不中断的,但它能够保证在出现系统故障时,能够很快恢复正常的服务,业务不致受到影响。而如果没有双机热备,则一旦出现服务器故障,可能会出现几个小时的服务中断,对业务的影响就可能会造成很严重的损失。

    3.双机热备技术与备份的概念区别

    热备份指的是:High Available(HA)即高可用,而备份指的是Backup,即数据备份的一种,这是两种不同的概念,应对的产品也是两种功能上完全不同的产品。热备份主要保障业务的连续性,实现的方法是故障点的转移。而备份,主要目的是为了防止数据丢失,而做的一份拷贝,所以备份强调的是数据恢复而不是应用的故障转移。

    4.双机热备方案的主要两种组建方式

    双机热备方案在进行讨论的时候一定要考虑到很多的因素,其中在各种环境下应用的时候需要格外的引起注意。当然还是有主要的两方式可以借鉴考虑的。

    第一种,双机热备它的工作原理是使用两台服务器,一台作为主服务器(Active),运行应用系统来提供服务。另一台作为备机,安装完全一样的应用系统,但处于待机状态(Standby)。当Active服务器出现故障时,通过软件诊测将Standby机器激活,保证应用在短时间内完成恢复正常使用。

    第二种,双机互备方式则是在双机热备的基础上,两个相对独立的应用在两台机器同时运行,但彼此均设为备机,当某一台服务器出现故障时,另一台服务器可以在短时间内将故障服务器的应用接管过来,从而保证了应用的持续性,这种方式实际上是双机热备方案的一种应用。

    但目前使用最多的还是主从模式的双机热备方案。其大致表示可如下图所示:


    目前基于存储共享的双机热备是双机热备方案的最标准方案。对于这种方式,采用两台服务器,使用共享的存储设备(磁盘阵列柜或存储区域网SAN)。两台服务器可以采用主从、互备等不同的方式。在工作过程中,两台服务器将以下一个虚拟的IP地址对外提供服务,依工作方式的不同,将服务请求发送给其中一台服务器承担。同时,服务器通过心跳线(目前往往采用建立私有网络的方式)侦测另一台服务器的工作状况。

    下图即为双机热备工作大致状况图,如下图所示:


    双机热备方案当一台服务器出现故障时,另一台服务器根据心跳侦测的情况做出判断,并进行切换,接管服务。对于用户而言,这一过程是全自动的,在很短时间内完成,从而不会对业务造成大的影响。由于使用共享的存储设备,因此两台服务器使用的实际上是一样的数据,由双机或集群软件对其进行管理。

    5.Mysql双机热备实现原理图

    有了上面对双机热备知识的讲解,对其实现原理就有了一个深入了解,那么我们要做mysql数据库的双机热备就清楚明了多了。

    Mysql双机热备系统的拓扑结构如下图所示:

     

     两台服务器通过以太网连接网络,通过网络对外提供服务、相互通信。

    两台服务器之间用com口直接互联,双机热备软件利用这个连接进行双机热备相关的通信、监控和控制等。

    两台服务器通过HBA卡连接FC网络,访问共同的磁盘阵列,实现双机热备系统必要的磁盘。

    6.Mysql双机热备实现的配置

    为了数据的安全,客户有两台机器作为互相备份,当一台机器出现故障时,自动切换到另一台服务器。大部分的软件是通过LifeKeeper来实现的,但是Mysql的双机备份在LifeKeeper里没有实现,所以只能自己手动来实现Mysql的双机备份了。

    其实,Mysql的双机备份有一个很简单的第三方软件可以实现,那就是SQLyog,他有一个功能叫sja(SQLyog Job Agent)可以轻松实现,但是却有一个不足之处,就是Mysql表里必须有一个primary key,即主键值,如果没有,则此表不能用sja来实现。

    第二种方法就是用Mysql自身的Replication机制来实现了。但是这个功能只有Mysql 3.23以上的版本才有。

    这里先说明下,由于我还没有通过实际的应用例子来检测这种双机热备方式是否能过通过,所以我会在我通过实例实现后在续写我后面的关于Mysql双机热备实现的配置部分。现在这部分内容主要讲的还是双机热备份的实现原理和意义。

     

     

     

    ★mysql双机热备的实现  
    接续上一篇关于mysql双机热备实现原理分析,在本文经过深思熟虑和多次用不同的方式实测试后。最后在这篇文章中,用一个小例子来完成mysql双机热备的实现。

    Mysql数据库没有增量备份的机制,当数据量太大的时候备份是一个很大的问题。还好mysql数据库提供了一种主从备份的机制,其实就是把主数据库的所有的数据同时写到备份的数据库中。实现mysql数据库的热备份。 

    要想实现双机的热备,首先要了解主从数据库服务器的版本的需求。要实现热备mysql的版本都高于3.2。还有一个基本的原则就是作为从数据库的数据版本可以高于主服务器数据库的版本,但是不可以低于主服务器的数据库版本。

    当然要实现mysql双机热备,除了mysql本身自带的REPLICATION功能可以实现外,也可以用Heartbeat这个开源软件来实现。不过本文主要还是讲如何用mysql自带的REPLICATION来实现mysql双机热备的功能。

     

    1. 准备服务器
     

    由于Mysql不同版本之间的(二进制日志)binlog格式可能会不太一样,因此最好的搭配组合是主(Master)服务器的Mysql版本和从(Slave)服务器版本相同或者更低,主服务器的版本肯定不能高于从服务器版本。

    本次我用于测试的两台服务器版本都是Mysql-5.5.17。

    2. Mysql 建立主-从服务器双机热备配置步骤
     

    2.1环境描述
    A服务器(主服务器Master):59.151.15.36

    B服务器(从服务器Slave):218.206.70.146

    主从服务器的Mysql版本皆为5.5.17

    Linux环境下

    将主服务器需要同步的数据库内容进行备份一份,上传到从服务器上,保证始初时两服务器中数据库内容一致。

    不过这里说明下,由于我是利用Mysql在安装后就有的数据库test进行测试的,所以两台服务器里面是没有建立表的,只不分别在test里面建立了同样的一张空表tb_mobile;

    Sql语句如下:

    mysql> create table tb_mobile( mobile VARCHAR(20) comment'手机号码', time timestamp DEFAULT now() comment'时间' );

    2.2 主服务器Master配置
    2.2.1 创建同步用户

    进入mysql操作界面,在主服务器上为从服务器建立一个连接帐户,该帐户必须授予REPLICATION SLAVE权限。因为从mysql版本3.2以后就可以通过REPLICATION对其进行双机热备的功能操作。

    操作指令如下:

    mysql> grant replication slave on *.* to 'replicate'@'218.206.70.146' identified by '123456';

    mysql> flush privileges;

    创建好同步连接帐户后,我们可以通过在从服务器(Slave)上用replicat帐户对主服务器(Master)数据库进行访问下,看下是否能连接成功。

    在从服务器(Slave)上输入如下指令:

    [root@YD146 ~]# mysql -h59.151.15.36 -ureplicate -p123456

    如果出现下面的结果,则表示能登录成功,说明可以对这两台服务器进行双机热备进行操作。

    2.2.2 修改mysql配置文件

    如果上面的准备工作做好,那边我们就可以进行对mysql配置文件进行修改了,首先找到mysql配置所有在目录,一般在安装好mysql服务后,都会将配置文件复制一一份出来放到/ect目录下面,并且配置文件命名为:my.cnf。即配置文件准确目录为/etc/my.cnf

    找到配置文件my.cnf打开后,在[mysqld]下修改即可:

    [mysqld]

    server-id = 1

    log-bin=mysql-bin                //其中这两行是本来就有的,可以不用动,添加下面两行即可

    binlog-do-db = test

    binlog-ignore-db = mysql

    2.2.3 重启mysql服务

    修改完配置文件后,保存后,重启一下mysql服务,如果成功则没问题。

    2.2.4 查看主服务器状态

    进入mysql服务后,可通过指令查看Master状态,输入如下指令:

    注意看里面的参数,特别前面两个File和Position,在从服务器(Slave)配置主从关系会有用到的。

    注:这里使用了锁表,目的是为了产生环境中不让进新的数据,好让从服务器定位同步位置,初次同步完成后,记得解锁。

    2.3 从服务器Slave配置
    2.3.1修改配置文件

    因为这里面是以主-从方式实现mysql双机热备的,所以在从服务器就不用在建立同步帐户了,直接打开配置文件my.cnf进行修改即可,道理还是同修改主服务器上的一样,只不过需要修改的参数不一样而已。如下:

    [mysqld]

    server-id = 2

    log-bin=mysql-bin

    replicate-do-db = test

    replicate-ignore-db = mysql,information_schema,performance_schema

    2.3.2重启mysql服务

    修改完配置文件后,保存后,重启一下mysql服务,如果成功则没问题。


     2.3.3用change mster 语句指定同步位置

    这步是最关键的一步了,在进入mysql操作界面后,输入如下指令:

    mysql>stop slave;          //先停步slave服务线程,这个是很重要的,如果不这样做会造成以下操作不成功。

    mysql>change master to

    >master_host='59.151.15.36',master_user='replicate',master_password='123456',

    > master_log_file=' mysql-bin.000016 ',master_log_pos=107;

    注:master_log_file, master_log_pos由主服务器(Master)查出的状态值中确定。也就是刚刚叫注意的。master_log_file对应File, master_log_pos对应Position。Mysql 5.x以上版本已经不支持在配置文件中指定主服务器相关选项。

    遇到的问题,如果按上面步骤之后还出现如下情况:


     则要重新设置slave。指令如下

    mysql>stop slave;

    mysql>reset slave;

    之后停止slave线程重新开始。成功后,则可以开启slave线程了。

    mysql>start slave;

    2.3.4查看从服务器(Slave)状态

    用如下指令进行查看

    mysql> show slave status\G;

    查看下面两项值均为Yes,即表示设置从服务器成功。

    Slave_IO_Running: Yes

    Slave_SQL_Running: Yes

    2.4 测试同步
    之前开始已经说过了在数据库test只有一个表tb_mobile没有数据,我们可以先查看下两服务器的数据库是否有数据:

    Master:59.151.15.36


     Slave:218.206.70.146


     好了,现在可以在Master服务器中插入数据看下是否能同步。

    Master:59.151.15.36


    Slave:218.206.70.146


     可以从上面两个截图上看出,在Master服务器上进行插入的数据在Slave服务器可以查到,这就表示双机热备配置成功了。

    3. Mysql 建立主-主服务器双机热备配置步骤
    服务器还是用回现在这两台服务器

    3.1创建同步用户

    同时在主从服务器建立一个连接帐户,该帐户必须授予REPLIATION SLAVE权限。这里因为服务器A和服务器B互为主从,所以都要分别建立一个同步用户。

    服务器A:

    mysql> grant replication slave on *.* to 'replicate'@'218.206.70.146' identified by '123456';

    mysql> flush privileges;

    服务器B:

    mysql> grant replication slave on *.* to 'replicate'@'59.151.15.36' identified by '123456';

    mysql> flush privileges;

    3.2修改配置文件my.cnf

    服务器A

    [mysqld]

           server-id = 1

    log-bin=mysql-bin 

    binlog-do-db = test

           binlog-ignore-db = mysql

    #主-主形式需要多添加的部分

           log-slave-updates

           sync_binlog = 1

           auto_increment_offset = 1

           auto_increment_increment = 2

           replicate-do-db = test

           replicate-ignore-db = mysql,information_schema

    服务器B:

    [mysqld]

    server-id = 2

    log-bin=mysql-bin 

    master-slave need

           replicate-do-db = test

           replicate-ignore-db = mysql,information_schema,performance_schema

          

    #主-主形式需要多添加的部分

           binlog-do-db = test

           binlog-ignore-db = mysql

           log-slave-updates

           sync_binlog = 1

           auto_increment_offset = 2

           auto_increment_increment = 2

    3.3分别重启A服务器和B服务器上的mysql服务

    重启服务器方式和上面的一样,这里就不做讲解了。

    3.4分别查A服务器和B服务器作为主服务器的状态

    服务器A:

     服务器B:


     3.5分别在A服务器和B服务器上用change master to 指定同步位置

    服务器A:

    mysql>change master to

    >master_host='218.206.70.146',master_user='replicate',master_password='123456',

    > master_log_file=' mysql-bin.000011 ',master_log_pos=497;

    服务器B:

    mysql>change master to

    >master_host='59.151.15.36',master_user='replicate',master_password='123456',

    > master_log_file=' mysql-bin.000016 ',master_log_pos=107;

    3.6 分别在A和B服务器上重启从服务线程

    mysql>start slave;

    3.7 分别在A和B服务器上查看从服务器状态

    mysql>show slave status\G;

    查看下面两项值均为Yes,即表示设置从服务器成功。

    Slave_IO_Running: Yes

    Slave_SQL_Running: Yes

    3.8 测试主-主同步例子

    测试服务器A:

    在服务器A上插入一条语句如下图所示:

     之后在服务器B上查看是否同步如下图所示:

     测试服务器B:

    在服务器B上插入一条语句如下图所示:


     然后在从服务器A上查看是否有同步数据如下图所示:


     最后从结果可以看出主-主形式的双机热备是能成功实现的。

    4. 配置参数说明
    Server-id

    ID值唯一的标识了复制群集中的主从服务器,因此它们必须各不相同。Master_id必须为1到232-1之间的一个正整数值,slave_id值必须为2到232-1之间的一个正整数值。

    Log-bin

    表示打开binlog,打开该选项才可以通过I/O写到Slave的relay-log,也是可以进行replication的前提。

    Binlog-do-db

    表示需要记录二进制日志的数据库。如果有多个数据可以用逗号分隔,或者使用多个binlog-do-dg选项。

    Binglog-ingore-db

    表示不需要记录二进制日志的数据库,如果有多个数据库可用逗号分隔,或者使用多binglog-ignore-db选项。

    Replicate-do-db

    表示需要同步的数据库,如果有多个数据可用逗号分隔,或者使用多个replicate-do-db选项。

    Replicate-ignore-db

    表示不需要同步的数据库,如果有多个数据库可用逗号分隔,或者使用多个replicate-ignore-db选项。

    Master-connect-retry

    master-connect-retry=n表示从服务器与主服务器的连接没有成功,则等待n秒(s)后再进行管理方式(默认设置是60s)。如果从服务器存在mater.info文件,它将忽略些选项。

    Log-slave-updates

    配置从库上的更新操作是否写入二进制文件,如果这台从库,还要做其他从库的主库,那么就需要打这个参数,以便从库的从库能够进行日志同步。

    Slave-skip-errors

    在复制过程,由于各种原因导致binglo中的sql出错,默认情况下,从库会停止复制,要用户介入。可以设置slave-skip-errors来定义错误号,如果复制过程中遇到的错误是定义的错误号,便可以路过。如果从库是用来做备份,设置这个参数会存在数据不一致,不要使用。如果是分担主库的查询压力,可以考虑。

    Sync_binlog=1 Or N

    Sync_binlog的默认值是0,这种模式下,MySQL不会同步到磁盘中去。这样的话,Mysql依赖操作系统来刷新二进制日志binary log,就像操作系统刷新其他文件的机制一样。因此如果操作系统或机器(不仅仅是Mysql服务器)崩溃,有可能binlog中最后的语句丢失了。要想防止这种情况,可以使用sync_binlog全局变量,使binlog在每N次binlog写入后与硬盘同步。当sync_binlog变量设置为1是最安全的,因为在crash崩溃的情况下,你的二进制日志binary log只有可能丢失最多一个语句或者一个事务。但是,这也是最慢的一种方式(除非磁盘有使用带蓄电池后备电源的缓存cache,使得同步到磁盘的操作非常快)。

    即使sync_binlog设置为1,出现崩溃时,也有可能表内容和binlog内容之间存在不一致性。如果使用InnoDB表,Mysql服务器处理COMMIT语句,它将整个事务写入binlog并将事务提交到InnoDB中。如果在两次操作之间出现崩溃,重启时,事务被InnoDB回滚,但仍然存在binlog中。可以用-innodb-safe-binlog选项来增加InnoDB表内容和binlog之间的一致性。(注释:在Mysql 5.1版本中不需要-innodb-safe-binlog;由于引入了XA事务支持,该选项作废了),该选项可以提供更大程度的安全,使每个事务的binlog(sync_binlog=1)和(默认情况为真)InnoDB日志与硬盘同步,该选项的效果是崩溃后重启时,在滚回事务后,Mysql服务器从binlog剪切回滚的InnoDB事务。这样可以确保binlog反馈InnoDB表的确切数据等,并使从服务器保持与主服务器保持同步(不接收回滚的语句)。

    Auto_increment_offset和Auto_increment_increment

    Auto_increment_increment和auto_increment_offset用于主-主服务器(master-to-master)复制,并可以用来控制AUTO_INCREMENT列的操作。两个变量均可以设置为全局或局部变量,并且假定每个值都可以为1到65,535之间的整数值。将其中一个变量设置为0会使该变量为1。

    这两个变量影响AUTO_INCREMENT列的方式:auto_increment_increment控制列中的值的增量值,auto_increment_offset确定AUTO_INCREMENT列值的起点。

    如果auto_increment_offset的值大于auto_increment_increment的值,则auto_increment_offset的值被忽略。例如:表内已有一些数据,就会用现在已有的最大自增值做为初始值。

    原文:https://blog.csdn.net/cf20160405/article/details/77962959 
     

    展开全文
  • 华为的双机热备是通过部署两台或多台防火墙实现热备及负载均衡,两台防火墙相互协同工作,犹如一个更大的防火墙。华为防火墙的双机热备包含以下两种模式:热备模式:同一时间只有一台防火墙转发数据,其他防火墙不...

    一、何为双机热备?

    所谓的双机热备无非就是以7X24小时不中断的为企业提供服务为目的,各种双机热备的技术很多,那么华为使用了这个共有协议的热备协议——VRRP。

    华为的双机热备是通过部署两台或多台防火墙实现热备及负载均衡,两台防火墙相互协同工作,犹如一个更大的防火墙。

    华为防火墙的双机热备包含以下两种模式:

    • 热备模式:同一时间只有一台防火墙转发数据,其他防火墙不转发,但是会同步会话表及server-map表,当目前工作的防火墙宕机以后,备份防火墙接替转发数据的工作。
    • 负载均衡模式:同一时间内,多台防火墙同时转发数据,并且互为备份,每个防火墙既是主设备,也是备用设备。防火墙之间同步会话表及server-map表。

    二、VRRP的概念

    VRRP(virtual router redundancy protocol,虚拟路由冗余协议),用来解决网关单点故障的路由协议。VRRP可以应用在路由器中提供网关冗余,也可以用在防火墙中做双机热备。

    VRRP的相关专业术语介绍:

    • VRRP路由器:运行VRRP协议的路由器。
    • 虚拟路由器:由一个主用路由器和若干个备用路由器组成一个备份组,一个备份组对客户端提供一个虚拟网关。
    • VRID:虚拟路由器标识,用来唯一的标识一个备份组。
    • 虚拟IP地址:提供给客户端的网关地址,也是分配给虚拟路由器的IP地址,在所有的VRRP中配置,只有主用设备提供该IP地址的ARP响应。
    • 虚拟MAC地址:基于VRID生成的用于VRRP的MAC地址,在客户端通过ARP协议解析网关的MAC地址时,主用路由器将提供该MAC地址。
    • IP地址拥有者:若将虚拟路由器的IP地址配置为某个成员物理接口的真实IP地址,那么该成员被称为IP地址拥有者。
    • 优先级:用于标识VRRP路由器的优先级,并通过每个VRRP路由器的优先级选举主用设备及备用设备。
    • 抢占模式:在抢占模式下,如果备用路由器的优先级高于备份组中其他路由器(包括当前的主用路由器),则将立即成为新的主用路由器。
    • 非抢占模式:在非抢占模式下,如果备用路由器的优先级高于备份组中其他路由器(包括当前的主用路由器),也不会立即成为主用路由器,直到下一次公平选举(如重启设备等)。

    三、VRRP的两种角色

    工作在VRRP模式下的路由器有两种角色,分别是Master路由器和Backup路由器。

    • Master路由器:正常情况下由Master路由器负责ARP响应及提供数据包的转发,并且默认每隔1s向其他路由器通告Master路由器当前状态信息。
    • Backup路由器:是Master路由器的备用路由器,正常情况下不提供数据包的转发,当master路由器故障时,在所有的Backup路由器中优先级最高的路由器将成为新的master路由器,接替转发数据包的工作,从而保证业务不中断。

    四、VRRP的选举流程

    VRRP选举master路由器和backup路由器的流程如下:

    首先选举优先级高的设备成为master路由器,如果优先级相同,再比较接口的IP地址大小,IP地址大(数值大)的设备将成为master路由器,而备份组中其他的路由器将成为backup路由器。

    除非手工将路由器配置为IP地址拥有者(优先级=255),否则VRRP的状态切换总是先经历Backup状态,即使路由器的优先级最高,也需要从backup状态过渡到master状态。此时,backup状态只是一个瞬间的过渡状态。

    VRRP中的默认接口优先级为100,取值范围为0~255,其中优先级0是系统保留,优先级255保留给IP地址拥有者,IP地址拥有者不需要配置优先级,默认优先级就是255。

    五、VRRP的三个状态

    VRRP定义了三种状态,分别如下:

    • Initalize状态:刚配置了VRRP时的状态下,在该状态下,不对VRRP报文做任何处理,当接口shutdown或接口故障时也将进入该状态。
    • Master状态:当前设备选举成为master路由器时的一种状态,该状态下会转发数据报文,并周期性地发送VRRP通告报文,当接口关闭或设备宕机后将立即切换至Initialize状态。
    • Backup状态:当前设备选举成为备用路由器时的一种状态,该状态不转发任何数据报文,只会接收master路由器发送VRRP通告报文,以便检测master路由器是否在正常工作,并且还同步主用设备上的状态信息。

    六、通过VGMP统一管理VRRP的状态

    在网络设备上使用VRRP和在其他情景下(Linux中的KeepAlived也使用了VRRP协议)使用并不一样,存在的原因如下图:

    5bd7985c156e3b643a5092bc94df0f22.png

    从上图中可以看出,正常情况下PC去往外部网络的数据包通过备份组1的master设备(FW1)转发,外部网络返回的数据包由备份组2的master设备(FW1)转发,但是当FW1的G1/0/0接口出现故障时,备份组1可以检测到这一故障,并将FW2作为备份组1的master设备。PC发起的数据包由备份组1的master设备(FW2)进行转发,而备份组2的状态没有发生任何改变(FW1的G1/0/1接口正常工作),所以由外部网络返回的流量仍然由备份组2的master设备(FW1转发),显然,因为FW1的接口G1/0/0故障,数据包无法继续转发。

    造成这种现象的原因就是两个VRRP备份组独立工作,所以需要使用VGMP(VRRP组管理协议)来实现对VRRP备份组的统一管理,以保证设备在各个备份组中的状态一致。VGMP通过在设备(FW1和FW2)上将所有的备份组(备份组1和备份组2)加入一个VGMP组中进行统一管理,一旦检测到某个备份组(备份组1)中的接口发生变化(如接口进入Initialize状态),VGMP组将自身优先级减2,并重新协商VGMP的Active组和standby组。选举出的Active组将所有的其他备份组(备份组1和备份组2)统一进行状态切换(备份组1和备份组2中的FW2将成为master设备)。

    可以简单理解为,VGMP就是用来统一设备在不同备份组中的状态的即可。

    VGMP的工作原理如下:

    • VGMP组的状态决定了VRRP备份组的状态,即设备的角色(如master和backup)不再通过VRRP报文选举,而是直接通过VGMP统一管理。
    • VGMP组的状态通过比较优先级决定,优先级高的VGMP组将成为Active,优先级低的VGMP组将成为standby。
    • 默认情况下,VGMP组的优先级为45000。
    • VGMP根据组内VRRP备份组的状态自动调整优先级,一旦检测到备份组的状态变成Initialize状态,VGMP组的优先级会自动减2。
    • VGMP通过心跳线协商VGMP状态信息。

    在加入VGMP组之后,VRRP中的状态标识从master和backup变成了active和standby。

    1、VGMP的报文封装

    VGMP通过心跳线协商VGMP的状态信息,通过发送VGMP报文实现。VGMP报文有以下两种形式:

    dbb857a5e3db3c887da89e3a9c675cac.png

    如上图中左边的网络图中,心跳线(G1/0/0)和对端的心跳线直连,或者通过二层交换机相连时,发送的报文属于组播报文,报文封装中不携带UDP头部信息,而当心跳线通过三层设备(当然这种情况并不多见)连接时,因为组播报文无法通过三层设备,所以在报文封装中会额外增加一个UDP头部消息,此时发送的报文属于单播。

    通过以下命令指定通过接口发送的报文属于哪种类型的封装。

    [USG6000V1]hrp interface GigabitEthernet 1/0/0 [USG6000V1]hrp interface GigabitEthernet 1/0/0 remote 1.1.1.1

    关于配置VGMP的其他注意事项:

    • 加入了VGMP后,心跳线的作用包含状态信息备份(会话表和server-map表)及VGMP状态协商。
    • 华为防火墙在默认情况下放行组播流量(如不带remote参数的VGMP报文)禁止单播流量(如带remote参数的VGMP报文),所以如果配置了remote参数,还需要配置local区域和心跳线接口所在的区域之间配置安全策略。
    • 配置了VRRP virtual-mac enable的接口不能作为心跳口。
    • 如果使用二层接口作为心跳接口,不能直接在二层接口上配置,而是将二层接口加入vlan,在vlan中配置心跳接口。
    • eNSPoint模拟器中,即使心跳接口之间相连,也必须配置remote参数,否则无法配置。

    2、双机热备的备份方式

    双机热备的备份方式包括以下三种:

    • 自动备份:该模式下,和双机热备有关的配置只能在主用设备上配置,并自动同步到备用设备中,主用设备自动将状态信息同步到备用设备中。
    • 手工批量备份:该模式下,主用设备上所有的配置命令和状态信息,只有在手工执行批量备份命令时才会自动同步到备用设备。该模式主要应用于主设备和备用设备配置不同步,需要立即进行同步的场景。
    • 快速备份:该模式下,不同步配置命令,只同步状态信息,在负载均衡方式的双机热备环境中,该默认必须启用,以快速更新状态信息。

    各个模式的配置命令如下:

    (1)开启双机热备功能:

    [USG6000V1]hrp enable HRP_S[USG6000V1] 

    (2)配置自动备份模式:

    HRP_M[USG6000V1]hrp auto-sync HRP_M[USG6000V1]security-policy (+B) 

    (3)配置手工批量备份模式:

    HRP_Mhrp sync [ config | connection-status ]  

    (4)配置快速备份模式:

    HRP_S[USG6000V1]hrp mirror session enable HRP_M[USG6000V1] 

    3、关于上游或下游设备的选路问题

    当双机热备的设备上游或下游是交换机时,是通过VRRP检测接口或设备的状态,但当上游或下游设备是路由器时,VRRP无法正常运行(VRRP依靠组播实现故障切换)。华为防火墙的做法是监控其接口状态,并配置OSPF实现流量切换,通过直接将接口加入VGMP组中,当接口故障时(即使是对端设备故障,本端接口的物理特性也将关闭)VGMP会感知接口状态变化,从而降低VGMP组的优先级,从Active状态切换至standby状态。而之前的standby组将提升为active状态,而处于standby的VGMP组在发布OSPF路由时,会自动将cost值增加65500,通过OSPF的自动收敛,最终将流量引导至active组设备中。

    七、配置实例

    环境如下(别看上面啰嗦了那么一堆概念,但真正配置起来,简单的很,但是若要排错,还是要理解透彻它的工作原理):

    85dba1d61e6168242738e20b1362ba22.png

    声明:该环境不以实际环境为目的,目的是为了介绍防火墙的双机热备,所以这是一个简化环境。

    需求如下:

    LSW1和LSW2是二层交换机,FW1、FW2、LSW1、LSW2组成双机热备网络,正常情况下,PC1发起的访问R1的流量通过FW1转发,当FW1出现故障时,在PC1不做任何调整的前提下,可以自动通过FW2转发。

    开始配置:

    FW1配置如下:

    sys [USG6000V1]in g1/0/0[USG6000V1-GigabitEthernet1/0/0]ip add 10.1.1.101 24[USG6000V1-GigabitEthernet1/0/0]in g1/0/1[USG6000V1-GigabitEthernet1/0/1]ip add 172.16.1.1 24[USG6000V1-GigabitEthernet1/0/1]in g1/0/2[USG6000V1-GigabitEthernet1/0/2]ip add 192.168.1.101 24[USG6000V1-GigabitEthernet1/0/2]quit[USG6000V1]firewall zone trust[USG6000V1-zone-trust]add in g1/0/2[USG6000V1-zone-trust]firewall zone dmz[USG6000V1-zone-dmz]add in g1/0/1[USG6000V1-zone-dmz]firewall zone untrust[USG6000V1-zone-untrust]add in g1/0/0[USG6000V1-zone-untrust]quit[USG6000V1]security-policy [USG6000V1-policy-security]rule name permit_heat[USG6000V1-policy-security-rule-permit_heat]source-zone local[USG6000V1-policy-security-rule-permit_heat]destination-zone dmz[USG6000V1-policy-security-rule-permit_heat]action permit [USG6000V1-policy-security-rule-permit_heat]quit[USG6000V1-policy-security]quit [USG6000V1]in g1/0/0[USG6000V1-GigabitEthernet1/0/0]vrrp vrid 2 virtual-ip 10.1.1.100 active[USG6000V1-GigabitEthernet1/0/0]in g1/0/2[USG6000V1-GigabitEthernet1/0/2]vrrp vrid 1 virtual-ip 192.168.1.100 active[USG6000V1-GigabitEthernet1/0/2]quit [USG6000V1]hrp in g1/0/1 remote 172.16.1.2 [USG6000V1]hrp enable HRP_S[USG6000V1]hrp auto-sync 

    至此,FW1的配置暂时就完成了。开始配置FW2,FW2的配置与FW1的配置类似,就不写注释了(体谅一下我这个懒货)。

    FW2配置如下:

    sys[USG6000V1]in g1/0/0[USG6000V1-GigabitEthernet1/0/0]ip add 10.1.1.102 24[USG6000V1-GigabitEthernet1/0/0]in g1/0/1[USG6000V1-GigabitEthernet1/0/1]ip add 172.16.1.2 24[USG6000V1-GigabitEthernet1/0/1]in g1/0/2[USG6000V1-GigabitEthernet1/0/2]ip add 192.168.1.102 24[USG6000V1-GigabitEthernet1/0/2]quit[USG6000V1]firewall zone trust[USG6000V1-zone-trust]add in g1/0/2[USG6000V1-zone-trust]firewall zone untrust[USG6000V1-zone-untrust]add in g1/0/0[USG6000V1-zone-untrust]firewall zone dmz[USG6000V1-zone-dmz]add in g1/0/1[USG6000V1-zone-dmz]quit[USG6000V1]security-policy [USG6000V1-policy-security]rule name permit_heat[USG6000V1-policy-security-rule-permit_heat]source-zone local[USG6000V1-policy-security-rule-permit_heat]destination-zone dmz[USG6000V1-policy-security-rule-permit_heat]action permit[USG6000V1-policy-security-rule-permit_heat]quit[USG6000V1-policy-security]quit[USG6000V1]in g1/0/0[USG6000V1-GigabitEthernet1/0/0]vrrp vrid 2 virtual-ip 10.1.1.100 standby [USG6000V1-GigabitEthernet1/0/0]in g1/0/2[USG6000V1-GigabitEthernet1/0/2]vrrp vrid 1 virtual-ip 192.168.1.100 standby [USG6000V1-GigabitEthernet1/0/2]quit[USG6000V1]hrp in g1/0/1 remote 172.16.1.1[USG6000V1]hrp enableHRP_S[USG6000V1]hrp auto-sync

    配置至此,双机热备状态已经同步了,现在FW2为备份状态,多数配置已经无法在FW2上进行,只能在FW1上配置后,自动同步到FW2,那么现在在FW1配置一条策略,以便允许trust区域访问untrust区域,并且在FW2防火墙设备上查看是否同步到这条策略。

    FW1配置如下:

     HRP_M[USG6000V1]security-policy (+B)HRP_M[USG6000V1-policy-security]rule name test1 (+B)HRP_M[USG6000V1-policy-security-rule-test1]source-zone trust (+B)HRP_M[USG6000V1-policy-security-rule-test1]destination-zone untrust (+B)HRP_M[USG6000V1-policy-security-rule-test1]action permit (+B)HRP_M[USG6000V1-policy-security-rule-test1]quitHRP_M[USG6000V1-policy-security]quit

    FW2设备上查看是否有FW1创建的策略:

    HRP_S[USG6000V1]security-policy  Error: The device is in HRP standby state, so this command can not be executed. HRP_S[USG6000V1]dis current-configuration  ...................... security-policy rule name permit_heat source-zone local destination-zone dmz action permit rule name test1  source-zone trust destination-zone untrust action permit

    配置R1路由器及PC及的IP地址,并ping通。

    R1路由器配置如下(R1路由器相当于运营商的公网上的路由器了,这里只是为了模拟一个这样的环境):

    sys[Huawei]in g0/0/0[Huawei-GigabitEthernet0/0/0]ip add 10.1.1.1 24[Huawei-GigabitEthernet0/0/0]quit[Huawei]ip route-static 192.168.1.0 24 10.1.1.100  

    PC1的IP地址配置如下:

    2e8c5f0bf333a42bc5a57018c5fc53cb.png

    PC1和R1路由器进行ping测试(最好在命令最后加“-t”选项,进行持续ping,以便查看会话表,否则会话表会老化,查不到相应数据):

    254d9c5b0327b7e9ecb3b70770dc617d.png

    在FW1查看会话表:

    HRP_M[USG6000V1]dis firewall session table  Current Total Sessions : 24 icmp ×××: public --> public 192.168.1.1:17547 --> 10.1.1.1:2048 icmp ×××: public --> public 192.168.1.1:18059 --> 10.1.1.1:2048 icmp ×××: public --> public 192.168.1.1:14987 --> 10.1.1.1:2048

    在FW2查看会话表:

    HRP_S[USG6000V1]dis firew se ta Current Total Sessions : 26 icmp ×××: public --> public Remote 192.168.1.1:9099 --> 10.1.1.1:2048 icmp ×××: public --> public Remote 192.168.1.1:9611 --> 10.1.1.1:2048 icmp ×××: public --> public Remote 192.168.1.1:10891 --> 10.1.1.1:2048 icmp ×××: public --> public Remote 192.168.1.1:12171 --> 10.1.1.1:2048

    可以看出两个防火墙上的会话表内容都是不一样的(但不会影响故障切换)。

    那么现在就可以进行故障切换的验证咯!

    模拟FW1设备故障(关闭FW1的任意一个接口即可,注:此时PC1还在持续pingR1,才可以看到故障切换的效果):

    HRP_M[USG6000V1]in g1/0/0 (+B)HRP_M[USG6000V1-GigabitEthernet1/0/0]shutdown 

    在关闭接口的后的一两秒钟,可以看到PC1丢了一个包,便又恢复正常了,说明故障切换成功。如下:

    62144676a12eac40ebdc5b798be5f8ee.png

    配置到此结束,下面是关于双机热备的一些查询命令:

     HRP_S[USG6000V1]display hrp state  Role: standby, peer: active (should be "active-standby") Running priority: 44998, peer: 45000 ...................... HRP_S[USG6000V1]dis hrp interface   GigabitEthernet1/0/1 : running

    八、总结

    1、两台防火墙用于心跳线的接口需要加入相同的安全区域。

    2、两台防火墙用于心跳线的接口的编号必须一致,如都是G1/0/1。

    3、建议用于双机热备的两台防火墙采用相同的型号,相同的VRP版本。连接同一个设备(路由器或交换机)都使用同一个接口编号。

    4、当热备组中的设备坏掉后,买来新的设备进行加入热备组时,在配置时,原来坏掉的那台设备在VGMP中配置的是active,哪怕现在备份组中有设备处于active状态,新买来的设备必须也配置active状态,否则无法协商。如在上面环境中,FW1配置时配置为active状态,然后FW1设备down掉了,此时FW2由standby状态变为active状态,那么,此时再买来一台FW3想要重新加入备份组,在配置时,须配置为active。如该条命令:vrrp vrid 1 virtual-ip 192.168.1.100 active。不过还有个弊端,就是配置后,新买的FW3变成了active状态,但是FW2上有很多安全策略及会话表就同步不过来了,因为只有备份设备去同步活跃设备,活跃设备是不会去同步备份设备的状态的,所以,更省事的方法,还是先将FW2重新使用vrrp vrid 1 virtual-ip 192.168.1.100 active这条命令,将原始的状态变为active状态,然后在配置FW3时,直接将FW3配置为standby状态,便可同步成功。

    展开全文
  • 1.MySQL双机热备原理双机热备就是使用MySQL提供的一种主从备份机制实现。所谓双机热备其实是一个复制的过程,复制过程中一个服务器充当主服务器,一个或多个服务器充当从服务。这个复制的过程实质上是从服务器复制主...

    1.MySQL双机热备原理

    双机热备就是使用MySQL提供的一种主从备份机制实现。所谓双机热备其实是一个复制的过程,复制过程中一个服务器充当主服务器,一个或多个服务器充当从服务。这个复制的过程实质上是从服务器复制主服务器上MySQL的二进制日志(bin-log),并在从服务器上还原主服务器上的sql语句操作,这样只要两个数据库的初态是一样的,就能一直同步。

    双机热备的实现需要MySQL的版本高于3.2.。另外由于这种备份是基于MySQL二进制日志实现,所以主从服务器上的MySQL版本最好能够一样,至少从服务器的MySQL版本不可以低于主服务器的数据库版本。因为MySQL不同的版本之间二进制日志可能不一样。

    2.节点信息

    IP

    主机名

    角色

    192.168.23.2

    risen02

    主备

    192.168.23.3

    risen03

    主备

    3.开始配置

    3.1.创建同步账户并授权

    在risen02的MySQL执行命令

    grant replication slave on *.* to 'risen'@'192.168.23.3' identified by '123456';

    flush privileges;

    在risen03的MySQL执行命令

    grant replication slave on *.* to 'risen'@'192.168.23.2' identified by '123456';

    flush privileges;

    3.2.修改MySQL配置文件

    修改risen02的MySQL配置文件my.cnf,添加以下内容:

    [mysqld]

    server-id = 1

    log-bin=mysql-bin

    binlog-do-db = test

    log-slave-updates

    sync_binlog = 1

    auto_increment_offset = 1

    auto_increment_increment = 2

    replicate-do-db = test

    replicate-ignore-db = mysql,information_schema

    修改risen03的MySQL配置文件my.cnf,添加以下内容:

    [mysqld]

    server-id = 2

    log-bin=mysql-bin

    replicate-do-db = test

    replicate-ignore-db = mysql,information_schema,performance_schema

    binlog-do-db = test

    binlog-ignore-db = mysql

    log-slave-updates

    sync_binlog = 1

    auto_increment_offset = 2

    auto_increment_increment = 2

    (上述配置根据实际需求进行配置)

    参数说明

    Server-id

    ID值唯一的标识了复制群集中的主从服务器,因此它们必须各不相同。Master_id必须为1到232-1之间的一个正整数值,slave_id值必须为2到232-1之间的一个正整数值。

    Log-bin

    表示打开binlog,打开该选项才可以通过I/O写到Slave的relay-log,也是可以进行replication的前提。

    Binlog-do-db

    表示需要记录二进制日志的数据库。如果有多个数据可以用逗号分隔,或者使用多个binlog-do-dg选项。

    Binglog-ingore-db

    表示不需要记录二进制日志的数据库,如果有多个数据库可用逗号分隔,或者使用多binglog-ignore-db选项。

    Replicate-do-db

    表示需要同步的数据库,如果有多个数据可用逗号分隔,或者使用多个replicate-do-db选项。

    Replicate-ignore-db

    表示不需要同步的数据库,如果有多个数据库可用逗号分隔,或者使用多个replicate-ignore-db选项。

    Master-connect-retry

    master-connect-retry=n表示从服务器与主服务器的连接没有成功,则等待n秒(s)后再进行管理方式(默认设置是60s)。如果从服务器存在mater.info文件,它将忽略些选项。

    Log-slave-updates

    配置从库上的更新操作是否写入二进制文件,如果这台从库,还要做其他从库的主库,那么就需要打这个参数,以便从库的从库能够进行日志同步。

    3.3分别重新启动MySQL服务

    risen02和risen03分别执行命令:

    service mysql restart

    571ad08d5da14fd67a6671aea9bb139c.png

    ceccacd2aa3c47247ced4be38329847c.png

    3.4分别查看MySQL主节点状态

    risen02的MySQL的主节点

    8d0b630e539c32daf96ffd25e6709e6a.png

    risen03的MySQL的主节点

    6cc9011a5911471d9bb93e865b83045f.png

    分别记下file和position两个选项

    3.5.分别在服务器上用change master to 指定同步位置

    (注意master_log_file和master _log_pos均是上面查询状态显示出来的,一定要填对)

    risen02的MySQL执行命令:

    change master to master_host='192.168.23.3',master_user='risen',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=120;

    risen03的MySQL执行命令:

    change master to master_host='192.168.23.2',master_user='risen',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=120;

    3.6.分别重启从服务线程

    risen02和risen03的MySQL分别执行命:

    mysql>start slave;

    3.7.分别查看从节点状态

    risen02和risen03的MySQL分别执行命令:

    mysql>show slave status\G;

    查看risen02从节点状态:

    6f2fecebd5b0d40ad7f2a992b1aff9f7.png

    查看risen03从节点状态:

    333ededfe123119d321888677a94f3f2.png

    红色框中两个配置项分别都是YES,则证明搭建成功。

    3.8.效果验证

    在risen02的test库中新建表info

    727f3e93e0830e34042bb8e006419e1d.png

    查看risen03:

    8f0418f92dc0e6daa56e8eb42431abf4.png

    反向验证

    进入risen03的test库中并插入一条数据到info表

    48ca5f38489782233d97466e26bae6a8.png

    查看risen02中的info表是否存在risen03插入的数据

    f9ef15c56afa01cf857a12c70bdce694.png

    数据存在,证明MySQL的双击热备到此搭建成功。

    展开全文
  • 一、双机热备是什么? 二、什么是VRRP? 三、VRRP的两种角色 四、VRRP的三个状态机 五、VRRP选举Master路由器和Backup路由器的流程 六、通过VGMP实现VRRP备份组的统一管理 七、双机热备的配置 八、总结 一、双机...
  • 1.MySQL双机热备原理双机热备就是使用MySQL提供的一种主从备份机制实现。所谓双机热备其实是一个复制的过程,复制过程中一个服务器充当主服务器,一个或多个服务器充当从服务。这个复制的过程实质上是从服务器复制主...
  • 华为的双机热备是通过部署两台或多台防火墙实现热备及负载均衡,两台防火墙相互协同工作,犹如一个更大的防火墙。 华为防火墙的双机热备包含以下两种模式: 热备模式:同一时间只有一台防火墙转发数据,其他防火墙...
  • 华为的双机热备是通过部署两台或多台防火墙实现热备及负载均衡,两台防火墙相互协同工作,犹如一个更大的防火墙。 二、VRRP的概念 VRRP(virtual router redundancy protocol,虚拟路由冗余协议),用来解...
  • 一提到防火墙,一般都会想到企业的边界设备,是内网用户与互联网的必经之路。防火墙承载了非常多的功能,比如:安全规则...博文大纲:一、双机热备工作原理二、VRRP协议(1)VRRP协议概述(2)VRRP的角色(3)VRRP的状态机...
  • mysql双机热备实现

    2020-01-06 11:35:00
    接续上一篇关于mysql双机热备实现原理分析,在本文经过深思熟虑和多次用不同的方式实测试后。最后在这篇文章中,用一个小例子来完成mysql双机热备的实现。 Mysql数据库没有增量备份的机制,当数据量太大的时候备份...
  • 接续上一篇关于mysql双机热备实现原理分析,在本文经过深思熟虑和多次用不同的方式实测试后。最后在这篇文章中,用一个小例子来完成mysql双机热备的实现。 Mysql数据库没有增量备份的机制,当数据量太大的时候备份...
  • 用Nginx实现双机热备实现高可用,解决Nginx服务器的单点故障问题。架构原理1、双机均正常工作。用户通过域名访问到DNS域名解析时,通过轮询的方式计算虚拟IP。获取对应的nginx服务器。进行请求转发操作2、当...
  • 什么是MySQL的双机热备?mysql的双机热备是怎样的一种机制呢?...MySQL数据库与php搭配是实现MySQL双机热备的最佳组合,其原理主要是通过对日志的更新,用MySQL数据库(和PHP搭配之最佳组合)的SELECT的文件来...
  • 为了实现高可用,我们接下来需要在MyCat中间件之前使用Keepalived实现双机热备 一.Keepalived如何实现双机热备? 为了实现高可用,我们使用keepalived来实现双机热备。 其主要工作原理是,在MyCat容器上面使用keepal...
  • Keepalived和nginx实现负载和双机热备原理
  • 提供关键业务的不间断服务,目前的解决办法是采用双机热备或者集群技术,采用基于开源LinuxHA项目下的免费...讨论了Heartbeat的基本原理,提出了一种基于Linux的双机热备系统,并基于B/S架构建立了该系统的管理模式。
  • 使用keepalived实现双机热备 通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务。当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常...
  • 双机热备份,即能够把主数据库中所有的数据同时写到备份的数据库中,从而实现MySQL数据库的热备份。MySQL Replication是MySQL提供的一种主从备份的机制,并且整个复制备份过程是异步进行的,其高效的性能设计,也让...
  • keepalived实现双机热备

    2020-03-09 15:34:11
    什么是双机热备 (1) 通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务。 (2) 当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短。 VRRP(Virtual...
  • 接续上一篇关于mysql双机热备实现原理分析,在本文经过深思熟虑和多次用不同的方式实测试后。最后在这篇文章中,用一个小例子来完成mysql双机热备的实现。 Mysql数据库没有增量备份的机制,当数据量太大的时候备份...
  • mysql双机热备实现 简介 Mysql数据库没有增量备份的机制,当数据量太大的时候备份是一个很大的问题。还好mysql数据库提供了一种主从备份的机制,其实就是把主数据库的所有的数据同时写到备份的数据库中,实现mysql...
  • 一、keepalived原理及配置解析 keepalived:vrrp协议的实现 vrrp协议:virtual router redundancy protocol 即虚拟路由器冗余协议 vrrp基本实现及工作流程: VRRP通过在一组路由器(一个VRRP组)之间共享一个虚拟...

空空如也

空空如也

1 2 3 4 5 ... 13
收藏数 253
精华内容 101
关键字:

双机热备实现原理