返回顶部
首页 > 资讯 > 数据库 >数据库集群的级联复制完整实现
  • 879
分享到

数据库集群的级联复制完整实现

2024-04-02 19:04:59 879人浏览 泡泡鱼
摘要

实验前的注意:如果要启用级联复制,需要在从服务器启用以下配置; [Mysqld] log_bin log_slave_updates log_slave_updates的作用:  &

实验前的注意:

如果要启用级联复制,需要在从服务器启用以下配置;

[Mysqld]
log_bin
log_slave_updates

log_slave_updates的作用:
    因为默认从主服务器过来的二进制日志保存在从服务器的中继日志;并应用到本地数据库;
    但是中间这个从服务器是即便是开启二进制日志的记录功能,他也是不记录到本地的二进制日志,
    那么也就不能将对数据库的操作再传输到从的从服务器上去。当log_slave_updates启用后,
    从服务器也就能将对主服务器的二进制日志在本地执行后,也记录到自己的二进制日志中;


删除数据库就可以干净做实验;
[root@master ~]$systemctl stop mariadb
[root@master ~]$rm -fr /var/lib/mysql/*
[root@master ~]$systemctl start mariadb


主、从、二级从服务器的配置:


[root@master ~]$cat /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
Socket=/var/lib/mysql/mysql.sock
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
innodb_file_per_table
log_bin
server-id=1

[root@slave ~]$cat /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
# Settings user and group are ignored when systemd is used.
innodb_file_per_table
server_id=2
read_only
log_bin
log_slave_updates

[root@slave2 ~]$cat  /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
server_id=3



主服务器和从服务器实现主从复制,配置和授权:

主服务器:
MariaDB [(none)]> grant replication slave on *.* to repluser@'192.168.27.%' identified by 'Centos';
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> show master logs;
+--------------------+-----------+
| Log_name           | File_size |
+--------------------+-----------+
| mariadb-bin.000001 |       264 |
| mariadb-bin.000002 |       401 |
+--------------------+-----------+
2 rows in set (0.00 sec)



中间的从服务器:
CHANGE MASTER TO
MASTER_HOST='192.168.27.7',
MASTER_USER='repluser',
MASTER_PASSWord='centos',
MASTER_LOG_FILE='mariadb-bin.000001',
MASTER_LOG_POS=245;

MariaDB [(none)]> CHANGE MASTER TO
    -> MASTER_HOST='192.168.27.7',
    -> MASTER_USER='repluser',
    -> MASTER_PASSWORD='centos',
    -> MASTER_LOG_FILE='mariadb-bin.000001',
    -> MASTER_LOG_POS=245;
Query OK, 0 rows affected (0.02 sec)

MariaDB [(none)]> start slave;
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.27.7
                  Master_User: repluser
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mariadb-bin.000002
          Read_Master_Log_Pos: 401
               Relay_Log_File: mariadb-relay-bin.000003
                Relay_Log_Pos: 687
        Relay_Master_Log_File: mariadb-bin.000002
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
         Exec_Master_Log_Pos: 401
              Relay_Log_Space: 1269
              Until_Condition: None
               Until_Log_File: 
                Until_Log_Pos: 0
           Master_SSL_Allowed: No
           Master_SSL_CA_File: 
           Master_SSL_CA_Path: 
              Master_SSL_Cert: 
            Master_SSL_Cipher: 
               Master_SSL_Key: 
        Seconds_Behind_Master: 0

MariaDB [(none)]> select user from mysql.user;
+----------+
| user     |
+----------+
| root     |
| repluser |
| root     |
|          |
| root     |
|          |
| root     |
+----------+
7 rows in set (0.00 sec)



MariaDB [(none)]> show master logs;
+--------------------+-----------+
| Log_name           | File_size |
+--------------------+-----------+
| mariadb-bin.000001 |       401 |
+--------------------+-----------+
1 row in set (0.00 sec)


二级从服务器上的配置:


在从的从服务器上执行:

[mysqld]
innodb_file_per_table
read-only
server-id=3


CHANGE MASTER TO
MASTER_HOST='192.168.27.17',
MASTER_USER='repluser',
MASTER_PASSWORD='centos',
MASTER_LOG_FILE='mariadb-bin.000001',
MASTER_LOG_POS=401;

您可能感兴趣的文档:

--结束END--

本文标题: 数据库集群的级联复制完整实现

本文链接: https://lsjlt.com/news/36929.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 数据库集群的级联复制完整实现
    实验前的注意:如果要启用级联复制,需要在从服务器启用以下配置; [mysqld] log_bin log_slave_updates log_slave_updates的作用:  &...
    99+
    2024-04-02
  • 数据库集群的主从复制模型完整实现
    主从配置过程: 参看:     https://mariadb.com/kb/en/library/setting-up-replication/  &nb...
    99+
    2024-04-02
  • 数据库的级联复制
    环境: 192.168.205.17: as master server 192.168.205.27: as middle server 192.168.205.37: as slave serv...
    99+
    2024-04-02
  • PHP实现数据库集群故障恢复的方法
    随着互联网应用的快速发展,对于高并发、高可用的要求也越来越高,而数据库的故障恢复是保证应用高可用的重要措施之一。本文将介绍PHP实现数据库集群故障恢复的方法。一、数据库集群数据库集群是指多个数据库服务器通过网络互联,组成一个大型的数据库系统...
    99+
    2023-05-19
    PHP 数据库集群 故障恢复
  • PHP实现数据库集群的方法
    随着Web应用程序和电子商务网站的不断发展,数据存储和处理的需求也日益增加。为了应对这一挑战,数据库集群成为了一种越来越受欢迎的解决方案。然而,由于各种原因,许多企业选择使用PHP作为开发语言来实现其数据库集群。本文将探讨如何使用PHP实现...
    99+
    2023-05-17
    PHP 实现方法 数据库集群
  • redis复制集群搭建的实现
    目录前言环境准备搭建过程问题总结前言 Redis 复制集群是开发中一种比较常用的集群模式,本篇演示如何在Centos7上快速搭建一个redis复制集群; 环境准备 1、基于centos7系统的服务器(或者云服务器); 2...
    99+
    2022-08-10
    redis复制集群搭建 redis复制集群
  • PHP实现Memcached数据库集群的方法
    随着互联网应用的快速发展,数据存储和处理变得越来越庞大和复杂。在这样的背景下,Memcached作为一款高性能、轻量级的分布式内存缓存系统,逐渐成为互联网应用领域中不可或缺的一部分。在PHP语言中,Memcached可以通过扩展内置的Mem...
    99+
    2023-05-15
    PHP memcached 数据库集群
  • PHP实现Redis数据库集群的方法
    Redis是一种常用的内存数据库,其具有高速读写、丰富的数据结构以及持久化等特点,已经成为了Web应用程序中非常重要的工具之一。随着业务的扩张和数据量的增大,单台Redis服务器已经难以满足业务需求,此时就需要使用Redis数据库集群来保证...
    99+
    2023-05-15
    PHP redis 集群
  • PHP实现Oracle数据库集群的方法
    在当前的互联网时代下,高可用性的需求变得越来越大。而数据库作为企业数据的核心,需要满足在面临各种异常情况时依然保持业务的正常运行。因此,数据库集群成为了当前较为流行的实现高可用性解决方案之一。本文将介绍如何使用PHP实现Oracle数据库集...
    99+
    2023-05-17
    PHP Oracle 集群
  • PHP实现MongoDB数据库集群的方法
    随着互联网的发展,数据量呈现爆炸式增长,如何处理海量数据成为了关键。MongoDB是一种NoSQL数据库,具有性能高、可扩展性强、数据结构灵活等特点,因此在大数据领域得到了广泛应用。为了更好地应对数据量的增长,实现高可用和高效率的数据处理,...
    99+
    2023-05-19
    PHP MongoDB 集群
  • Mysql数据库实现完整备份与恢复方法
    下面讲讲关于Mysql数据库实现完整备份与恢复方法,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完Mysql数据库实现完整备份与恢复方法这篇文章你一定会有所受益。数据库备份的重要...
    99+
    2024-04-02
  • PHP如何实现MySQL数据库集群
    这篇文章主要讲解了“PHP如何实现MySQL数据库集群”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP如何实现MySQL数据库集群”吧!一、MySQL数据库集群概述MySQL数据库集群是...
    99+
    2023-07-06
  • PHP实现数据库集群扩容的方法
    数据库集群是现代大型网站和企业级应用程序中常用的高可用性解决方案,实现负载均衡和数据冗余。随着业务规模的不断扩大,扩容或缩容成为集群管理的一项重要任务。本文将介绍如何利用PHP语言实现数据库集群的扩容。数据库集群数据库集群是由多个数据库服务...
    99+
    2023-05-15
    PHP 数据库集群 扩容
  • 完整且详细的Yolov8复现+训练自己的数据集
    Yolov8 的源代码下载:ultralytics/ultralytics: NEW - YOLOv8 🚀 in PyTorch > ONNX > CoreML > TFLite (github.com)https://gi...
    99+
    2023-08-31
    YOLO
  • PHP怎么实现数据库集群备份
    这篇“PHP怎么实现数据库集群备份”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“PHP怎么实现数据库集群备份”文章吧。一、概...
    99+
    2023-07-06
  • MYSQL数据库GTID实现主从复制实现(超级方便)
    一、添加Maria源 vi /etc/yum.repos.d/MariaDB.repo 粘贴阿里云的最新mariadb镜像: [mariadb] name = MariaDB baseurl = http...
    99+
    2022-05-12
    MYSQL GTID主从复制 MYSQL 主从复制
  • 实现mysql级联复制的方法示例
    所谓级联复制就是master服务器,只给一台slave服务器同步数据,然后slave服务器在向后端的所有slave服务器同步数据,降低master服务器的写压力,和复制数据的网络IO。 一,配置master...
    99+
    2024-04-02
  • 怎么使用PHP实现Redis数据库集群
    本篇内容主要讲解“怎么使用PHP实现Redis数据库集群”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用PHP实现Redis数据库集群”吧!一、Redis集群架构Redis集群采用分布式架...
    99+
    2023-07-06
  • PHP实现数据库集群异常处理的方法
    随着互联网的不断发展,越来越多的企业和组织开始规划数据库集群来满足其数据处理需求。数据库集群可能包含数百甚至数千个节点,因此在节点之间确保数据同步和协调非常重要。 在该环境下,存在着很多的异常情况,如单节点故障,网络分区,数据同步错误等,并...
    99+
    2023-05-15
    PHP编程 异常处理 数据库集群
  • 数据库实现主从复制
    MySQL的主从复制,依赖于二进制日志的拉取和sql线程的转换。确认主备关系后,IO线程负责将主库的二进制日志拉取到备库,由SQL线程将二进制日志回读成具体的操作等。主备搭建主库的配置 vi /etc/my.cnf [mysqld] #在...
    99+
    2016-02-20
    数据库实现主从复制 数据库入门 数据库基础教程 数据库 mysql
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作