当前位置:网站首页>Raj delivery notes - separation 第08 speak, speaking, reading and writing
Raj delivery notes - separation 第08 speak, speaking, reading and writing
2022-08-02 14:21:00 【Shaw hedge garment】
Let the project read and write separation,写走主库,读走从库,From a single database to multiple databases,Reduced access pressure.The structure of synchronizing the data of the master library to the slave library is calledMysql主从复制.
一、Mysql主从复制
1.介绍
MySQL主从复制是一个异步的复制过程,底层是基于MySQL数据库自带的二进制日志功能.就是一台或多台MySQL数据库(slave,即从库)从另一台MySQL数据库(master,即主库)进行日志的复制然后再解析日志并应用到自身,最终实现从库的数据和主库的数据保持一致.MySQL主从复制是MySQL数据库自带功能,无需借助第三方工具.
MySQL复制过程分成三步:
● master将改变记录到二进制日志(binary log)
● slave将master的binary log拷贝到它的中继日志(relay log)
● slave重做中继日志中的事件,将改变应用到自己的数据库中
2.配置
2.1 前提条件
提前准备好两台服务器,分别安装MySQL并启动服务成功.The name of the main library for my remote connection to the main library here islocalhost,The other is from the library.Two servers can be achieved by cloning virtual machines,Be careful to take a snapshot before cloning,It can be returned to the original state in case of an error.克隆安装mysqlThe virtual machine needs to be changedmysql的uuid,8.0version to reconfigure the user encryption method.
主库Master:192.168.72.131
从库Slave:192.168.72.132
2.2 配置——主库Master
第一步:修改Mysql数据库的配置文件 etc/my.cnf
启动MySQL( systemctl status mysqld )后输入口令( vim /etc/my.cnf )进入编辑,加入两行代码:
log-bin=mysql-bin #[必须]启用二进制日志
server-id=100 #[必须]服务器唯一id
第二步:重启MySql服务
systemctl restart mysqld
No error is reported, indicating that the restart was successful
第三步:登录 MySql数据库,执行以下SQL
mysql -uroot -proot
grant replication slave on *.* to 'xiaoming'@'%' identified by '[email protected]';
注:上面SQL的作用是创建一个用户xiaoming,密码为[email protected],and granted to the userreplication slave权限.常用于建立复制时所需要用到的用户权限,也就是slave必须被master授权具有该权限的用户,才能通过该用户复制.这里如果是mysql8Do not add the version identified by 'password',会导致语法错误.I set it directly here123456If the error message is not safe, it is recommended to set more complicated settings.
第四步:登录MySQL数据库,执行下面SQL,记录下结果中File和Position的值
show master status;
2.3 配置——从库Slave
第一步:修改MySQL数据库的配置文件 etc/my.cnf
server-id=101 #[必须]服务器唯一id
第二步:重启MySql服务
systemctl restart mysqld
第三步:登录 MySql数据库,执行以下SQL
记得先登录: mysql -uroot -proot
change master to master_host='192.168.72.131',master_user='xiaoming',master_password='[email protected]',master_log_file='mysql-bin.000001',master_log_pos=441;
start slave;
appears in the code block abovemaster_log_file='mysql-bin.000001',master_log_pos=441;One-to-one correspondence with those found in the main library.
Here is the first master-slave read and write,如果之前有过slave可能会报错,使用 stop slave Execute again after stoppingSQLpassword to succeed.
使用 start slave; The password makes the thread run
第四步:登录MySQL数据库,执行下面SQL,查看从库的状态
show slave status;
We will find that the content is messy,The entire content returned can be copied to a text editor for viewing.或者show slave status\G;This can be seen very clearly.
3.测试
第一步:Both the master library and the slave library are connectedNavicat,The host writes two virtual machinesIP地址,My username and password are bothroot
第二步:主库新建一个waimai数据库,Refresh from library
二、读写分离案例
2.1 背景
面对日益增加的系统访问量,数据库的吞吐量面临着巨大瓶颈.对于同一时刻有大量并发读操作和较少写操作类型的应用系统来说,将数据库拆分为主库和从库,主库负责处理事务性的增删改操作,从库负责处理查询操作,能够有效的避免由数据更新导致的行锁,使得整个系统的查询性能得到极大的改善.
2.2 Sharding-JDBC介绍
Sharding-JDBC定位为轻量级Java框架,在Java的JDBC层提供的额外服务.它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可理解为增强版的JDBC驱动,完全兼容JDBC和各种ORM框架.
使用Sharding-JDBC可以在程序中轻松的实现数据库读写分离.
适用于任何基于JDBC的ORM框架,如:JPA,Hibernate,Mybatis,SpringJDBC Template或直接使用JDBC.
支持任何第三方的数据库连接池,如:DBCP,C3PO,BoneCP,Druid,HikariCP等.
支持任意实现JDBC规范的数据库.目前支持MySQL,Oracle,SQLServer,PostgreSQL以及任何遵循SQL92标准的数据库.
2.3 入门案例
第一步:Create a new database master databaseuser表,字段为id,name,age,address
第二步:使用Sharding-JDBC实现读写分离步骤:
1. 导入maven坐标
<dependency>
<groupId>org.apache.shardingsphere</groupId>
<artifactId>sharding-jdbc-spring-boot-starter</artifactId>
<version>4.0.0-RC1</version>
</dependency>
2. 在配置文件中配置读写分离规则
spring:
shardingsphere:
datasource: #指定数据源
names:
master,slave #这里的master,slave可以改变,It can correspond to the following
# 主数据源
master:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.72.131:3306/rw?characterEncoding=utf-8
username: root
password: root
# 从数据源
slave:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.72.132:3306/rw?characterEncoding=utf-8
username: root
password: root
masterslave:
# 读写分离配置
load-balance-algorithm-type: round_robin #轮询
# 最终的数据源名称
name: dataSource
# 主库数据源名称
master-data-source-name: master
# 从库数据源名称列表,多个逗号分隔
slave-data-source-names: slave
props:
sql:
show: true #开启SQL显示,默认false
3. 在配置文件中配置允许bean定义覆盖配置项
main:
allow-bean-definition-overriding: true
4. 启动
VMClone virtual host causedMySQL的UUID重复问题
第一步:进入到auto.cnf文件的上一级目录
cd /var/lib/mysql
ls
第二步:移除UUID
mv auto.cnf auto.cnf.bak
第三步:生成UUID
/usr/local/mysql/bin/mysqld_safe --defaults-file=/etc/my3306.cnf --user=mysql &
第四步:重启服务
Finally, go back to the slave library interface to view it again
完整代码下载地址:稍后补充
MySQLMaster-slave replication project instance-Java文档类资源-CSDN下载
边栏推荐
猜你喜欢
MobileNet ShuffleNet & yolov5 replace backbone
[ROS] (06) ROS Communication - Topic Communication
Network pruning (1)
The IDEA of packaged jar package
[ROS] (05) ROS Communication - Node, Nodes & Master
What are the file encryption software?Keep your files safe
Some impressions of the 519 plummet 2021-05-21
海明校验码纠错设计原理
[ROS](03)CMakeLists.txt详解
第八单元 中间件
随机推荐
Flask-RESTful request response and SQLAlchemy foundation
How to solve mysql service cannot start 1069
(ROS) (03) CMakeLists. TXT, rounding
【Tensorflow】AttributeError: module 'keras.backend' has no attribute 'tf'
Flask请求应用上下文源码分析
redis分布式锁和看门狗的实现
浅浅写一下PPOCRLabel的使用及体验
yolov5,yolov4,yolov3乱七八糟的
线代:已知一个特征向量快速求另外两个与之正交的特征向量
动手学ocr(一)
跑yolov5又出啥问题了(1)p,r,map全部为0
How does Apache, the world's largest open source foundation, work?
vim复制粘贴_vim如何复制粘贴
期货具体是如何开户的?
跑跑yolov5吧
You can't accept 60% slump, there is no eligible for gain of 6000% in 2021-05-27
AWVS工具介绍[通俗易懂]
动态刷新日志级别
[ROS]ROS常用工具介绍(待续)
WeChat Mini Program-Recent Dynamic Scrolling Implementation