> 데이터 베이스 > MySQL 튜토리얼 > mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?

WBOY
풀어 주다: 2022-03-28 16:30:08
원래의
9550명이 탐색했습니다.

mysql에서는 "mysql-proxy"를 사용하여 읽기-쓰기 분리를 달성할 수 있습니다. "mysql-proxy"는 미들웨어라고도 불리는 읽기-쓰기 분리를 달성하기 위해 mysql에서 공식적으로 제공하는 소프트웨어입니다. 쓰기 작업. 데이터베이스에서 쿼리를 처리할 때 마스터-슬레이브 복제를 통해 데이터베이스 일관성이 달성됩니다.

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?

이 튜토리얼의 운영 환경: windows10 시스템, mysql8.0.22 버전, Dell G3 컴퓨터.

mysql 읽기 및 쓰기 분리 구현 방법은 무엇인가요?

읽기 및 쓰기 분리를 구현할 수 있는 Mysql 플러그인에는 mysql-proxy / Mycat / Amoeba와 함께 제공되는 플러그인이 있습니다. 이 실험은 이를 달성하기 위해 주로 사용됩니다. 읽기/쓰기 분할

mysql-proxy는 "읽기/쓰기 분할"(MySQL에서 공식적으로 제공, 미들웨어라고도 함)을 구현하는 소프트웨어입니다. 데이터베이스는 쓰기 작업(삽입, 업데이트, 삭제)을 처리하고 데이터베이스에서 쿼리 작업(선택)을 처리합니다. 데이터베이스의 일관성은 마스터-슬레이브 복제를 통해 달성됩니다

MySQL-프록시는 주로 내부 Lua 스크립트(읽기 및 쓰기 문 판단을 실현할 수 있음)에 의존하여 읽기 및 쓰기 문 간의 구별을 실현할 수 있습니다

만약 그렇다면 메인 서버에서만(쓰기 서버에서 데이터 쓰기 작업이 완료됨) 이때 슬레이브 서버에서는 쓰기 작업이 수행되지 않으며, 이 때 다른 기술을 사용해야 합니다. 마스터-슬레이브 복제 기술이라 불리는 이 기술은 읽기-쓰기 분리의 기본입니다.

읽기-쓰기 분리(MySQL-Proxy) 마스터는 쓰기 작업을 처리하고 슬레이브는 읽기 작업을 처리하게 합니다. 상대적으로 읽기 작업량이 많은 시나리오에 매우 적합하며 마스터의 작업량을 줄일 수 있습니다.

mysql-proxy를 사용하여 읽기와 쓰기의 분리를 실현하세요. mysql.mysql-proxy는 실제로 백엔드 mysql 마스터-슬레이브 서버의 프록시 역할을 하며 클라이언트의 요청을 직접 받아들이고 SQL 문을 분석하여 읽기 작업인지 쓰기 작업인지 결정합니다. 해당 mysql 서버에 배포

데이터베이스 쓰기 작업은 읽기 작업보다 시간이 많이 걸리기 때문에 데이터베이스 읽기와 쓰기를 분리하면 데이터베이스에 쓰기 문제가 해결되어 쿼리 효율성에 영향을 미칩니다.

server1에서 server2로 gtid 마스터-슬레이브 복제를 먼저 구성하세요

gtid 마스터-슬레이브 복제는 이전 블로그에서 설명했기 때문에 여기서는 자세히 설명하지 않고 최종 효과만 보여드리겠습니다

westos라는 것을 알 수 있습니다 server1에 데이터베이스가 구축되고 해당 server2가 동기화됩니다



mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?server3 프록시 구성(mysql-proxy)

server3에 mysql-proxy 프록시 서버 구축(클라이언트가 server1에 쓰고 server2에서 데이터를 읽을 수 있음) )

(1) 물리적 머신 패키지에서 server3



에 대한 mysql-proxy 설치를 가져옵니다. (2) server3mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?

[root@server3 ~]# systemctl status mysqld	##查看mysqld服务状态
[root@server3 ~]# systemctl stop mysqld	##关闭mysqld服务,因为代理服务器要用3306端口
[root@server3 ~]# tar zxf mysql-proxy-0.8.5-linux-glibc2-x86-64bit.tar.gz -C /usr/local/	##解压到/usr/local/目录下
로그인 후 복사

에서 구성 관리를 위한 소프트 연결 만들기mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?

ln -s mysql-proxy-0.8.5-linux-glibc2-x86-64bit mysql-proxy
로그인 후 복사

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?구성 파일이 없습니다. mysql-proxy 디렉터리이므로 직접 구성 파일을 생성해야 합니다. Directory, 구성 파일을 생성하세요

다음 두 명령을 사용하여 구성 파일에 적힌 매개변수를 확인하세요mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?

[root@server3 bin]# ./mysql-proxy --help
[root@server3 bin]# ./mysql-proxy --help-proxy
로그인 후 복사
[mysql-proxy]	##指定语句块
proxy-address=0.0.0.0:3306	##指定proxy访问的主机和端口,3306是一个对外的通用端口
proxy-read-only-backend-addresses=172.25.254.2:3306	##读主机的ip和端口
proxy-backend-addresses=172.25.254.1:3306	##执行写主机的ip和端口
proxy-lua-script=/usr/local/mysql-proxy/share/doc/mysql-proxy/rw-splitting.lua	##指定读写分离操作使用的lua文件路径
pid-file=/usr/local/mysql-proxy/log/mysql-proxy.pid	##pid存放路径
log-file=/usr/local/mysql-proxy/log/mysql-proxy.log	##日志存放路径
plugins=proxy	##指定使用的插件
log-level=debug	##日志的等级
keepalive=true	##开启守护进程
daemon=true	##使用后台方式运行
로그인 후 복사

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?저장 후, 구성 파일의 권한을 660으로 변경하고 로그 디렉터리를 생성해야 합니다

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까? 데이터베이스에서 읽기-쓰기 분리가 발생할 때 최대 및 최소 연결 수를 수정합니다

[root@server3 mysql-proxy]# find . -name *.lua 
./share/doc/mysql-proxy/rw-splitting.lua
[root@server3 mysql-proxy]# cd share/doc/mysql-proxy 
[root@server3 mysql-proxy]# ls 
[root@server3 mysql-proxy]# vim rw-splitting.lua		##将lua脚本里原本启动机制的最小4个最大8个连接,改为1和2
min_idle_connections = 1, 最小连接数 
max_idle_connections = 2, 最大连接数
로그인 후 복사

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
(3 ) mysql-proxy 시작mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?

/usr/local/mysql-proxy/bin/mysql-proxy --defaults-file=/usr/local/mysql-proxy/conf/mysql-proxy.conf	##启动
cat /usr/local/mysql-proxy/log/mysql-proxy.log	##查看日志
로그인 후 복사

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?읽기-쓰기 분리 테스트

(1) server1에 새 서버를 생성하고 권한을 부여받은 사용자

mysql> grant insert,update,select on *.* to kkxili@'%' identified by 'Red1hat*';
mysql> FLUSH PRIVILEGES;	##刷新授权表
mysql> USE westos;
Database changed
mysql> CREATE TABLE linux (
    -> username varchar(10) not null,
    -> password varchar(15) not null);
mysql>DESC linux;
로그인 후 복사

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
(2)server3安装lsof
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
(3)在用户端虚拟机server4上第一次连接数据库代理server3
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
在server3上面:lsof -i:3306
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
(4)在用户端虚拟机server4上第二次连接数据库代理server3
在server3上面:lsof -i:3306
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
(5)在用户端虚拟机server4上第三次连接数据库代理server3
在server3上面:lsof -i:3306
开始读写分离

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?上面是读写分离的读访问测试
写测试
在用户端插入数据

use westos;
insert into linux values('user1','123');
로그인 후 복사

mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
server1和server2都可以看到插入的数据
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
在server2中关闭主从复制
用户端再次写入数据,看不到刚刚写的数据
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
写在server1上,可以查看到数据
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
在server2上实现了读写分离
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
server2重新开启主从复制可以看到数据
mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?
客户端读的是server2,server2只能读,不能写,因此看不到刚才写进去的东西,server1可以看到
实现了客户端(虚拟机)对server1的写,对server2的读

当访问数据库的用户数量很多时,数据库的代理就把后端的数据库实现读写分离
server1是写的数据库、server2是读的数据库
当server1和server2满足gtid的主从复制时,用户往数据库写入的数据其实是写入了server1,并没有写入server2,server2上面的数据是复制过去的,因此server1、server2、客户机上面都能查到刚刚写进去的数据,其实客户机查的是server2(读)
当关闭server1和server2的异步复制时,客户机往数据库写入的数据只写进了server1,没有写进去server2,server2也没有复制一份
因此server1可以查看到,server2和客户机上面都查不到刚刚写进去的数据,此时的客户机读的是server2

推荐学习:mysql视频教程

위 내용은 mysql 읽기 및 쓰기 분리 구현 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿