Linux服务器双机热备详细过程
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux服务器双机热备详细过程相关的知识,希望对你有一定的参考价值。
现有两台IBM3650服务器,linux系统,一台DS5020磁盘阵列柜。如何配置能让这两台服务器共享磁盘阵列柜。采用oracle数据库应该如何安装?
服务器通过光纤线连接磁盘阵列
通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务。
当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短。
下面来以keepalived结合tomcat来实现一个web服务器的双机热备过程:
keepalived的工作原理是VRRP虚拟路由冗余协议。
在VRRP中有两组重要的概念:VRRP路由器和虚拟路由器,主控路由器和备份路由器。
VRRP路由器是指运行VRRP的路由器,是物理实体,虚拟路由器是指VRRP协议创建的,是逻辑概念。一组VRRP路由器协同工作,共同构成一台虚拟路由器。Vrrp中存在着一种选举机制,用以选出提供服务的路由即主控路由,其他的则成了备份路由。
当主控路由失效后,备份路由中会重新选举出一个主控路由,来继续工作,来保障不间断服务。
两台物理服务器和一个虚拟服务器(vip):master:redhat2.6.18-53.el5192.168.8.4;backup:redhat2.6.18-53.el5192.168.8.6;vip:192.168.8.100。
节点A192.168.8.4(主节点),节点B192.168.8.6(备用节点),虚拟IP(对外提供服务的IP192.168.8.100)
在这种模式下,虚拟IP在某时刻只能属于某一个节点,另一个节点作为备用节点存在。
当主节点不可用时,备用节点接管虚拟IP(即虚拟IP漂移至节点B),提供正常服务。
keepalived的原理可以这样简单理解:
keepalived安装在两台物理服务器上,并相互监控对方是否在正常运行。
当节点A正常的时候:节点A上的keepalived会将下面的信息广播出去:
192.168.8.100这个IP对应的MAC地址为节点A网卡的MAC地址
其它电脑如客户端和NodeB会更新自己的ARP表,对应192.168.8.100的MAC地址=节点A网卡的MAC地址。
当节点A发生故障的时候,节点B上的keepalived会检测到,并且将下面的信息广播出去:
192.168.8.100这个IP对应的MAC地址为节点B网卡的MAC地址
其它电脑如客户端会更新自己的ARP表,对应192.168.8.100的MAC地址=节点B网卡的MAC地址。
扩展资料:
双机热备特指基于active/standby方式的服务器热备。服务器数据包括数据库数据同时往两台或多台服务器执行写操作,或者使用一个共享的存储设备。在同一时间内只有一台服务器运行。
当其中运行着的一台服务器出现故障无法启动时,另一台备份服务器会通过软件诊测(一般是通过心跳诊断)将standby机器激活,保证应用在短时间内完全恢复正常使用。
Keepalived的运行原理是基于VRRP(虚拟路由冗余协议)机制,在VRRP中有两个重要的概念:VRRP路由器和虚拟路由器,主控路由器和备份路由器。
VRRP路由器是一种实体路由器设备,而虚拟路由器则是基于VRRP协议构建的虚拟路由器,是软性的虚拟概念,一组VRRP路由器协同工作,共同构造一台虚拟服务器。
VRRP协议支持一种选举机制,主要用来选出用来提供服务的路由即主控路由,其它的就是备份路由了,当主控路由失效之后,备份路由中重新选出一个主控路由(往往按照设置好的优先级别重新分配),接管主控服务,继续工作,来保证不间断的提供服务。
参考资料:百度百科-双机热备
参考技术A 双机热备份(HotStandby)是一种软硬件相结合的高可靠性应用方案。双机热备系统由两台独立的服务器以及相应的控制软件构成,两台服务器在网络中表现为单一的系统,对外表现为一个独立的网络IP,并以单一系统的模式进行控制和管理。该系统将两台服务器的数据和运行状态(包括硬盘数据和内存数据)进行镜像,可以实现两台服务器之间的热备份,并能够做到无缝切换,从而对外提供稳定可靠的服务,实现双机系统的高可用性解决方案。
1.1.2 功能概述
双机热备份系统由相应的应用软件进行控制,操作系统和应用程序安装在两台服务器的系统盘上。每一台服务器分配一个固定的IP地址,此外还指定了一个独立IP地址作为集群IP(cluster
IP),该IP是双机系统对外提供服务的接口。两台服务器一台成为主节点(Primary
Server),另一台成为从节点(Standby
Server),主节点与从节点之间保持固定时间间隔的心跳信号,通过心跳信号实现两个对等系统之间的周期性的握手,从而能够监视对方的运行状态,进行主机及网络的故障检测。
在系统正常情况下,主节点占用系统资源并运行所有的服务,为信息系统提供支持,从节点通过心跳信号监视主节点的运行情况。一旦主节点发生故障(如主机故障,网络故障,软件故障等),从节点就会自动接管(Take
Over)主节点的资源和服务,继续支持信息的运营,从而保证整个双机系统能够不间断的运行(Non-Stop)。主节点在恢复运行后,又可以自动获取资源并取代从节点。
在集群系统的实现方案中双机热备份系统是硬件配置最简单和价格最低廉的解决方案,通常镜像服务的硬件配置需要两台独立的服务器,每台服务器有独立的操作系统硬盘和数据存贮硬盘,每台服务器有提供网络连接功能的网卡,此外还可以有一对完成内部连接和数据镜像功能的网卡。
双机系统的两台服务器拥有共享的数据存储空间(可以是一个数据存储硬盘或一台专门的数据存储服务器)。任何一台服务器在运行服务时,从共享的数据存储空间内读取和存储数据。每台服务器的操作系统和应用程序文件存储在各自的本地存储空间上。
双机热备份系统采用内存镜像的技术,即把两台服务器的数据和运行状态(包括硬盘数据和内存数据)进行镜像。这个技术的优点是所有的应用程序和操作数据在两台服务器上镜像同步,当主节点出现故障时,从节点可以在几乎没有延迟的情况下接管主节点运行的服务,从而实现无缝切换和热备份。该技术的缺点是,由于两台服务器的内存完全一致,当由于系统应用程序带有缺陷而导致系统宕机时,两台服务器会同步宕机。也可以在双机系统中使用第三方生产的磁盘阵列柜,在磁盘阵列柜中安装有磁盘阵列控制卡,阵列柜可以直接将柜中的硬盘配置成为逻辑盘阵。该结构不采用内存镜像技术,因此需要有一定的切换时间,同时由于所有的数据全部存贮在磁盘阵列柜中,当主节点出现故障时,从节点接替主节点,从磁盘阵列柜中读取数据,所以不会产生数据不同步的问题。由于这种方案不需要网络镜像同步,因此这种集群方案服务器的性能要比镜像服务器结构高出很多。双机热备份系统的两台服务器通过内部局域网进行连接,通过周期性的心跳信号保持通信和进行相互监视。两台服务器之间可以采用多种连接方式,可以使用串口线,也可以通过以太网ethernet进行连接,还可以采用并存的多种连接方式实现两台主机的多重互连。如果双机系统有冗余连接,在第一条通信路径失效的情况下,控制软件可以尝试使用第二条通信路径进行连接。因此,为了避免不必要的失效切换,最好建立两种以上独立的物理路径,使用至少两种心跳。双机热备份系统具有配置简单,使用方便,价格低廉等诸多优点,但由于镜像服务器需要采用网络
方式镜像数据,通过镜像软件实现数据的同步,因此需要占用网络服务器的CPU及内存资源,造成服务器的性能有所降低。
本方案仅讨论Redhat
Linux系统下的双机热备份系统的实现,使用的双机控制软件是Linux-HAheartbeat。因此,除了安装操作系统及相关的应用服务程序之外,还需要安装heartbeat控制软件。通过对heartbeat软件的配置,可以把两台服务器分别指定为主节点和从节点,指定心跳信号的时间间隔,指定cluster
IP、子网掩码、广播地址、鉴权方式,还可以设置heartbeat启动的服务,该服务最终由双机系统通过cluster
IP对外提供。
Heartbeat可以最大限度地保护用户端的应用连续性。用户的硬件资源(如网卡),软件资源(如操作系统、数据库管理系统、数据库应用系统、电子邮件系统等)均能处于heartbeat容错软件的保护之下,当这些被保护的资源出现技术故障时, heartbeat容错软件可以随时实施系统资源的切换。因此,heartbeat真正实现了用户硬件或是软件资源发生故障时系统及应用层上的在线热切换。
Heartbeat软件的特点有:
不需增加额外硬件资源,纯软件方式实现双机容错,并且对双机无硬件配置要求。
可支持DB2,Notes、Exchange、SQL
Server、Sybase、Informix、Oracle
、SAP等多种系统的应用层热切换。支持共享磁盘阵列柜和内存镜像等多种方式,给用户提供了选择上的灵活性,同时也能适应各种机型、网络结构、软件平台及应用系统。
占用系统资源较少,不增加网络负荷,并且不会干扰具体应用程序的运行和操作。
真正实现无人值守,全自动地实现系统资源和应用服务的切换。
方案说明
服务器Server
A和Server
B构成双机热备份系统的两台主机,并且分别作为主节点(Primary
Server)和从节点(Standby
Server)。两台主机均运行Linux-HA
heartbeat,该软件成为双机热备系统的控制程序。
两台主机通过串口线、以太网等多种方式进行连接,传送数据和心跳信号,并互相进行状态监视。可以只使用一种连接方式(如以太网连接),但是多种连接方式下的冗余路径可以保证双机连接的可靠性和服务质量。
数据库服务器或磁盘阵列柜是专门的数据存储和共享设备,两台服务器在运行时,均从该设备中读取和存储数据。这种方式可以有效地提高数据传输效率,提高双机热备服务器的系统性能,并且能够保证两台服务器之间的数据同步。
双机备份系统有两种配置方式,分别是“基于系统切换的双机系统”和“基于系统镜像的双机系统”,二者的区别是:
基于系统切换的双机系统仅仅把两台服务器的硬盘数据进行镜像,在主节点失效的情况下,从节点将进行系统一级的切换。该方式不能实现无缝切换,实现的是冷备份。
基于系统镜像的双机系统把两台服务器的硬盘数据和内存数据都进行镜像。为保证完全的内存镜像,两台服务器之间需通过专用连接网段实时地保持一个连续的、双向的镜像进程,该进程确保两台服务器之间的数据同步。一旦故障发生,无论任何一台服务器失效,失效服务器上的数据和应用,将立即切换到另一台服务器上,从而使用户在没有中断的情况下可以继续使用双机系统提供的服务。该方式能够做到无缝切换,实现的是热备份。
本方案描述的heartbeat双机热备份系统是一种基于系统镜像的双机系统,实现方法是,主节点在出现故障的情况下,集群IP地址无缝地切换到从节点,从而客户机对服务器的访问可以由从节点来支持。但是两台服务器之间并没有镜像进程完成彻底的内存镜像,因而主节点在故障时所运行的数据信息不能切换到从节
点,造成数据丢失以及服务中断。所以该方案不是严格意义上的系统镜像,实现的是服务一级的切换,并不能实现实时数据的切换。 参考技术B 连接存储控制器上的网络口,一般有一个默认ip,安装存储管理软件连接这个ip。
在管理软件中创建阵列、磁盘、lun、vol等(例如最后创建了vote、data、fra等卷),然后再配置主机,就是以3650上的HBA的wwn号作为标识(wwn1、wwn2),然后分别配置wwn1、wwn2对vote、data、fra等卷的连接权限,这样两台3650均安装hba驱动和多路径存储的补丁,这样就能实现共享存储。
接下来参考oracle rac的安装手册进行安装配置。 参考技术C LINUX系统做双机热备还是很繁琐的,其实在这里不会有朋友给您分享方案的,建议您还是选择双机热备供应商比较好,这样可以指定标准的方案,并且还有售后的服务支持,一举多得。睿芸翰林就很不错,您可以进行了解。
Linux系统下使用MySql双机热备功能
文章目录
概述
试验目的
验证、测试Linux系统下的MySQL双机热备功能。
试验环境
准备两台服务器,分别安装好操作系统和数据库,数据库的版本要一样。
环境项目 | 环境配置 | 备注 |
---|---|---|
硬件环境 | 华为 2288H V5服务器 | 服务器1:192.168.200.1 服务器2:192.168.200.2 |
操作系统 | Ubuntu20.04 LTS | |
MySQL | 8.0.25-0-ubuntu0.20.04.1 |
准备数据库
在两台服务器上分别新建测试用的数据库:
CREATE DATABASE `mytest` CHARACTER SET 'utf8' COLLATE 'utf8_general_ci';
准备账号
在服务器1上建立一个只能从服务器2登录的账号
示例中的账号为
syn
,密码为:123456
# 新建用户
CREATE USER `syn`@`192.168.200.2` IDENTIFIED WITH mysql_native_password BY '123456';
# 查看验证
SELECT user,host,plugin FROM mysql.user;
# 授予数据复制的权限
GRANT Replication Slave ON *.* TO `syn`@`192.168.200.2`;
在服务器2上建立一个只能从服务器1登录的账号
示例中的账号为
syn
,密码为:123456
# 新建用户
CREATE USER `syn`@`192.168.200.1` IDENTIFIED WITH mysql_native_password BY '123456';
# 查看验证
SELECT user,host,plugin FROM mysql.user;
# 授予数据复制的权限
GRANT Replication Slave ON *.* TO `syn`@`192.168.200.1`;
测试账号
- 在服务器1上,用服务器2的账号,登录服务器2上的数据库
mysql -h 192.168.200.2 -u syn -p
- 在服务器2上,用服务器1的账号,登录服务器1上的数据库
mysql -h 192.168.200.1 -u syn -p
- 测试账号时的问题
如果测试账号时出现类似如下的问题:
- 请检查配置文件
/etc/mysql/mysql.conf.d/mysqld.cnf
中的bind_address
参数是否允许了访问的IP地址。- 检查被访问服务器的防火墙是否开启了3306端口。
- 检查账号的
host
是否设置正确。
这是因为用户名或者密码错误:
修改测试配置
修改配置文件
两台服务器分别修改配置文件/etc/mysql/my.cnf
sudo vim /etc/mysql/my.cnf
在文件的最后添加如下代码:
[mysqld]
#其中的mytest是数据库名
# 主服务器唯一ID,服务器之间不能一样
server-id=1
# 启用二进制日志
log-bin=backuplog
sync_binlog=1
binlog_format=row
auto_increment_increment = 1
auto_increment_offset = 1
max_binlog_size=512m
expire_logs_days=1
# 设置需要记录二进制日志的数据库(需要同步复制的都要记录,可设置多个,如果不配置,则全部记录)
binlog_do_db=mytest
# 设置不要复制的数据库(可设置多个)
binlog_ignore_db=mysql
binlog_ignore_db=information_schema
# 设置需要复制的数据库(可设置多个,如果不配置,则全部同步)
replicate_do_db=mytest
replicate_wild_ignore_table=mytest.log
slave_skip_errors=all
如果只是想要主从复制,比如服务器1是主服务器,服务器2是从服务器,只从主服务器复制数据到从服务器,那么从服务器只需要填写
server-id
一项即可。
重启MySQL服务
修改好之后,记得重启MySQL服务
sudo service mysql restart
正常重启:
重启时候有问题,需要检查配置:
检查master服务状态
sudo mysql
mysql> show master status;
要分别检查服务器1和服务器2的master状态,并记住
File
和Position
的值,下面指定同步位置的时候,master_log_file
要填写File
的值,master_log_pos
要填写Postition
的值。
配置主从
配置master参数
如果只是想要主从复制,比如服务器1是主服务器,服务器2是从服务器,只从主服务器复制数据到从服务器,那么此处只需要指定服务器2的同步位置。
- 服务器1
mysql> stop slave;
mysql> change master to master_host='192.168.200.2',master_user='syn',master_password='123456', master_log_file='backuplog.000001',master_log_pos=156;
mysql> start slave;
- 服务器2
mysql> stop slave;
mysql> change master to master_host='192.168.200.1',master_user='syn',master_password='123456', master_log_file='backuplog.000001',master_log_pos=156;
mysql> start slave;
检查slave状态
分别检查两台服务器的slave状态:
查看参数 Slave_IO_Running 和 Slave_SQL_Running 是否都为yes,则证明配置成功。若为no或其他,则需要查看对应的 Last_IO_Error 或 Last_SQL_Error 的异常值。
show slave status\\G;
同步测试
创建表
- 在服务器1创建表
不要复制这个代码
mysql> use mytest;
mysql> CREATE TABLE tb_by_1(
->id INT NOT NULL AUTO_INCREMENT,
->dtext VARCHAR(20) NOT NULL,
->PRIMARY KEY (id)
->)ENGINE=InnoDB DEFAULT CHARSET=utf8;
在服务器2上查看是否有这个表了:
mysql> use mytest;
mysql> show tables;
已经有了。
- 在服务器2上创建表
在服务器1上查询:
都能查询到了。
数据测试
- 在服务器1上往表1插入数据
INSERT INTO tb_by_1 (dtext) VALUES ('input by s1');
在服务器2上查询:
也可以查到了。
- 其他测试略
参考文献
Linux安装Mysql8.0.20并配置主从复制(一主一从,双主双从)
Windows配置MySQL双机热备
以上是关于Linux服务器双机热备详细过程的主要内容,如果未能解决你的问题,请参考以下文章