当前位置: 首页 > news >正文

mysql部署(2)主从复制

在前面的基础上,现有26、41两个mysql8的实例,下面以26为主41为从搭建主从复制:

机器主从端口号root密码主从复制账号密码
xxx.xx.xxx.263306Mysql#26user1/user1#26
xxx.xx.xxx.413306Mysql#41

一、master主库配置

1、修改mysql配置文件my.cnf
vim /etc/my.cnf#修改内容如下
#服务器id 此id在主从复制服务器集群中要保持唯一(每台服务器的这值都是唯一的)
server-id=1
#二进制文件存放路径,非必须,mysql8后默认存放/var/lib/mysql这里
log-bin=mysql-bin
#想要同步的数据库,如果有多个以空格隔开db1 db2 db3 ....
#如果不指明同步哪些库,就去掉这行,表示所有库的同步(除了ignore忽略的库)。
#binlog-do-db=db_test
#不同步的数据(可以不配置)  如果有多个以空格隔开db1 db2 db3 ....
replicate-ignore-db=mysql,information_schema,sys,performance_schema

此时,my.cnf完整的内容为:

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
# 套接字文件所在目录
socket=/var/lib/mysql/mysql.sock[mysqld]
#主从复制
#服务器id 此id在主从复制服务器集群中要保持唯一(每台服务器的这值都是唯一的)
server-id=1
#二进制文件存放路径,非必须,mysql8后默认存放/var/lib/mysql这里
log-bin=mysql-bin
#想要同步的数据库,如果有多个以空格隔开db1 db2 db3 ....
#如果不指明同步哪些库,就去掉这行,表示所有库的同步(除了ignore忽略的库)。
#binlog-do-db=db_test
#不同步的数据(可以不配置)  如果有多个以空格隔开db1 db2 db3 ....
replicate-ignore-db=mysql,information_schema,sys,performance_schema# 服务端口号,默认为 3306
port=3306
user=root
# 指定 MySQL 数据存放的绝对路径;
datadir=/var/lib/mysql
# socket 文件所在目录
socket=/var/lib/mysql/mysql.sock
# 数据库默认字符集,主流字符集支持一些特殊表情符号(特殊表情符占用 4 个字节)
character-set-server=utf8mb4
# 设置 client 连接 mysql 时的字符集,防止乱码
init_connect='SET NAMES utf8mb4'
# 允许最大连接数
max_connections=100000
# 是否对 sql 语句大小写敏感,1 表示不敏感
lower_case_table_names=1
# 表示 SQL 模式的参数,通过这个参数可以设置检验 SQL 语句的严格程度
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
#导出限制 
secure-file-priv="" 
#事件开启 
event_scheduler=on 
# 关闭通用查询日志
general_log=1
# 通用查询日志存放路径
general_log_file=/var/log/mysql/mysql.log
innodb_data_home_dir=/usr/local/mysql/mysql-8.0/data
# 在事务被提交并写入到表空间磁盘文件上之前,事务数据存储在InnoDB的redo日志文件里
innodb_log_group_home_dir=/usr/local/mysql/mysql-8.0/data/
# 默认为ON,设置为OFF,关闭事务自动提交
autocommit=1
# 默认使用“mysql_native_password”插件认证
#default_authentication_plugin=mysql_native_password
authentication_policy=* 
[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
2、重启mysql服务

修改配置文件需要重启生效 : systemctl restart mysqld;

3、创建用于主从复制的账号

(1)进入数据库

mysql -u root -p #空格输入密码进入mysql数据库

(2)创建用于主从复制的用户user1

create user 'user1'@'%' identified with	 mysql_native_password by 'user1#26';

(3)赋予权限

GRANT ALL PRIVILEGES ON *.* TO 'user1'@'%'WITH GRANT OPTION;

(4)刷新缓存,使配置命令生效

flush privileges;

(5)查看master状态(必须)

show master status 

记住记录文件名 和 binlog日志偏移量 ,这在后面的从库创建复制命令中是必要的参数! 

二、从库配置

1、修改mysql配置文件my.cnf
# 添加以下配置
[mysqld]
#[必须]从服务器唯一ID
server-id=2
#[可选]启用中继日志
relay-log=mysql-relay
#[可选] 0(默认)表示读写(主机),1表示只读(从机)
read-only=1 
#[可选] 选择复制的数据库,不填则默认复制主库授权可以复制的数据库
#replicate-do-db=master_db
#[可选] 表示不随着数据库启动而启动复制
#skip-slave-start
 2、重启mysql服务

修改配置文件需要重启生效 : systemctl restart mysqld。

http://www.lryc.cn/news/321343.html

相关文章:

  • FX-数组的使用
  • springboot283图书商城管理系统
  • FFmpeg-- c++实现:音频流aac和视频流h264封装
  • 单片机烧录方式,JTAG,ISP,SWD,
  • 【项目管理后台】Vue3+Ts+Sass实战框架搭建一
  • 基于python 变配电室运行状态评估与预警系统flask-django-nodejs-php
  • 【自记录】VS2022编译OpenSSL1.0.2u
  • ES代替品:轻量级搜索引擎MeiliSearch
  • 用C语言打造自己的Unix风格ls命令
  • git的起源
  • 软件杯 深度学习 python opencv 火焰检测识别
  • C# double类型计算精度问题解决
  • 基于Springcloud+Vue校园招聘系统 Eureka分布式微服务
  • 【NLP笔记】RNN总结
  • [c++]内存管理
  • k8s通过编排文件,实现服务的滚动更新
  • 安卓面试题多线程 96-100
  • 第二十六章 配置 Web Gateway 的默认参数
  • npm i安装依赖报错,但是cnpm i 却安装成功
  • C语言经典算法-9
  • React 19的变化
  • Kafka整理-Kafka与传统消息队列系统(如RabbitMQ, ActiveMQ)的区别是什么?
  • 汽车电子零部件(8):T_Box
  • 数库据设计最佳实践
  • ESSBAE 数据挖掘
  • 在Linux/Ubuntu/Debian中使用iFuse访问iOS 设备(例如 iPhone 或 iPad)上的文件可双向复制粘贴
  • 驱动开发中的DMA是什么
  • websocket 升级协议时的协议切换点
  • 在Linux中开发C++
  • 【linux】Debian访问Debian上的共享目录