[MySQL] Information Schema - InnoDB : 1번째
- Databases/MySQL
- 2020. 12. 22.
■ INNODB_BUFFER_PAGE Table
INNODB_BUFFER_PAGE 테이블은 InnoDB 버퍼 풀의 각 페이지에 대한 정보를 제공합니다.
중요사항
INNODB_BUFFER_PAGE 테이블을 쿼리하면 성능에 영향을 줄 수 있습니다. 성능 영향을 인식하고 허용할 수 있다고 결정하지 않는한 프로덕션 시스템에서이 테이블을 쿼리하면 안됩니다.
프로덕션 시스템의 성능에 영향을 주지 않으려면 조사하려는 문제를 재현하고 테스트 인스턴스에서 버퍼풀 통계를 쿼리합니다.
각 컬럼의 정보는 다음과 같습니다.
• POOL_ID
버퍼 풀 ID입니다. 여러 버퍼 풀 인스턴스를 구별하기위한 식별자입니다.
• BLOCK_ID
버퍼 풀 블록 ID입니다.
• SPACE
테이블 스페이스 ID입니다. INNODB_SYS_TABLES.SPACE와 동일한 값.
• PAGE_NUMBER
페이지 번호.
• PAGE_TYPE
페이지 유형입니다. 다음 표는 허용되는 값을 보여줍니다.
테이블 1. INNODB_BUFFER_PAGE.PAGE_TYPE Values
Page Type | Description |
ALLOCATED | 새로 할당 된 페이지 |
BLOB | 압축되지 않은 BLOB페이지 |
COMPRESSED_BLOB2 | 후속 압축 BLOB 페이지 |
COMPRESSED_BLOB | 첫번째로 압축된 BLOB페이지 |
EXTENT_DESCRIPTOR | 익스텐트 설명자 페이지 |
FILE_SPACE_HEADER | 파일 공간 헤더 |
IBUF_BITMAP | 인서트 버퍼 비트맵 |
IBUF_FREE_LIST | 인서트 버퍼 여유 리스트 |
IBUF_INDEX | 인서트 버퍼 인덱스 |
INDEX | B-tree 노드 |
INODE | Index 노드 |
RTREE_INDEX | R-tree 인덱스 |
SYSTEM | 시스템 페이지 |
TRX_SYSTEM | 트랜잭션 시스템 데이터 |
UNDO_LOG | 언두 로그 페이지 |
UNKNOWN | 알수 없음 |
• FLUSH_TYPE
플러시 유형입니다.
• FIX_COUNT
버퍼 풀 내에서이 블록을 사용하는 스레드 수입니다. 0이면 블록이 제거 될 수 있습니다.
• IS_HASHED
이 페이지에 해시 인덱스가 작성되었는지 여부.
• NEWEST_MODIFICATION
가장 최근 수정된 로그 시퀀스 번호입니다.
• OLDEST_MODIFICATION
가장 오래된 수정의 로그 시퀀스 번호입니다.
• ACCESS_TIME
페이지의 첫 번째 액세스 시간을 판단하는 데 사용되는 추상 번호입니다.
• TABLE_NAME
페이지가 속한 테이블의 이름입니다. 이 컬럼은 PAGE_TYPE 값이 INDEX 인 페이지에만 적용됩니다.
• INDEX_NAME
페이지가 속한 인덱스의 이름입니다. 클러스터형 인덱스 또는 보조 인덱스의 이름이 될 수 있습니다. 이 컬럼은 PAGE_TYPE값이 INDEX인 페이지에만 적용됩니다.
• NUMBER_RECORDS
페이지 내의 레코드 수입니다.
• DATA_SIZE
레코드 크기의 합계입니다. 이 열은 PAGE_TYPE 값이 INDEX 인 페이지에만 적용됩니다.
• COMPRESSED_SIZE
압축 된 페이지 크기입니다. 압축되지 않은 페이지의 경우 NULL입니다.
• PAGE_STATE
페이지 상태입니다. 다음 표는 허용되는 값을 보여줍니다.
테이블 2 : INNODB_BUFFER_PAGE.PAGE_STATE 값
Page State | Description |
FILE_PAGE | 버퍼가 할당된 파일 페이지 |
MEMORY | 주 메모리 개체를 포함 |
NOT_USED | 여유 리스트 |
NULL | 압축된 페이지 정리, 플러시 목록의 압축된 페이지, 버퍼풀 감시 센티널로 사용되는 페이지 |
READY_FOR_USE | 여유 페이지. 사용할 수 있는 페이지 |
REMOVE_HASH | 여유 목록에 배치하기 전에 해시 인덱스를 제거해야 하는 목록. |
• IO_FIX
이 페이지에 대해 I / O가 보류 중인지 여부 : IO_NONE = 보류중인 I / O 없음, IO_READ = 읽기 보류, IO_WRITE = 쓰기 보류.
• IS_OLD
블록이 LRU 목록에있는 이전 블록의 하위 목록에 있는지 여부입니다.
• FREE_PAGE_CLOCK
블록이 LRU 목록의 맨 위에 마지막으로 배치되었을 때 freed_page_clock 카운터의 값입니다. freed_page_clock 카운터는 LRU 목록의 끝에서 제거 된 블록 수를 추적합니다.
• 예제
mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_PAGE LIMIT 1\G
*************************** 1. row ***************************
POOL_ID: 0
BLOCK_ID: 0
SPACE: 97
PAGE_NUMBER: 2473
PAGE_TYPE: INDEX
FLUSH_TYPE: 1
FIX_COUNT: 0
IS_HASHED: YES
NEWEST_MODIFICATION: 733855581
OLDEST_MODIFICATION: 0
ACCESS_TIME: 3378385672
TABLE_NAME: `employees`.`salaries`
INDEX_NAME: PRIMARY
NUMBER_RECORDS: 468
DATA_SIZE: 14976
COMPRESSED_SIZE: 0
PAGE_STATE: FILE_PAGE
IO_FIX: IO_NONE
IS_OLD: YES
FREE_PAGE_CLOCK: 66
• 참고사항
+ 이 표는 주로 전문가 수준의 성능 모니터링이나 MySQL용 성능 관련 확장을 개발할 때 유용합니다.
+ 이 테이블을 쿼리하려면 PROCESS 권한이 있어야 합니다.
+ INFORMATION_SCHEMA COLUMNS 테이블 또는 SHOW COLUMNS 문을 사용하여 데이터 유형 및 기본값을 포함하여이 테이블의 컬럼에 대한 추가 정보를 봅니다.
+ 테이블, 테이블 행, 파티션 또는 인덱스가 삭제되면 다른 데이터를위한 공간이 필요할 때까지 관련 페이지가 버퍼 풀에 남아 있습니다.
INNODB_BUFFER_PAGE 테이블은 버퍼 풀에서 제거 될 때까지 이러한 페이지에 대한 정보를보고합니다.
■ INNODB_BUFFER_PAGE_LRU Table
INNODB_BUFFER_PAGE_LRU 테이블은 InnoDB 버퍼풀의 페이지에 대한 정보를 제공합니다. 특히 버퍼풀이 가득차면 버퍼풀에서 제거할 페이지를 결정하는 LRU 목록에서 순서가 지정됩니다.
INNODB_BUFFER_PAGE_LRU 테이블에는 INNODB_BUFFER_PAGE 테이블과 동일한 컬럼이 있습니다. 단, INNODB_BUFFER_PAGE_LRU 테이블에는 BLOCK_ID 및 PAGE_STATE 컬럼 대신 LRU_POSITION 및 COMPRESSED 컬럼이 있습니다.
+ 중요사항.
INNODB_BUFFER_PAGE_LRU 테이블을 쿼리하면 성능에 영향을 미칠 수 있습니다. 성능 영향을 인식하고 허용 할 수 있다고 결정하지 않는 한 프로덕션 시스템에서이 테이블을 쿼리하면 안됩니다.
프로덕션 시스템의 성능에 영향을주지 않으려면 조사하려는 문제를 재현하고 테스트 인스턴스에서 버퍼풀 통계를 쿼리합니다.
각 컬럼의 정보는 다음과 같습니다.
• POOL_ID
버퍼풀 ID입니다. 여러 버퍼풀 인스턴스를 구별하기위한 식별자입니다.
• LRU_POSITION
LRU 목록에서 페이지의 위치입니다.
• SPACE
테이블 스페이스 ID입니다. INNODB_SYS_TABLES.SPACE와 동일한 값.
• PAGE_NUMBER
페이지 번호.
• PAGE_TYPE
페이지 유형입니다. 다음 표는 허용되는 값을 보여줍니다.
테이블 : INNODB_BUFFER_PAGE_LRU.PAGE_TYPE Values
Page Type | Description |
ALLOCATED | Freshly allocated page |
BLOB | Uncompressed BLOB page |
COMPRESSED_BLOB2 | Subsequent comp BLOB page |
COMPRESSED_BLOB | First compressed BLOB page |
EXTENT_DESCRIPTOR | Extent descriptor page |
FILE_SPACE_HEADER | File space header |
IBUF_BITMAP | Insert buffer bitmap |
IBUF_FREE_LIST | Insert buffer free list |
IBUF_INDEX | Insert buffer index |
INDEX | B-tree node |
INODE | Index node |
RTREE_INDEX | R-tree index |
SYSTEM | System page |
TRX_SYSTEM | Transaction system data |
UNDO_LOG | Undo log page |
UNKNOWN | Unknown |
• FLUSH_TYPE
플러시 유형입니다.
• FIX_COUNT
버퍼 풀 내에서이 블록을 사용하는 스레드 수입니다. 0이면 블록이 제거 될 수 있습니다.
• IS_HASHED
이 페이지에 해시 인덱스가 작성되었는지 여부.
• NEWEST_MODIFICATION
가장 최근에 수정된 로그 시퀀스 번호입니다.
• OLDEST_MODIFICATION
가장 오래된 수정의 로그 시퀀스 번호입니다.
• ACCESS_TIME
페이지의 첫 번째 액세스 시간을 판단하는 데 사용되는 추상 번호입니다.
• TABLE_NAME
페이지가 속한 테이블의 이름입니다. 이 컬럼은 PAGE_TYPE 값이 INDEX인 페이지에만 적용됩니다.
• INDEX_NAME
페이지가 속한 인덱스의 이름입니다. 클러스터형 인덱스 또는 보조 인덱스의 이름이 될 수 있습니다. 이 컬럼은 PAGE_TYPE 값이 INDEX인 페이지에만 적용됩니다.
• NUMBER_RECORDS
페이지 내의 레코드 수입니다.
• DATA_SIZE
레코드 크기의 합계입니다. 이 열은 PAGE_TYPE 값이 INDEX 인 페이지에만 적용됩니다.
• COMPRESSED_SIZE
압축 된 페이지 크기입니다. 압축되지 않은 페이지의 경우 NULL입니다.
• COMPRESSED
페이지가 압축되었는지 여부.
• IO_FIX
이 페이지에 대해 I/O가 보류 중인지 여부 : IO_NONE=보류중인 I/O 없음, IO_READ=읽기 보류, IO_WRITE=쓰기 보류.
• IS_OLD
블록이 LRU 목록에있는 이전 블록의 하위 목록에 있는지 여부.
• FREE_PAGE_CLOCK
블록이 LRU목록의 맨 위에 마지막으로 배치되었을 때 freed_page_clock 카운터의 값입니다. freed_page_clock 카운터는 LRU 목록의 끝에서 제거된 블록 수를 추적합니다.
• 예제
mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_PAGE_LRU LIMIT 1\G
*************************** 1. row ***************************
POOL_ID: 0
LRU_POSITION: 0
SPACE: 97
PAGE_NUMBER: 1984
PAGE_TYPE: INDEX
FLUSH_TYPE: 1
FIX_COUNT: 0
IS_HASHED: YES
NEWEST_MODIFICATION: 719490396
OLDEST_MODIFICATION: 0
ACCESS_TIME: 3378383796
TABLE_NAME: `employees`.`salaries`
INDEX_NAME: PRIMARY
NUMBER_RECORDS: 468
DATA_SIZE: 14976
COMPRESSED_SIZE: 0
COMPRESSED: NO
IO_FIX: IO_NONE
IS_OLD: YES
FREE_PAGE_CLOCK: 0
• 참고사항
+ 이 표는 주로 전문가 수준의 성능 모니터링 또는 MySQL용 성능 관련 확장을 개발할 때 유용합니다.
+ 이 테이블을 쿼리하려면 PROCESS 권한이 있어야 합니다.
+ INFORMATION_SCHEMA COLUMNS테이블 또는 SHOW COLUMNS 명령문을 사용하여 데이터 유형 및 기본값을 포함하여이 테이블의 컬럼에 대한 추가 정보를 봅니다.
+ 이 테이블을 쿼리하려면 MySQL이 버퍼 풀에있는 활성 페이지 수의 64바이트보다 큰 연속 메모리 블록을 할당해야 할 수 있습니다. 이 할당은 특히 멀티 기가 바이트 버퍼 풀이있는 시스템의 경우 잠재적으로 메모리 부족 오류를 유발할 수 있습니다.
+ 이 테이블을 쿼리하려면 MySQL이 LRU 목록을 순회하는 동안 버퍼 풀을 나타내는 데이터 구조를 잠그도록 해야합니다. 이는 특히 멀티 기가 바이트 버퍼 풀이있는 시스템의 경우 동시성을 줄일 수 있습니다.
+ 테이블, 테이블 행, 파티션 또는 인덱스가 삭제되면 다른 데이터에 공간이 필요할 때까지 관련 페이지가 버퍼 풀에 남아 있습니다. INNODB_BUFFER_PAGE_LRU 테이블은 버퍼풀에서 제거될때까지 이러한 페이지에 대한 정보를 보고합니다.
■ INNODB_BUFFER_POOL_STATS Table
INNODB_BUFFER_POOL_STATS 테이블은 SHOW ENGINE INNODB STATUS 출력에 제공된것과 동일한 버퍼풀 정보를 많이 제공합니다. InnoDB 버퍼풀 서버 상태 변수를 사용하여 동일한 정보를 많이 얻을 수도 있습니다.
버퍼 풀에서 페이지를 "최신(young)"또는 "최신이 아닌(not young)"으로 만드는 개념은 버퍼풀 데이터 구조의 헤드와 테일에있는 하위 목록간에 페이지를 전송하는 것을 의미합니다.
버퍼 풀에서 "최신"페이지는 오래 사용되는 반면 "최신이 아닌(not young)"페이지는 제거 지점에 훨씬 더 가깝게 이동됩니다.
각 컬럼의 정보는 다음과 같습니다.
• POOL_ID
버퍼 풀 ID입니다. 여러 버퍼 풀 인스턴스를 구별하기위한 식별자입니다.
• POOL_SIZE
페이지 단위의 InnoDB 버퍼풀 크기.
• FREE_BUFFERS
InnoDB 버퍼풀의 사용 가능한 페이지 수 입니다.
• DATABASE_PAGES
데이터를 포함하는 InnoDB 버퍼 풀의 페이지 수입니다. 이 숫자에는 더티 페이지와 깨끗한 페이지가 모두 포함됩니다.
• OLD_DATABASE_PAGES
이전 버퍼 풀 하위 목록의 페이지 수입니다.
• MODIFIED_DATABASE_PAGES
수정된(더티) 데이터베이스 페이지 수입니다.
• PENDING_DECOMPRESS
압축 해제를 보류중인 페이지 수입니다.
• PENDING_READS
보류중인 읽기 수입니다.
• PENDING_FLUSH_LRU
LRU에서 플러시를 보류중인 페이지 수입니다.
• PENDING_FLUSH_LIST
플러시 목록에서 플러시 보류중인 페이지 수입니다.
• PAGES_MADE_YOUNG
젊게 만든 페이지 수입니다.
• PAGES_NOT_MADE_YOUNG
젊게 만들지 않은 페이지 수입니다.
• PAGES_MADE_YOUNG_RATE
초당 최신 페이지로 변경되는 수 (마지막 페이지 배포 또는 활동이후 최신(young)으로 변경된 페이지 / 소요시간).
• PAGES_MADE_NOT_YOUNG_RATE
초당 최신 페이지로 변경되지 않은 수 (마지막 페이지 배포 또는 활동이후 최신(young)으로 변경되지 않은 페이지 / 소요시간).
• NUMBER_PAGES_READ
읽은 페이지 수입니다.
• NUMBER_PAGES_CREATED
생성 된 페이지 수입니다.
• NUMBER_PAGES_WRITTEN
기록 된 페이지 수입니다.
• PAGES_READ_RATE
초당 읽은 페이지 수 (마지막 페이지 배포 또는 활동이후 읽은 페이지 수/소요시간).
• PAGES_CREATE_RATE
초당 생성 된 페이지 수 (마지막 페이지 배포 또는 활동이후 생성된 페이지수/소요시간).
• PAGES_WRITTEN_RATE
초당 기록 된 페이지 수 (마지막 페이지 배포 또는 활동이후 기록된 페이지수/소요시간).
• NUMBER_PAGES_GET
논리적 읽기 요청 수입니다.
• HIT_RATE
버퍼 풀 적중률.
• YOUNG_MAKE_PER_THOUSAND_GETS
천개당 최신 페이지(young)로 변경된 수를 얻습니다.
• NOT_YOUNG_MAKE_PER_THOUSAND_GETS
천개당 최신 페이지(young)로 변경되지 않은 수를 얻습니다.
• NUMBER_PAGES_READ_AHEAD
미리 읽은 페이지 수입니다.
• NUMBER_READ_AHEAD_EVICTED
쿼리에서 액세스하지 않고 나중에 제거된 미리 읽기 백그라운드 스레드가 InnoDB 버퍼 풀로 읽은 페이지 수 입니다.
• READ_AHEAD_RATE
초당 미리 읽기 속도 (마지막 페이지 배포 또는 활동이후 미리 읽은 페이지 수 / 소요시간).
• READ_AHEAD_EVICTED_RATE
초당 액세스 없이 제거된 미리 읽기 페이지 수(마지막 페이지 배포 또는 활동이후 액세스되지 않은 미리 읽기 페이지/소요시간)입니다.
• LRU_IO_TOTAL
총 LRU I/O.
• LRU_IO_CURRENT
현재 간격에 대한 LRU I/O.
• UNCOMPRESS_TOTAL
압축 해제된 총 페이지 수
• UNCOMPRESS_CURRENT
현재 간격에서 압축이 풀린 페이지 수입니다.
• 예제
mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_BUFFER_POOL_STATS\G
*************************** 1. row ***************************
POOL_ID: 0
POOL_SIZE: 8192
FREE_BUFFERS: 1
DATABASE_PAGES: 8085
OLD_DATABASE_PAGES: 2964
MODIFIED_DATABASE_PAGES: 0
PENDING_DECOMPRESS: 0
PENDING_READS: 0
PENDING_FLUSH_LRU: 0
PENDING_FLUSH_LIST: 0
PAGES_MADE_YOUNG: 22821
PAGES_NOT_MADE_YOUNG: 3544303
PAGES_MADE_YOUNG_RATE: 357.62602199870594
PAGES_MADE_NOT_YOUNG_RATE: 0
NUMBER_PAGES_READ: 2389
NUMBER_PAGES_CREATED: 12385
NUMBER_PAGES_WRITTEN: 13111
PAGES_READ_RATE: 0
PAGES_CREATE_RATE: 0
PAGES_WRITTEN_RATE: 0
NUMBER_PAGES_GET: 33322210
HIT_RATE: 1000
YOUNG_MAKE_PER_THOUSAND_GETS: 18
NOT_YOUNG_MAKE_PER_THOUSAND_GETS: 0
NUMBER_PAGES_READ_AHEAD: 2024
NUMBER_READ_AHEAD_EVICTED: 0
READ_AHEAD_RATE: 0
READ_AHEAD_EVICTED_RATE: 0
LRU_IO_TOTAL: 0
LRU_IO_CURRENT: 0
UNCOMPRESS_TOTAL: 0
UNCOMPRESS_CURRENT: 0
• 참고사항
+ 이 표는 주로 전문가 수준의 성능 모니터링이나 MySQL 용 성능 관련 확장을 개발할 때 유용합니다.
+ 이 테이블을 쿼리하려면 PROCESS 권한이 있어야합니다.
+ INFORMATION_SCHEMA COLUMNS 테이블 또는 SHOW COLUMNS 문을 사용하여 데이터 유형 및 기본값을 포함하여이 테이블의 컬럼에 대한 추가 정보를 볼 수 있습니다.
■ INNODB_CMP and INNODB_CMP_RESET Tables
INNODB_CMP 및 INNODB_CMP_RESET 테이블은 압축 된 InnoDB 테이블과 관련된 작업에 대한 상태 정보를 제공합니다.
각 컬럼의 정보는 다음과 같습니다.
• PAGE_SIZE
압축된 페이지 크기 (바이트)입니다.
• COMPRESS_OPS
PAGE_SIZE 크기의 B-tree 페이지가 압축된 횟수입니다. 빈 페이지가 생성되거나 압축되지 않은 수정 로그의 공간이 부족할 때마다 페이지가 압축됩니다.
• COMPRESS_OPS_OK
PAGE_SIZE 크기의 B-tree 페이지가 성공적으로 압축된 횟수입니다. 이 수는 COMPRESS_OPS를 초과하지 않아야합니다.
• COMPRESS_TIME
PAGE_SIZE 크기의 B-tree 페이지를 압축하는데 사용된 총 시간(초)입니다.
• UNCOMPRESS_OPS
크기가 PAGE_SIZE 인 B-tree 페이지가 압축 해제된 횟수입니다. B-tree 페이지는 압축이 실패할 때마다 또는 압축되지 않은 페이지가 버퍼풀에 없을때, 처음 액세스 할 때 압축이 해제됩니다.
• UNCOMPRESS_TIME
PAGE_SIZE 크기의 B-tree 페이지를 압축 해제하는 데 사용된 총 시간 (초)입니다.
• 예제
mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_CMP\G
*************************** 1. row ***************************
page_size: 1024
compress_ops: 0
compress_ops_ok: 0
compress_time: 0
uncompress_ops: 0
uncompress_time: 0
*************************** 2. row ***************************
page_size: 2048
compress_ops: 0
compress_ops_ok: 0
compress_time: 0
uncompress_ops: 0
uncompress_time: 0
*************************** 3. row ***************************
page_size: 4096
compress_ops: 0
compress_ops_ok: 0
compress_time: 0
uncompress_ops: 0
uncompress_time: 0
*************************** 4. row ***************************
page_size: 8192
compress_ops: 86955
compress_ops_ok: 81182
compress_time: 27
uncompress_ops: 26828
uncompress_time: 5
*************************** 5. row ***************************
page_size: 16384
compress_ops: 0
compress_ops_ok: 0
compress_time: 0
uncompress_ops: 0
uncompress_time: 0
• 참고사항.
+ 이 테이블을 사용하여 데이터베이스에서 InnoDB 테이블 압축의 효과를 측정합니다.
+ 이 테이블을 쿼리하려면 PROCESS 권한이 있어야 합니다.
+ INFORMATION_SCHEMA COLUMNS 테이블 또는 SHOW COLUMNS명령문을 사용하여 데이터 유형 및 기본값을 포함하여이 테이블의 컬럼에 대한 추가 정보를 봅니다.
■ INNODB_CMPMEM and INNODB_CMPMEM_RESET Tables
INNODB_CMPMEM 및 INNODB_CMPMEM_RESET 테이블은 InnoDB 버퍼 풀 내의 압축 된 페이지에 대한 상태 정보를 제공합니다.
각 컬럼의 정보는 다음과 같습니다.
• PAGE_SIZE
블록 크기 (바이트)입니다. 이 테이블의 각 레코드는 이 크기의 블록을 설명합니다.
• BUFFER_POOL_INSTANCE
버퍼 풀 인스턴스의 고유 ID입니다.
• PAGES_USED
현재 사용중인 PAGE_SIZE 크기의 블록 수입니다.
• PAGES_FREE
현재 할당 가능한 크기가 PAGE_SIZE인 블록 수입니다. 이 컬럼은 메모리 풀의 외부 단편화를 보여줍니다. 이상적으로 이 숫자는 최대 1이어야 합니다.
• RELOCATION_OPS
크기가 PAGE_SIZE인 블록이 재배치된 횟수입니다. 버디 시스템(buddy system)은 더 큰 해제 블록을 형성하려고 할 때 해제 된 블록의 할당 된 "buddy neighbor"을 재배치 할 수 있습니다. INNODB_CMPMEM_RESET 테이블에서 읽으면이 계수가 재설정됩니다.
• RELOCATION_TIME
크기가 PAGE_SIZE인 블록을 재배치하는데 사용된 총 시간 (마이크로 초)입니다. INNODB_CMPMEM_RESET 테이블에서 읽으면이 계수가 재설정됩니다.
• 예제
mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_CMPMEM\G
*************************** 1. row ***************************
page_size: 1024
buffer_pool_instance: 0
pages_used: 0
pages_free: 0
relocation_ops: 0
relocation_time: 0
*************************** 2. row ***************************
page_size: 2048
buffer_pool_instance: 0
pages_used: 0
pages_free: 0
relocation_ops: 0
relocation_time: 0
*************************** 3. row ***************************
page_size: 4096
buffer_pool_instance: 0
pages_used: 0
pages_free: 0
relocation_ops: 0
relocation_time: 0
*************************** 4. row ***************************
page_size: 8192
buffer_pool_instance: 0
pages_used: 7673
pages_free: 15
relocation_ops: 4638
relocation_time: 0
*************************** 5. row ***************************
page_size: 16384
buffer_pool_instance: 0
pages_used: 0
pages_free: 0
relocation_ops: 0
relocation_time: 0
• 참고사항.
+ 이 테이블을 사용하여 데이터베이스에서 InnoDB 테이블 압축의 효율성을 측정합니다.
+ 이 테이블을 쿼리하려면 PROCESS 권한이 있어야합니다.
+ INFORMATION_SCHEMA COLUMNS 테이블 또는 SHOW COLUMNS명령문을 사용하여 데이터 유형 및 기본값을 포함하여이 테이블의 컬럼에 대한 추가 정보를 봅니다.
■ INNODB_CMP_PER_INDEX and INNODB_CMP_PER_INDEX_RESET Tables
INNODB_CMP_PER_INDEX 및 INNODB_CMP_PER_INDEX_RESET 테이블은 압축 된 InnoDB 테이블 및 인덱스와 관련된 작업에 대한 상태 정보를 데이터베이스, 테이블 및 인덱스의 각 조합에 대한 별도의 통계와 함께 제공하여 특정 테이블에 대한 압축의 성능과 유용성을 평가하는 데 도움을줍니다.
압축 된 InnoDB 테이블의 경우 테이블 데이터와 모든 보조 인덱스가 모두 압축됩니다. 이 컨텍스트에서 테이블 데이터는 모든 컬럼을 포함하는 다른 인덱스 인 클러스터형 인덱스로 처리됩니다.
각 컬럼의 정보는 다음과 같습니다.
• DATABASE_NAME
해당 테이블을 포함하는 스키마 (데이터베이스)입니다.
• TABLE_NAME
압축 통계를 모니터링 할 테이블입니다.
• INDEX_NAME
압축 통계를 모니터링 할 인덱스입니다.
• COMPRESS_OPS
시도한 압축 작업 수 입니다. 빈 페이지가 작성되거나 압축되지 않은 수정 로그 공간이 부족할 때마다 페이지가 압축됩니다.
• COMPRESS_OPS_OK
성공적인 압축 작업 수 입니다. 압축 실패 횟수를 얻으려면 COMPRESS_OPS 값에서 뺍니다. 압축 실패 백분율을 얻으려면 COMPRESS_OPS 값으로 나눕니다.
• COMPRESS_TIME
이 인덱스에서 데이터를 압축하는데 사용된 총 시간(초)입니다.
• UNCOMPRESS_OPS
수행된 압축 해제 작업 수 입니다. 압축된 InnoDB 페이지는 압축이 실패할 때마다 또는 압축된 페이지가 버퍼풀에서 처음 액세스되고 압축되지 않은 페이지가 존재하지 않을 때마다 압축 해제됩니다.
• UNCOMPRESS_TIME
이 인덱스에서 데이터를 압축 해제하는데 사용된 총 시간 (초)입니다.
• 예제
mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_CMP_PER_INDEX\G
*************************** 1. row ***************************
database_name: employees
table_name: salaries
index_name: PRIMARY
compress_ops: 0
compress_ops_ok: 0
compress_time: 0
uncompress_ops: 23451
uncompress_time: 4
*************************** 2. row ***************************
database_name: employees
table_name: salaries
index_name: emp_no
compress_ops: 0
compress_ops_ok: 0
compress_time: 0
uncompress_ops: 1597
uncompress_time: 0
• 참고사항.
+ 이 테이블을 사용하여 특정 테이블, 인덱스 또는 둘 다에 대한 InnoDB 테이블 압축의 효율성을 측정합니다.
+ 이러한 테이블을 쿼리하려면 PROCESS 권한이 있어야합니다.
+ INFORMATION_SCHEMA COLUMNS 테이블 또는 SHOW COLUMNS 문을 사용하여 데이터 유형 및 기본값을 포함하여 이러한 테이블의 열에 대한 추가 정보를 볼 수 있습니다.
+ 모든 인덱스에 대해 별도의 측정을 수집하면 상당한 성능 오버 헤드가 발생하므로 INNODB_CMP_PER_INDEX 및 INNODB_CMP_PER_INDEX_RESET 통계는 기본적으로 수집되지 않습니다. 모니터링하려는 압축 테이블에서 작업을 수행하기 전에 innodb_cmp_per_index_enabled 시스템 변수를 활성화해야 합니다.
■ INNODB_LOCKS Table
INNODB_LOCKS 테이블은 InnoDB 트랜잭션이 요청했지만 아직 획득하지 않은 각 잠금 및 다른 트랜잭션을 차단하는 트랜잭션이 보유하는 각 잠금에 대한 정보를 제공합니다.
- 참고사항
이 테이블은 MySQL 5.7.14에서 더 이상 사용되지 않으며 MySQL 8.0에서 제거되었습니다.
각 컬럼의 정보는 다음과 같습니다.
• LOCK_ID
InnoDB 내부의 고유 한 잠금 ID 번호. 불투명한 문자열로 취급합니다. LOCK_ID에 현재 TRX_ID가 포함되어 있지만 LOCK_ID의 데이터 형식은 언제든지 변경될 수 있습니다. LOCK_ID 값을 구문 분석하는 애플리케이션을 작성하면 않됩니다.
• LOCK_TRX_ID
잠금을 보유한 트랜잭션의 ID입니다. 트랜잭션에 대한 세부 정보를 얻으려면이 컬럼을 INNODB_TRX 테이블의 TRX_ID 열과 조인합니다.
• LOCK_MODE
잠금 요청 방법. 허용되는 잠금 모드 설명자는 S, X, IS, IX, GAP, AUTO_INC 및 UNKNOWN입니다. 잠금 모드 설명자를 조합하여 특정 잠금 모드를 식별할 수 있습니다.
• LOCK_TYPE
잠금 유형입니다. 허용되는 값은 행 레벨 잠금의 경우 RECORD, 테이블 레벨 잠금의 경우 TABLE입니다.
• LOCK_TABLE
잠겼거나 잠긴 레코드를 포함하는 테이블의 이름입니다.
• LOCK_INDEX
LOCK_TYPE이 RECORD인 경우 인덱스의 이름입니다. 그렇지 않으면 NULL입니다.
• LOCK_SPACE
LOCK_TYPE이 RECORD인 경우 잠긴 레코드의 테이블 스페이스 ID입니다. 그렇지 않으면 NULL입니다.
• LOCK_PAGE
LOCK_TYPE이 RECORD인 경우 잠긴 레코드의 페이지 번호입니다. 그렇지 않으면 NULL입니다.
• LOCK_REC
LOCK_TYPE이 RECORD인 경우 페이지 내 잠긴 레코드의 힙 번호입니다. 그렇지 않으면 NULL입니다.
• LOCK_DATA
잠금과 연관된 데이터(있는 경우). LOCK_TYPE이 RECORD이면 값이 표시되고 그렇지 않으면 값이 NULL입니다. 잠긴 레코드의 기본 키 값은 기본 키 인덱스에 배치 된 잠금에 대해 표시됩니다.
잠긴 레코드의 보조 인덱스 값은 고유 한 보조 인덱스에 배치 된 잠금에 대해 표시됩니다. 보조 인덱스가 고유하지 않은 경우 보조 인덱스 값이 추가 된 기본 키 값과 함께 표시됩니다.
기본 키가없는 경우 LOCK_DATA는 InnoDB 클러스터형 인덱스 사용을 관리하는 규칙에 따라 선택한 고유 인덱스의 키 값 또는 고유 한 InnoDB 내부 행 ID번호를 표시합니다.
LOCK_DATA는 최고 의사 레코드(supremum pseudo-record)에서 수행된 잠금에 대해 "최고 의사 레코드(supremum pseudo-record)"를 보고합니다.
잠긴 레코드가 포함된 페이지가 잠금이 유지되는 동안 디스크에 기록되어 버퍼풀에 없으면 InnoDB는 디스크에서 페이지를 가져오지 않습니다. 대신 LOCK_DATA는 NULL을 보고합니다.
• 참고사항 1
mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS\G
*************************** 1. row ***************************
lock_id: 3723:72:3:2
lock_trx_id: 3723
lock_mode: X
lock_type: RECORD
lock_table: `mysql`.`t`
lock_index: PRIMARY
lock_space: 72
lock_page: 3
lock_rec: 2
lock_data: 1, 9
*************************** 2. row ***************************
lock_id: 3722:72:3:2
lock_trx_id: 3722
lock_mode: S
lock_type: RECORD
lock_table: `mysql`.`t`
lock_index: PRIMARY
lock_space: 72
lock_page: 3
lock_rec: 2
lock_data: 1, 9
• 참고사항 2
+ 이 표를 사용하면 동시로드가 많은 시간에 발생하는 성능 문제를 진단하는데 도움이 됩니다.
+ 이 테이블을 쿼리하려면 PROCESS 권한이 있어야합니다.
+ INFORMATION_SCHEMA COLUMNS 테이블 또는 SHOW COLUMNS 문을 사용하여 데이터 유형 및 기본값을 포함하여이 테이블의 열에 대한 추가 정보를 봅니다.
■ INNODB_LOCK_WAITS Table
INNODB_LOCK_WAITS 테이블에는 차단 된 각 InnoDB 트랜잭션에 대해 하나 이상의 행이 포함되어 요청한 잠금과 해당 요청을 차단하는 잠금을 나타냅니다.
- 참고사항
이 테이블은 MySQL 5.7.14에서 더 이상 사용되지 않으며 MySQL 8.0에서 제거되었습니다.
각 컬럼의 정보는 다음과 같습니다.
• REQUESTING_TRX_ID
요청(차단된) 트랜잭션의 ID입니다.
• REQUESTED_LOCK_ID
트랜잭션이 대기중인 잠금의 ID입니다. 잠금에 대한 세부 사항을 얻으려면이 열을 INNODB_LOCKS 테이블의 LOCK_ID컬럼과 결합합니다.
• BLOCKING_TRX_ID
차단 트랜잭션의 ID입니다.
• BLOCKING_LOCK_ID
다른 트랜잭션의 진행을 차단하는 트랜잭션이 보유한 잠금의 ID입니다. 잠금에 대한 세부 사항을 얻으려면이 열을 INNODB_LOCKS 테이블의 LOCK_ID 컬럼과 결합합니다.
예제
mysql> SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS\G
*************************** 1. row ***************************
requesting_trx_id: 3396
requested_lock_id: 3396:91:3:2
blocking_trx_id: 3395
blocking_lock_id: 3395:91:3:2
참고사항.
+ 이 테이블을 사용하면 동시로드가 많은 시간에 발생하는 성능 문제를 진단하는 데 도움이됩니다.
+ 이 테이블을 쿼리하려면 PROCESS 권한이 있어야 합니다.
+ INFORMATION_SCHEMA COLUMNS 테이블 또는 SHOW COLUMNS 문을 사용하여 데이터 유형 및 기본값을 포함하여이 테이블의 열에 대한 추가 정보를 봅니다.
'Databases > MySQL' 카테고리의 다른 글
[MySQL] Information Schema - InnoDB 시스템 테이블 (0) | 2020.12.25 |
---|---|
[MySQL] Information Schema - InnoDB : 2번째 (0) | 2020.12.22 |
[MySQL] Information Schema - System : 2번째 (0) | 2020.12.20 |
[MySQL] Information Schema - System : 1번째 (0) | 2020.12.20 |
[MySQL] FEDERATED Storage Engine - 실무 (0) | 2020.12.17 |