mysql 클러스터에 대한 간략한 소개(그림)
1.MySQL클러스터
MySQL 클러스터는 비공유 분산 노드 아키텍처 스토리지 체계로, 다음을 제공하도록 설계되었습니다. 내결함성과 고성능.
데이터 업데이트는 읽기 커밋 격리 수준을 사용하여 모든 노드 데이터의 일관성을 보장하고 2단계 커밋 메커니즘을 사용하여 모든 노드가 동일한 데이터를 갖도록 보장합니다(쓰기 작업이 실패할 경우, 업데이트가 실패합니다).
비공유 피어 노드는 한 서버의 업데이트를 다른 서버에 즉시 표시합니다. 업데이트 전파는 네트워크 전체에서 높은 처리량을 제공하도록 설계된 복잡한 통신 메커니즘을 사용합니다.
여러 MySQL 서버를 통해 로드를 분산하여 프로그램 성능을 극대화하고 데이터를 서로 다른 위치에 저장하여 고가용성과 중복성을 보장합니다.
2. 아키텍처 다이어그램
3. 데이터 저장 방법
1. Mysqlcluster 데이터 노드 그룹의 마스터-슬레이브 동기화는 그룹 내 노드 데이터의 일관성을 보장하기 위해 동기 복제를 사용합니다. 일반적으로 Two-Phase Commit 프로토콜을 통해 구현되며 일반적인 작업 프로세스는 다음과 같습니다.
a) 마스터가 커밋 문을 실행하면 해당 트랜잭션이 슬레이브로 전송되고, 슬레이브는 트랜잭션 제출을 준비하기 시작합니다.
b) 각 슬레이브는 트랜잭션을 준비한 다음 마스터에 OK(또는 ABORT) 메시지를 보내 트랜잭션이 준비되었음을 나타냅니다(또는 트랜잭션을 준비할 수 없음).
c) 마스터는 모든 슬레이브가 OK 또는 ABORT 메시지를 보내기를 기다립니다.
마스터가 모든 슬레이브로부터 OK 메시지를 받으면 메시지를 보냅니다. 슬레이브는 슬레이브에게 트랜잭션을 제출하라고 알리는 커밋 메시지를 보냅니다.
마스터가 슬레이브로부터 ABORT 메시지를 받으면 모든 슬레이브에 ABORT 메시지를 보내 슬레이브에게 중단을 알립니다. 거래.
e) 각 슬레이브는 마스터로부터 OK 또는 ABORT 메시지를 기다립니다.
슬레이브가 커밋 요청을 받으면 트랜잭션을 커밋하고 트랜잭션이 마스터에 제출되었다는 확인을 보냅니다.
슬레이브가 취소 요청을 받으면 모든 변경 사항을 취소하고 점유된 리소스를 해제하여 트랜잭션을 중단한 다음 트랜잭션이 중단되었다는 확인을 Masterv에 보냅니다.
f) 마스터가 모든 슬레이브로부터 확인을 받으면 트랜잭션이 커밋(또는 중단)되었음을 보고하고 다음 트랜잭션을 계속합니다.
동기 복제에는 총 4번의 메시지 전송이 필요하기 때문에 mysql 클러스터의 데이터 업데이트 속도는 독립형 mysql보다 느립니다. 따라서 mysql 클러스터는 Gigabit 이상의 LAN에서 실행되어야 하며 노드는 듀얼 네트워크 카드를 사용할 수 있으며 노드 그룹은 직접 연결되어야 합니다.
질문: 클러스터를 확장하고 데이터 노드 그룹을 추가하면 데이터 업데이트 속도가 느려지나요?
답변: 아니요, 데이터 업데이트 속도가 빨라집니다. 데이터를 별도로 처리하기 때문에 각 노드 그룹에 저장되는 데이터가 다르기 때문에
잠금도 줄일 수 있습니다.
2. Mysqlcluster는 모든 인덱스 컬럼을 메인 메모리에 저장하고, 인덱스가 아닌 다른 컬럼은 테이블스페이스를 생성하여 메모리에 저장하거나 디스크에 저장할 수 있습니다. 데이터가 변경(삽입, 업데이트, 삭제 등)되면 mysql 클러스터는 변경된 레코드를 redo 로그에 기록한 후 체크포인트를 통해 정기적으로 디스크에 데이터를 쓴다. 리두 로그는 비동기적으로 커밋되기 때문에 오류 발생 시 소수의 트랜잭션이 손실될 수 있습니다. 트랜잭션 손실을 줄이기 위해 MySQL Cluster는 지연된 쓰기(기본 지연 2초, 구성 가능)를 구현하여 오류가 발생할 때 마지막 체크포인트를 잃지 않고 체크포인트 쓰기를 완료할 수 있습니다. 일반적으로 단일 데이터 노드에 장애가 발생하더라도 클러스터 내에서는 동기식 데이터 복제가 사용되므로 데이터 손실이 발생하지 않습니다.
4. MySQL클러스터 수평 확장
1. 확장할 데이터 노드 그룹을 추가합니다. 클러스터의 저장 용량을 향상시키기 위한 쓰기 작업입니다. 온라인 확장을 지원합니다. 먼저 clsuter에 새 노드를 추가합니다. 시작한 후
ALTER ONLINE TABLE table_name REORGANIZE PARTITION
명령을 사용하여 데이터를 데이터 노드에 균등하게 배포합니다.
2. 슬레이브를 추가하면 읽기만 확장되고 쓰기 작업의 수평 확장은 불가능합니다.
전체 시스템의 평균 부하는 다음과 같이 설명할 수 있습니다.
AverageLoad=∑readload+ ∑writeload / ∑capacity
각 서버가 초당 10,000개의 트랜잭션을 가지고 있고, 마스터의 초당 쓰기 부하는 4,000개의 트랜잭션이고, 읽기 부하는 초당 로드는 6000이고 결과는 다음과 같습니다.
AverageLoad=6000+4000/10000=100%
이제 슬레이브를 3개 추가하면 초당 트랜잭션 볼륨이 40,000으로 늘어납니다. 쓰기 작업도 복제되므로 각 쓰기 작업은 4번 실행되므로 각 슬레이브의 쓰기 부하는 초당 4000 트랜잭션입니다. 현재 로드 평균은
AverageLoad=6000+4*4000/ 4*10000=55%
5입니다. MySQL 클러스터링의 장점과 단점
장점:
a) 99.999% 고가용성
b) 빠른 자동 장애 조치
c) 유연한 분산 아키텍처, 단일 장애 지점 없음
d )높은 처리량 및 낮은 지연
e) 강력한 확장성, 온라인 확장 지원
단점:
a) 다음과 같은 많은 제한 사항이 있습니다. 외래 키가 지원되지 않습니다
b) 배포, 관리 및 구성이 복잡합니다
c) 디스크 공간과 메모리를 많이 차지
d) 백업 및 복구가 불편함
e) 다시 시작하면 데이터 노드가 Loading됨 메모리에 들어가는 데 시간이 오래 걸립니다
위 내용은 mysql 클러스터에 대한 간략한 소개(그림)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) 데이터베이스 및 테이블 작성 : CreateAbase 및 CreateTable 명령을 사용하십시오. 2) 기본 작업 : 삽입, 업데이트, 삭제 및 선택. 3) 고급 운영 : 가입, 하위 쿼리 및 거래 처리. 4) 디버깅 기술 : 확인, 데이터 유형 및 권한을 확인하십시오. 5) 최적화 제안 : 인덱스 사용, 선택을 피하고 거래를 사용하십시오.

다음 단계를 통해 phpmyadmin을 열 수 있습니다. 1. 웹 사이트 제어판에 로그인; 2. phpmyadmin 아이콘을 찾고 클릭하십시오. 3. MySQL 자격 증명을 입력하십시오. 4. "로그인"을 클릭하십시오.

Navicat Premium을 사용하여 데이터베이스 생성 : 데이터베이스 서버에 연결하고 연결 매개 변수를 입력하십시오. 서버를 마우스 오른쪽 버튼으로 클릭하고 데이터베이스 생성을 선택하십시오. 새 데이터베이스의 이름과 지정된 문자 세트 및 Collation의 이름을 입력하십시오. 새 데이터베이스에 연결하고 객체 브라우저에서 테이블을 만듭니다. 테이블을 마우스 오른쪽 버튼으로 클릭하고 데이터 삽입을 선택하여 데이터를 삽입하십시오.

MySQL 및 SQL은 개발자에게 필수적인 기술입니다. 1.MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템이며 SQL은 데이터베이스를 관리하고 작동하는 데 사용되는 표준 언어입니다. 2.MYSQL은 효율적인 데이터 저장 및 검색 기능을 통해 여러 스토리지 엔진을 지원하며 SQL은 간단한 문을 통해 복잡한 데이터 작업을 완료합니다. 3. 사용의 예에는 기본 쿼리 및 조건 별 필터링 및 정렬과 같은 고급 쿼리가 포함됩니다. 4. 일반적인 오류에는 구문 오류 및 성능 문제가 포함되며 SQL 문을 확인하고 설명 명령을 사용하여 최적화 할 수 있습니다. 5. 성능 최적화 기술에는 인덱스 사용, 전체 테이블 스캔 피하기, 조인 작업 최적화 및 코드 가독성 향상이 포함됩니다.

응용 프로그램을 열고 새로운 연결 (Ctrl n)을 선택하여 Navicat에서 새로운 MySQL 연결을 만들 수 있습니다. "MySQL"을 연결 유형으로 선택하십시오. 호스트 이름/IP 주소, 포트, 사용자 이름 및 비밀번호를 입력하십시오. (선택 사항) 고급 옵션을 구성합니다. 연결을 저장하고 연결 이름을 입력하십시오.

백업 또는 트랜잭션 롤백 메커니즘이없는 한 데이터베이스에서 직접 삭제 된 행 복구는 일반적으로 불가능합니다. 키 포인트 : 거래 롤백 : 트랜잭션이 데이터를 복구하기 전에 롤백을 실행합니다. 백업 : 데이터베이스의 일반 백업을 사용하여 데이터를 신속하게 복원 할 수 있습니다. 데이터베이스 스냅 샷 : 데이터베이스의 읽기 전용 사본을 작성하고 데이터를 실수로 삭제 한 후 데이터를 복원 할 수 있습니다. 주의해서 삭제 명령문을 사용하십시오. 실수로 데이터를 삭제하지 않도록 조건을주의 깊게 점검하십시오. WHERE 절을 사용하십시오 : 삭제할 데이터를 명시 적으로 지정하십시오. 테스트 환경 사용 : 삭제 작업을 수행하기 전에 테스트하십시오.

Redis는 단일 스레드 아키텍처를 사용하여 고성능, 단순성 및 일관성을 제공합니다. 동시성을 향상시키기 위해 I/O 멀티플렉싱, 이벤트 루프, 비 블로킹 I/O 및 공유 메모리를 사용하지만 동시성 제한 제한, 단일 고장 지점 및 쓰기 집약적 인 워크로드에 부적합한 제한이 있습니다.

phpmyadmin을 사용하여 MySQL에 연결하는 방법? phpmyadmin에 액세스하기위한 URL은 일반적으로 http : // localhost/phpmyadmin 또는 http : // [서버 IP 주소]/phpmyadmin입니다. MySQL 사용자 이름 및 비밀번호를 입력하십시오. 연결하려는 데이터베이스를 선택하십시오. "연결"버튼을 클릭하여 연결을 설정하십시오.
