mysql에서는 "mysql-proxy"를 사용하여 읽기-쓰기 분리를 달성할 수 있습니다. "mysql-proxy"는 미들웨어라고도 불리는 읽기-쓰기 분리를 달성하기 위해 mysql에서 공식적으로 제공하는 소프트웨어입니다. 쓰기 작업. 데이터베이스에서 쿼리를 처리할 때 마스터-슬레이브 복제를 통해 데이터베이스 일관성이 달성됩니다.
이 튜토리얼의 운영 환경: windows10 시스템, mysql8.0.22 버전, Dell G3 컴퓨터.
읽기 및 쓰기 분리를 구현할 수 있는 Mysql 플러그인에는 mysql-proxy / Mycat / Amoeba와 함께 제공되는 플러그인이 있습니다. 이 실험은 이를 달성하기 위해 주로 사용됩니다. 읽기/쓰기 분할
mysql-proxy는 "읽기/쓰기 분할"(MySQL에서 공식적으로 제공, 미들웨어라고도 함)을 구현하는 소프트웨어입니다. 데이터베이스는 쓰기 작업(삽입, 업데이트, 삭제)을 처리하고 데이터베이스에서 쿼리 작업(선택)을 처리합니다. 데이터베이스의 일관성은 마스터-슬레이브 복제를 통해 달성됩니다
MySQL-프록시는 주로 내부 Lua 스크립트(읽기 및 쓰기 문 판단을 실현할 수 있음)에 의존하여 읽기 및 쓰기 문 간의 구별을 실현할 수 있습니다
만약 그렇다면 메인 서버에서만(쓰기 서버에서 데이터 쓰기 작업이 완료됨) 이때 슬레이브 서버에서는 쓰기 작업이 수행되지 않으며, 이 때 다른 기술을 사용해야 합니다. 마스터-슬레이브 복제 기술이라 불리는 이 기술은 읽기-쓰기 분리의 기본입니다.
읽기-쓰기 분리(MySQL-Proxy) 마스터는 쓰기 작업을 처리하고 슬레이브는 읽기 작업을 처리하게 합니다. 상대적으로 읽기 작업량이 많은 시나리오에 매우 적합하며 마스터의 작업량을 줄일 수 있습니다.
mysql-proxy를 사용하여 읽기와 쓰기의 분리를 실현하세요. mysql.mysql-proxy는 실제로 백엔드 mysql 마스터-슬레이브 서버의 프록시 역할을 하며 클라이언트의 요청을 직접 받아들이고 SQL 문을 분석하여 읽기 작업인지 쓰기 작업인지 결정합니다. 해당 mysql 서버에 배포
데이터베이스 쓰기 작업은 읽기 작업보다 시간이 많이 걸리기 때문에 데이터베이스 읽기와 쓰기를 분리하면 데이터베이스에 쓰기 문제가 해결되어 쿼리 효율성에 영향을 미칩니다.
server1에서 server2로 gtid 마스터-슬레이브 복제를 먼저 구성하세요
server3 프록시 구성(mysql-proxy)
에 대한 mysql-proxy 설치를 가져옵니다. (2) server3
[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/目录下
에서 구성 관리를 위한 소프트 연결 만들기
ln -s mysql-proxy-0.8.5-linux-glibc2-x86-64bit mysql-proxy
구성 파일이 없습니다. mysql-proxy 디렉터리이므로 직접 구성 파일을 생성해야 합니다. Directory, 구성 파일을 생성하세요
다음 두 명령을 사용하여 구성 파일에 적힌 매개변수를 확인하세요
[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 ##使用后台方式运行
저장 후, 구성 파일의 권한을 660으로 변경하고 로그 디렉터리를 생성해야 합니다
데이터베이스에서 읽기-쓰기 분리가 발생할 때 최대 및 최소 연결 수를 수정합니다[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, 最大连接数
(3 ) mysql-proxy 시작
/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> 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;
(2)server3安装lsof
(3)在用户端虚拟机server4上第一次连接数据库代理server3
在server3上面:lsof -i:3306
(4)在用户端虚拟机server4上第二次连接数据库代理server3
在server3上面:lsof -i:3306
(5)在用户端虚拟机server4上第三次连接数据库代理server3
在server3上面:lsof -i:3306
开始读写分离
上面是读写分离的读访问测试
写测试
在用户端插入数据
use westos; insert into linux values('user1','123');
server1和server2都可以看到插入的数据
在server2中关闭主从复制
用户端再次写入数据,看不到刚刚写的数据
写在server1上,可以查看到数据
在server2上实现了读写分离
server2重新开启主从复制可以看到数据
客户端读的是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 중국어 웹사이트의 기타 관련 기사를 참조하세요!