`
hongtoushizi
  • 浏览: 382807 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

MySQL 数据库镜像(复制) / 实时备份Zen Cart数据库 十一

阅读更多

通过实现MySQL数据库镜像(复制),可以远程实时备份MySQL数据库。这样如果主机出现故障,或者主机帐号被封,都能迅速切换zencart网店到新的服务器上。

数据库镜像,需要两台服务器(或者用两台VPS主机)。一台为主服务器,另一台为从服务器,所有主服务器上数据库的变化,都实时镜像到从服务器上。

1. 在主服务器上,创建用于数据库镜像的数据库用户,从服务器用这个帐号连接主服务器。
该数据库用户可以是任何数据库用户,只要有REPLICATION SLAVE权限,由于该用户名、密码将明文保存在master.info文件中,因此建议创建、使用单独的镜像用户。

创建一个镜像用户 repl 的命令:

mysql> GRANT REPLICATION SLAVE ON *.*
    -> TO 'repl'@'localhost' IDENTIFIED BY 'slavepass';

2. 设置主服务器

首先,主服务器必须打开二进制日志的功能。每台参与镜像的服务器都必须有一个唯一的标识符。该标识符为 1-231 之间的一个任意整数,只要各服务器的标识符不重复。

要设置二进制日志和服务器标识符,必须停止MySQL服务器,然后在 my.cnf 或者 my.ini 配置文件中加入下面的定义:

[mysqld]
log-bin=mysql-bin
server-id=1
3. 设置从服务器

从服务器只需要设置服务器标识符。停止MySQL服务器,然后在 my.cnf 或者 my.ini 配置文件中加入下面的定义:

[mysqld]
server-id=2

如果设置多台从服务器,每台服务器都需要有唯一的标识符。从服务器不需要打开二进制功能,除非你想把从服务器作为另一台镜像服务器的主服务器。
4. 获取主服务器的信息

要设置镜像,必须查找主服务器的二进制日志的当前记录点。在从服务器启动镜像功能时需要该数据。

操作步骤分A、B两步:

A. 锁定主数据库

mysql> FLUSH TABLES WITH READ LOCK;
锁定数据库后,不要退出客户端(命令行),否者数据库解锁。

B. 查找二进制日志的当前记录点

 

mysql > SHOW MASTER STATUS;

+---------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------+----------+--------------+------------------+
| mysql-bin.003 | 73 | test | manual,mysql |
+---------------+----------+--------------+------------------+

上面File栏下显示日志文件名,Position栏下显示当前记录点,记下这两个数据。

5. 使用mysqldump导出zencart网店的数据库初始数据

首先要将主服务器上的现有数据传到从服务器上。在第4步的客户端仍然锁定数据库的情况下,新开一个session连接到主服务器,然后执行:

shell> mysqldump database_name1 --lock-all-tables > dbdump_database_name1.db

其中,database_name1是需要镜像的zencart网店的数据库名。如果有多个zencart网店的数据库需要镜像,重复mysqldump导出。
然后将导出的 dbdump_database_name1.db 传送到从服务器上。

现在,可以在第4步的客户端,解锁数据库:

mysql> UNLOCK TABLES;
6. 启动从服务器的实时数据库镜像

在从服务器上恢复第5步导出的主服务器的zencart网店的初始数据

A. 起动从服务器数据库,带参数 --skip-slave-start:

            shell> /etc /init.d/mysqld stop
            shell> /etc /init.d/mysqld start --skip-slave-start
B. 导入初始数据:

shell> mysql < dbdump_database_name1.db

C. 设置从服务器的参数:

        mysql> CHANGE MASTER TO
            ->     MASTER_HOST='master_host_name',
            ->     MASTER_USER='replication_user_name',
            ->     MASTER_PASSWORD='replication_password',
            ->     MASTER_LOG_FILE='recorded_log_file_name',
            ->     MASTER_LOG_POS=recorded_log_position;

D. 开启镜像功能:

mysql> START SLAVE;

注意:如果主服务器有防火墙,需要开通MySQL的端口3306,该端口只要对从服务器的IP开放就可以了。
文章出处:http://www.zen-cart.cn/forum/mysql-mirror-database-backup-t10952.html

 

转载:http://www.4u4v.net/mysql-database-mirroring-copying-real-time-database-backup-zen-cart.html

分享到:
评论

相关推荐

    mysql数据库每天凌晨3点备份数据库的脚本

    MySQL数据库的日常维护中,定期备份是至关重要的环节,它能确保在系统出现故障或数据丢失时能够迅速恢复。本文将详细介绍如何编写一个在Linux环境下,每天凌晨3点自动执行的MySQL数据库备份脚本,以及如何配置Linux...

    mysql数据库自动定时备份

    MySQL数据库的自动定时备份是数据库管理中的重要环节,它确保了数据的安全性和可恢复性,尤其是在发生意外情况如系统故障、硬件损坏或人为错误时。本教程将详细讲解如何设置MySQL数据库的自动定时备份,包括步骤、所...

    最新全国行政区域编码及mysql数据库(省/市/区县/街道)

    4.城乡划分代码说明:mysql数据库,树结构存储。包括:编码;名称;全称;所属省,市,区县,街道;拼音首字母;城市类型(直辖市,省会);同级下排序;深度;城乡分类代码及经纬度。 5.三级地址:...

    C#实现备份、还原MySql数据库

    对于使用MySQL数据库的系统,定期备份和恢复数据库可以防止数据丢失,确保业务连续性。本篇将详细讲解如何使用C#语言来实现MySQL数据库的备份与还原功能,并探讨如何通过线程设置定时自动备份。 首先,我们需要了解...

    MySQL数据库备份和恢复

    ### MySQL数据库备份与恢复:深度解析与实践指南 在当今数据驱动的世界中,数据库的稳定性和数据的安全性显得尤为重要。MySQL作为全球最流行的开源关系型数据库管理系统之一,其备份和恢复策略是确保数据安全和系统...

    自动定时备份远程服务器的mysql数据库并存储在本地

    对于远程服务器上的MySQL数据库,定期进行自动备份是防止数据丢失的有效手段。本篇文章将详细介绍如何实现这一目标,将远程服务器的MySQL数据库自动定时备份并存储在本地。 首先,我们需要了解MySQL的数据备份类型...

    mysql5.7.20镜像安装包

    mysql5.7.20镜像安装包,该镜像为mysql数据库镜像,安装后可直接使用。 mysql5.7.20镜像安装包,该镜像为mysql数据库镜像,安装后可直接使用。 安装完成后,我们可以使用以下命令来运行 mysql 容器: $ docker run ...

    如何用SQLyog备份及导入mysql数据库

    MySQL数据库备份和导入使用SQLyog MySQL数据库备份和导入是数据库管理员和开发者经常需要执行的任务。为了将数据库备份到安全的位置,以防止数据丢失,并且在需要时可以将其恢复到原来的状态。本文将介绍如何使用...

    nbu&mysql备份恢复.docx

    2. 将libmysqlclient.so库文件复制到/usr/local/mysql/lib目录下 3. 配置NBU,以使用libmysqlclient.so库文件 配置mysql备份代理配置文件 mysql备份代理配置文件是NBU备份mysql数据库所需的配置文件。配置过程可以...

    tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作

    tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份操作tp5数据库备份...

    delphi备份和还原MySql数据库.zip

    《使用Delphi进行MySQL数据库的备份与还原》 在IT领域,数据库的备份与还原是至关重要的环节,尤其是在开发和维护阶段,确保数据的安全性是每个程序员必须关注的问题。本篇将详细介绍如何利用Delphi这一强大的集成...

    Mysql数据库定时备份

    "Mysql数据库定时备份" Mysql数据库定时备份是数据库管理中非常重要的一步操作,目的是为了防止数据丢失和保护数据的安全。通过定时备份,可以在数据库发生故障或数据丢失时快速恢复数据,减少损失。 在本文中,...

    shell编程备份mysql数据库.sh

    防止误删服务器数据库 ,使用Shell脚本备份数据库: ### 1、需求分析: 1)每天凌晨2:10备份数据库atguiguDB到/data/backup/db 2)备份开始和备份结束能够给出相应的提示信息 3)备份后的文件要求以备份时间为...

    如何在linux下实现mysql数据库每天自动备份 txt

    ### 如何在Linux下实现MySQL数据库每天自动备份 在Linux环境下进行MySQL数据库的日常自动备份是一项重要的维护工作,它能够确保数据的安全性与完整性。本文将详细介绍如何通过编写Shell脚本并结合Cron定时任务来...

    mysql数据库备份/还原的PB程序

    在这个“mysql数据库备份/还原的PB程序”中,我们将探讨如何使用PB实现MySQL数据库的备份和还原操作。 首先,要理解备份的必要性。数据库备份是为了防止数据丢失,这可能由硬件故障、软件错误、恶意攻击或意外删除...

    mysql数据库备份策略

    本文将重点介绍四种策略:直接拷贝数据库文件、使用`mysqlhotcopy`备份数据库、使用`mysqldump`备份数据库以及利用主从复制机制实现实时备份。下面将逐一展开讨论这些策略的特点、应用场景以及实施步骤。 #### 三、...

    MySQL数据库实时备份策略与实践

    通过使用mysqldump、Percona XtraBackup或配置MySQL复制,我们可以在数据库运行时进行数据备份,从而最小化对业务的影响。在实际应用中,应根据业务需求和数据量选择合适的备份策略,并定期测试备份的恢复能力,以...

    mysql数据库备份shell脚本,每天备份,只保留30天的备份数据

    mysql数据库备份shell脚本,每天备份,只保留30天的备份数据

    定时批量备份mysql数据库

    定时批量备份mysql数据库 保存详细的备份记录

Global site tag (gtag.js) - Google Analytics