MySQL数据库主从安装配置使用指南

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 本篇文章介绍了在Linux环境中安装MySQL数据库,实现数据库主从配置的详细的指导过程。本文使用的MySQL数据库的一个分支MariaDB实现主从数据库的安装配置。介绍了数据库的安装方法,主从配置的方式,以及针对在配置过程中出现的一些问题,提供一些解决方案。

MariaDB主从安装配置

  • 使用MariaDB做数据库实现主从配置

    • MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区维护,完全兼容MySQL,包括API和命令行,可以作为MySQL的替代品
    • 在存储引擎方面,使用XtraDB代替MySQL的InnoDB
  • 邮件类型:

    • 用户安全类
    • 订单类
    • 统计类
    • 消息类

Linux 7修改IP地址

  • 在网络适配器中生成MAC地址
  • 进入编辑 /etc/sysconfig/network-scripts/ifcfg-eno16777736
  • 修改HWADDRMAC地址,修改IPADDRIP地址
  • 运行service network restart
  • 进入 /etc/hostname修改hostname
  • 运行hostname bhz34

安装MariaDB

配置本地yum源:

  • cd /etc/yum.repos.d/
  • 创建一个文件,以repo结尾:yum.repo
  • 添加如下配置:
name=yum
enabled=1
baseurl=(url地址)
gpgcheck=0
  • 查询是否已经存在MariaDB
systemctl stop mariadb            停止MariaDB服务
rpm -qa | grep mariadb            查询安装包
  • 卸载已经存在的MariaDB
rpm -e mariadb-server
rpm -e mariadb
rpm -e --nodeps mariadb-libs
  • 执行yum安装MariaDB
yum -y install mariadb mariadb-server
  • 复制配置文件
cp /usr/share/mysql/my-huge.cnf /etc/my.cnf
  • 配置不区分表名的大小写
vim /etc/my.cnf

在[mysqld]后增加配置
lower_case_table_names=1
  • 启动mariadb服务并开机自动运行
systemctl start mariadb
systemctl enable mariadb
  • 禁用防火墙
systemctl status firewalld        查看防火墙状态
systemctl stop firewalld        停止防火墙
systemctl disable firewalld        设置开机不启用防火墙
  • 配置MariaDB数据库,执行脚本: /usr/bin/mysql_secure_installation,然后根据提示操作
/usr/bin/mysql_secure_installation

MariaDB主从配置

  • 修改 /etc/my.cnf配置文件中的server-id

    • 主节点默认为1,不需要修改
    • 修改从节点的server-id
server-id=2
  • 重启从节点(slave)上的MariaDB
systemctl restart mariadb
  • 在主节点创建主从复制用户并授权Slave
mysql -uroot -proot            登录MariaDB数据库
<mysql> GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' IDENTIFIED BY 'slave';        *.* - 所有权限    % - 任意地址
  • 查询MySQL中主节点(master)的状态
show master status;
  • 配置从节点(slave)
mysql -uroot -proot            登录从节点的MariaDB数据库
<mysql> CHANGE MASTER TO MASTER_HOST='主节点IP',MASTER_USER='主节点授权用户',MASTER_PASSWORD='主节点授权用户密码',MASTER_LOG_FILE='主节点状态中的File',MASTER_LOG_POS='主节点状态中的Position';
  • 查看主从状态验证
show slave status\G;
  • 授权远程root登录,主从数据库都要进行授权
mysql -uroot -proot        登录MariaDB数据库
<mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
<mysql> FLUSH PRIVILEGES;

注意点

  • ==使用MySQL做主从数据库,不允许对从节点数据库进行修改==

解决方案

  • 原因:

    • 程序可能在slave上进行了写操作
    • 可能是slave机器重启后,事务回滚造成的
  • 事务回滚的解决办法:
<mysql> stop slave;
<mysql> set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
<mysql> start slave;

  • 首先停掉slave服务
<mysql> slave stop;
  • 进入master服务器查看主机状态,记录FilePosition对应的值
<mysql> show master status;
  • 然后进入slave服务器执行手动同步
<mysql> CHANGE MASTER TO MASTER_HOST='主节点IP',MASTER_USER='主节点授权用户',MASTER_PASSWORD='主节点授权用户密码',MASTER_LOG_FILE='主节点状态中的File',MASTER_LOG_POS='主节点状态中的Position';
  • 最后启动slave数据库
<mysql> start slave;
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
23天前
|
Java 数据库连接 数据库
hibernate正向生成数据库表以及配置——TestStu.java
hibernate正向生成数据库表以及配置——TestStu.java
16 1
|
23天前
|
Java 数据库连接 数据库
hibernate正向生成数据库表以及配置——Teacher.hbm.xml
hibernate正向生成数据库表以及配置——Teacher.hbm.xml
13 1
|
23天前
|
Java 数据库连接 数据库
hibernate正向生成数据库表以及配置——Teacher.java
hibernate正向生成数据库表以及配置——Teacher.java
11 0
|
23天前
|
Java 数据库连接 数据库
hibernate正向生成数据库表以及配置——Student.java
hibernate正向生成数据库表以及配置——Student.java
10 0
|
27天前
|
存储 SQL 关系型数据库
创建并配置RDS实例
在阿里云上创建RDS实例涉及登录控制台、进入RDS管理页面、创建实例、选择数据库引擎和版本、配置实例规格与存储、设定网络与安全组、设置实例信息、确认订单并支付,最后初始化数据库。操作步骤可能因界面更新或数据库引擎不同略有差异。
18 1
|
1月前
|
关系型数据库 MySQL 开发工具
MySQL5.7主从配置(Docker)
MySQL5.7主从配置(Docker)
725 0
|
1月前
|
SQL 关系型数据库 MySQL
解决MySQL主从慢同步问题的常见的解决方案:
解决MySQL主从慢同步问题的方法有很多,以下是一些常见的解决方案: 1. 检查网络连接:确保主从服务器之间的网络连接稳定,避免网络延迟或丢包导致数据同步缓慢。 2. 优化数据库配置:调整MySQL的配置参数,如增大binlog文件大小、调整innodb_flush_log_at_trx_commit等参数,以提高主从同步性能。 3. 检查IO线程和SQL线程状态:通过SHOW SLAVE STATUS命令检查IO线程和SQL线程的状态,确保它们正常运行并没有出现错误。 4. 检查主从日志位置:确认主从服务器的binlog文件和位置是否正确,避免由于错误的日志位置导致同步延迟。 5.
112 1
|
8天前
|
SQL 缓存 关系型数据库
mysql性能优化-慢查询分析、优化索引和配置
mysql性能优化-慢查询分析、优化索引和配置
74 0
|
14天前
|
缓存 关系型数据库 MySQL
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
|
1月前
|
分布式计算 关系型数据库 MySQL
Sqoop【部署 01】CentOS Linux release 7.5 安装配置 sqoop-1.4.7 解决警告并验证(附Sqoop1+Sqoop2最新版安装包+MySQL驱动包资源)
【2月更文挑战第8天】Sqoop CentOS Linux release 7.5 安装配置 sqoop-1.4.7 解决警告并验证(附Sqoop1+Sqoop2最新版安装包+MySQL驱动包资源)
92 1

推荐镜像

更多