首页 > 数据库 >基于中间件实现MySQL读写分离

基于中间件实现MySQL读写分离

时间:2023-06-15 13:56:42浏览次数:59  
标签:log ## 读写 MySQL 中间件 MYSQL MASTER mysql master

1.场景

在数据库读多写少的时候

2.读写分离

只在主服务器上写,只在从服务器上读。
使用amoeba中间件

3.部署

3.1 Docker compose 一键部署

Compose 文件:

       version: '3.8'

        services:

          mysql_master:

            image: mysql:8.0.33-oracle

            restart: always

            privileged: true

            ports:

              - "3306:3306"

            environment:

              - MYSQL_ROOT_PASSWORD=admin123

              - MYSQL_DATABASE=db01

            volumes:

              - ./3306_log:/var/log/mysql

              - ./3306_data:/var/lib/mysql  

              - ./3306_conf/my.cnf:/etc/mysql/my.cnf

            networks:

              - mysql_network



          mysql_slave1:

            image: mysql:8.0.33-oracle

            restart: always

            privileged: true

            ports:

              - "3307:3306"

            environment:

              - MYSQL_ROOT_PASSWORD=admin123

              - MYSQL_DATABASE=db01

            volumes:

              - ./3307_log:/var/log/mysql

              - ./3307_data:/var/lib/mysql  

              - ./3307_conf/my.cnf:/etc/mysql/my.cnf

            networks:

              - mysql_network



          mysql_slave2:

            image: mysql:8.0.33-oracle

            restart: always

            privileged: true

            ports:

              - "3308:3306"

            environment:

              - MYSQL_ROOT_PASSWORD=admin123

              - MYSQL_DATABASE=db01

            volumes:

              - ./3308_log:/var/log/mysql

              - ./3308_data:/var/lib/mysql  

              - ./3308_conf/my.cnf:/etc/mysql/my.cnf

            networks:

              - mysql_network



        networks:

          mysql_network:

3.2 配置文件

conf文件:

     3306 端口

[mysqld]

## 设置server_id,同一局域网中需要唯一

server_id=101 

## 指定不需要同步的数据库名称

binlog-ignore-db=mysql  

## 开启二进制日志功能

log-bin=mall-mysql-bin

## 允许服务器更新二进制文件

log-slave-updates=true

## 设置二进制日志使用内存大小(事务)

binlog_cache_size=1M  

## 设置使用的二进制日志格式(mixed,statement,row)

binlog_format=mixed  

## 二进制日志过期清理时间。默认值为0,表示不自动清理。

expire_logs_days=7  

## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。

## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致

slave_skip_errors=1062

character-set-server=utf8

bind-address=0.0.0.0



3307 端口



[mysqld]

## 设置server_id,同一局域网中需要唯一

server_id=102

## 指定不需要同步的数据库名称

binlog-ignore-db=mysql  

## 开启二进制日志功能,以备Slave作为其它数据库实例的Master时使用

log-bin=mall-mysql-slave1-bin  

## 设置二进制日志使用内存大小(事务)

binlog_cache_size=1M  

## 设置使用的二进制日志格式(mixed,statement,row)

binlog_format=mixed  

## 二进制日志过期清理时间。默认值为0,表示不自动清理。

expire_logs_days=7  

## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。

## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致

slave_skip_errors=1062  

## relay_log配置中继日志

relay_log=mall-mysql-relay-bin  

## log_slave_updates表示slave将复制事件写进自己的二进制日志

log_slave_updates=1  

## slave设置为只读(具有super权限的用户除外)

read_only=1

3.3 中间操作

      # 主机

    CREATE USER slave@'%' IDENTIFIED WITH mysql_native_password BY '12345678';

    GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%'; 

    """

    参数说明

    % 表示该用户可以从任何主机连接到MySQL服务器

    *.* 表示数据库名,支持正则

    REPLICATION SLAVE 允许用户作为MySQL复制的从服务器,接受来自主服务器的二进制日志并应用到本地数据库

    REPLICATION CLIENT 权限允许用户连接到主服务器并检索复制相关的信息。

    若想让用户拥有只读权限:GRANT SELECT ON *.* TO 'readonly'@'%';

    """

    flush privileges;



    show master status;



    # 从机

    change master to master_host='192.168.128.2', master_user='slave', 
    master_password='12345678', master_port=3306, 
    master_log_file='mall-mysql-bin.000004',master_log_pos=848,master_connect_retry=10;



    CHANGE MASTER TO MASTER_HOST='mysql_master', MASTER_PORT=3306, 
    MASTER_USER='slave', MASTER_PASSWORD='12345678';



    START SLAVE;



    SHOW SLAVE STATUS\G





    ---- 暂且不看

    CHANGE MASTER TO

      MASTER_HOST='${MYSQL_MASTER_HOST}',

      MASTER_USER='${MYSQL_MASTER_USER}',

      MASTER_PASSWORD='${MYSQL_MASTER_PASSWORD}',

      MASTER_PORT=${MYSQL_MASTER_PORT},

      MASTER_LOG_FILE='${MYSQL_MASTER_LOG_FILE}',

      MASTER_LOG_POS=${MYSQL_MASTER_LOG_POS},

      MASTER_CONNECT_RETRY=${MYSQL_MASTER_CONNECT_RETRY};



    master_log_file='mall-mysql-bin.000001',  # 指定从数据库要复制数据的日志文件,通过查看主数据的状态,获取File参数

    master_log_pos=769,  # 指定从数据库从哪个位置开始复制数据,通过查看主数据的状态,获取Position参数;

    master_connect_retry=30; 连接失败重试的时间间隔,单位为秒。

作者:***乐园

标签:log,##,读写,MySQL,中间件,MYSQL,MASTER,mysql,master
From: https://www.cnblogs.com/DTCLOUD/p/17482646.html

相关文章

  • windows环境下操作,同一台机器 如何跑两个mysql服务?
    在同一台机器上运行两个MySQL服务是可行的,但需要注意以下几点:确保端口号不冲突。每个MySQL服务都需要监听一个独立的端口,以便客户端可以连接到正确的服务。配置文件的区分。每个MySQL实例需要有自己独立的配置文件,包括数据存储路径、日志文件路径等信息。确保资源......
  • 如何从CLI管理阿里巴巴MySQL数据库
    阿里云提供高度可用的按需MySQL,SQLServer和PostgreSQL数据库,作为其ApsaraDBforRDS  (关系数据库服务)的一部分。RDS易于设置和部署。该服务处理数据库服务器的所有管理任务,包括在发生灾难时进行配置,修补和恢复。除了这个即用型数据库服务,您还可以选择从弹性计算服务(ECS)实例设置......
  • MySQL中的非确定性函数(即rand)可能会让您感到惊讶
    使用sysbench处理测试用例,我遇到了这个问题:的MySQL>选择*从sbtest1其中ID=ROUND(RAND()*10000,0);+------+--------+-------------------------------------------------------------------------------------------------------------------------+----------------......
  • MySQL数据库运维实录--通过MySQL Shell Dump/Load 实现数据库对象的逻辑备份与恢复
    [mysql@node01~]$mysqlshMySQLJS>\connectroot@node01:3306MySQLnode01:3306sslJS>util.dumpInstance('/home/mysql/backup')[mysql@node01~]$scp-rbackup/*node02:/home/mysql/backup/util.dumpInstance的关键特性1,多线程备份。并发线程数由thr......
  • CentOS搭建NFS服务、windows挂载权限问题; NFS读写缓慢调优
    CentOS搭建NFS服务、windows挂载权限问题CentOS和统信UOS(与ubuntu一样)命令不一样,但操作大同小异,参考如下:https://blog.csdn.net/wangzongyu/article/details/127009158 windows读写linux搭建的NFS内文件是比较慢,调优:https://blog.csdn.net/yysalad/article/details/11736623......
  • mysql8.0创建新用户
     查看当前用户usemysql;selectcurrent_user();或者:selectUser,authentication_string,Hostfromuser;查看权限showgrantsfor'user'@'ip';或者showgrants;创建一个给新用户的数据库createdatabasetestDatabase;创建新用户同时配置给该用户testData......
  • MySQL8.0设置外网访问
    1.登进MySQL之后mysql-uroot-p***2,输入以下语句,进入mysql库:usemysql3,更新域属性,'%'表示允许外部访问:updateusersethost='%'whereuser='root';4,执行以上语句之后再执行:FLUSHPRIVILEGES;5,再执行授权语句:GRANTALLPRIVILEGESON*.*TO'root'@'%......
  • DataX在Windows上实现Mysql到Mysql同步数据以及配置多个job/多个表同步定时执行bat
    场景DataX-阿里开源离线同步工具在Windows上实现Sqlserver到Mysql全量同步和增量同步:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/130330353DataX-在Windows上实现postgresql同步数据到mysql:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/130......
  • 解决MySQL8.0报错:Unknown system variable 'validate_password_policy'
    解决MySQL8.0报错:Unknownsystemvariable'validate_password_policy'解决MySQL8.0报错:Unknownsystemvariable'validate_password_policy'一、问题描述1.通过yum安装好mysql8.0,通过生成的临时密码登录后操作mysql时会报如下错误:mysql>showdatabases;ERROR1820......
  • CentOS yum升级MySQL 5.6到5.7.42
    注意:升级前一定要做好备份升级前请将mysql5.6小版本升级到最高升级时可将my.cnf配置文件备份,保留最基本的配置,避免因配置问题造成异常,升级完成后在逐步还原安装mysql5.7yum源如果之前已经安装了5.6的yum源,需要先卸载后在安装rpm-Uvhhttps://dev.mysql.com/get/mysql......