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

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL의 장소 : 데이터베이스 및 프로그래밍MySQL의 장소 : 데이터베이스 및 프로그래밍Apr 13, 2025 am 12:18 AM

데이터베이스 및 프로그래밍에서 MySQL의 위치는 매우 중요합니다. 다양한 응용 프로그램 시나리오에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) MySQL은 웹, 모바일 및 엔터프라이즈 레벨 시스템을 지원하는 효율적인 데이터 저장, 조직 및 검색 기능을 제공합니다. 2) 클라이언트 서버 아키텍처를 사용하고 여러 스토리지 엔진 및 인덱스 최적화를 지원합니다. 3) 기본 사용에는 테이블 작성 및 데이터 삽입이 포함되며 고급 사용에는 다중 테이블 조인 및 복잡한 쿼리가 포함됩니다. 4) SQL 구문 오류 및 성능 문제와 같은 자주 묻는 질문은 설명 명령 및 느린 쿼리 로그를 통해 디버깅 할 수 있습니다. 5) 성능 최적화 방법에는 인덱스의 합리적인 사용, 최적화 된 쿼리 및 캐시 사용이 포함됩니다. 모범 사례에는 거래 사용 및 준비된 체계가 포함됩니다

MySQL : 소기업에서 대기업에 이르기까지MySQL : 소기업에서 대기업에 이르기까지Apr 13, 2025 am 12:17 AM

MySQL은 소규모 및 대기업에 적합합니다. 1) 소기업은 고객 정보 저장과 같은 기본 데이터 관리에 MySQL을 사용할 수 있습니다. 2) 대기업은 MySQL을 사용하여 대규모 데이터 및 복잡한 비즈니스 로직을 처리하여 쿼리 성능 및 트랜잭션 처리를 최적화 할 수 있습니다.

Phantom은 무엇을 읽고, Innodb는 어떻게 그들을 막을 수 있습니까 (다음 키 잠금)?Phantom은 무엇을 읽고, Innodb는 어떻게 그들을 막을 수 있습니까 (다음 키 잠금)?Apr 13, 2025 am 12:16 AM

InnoDB는 팬텀 읽기를 차세대 점화 메커니즘을 통해 효과적으로 방지합니다. 1) Next-Keylocking은 Row Lock과 Gap Lock을 결합하여 레코드와 간격을 잠그기 위해 새로운 레코드가 삽입되지 않도록합니다. 2) 실제 응용 분야에서 쿼리를 최적화하고 격리 수준을 조정함으로써 잠금 경쟁을 줄이고 동시성 성능을 향상시킬 수 있습니다.

MySQL : 프로그래밍 언어는 아니지만 ...MySQL : 프로그래밍 언어는 아니지만 ...Apr 13, 2025 am 12:03 AM

MySQL은 프로그래밍 언어가 아니지만 쿼리 언어 SQL은 프로그래밍 언어의 특성을 가지고 있습니다. 1. SQL은 조건부 판단, 루프 및 가변 작업을 지원합니다. 2. 저장된 절차, 트리거 및 기능을 통해 사용자는 데이터베이스에서 복잡한 논리 작업을 수행 할 수 있습니다.

MySQL : 세계에서 가장 인기있는 데이터베이스 소개MySQL : 세계에서 가장 인기있는 데이터베이스 소개Apr 12, 2025 am 12:18 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

MySQL의 중요성 : 데이터 저장 및 관리MySQL의 중요성 : 데이터 저장 및 관리Apr 12, 2025 am 12:18 AM

MySQL은 데이터 저장, 관리, 쿼리 및 보안에 적합한 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1. 다양한 운영 체제를 지원하며 웹 응용 프로그램 및 기타 필드에서 널리 사용됩니다. 2. 클라이언트-서버 아키텍처 및 다양한 스토리지 엔진을 통해 MySQL은 데이터를 효율적으로 처리합니다. 3. 기본 사용에는 데이터베이스 및 테이블 작성, 데이터 삽입, 쿼리 및 업데이트가 포함됩니다. 4. 고급 사용에는 복잡한 쿼리 및 저장 프로 시저가 포함됩니다. 5. 설명 진술을 통해 일반적인 오류를 디버깅 할 수 있습니다. 6. 성능 최적화에는 인덱스의 합리적인 사용 및 최적화 된 쿼리 문이 포함됩니다.

MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점Apr 12, 2025 am 12:17 AM

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

InnoDB 잠금 장치 (공유 잠금, 독점 잠금, 의도 잠금, 레코드 잠금, 갭 잠금, 차세대 자물쇠)를 설명하십시오.InnoDB 잠금 장치 (공유 잠금, 독점 잠금, 의도 잠금, 레코드 잠금, 갭 잠금, 차세대 자물쇠)를 설명하십시오.Apr 12, 2025 am 12:16 AM

InnoDB의 잠금 장치에는 공유 잠금 장치, 독점 잠금, 의도 잠금 장치, 레코드 잠금, 갭 잠금 및 다음 키 잠금 장치가 포함됩니다. 1. 공유 잠금을 사용하면 다른 트랜잭션을 읽지 않고 트랜잭션이 데이터를 읽을 수 있습니다. 2. 독점 잠금은 다른 트랜잭션이 데이터를 읽고 수정하는 것을 방지합니다. 3. 의도 잠금은 잠금 효율을 최적화합니다. 4. 레코드 잠금 잠금 인덱스 레코드. 5. 갭 잠금 잠금 장치 색인 기록 간격. 6. 다음 키 잠금은 데이터 일관성을 보장하기 위해 레코드 잠금과 갭 잠금의 조합입니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구