검색

7.4. 데이터베이스 복제 성능 테스트

download PDF

클러스터와 개별 노드가 모두 정상이고 안정적인 경우 특정 데이터베이스 변수를 쿼리하여 복제 처리량에서 성능 벤치마크 테스트를 실행할 수 있습니다.

이러한 변수 중 하나를 쿼리할 때마다 FLUSH STATUS 명령이 변수 값을 재설정합니다. 벤치마크 테스트를 실행하려면 여러 쿼리를 실행하고 분산을 분석해야 합니다. 이러한 변동은 클러스터의 성능에 영향을 미치는 흐름 제어 의 양을 결정하는 데 도움이 될 수 있습니다.

흐름 제어는 클러스터가 복제를 관리하는 데 사용하는 메커니즘입니다. 로컬 수신된 큐 가 특정 임계값을 초과하면 Flow Control은 대기열 크기가 중단될 때까지 복제를 일시 중지합니다. Flow Control에 대한 자세한 내용은 Galera Cluster 웹 사이트에서 Flow Control 을 참조하십시오.

절차

다음 명령을 실행하고 확인할 wsrep 데이터베이스 변수로 VArichBLE을 바꿉니다.

$ sudo docker exec galera-bundle-docker-0 sudo mysql -B --password="[MYSQL-HIERA-PASSWORD]" -e "SHOW STATUS LIKE 'VARIABLE';"

다음 표에는 데이터베이스 복제 성능을 테스트하는 데 사용할 수 있는 wsrep 데이터베이스 변수가 나열되어 있습니다.

표 7.3. 데이터베이스 복제 성능을 확인하는 데이터베이스 변수
변수요약사용법

wsrep_local_recv_queue_avg

마지막 쿼리 이후의 로컬 수신된 쓰기 세트 대기열의 평균 크기입니다.

값이 0.0 보다 높으면 노드가 쓰기 세트를 수신할 때마다 write-sets를 적용할 수 없음을 나타냅니다. 이 경우 복제 제한을 트리거합니다. 이 벤치마크를 자세히 살펴보려면 wsrep_local_recv_queue_minwsrep_local_recv_queue_max 를 확인합니다.

wsrep_local_send_queue_avg

마지막 쿼리 후 평균 대기열 길이입니다.

값이 0.0 보다 큰 경우 복제 제한 및 네트워크 처리량 문제가 발생할 가능성이 높습니다.

wsrep_local_recv_queue_minwsrep_local_recv_queue_max

마지막 쿼리 후 로컬 수신 대기열의 최소 및 최대 크기입니다.

wsrep_local_recv_queue_avg 의 값이 0.0 보다 큰 경우 이러한 변수를 확인하여 큐 크기의 범위를 확인할 수 있습니다.

wsrep_flow_control_paused

마지막 쿼리 후 Flow Control이 노드를 일시 중지한 시간입니다.

값이 0.0 보다 큰 경우 Flow Control이 노드를 일시 중지했음을 나타냅니다. 일시 중지 기간을 결정하려면 wsrep_flow_control_paused 값을 쿼리 간에 초 단위로 곱합니다. 최적의 값은 0.0 에 최대한 가깝습니다.

예를 들어 다음과 같습니다.

  • wsrep_flow_control_paused 값이 마지막 쿼리 후 0.50 1분이면 Flow Control이 노드를 30초 동안 일시 중지했습니다.
  • wsrep_flow_control_paused 값이 마지막 쿼리 후 1.0 1분이면 Flow Control이 노드 전체 분 동안 일시 중지되었습니다.

wsrep_cert_deps_distance

병렬로 적용할 수 있는 가장 낮은 시퀀스 번호 (seqno) 값 간의 평균 차이점

제한 및 일시 중지의 경우 이 변수는 평균적으로 동시에 적용할 수 있는 쓰기 집합의 수를 나타냅니다. 값을 wsrep_slave_threads 변수와 비교하여 실제로 동시에 적용할 수 있는 쓰기 세트 수를 확인합니다.

wsrep_slave_threads

동시에 적용할 수 있는 스레드 수

이 변수의 값을 늘려 더 많은 스레드를 동시에 적용할 수 있으므로 wsrep_cert_deps_distance 값이 증가합니다. wsrep_slave_threads 값은 노드의 CPU 코어 수보다 클 수 없습니다.

예를 들어 wsrep_cert_deps_distance 값이 20 인 경우 wsrep_slave_threads 값을 2 에서 4 로 늘려 노드가 적용할 수 있는 쓰기 세트 양을 늘릴 수 있습니다.

문제가 있는 노드에 이미 최적의 wsrep_slave_threads 값이 있는 경우 가능한 연결 문제를 조사하는 동안 클러스터에서 노드를 제외할 수 있습니다.

Red Hat logoGithubRedditYoutubeTwitter

자세한 정보

평가판, 구매 및 판매

커뮤니티

Red Hat 문서 정보

Red Hat을 사용하는 고객은 신뢰할 수 있는 콘텐츠가 포함된 제품과 서비스를 통해 혁신하고 목표를 달성할 수 있습니다.

보다 포괄적 수용을 위한 오픈 소스 용어 교체

Red Hat은 코드, 문서, 웹 속성에서 문제가 있는 언어를 교체하기 위해 최선을 다하고 있습니다. 자세한 내용은 다음을 참조하세요.Red Hat 블로그.

Red Hat 소개

Red Hat은 기업이 핵심 데이터 센터에서 네트워크 에지에 이르기까지 플랫폼과 환경 전반에서 더 쉽게 작업할 수 있도록 강화된 솔루션을 제공합니다.

© 2024 Red Hat, Inc.