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

旅游网站wordpress中美网站建设

旅游网站wordpress,中美网站建设,网页游戏2022排行榜前十名,一个网站主机多少钱一年以下笔记都是基于黑马程序员的面试题写的: Mysql定位慢查询-CSDN博客 Mysql索引-CSDN博客 MySQL事物相关-CSDN博客 MySQL主从同步集群(Docker搭建)-CSDN博客 MySQL相关面试问题总结-CSDN博客 主从同步(Master-Slave Replicat…

 以下笔记都是基于黑马程序员的面试题写的:

Mysql定位慢查询-CSDN博客

Mysql索引-CSDN博客

MySQL事物相关-CSDN博客

MySQL主从同步集群(Docker搭建)-CSDN博客

MySQL相关面试问题总结-CSDN博客


        主从同步(Master-Slave Replication)是数据库集群中常用的高可用、高并发解决方案,通过将主数据库(Master)的数据变更同步到从数据库(Slave),实现数据的多副本存储和读写分离。

一、主从同步的核心目标

  1. 数据备份:从库作为主库的副本,避免单库故障导致数据丢失。
  2. 读写分离:主库负责写操作(INSERT/UPDATE/DELETE),从库负责读操作(SELECT),分散数据库压力,提升并发能力。
  3. 故障转移:主库故障时,可将从库切换为主库,保证服务连续性。

二、工作原理

MySQL主从复制的核心就是二进制日志。

二进制日志(BINLOG)记录了所有的 DDL(数据定义语言)语句和 DML(数据操纵语言)语句,但不包括数据查询(SELECT、SHOW)语句。

复制分成三步:

  1. Master 主库在事务提交时,会把数据变更记录在二进制日志文件 Binlog 中。
  2. 从库读取主库的二进制日志文件 Binlog ,写入到从库的中继日志 Relay Log 。
  3. slave重做中继日志中的事件,将改变反映它自己的数据。

三、主从同步的常见架构

一主一从:最简单的架构,主库写入,从库备份 + 读。

一主多从:主库连接多个从库,分担更多读压力(如电商详情页的高频查询)。

级联复制(主 -> 从 -> 从):主库只同步给一个从库,该从库再同步给其他从库,减轻主库的 binlog 发送压力。

四、Docker搭建MySQL主从同步集群

1.环境

centos7,MySQL8.0.19、MobaXterm

目的:

实现MySQL主从同步集群——一主一从

2.步骤

1.拉取镜像并创建网络

拉取镜像:

docker pull mysql:8.0.19

创建网络:

docker network create mysql-net

2.创建挂载目录

master:

创建挂载目录:

mkdir -p mysql-demo/master3307/{conf,data,logs}

vi /home/hl/mysql-demo/master3307/conf/my.cnf 

vi /home/hl/mysql-demo/master3307/logs/mysql-slow.log

将以下内容复制进my.cnf:

[mysqld]
# 开启慢查询日志
slow_query_log = 1
# 慢查询日志路径(需对应容器内路径,已挂载到本地 /docker/mysql/logs)
slow_query_log_file = /var/log/mysql/mysql-slow.log
# 慢查询阈值(单位:秒,超过此值的 SQL 会被记录)
long_query_time = 1# 主库唯一ID(必须与从库不同)
server-id=1  
# 开启binlog,日志文件名前缀
log_bin=mysql-bin 
# 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7

赋予权限:

chown -R 999:999 /home/hl/mysql-demo/master3307/logs

slave操作同上,my.cnf内容不同:

[mysqld]
# 从库唯一ID(必须与主库不同)
server-id = 2  
# 中继日志文件名前缀
relay_log = mysql-relay-bin  
# 从库设为只读(可选,增强安全性,root用户不受限)
read_only = 1  

3.创建容器

docker run -d \--name mysql-master \--network mysql-net \-p 3307:3306 \-e MYSQL_ROOT_PASSWORD=1234 \-v /home/hl/mysql-demo/master3307/conf:/etc/mysql/conf.d \-v /home/hl/mysql-demo/master3307/data:/var/lib/mysql \-v /home/hl/mysql-demo/master3307/logs:/var/log/mysql \mysql:8.0.19
docker run -d \--name mysql-slave \--network mysql-net \-p 3308:3306 \-e MYSQL_ROOT_PASSWORD=1234 \-v /home/hl/mysql-demo/slave3308/conf:/etc/mysql/conf.d \-v /home/hl/mysql-demo/slave3308/data:/var/lib/mysql \-v /home/hl/mysql-demo/slave3308/logs:/var/log/mysql \mysql:8.0.19

4.配置主库

进入主库 MySQL 命令行,查看慢日志是否开启:


# 进入容器
docker exec -it mysql8 bash# 登录 MySQL
mysql -u root -p# 查看慢查询配置
SHOW VARIABLES LIKE 'slow_query_log';  # 应显示 ON
SHOW VARIABLES LIKE 'long_query_time'; # 应显示 1.000000
SHOW VARIABLES LIKE 'slow_query_log_file'; # 应显示日志路径

不用退出,执行 SQL 创建用于从库同步的用户(如repl,密码repl123):

-- 删除原用户(若存在)
DROP USER 'repl'@'%';
-- 重新创建用户,指定认证插件为 mysql_native_password
CREATE USER 'repl'@'%' IDENTIFIED WITH mysql_native_password BY 'repl123';
-- 授予复制权限
GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';
-- 刷新权限
FLUSH PRIVILEGES;-- 查看主库binlog信息(记录文件名和位置,后续从库配置需要)
SHOW MASTER STATUS;

需记录FilePosition:

5.配置从库

进入从库,执行 SQL 配置主库连接信息(替换为实际的FilePosition、主库 IP / 容器名):

-- 停止同步(若已配置过)
STOP SLAVE;-- 配置主库信息
CHANGE MASTER TOMASTER_HOST='mysql-master',  # 主库容器名(或主机IP,需在同一网络)MASTER_USER='repl',          # 主库创建的同步用户MASTER_PASSWORD='repl123',   # 同步用户密码MASTER_LOG_FILE='mysql-bin.000003',  # 主库SHOW MASTER STATUS中的FileMASTER_LOG_POS=1750;          # 主库SHOW MASTER STATUS中的Position-- 启动同步
START SLAVE;-- 查看从库同步状态(关键看Slave_IO_Running和Slave_SQL_Running是否为Yes)
SHOW SLAVE STATUS\G

若输出中:

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

则表示主从同步配置成功。

3.验证主从同步

主库插入数据
主库 MySQL 命令行执行:

USE test;
CREATE TABLE t1 (id INT PRIMARY KEY AUTO_INCREMENT, name VARCHAR(20));
INSERT INTO t1 (name) VALUES ('test1'), ('test2');

从库查询数据
从库 MySQL 命令行执行:

USE test;
SELECT * FROM t1;

若能查询到主库插入的test1test2,则同步成功。

五、相关面试问题

5.1 主从同步的原理是什么?

        主从同步的核心就是二进制文件binlog,其中记录了全部的DDL语句和DML语句,但不包括数据查询(SELECT、SHOW)语句。

        主从同步复制分为以下三步:

        第一,master主库在事物提交时,将数据变更语句写入到binlog中。

        第二,从库读取binlog中的记录,并写入到中继日志replay log中。

        第三,从库执行replay log中的语句,实现与主库数据的同步。

http://www.dtcms.com/a/484974.html

相关文章:

  • 自己怎么做入网站回收书报连锁酒店的网站建设
  • 捕鱼网站开发wordpress安装的模板文件
  • 教育网站制作软件新乡个人网站建设
  • 住房建设官方网站给网站做seo诊断
  • 邢台网站制作那家便宜怎么样才能在网上卖东西
  • h5网站案例腾讯云wordpress 主机
  • 网站建设优化培训班上海网站建设 乐云seo
  • 安庆怀宁网站建设兼职wordpress修改中文
  • 网站建设的创意网站制作公司排行榜
  • 小橘子被做h网站商城开发建设
  • 网络建站公司如何做市场如何网上卖东西
  • 设计制作简单的手机网站杭州网站维护外包
  • 南京网站设计公司兴田德润优惠吗手机版html编辑软件
  • 建站公司兴田德润实惠最火的自媒体平台排名
  • 长春网站建设定制百度大盘指数
  • 金融网站html5模板wordpress 自定义类型
  • 如何逐步提升网站权重简单项目计划书
  • 建p2p网站长沙建设网站
  • 一步步教你为网站开发android客户端北京文化传媒有限公司
  • 如何借助织梦制作一个简单的网站wordpress安装教程 linux
  • 新网站如何做快照wordpress 内容扩展
  • 网线制作一般包括怎么进行网站关键词优化
  • 设计的好网站wordpress主题访问慢
  • 邯郸移动网站建设费用苏州公司网站建设公司
  • 学院网站建设进度情况说明90后做受网站
  • 注册公司网站模板网上挣钱
  • 网站收录很慢上海什么公司最有名
  • 植物提取网站做的比较好的厂家wordpress 置顶 评论
  • 网站做视频网络推广外包一年多少钱
  • 手机网站设计方案线上销售技巧