2. DBMS이야기 139

MySQL InnoDB Next-Key Locking

InnoDB Next-Key Locking (phantom row 방지 기법) MySQL(InnoDB)의 트랜잭션 모델은 Repeatable Read Isolation 레벨을 기본으로 하고 있다. Repeatable Read는 Read Uncommitted, Read Committed 레벨과는 달리 Phatom Row가 발생하지 않는다는 장점이 있다. Phantom Row의 "Phatom"은 유령이라는 뜻으로, 아래와 같이 트랜잭션 수행중 다른 트랜잭션이 생성한 Row가 갑자기 나타나는 것을 말한다. 아래 예제에서는 Phantom Row를 만들기 위해 세션의 Isolation 레벨을 Read Committed로 변경하고, 2번째 SELECT 쿼리를 수행하기 전에 다른 트랜잭션에서 새로운 값을 INSERT..

[PostgreSQL]Hot-Standby Replication

Hot-Standby Replication 1. Architecture - 초기 Standby 서버 구성시 Primary DB의 백업본을 이용한 Restore 후, 변경분의 xLog를 이용하여 Replication 2. Flow (Hot standby) 3. 실습환경 구성 MASTER postgresql.conf 설정 wal_level = hot_standby archive_mode = on archive_command = "\\cp -f %p /archive/temp/%f && \\mv /archive/temp/%f /archive/pgdata && \\scp /archive/pgdata/%f standby_ip:/archive/pgdata/%f" -> Archive Log 파일 Slave DB로 전송..

MySQL Fulltext Indexing and searching

MySQL은 3.23.23 버전부터 Fulltext 인덱스를 지원한다. varchar 와 text 컬럼에 fulltext 인덱스를 지원하고 MySQL에서 Fulltext search 를 하기 위해서는 특별한 SQL 구문을 사용해야 한다. FULLTEXT 인덱스를 어떤 컬럼에 정의하려 할 때, 다른 인덱스 처럼 fulltext 인덱스도 여러 컬럼을 포함할 수 있다. 다음과 같이 Fulltext 인덱스를 정의한다. ALTER TABLE TB_Test ADD FULLTEXT(col1, col2); 이렇게 Fulltext 인덱스를 생성하면, MATCH, AGAINST 구문을 이용해 검색할 수 있다. SELECT (col1, col2 FROM TB_TestWHERE MATCH (col1, col2) AGAINST..

MySQL ERROR 1069

MySQL error 1069 는 다음과 같이 나타난다. ERROR 1069 (42000): Too many keys specified; max 64 keys allowed 일반적으로는 타당한 사용은 아니고, MySQL 테이블에 64개의 인덱스보다 더 많이 요구했을 때 발생한다. 그러나 이 에러메시지는 반드시 이런 경우에만 나타나는 것이 아니라, 명시적으로 인덱스를 지정하지 않았을 경우에도 발생할 수 있다. mysql> alter table TB_1 add index id_1 (name); Query OK, 0 rows affected (0.03 sec) Records: 0 Duplicates: 0 Warnings: 0mysql> alter table TB_1 add index id_1 (name);ER..

MySQL Index 유형별 적용

MySQL에서 인덱싱 컬럼은 일반적으로 속도를 향상시키나 적절한 유형의 인덱스는 성능에 더 큰 효율을 가져온다. SQL 구문에 최적화하기 위해 인덱스를 적용할 경우에는 일반적으로 4가지 인덱스 유형이 있다. 1. Column Index2. Concatenated Index3. Covering Index4. Partial Index 1. Column Index 단순하게 말해서, 단일 컬럼의 성능을 높이기 위한 인덱스이다. SELECT user_name, adress FROM TB_Test WHERE id = 1;id 컬럼에 인덱스를 추가한다.ALTER TABLE TB_Test ADD INDEX (id); 2. Concatenated Index 종종 테이블들에 많은 단일 컬럼 인덱스가 있는 것을 볼 수 있다..

Busy한 MySQL 서버에서 Deadlock Troubleshooting

관리자가 관리해야 하는 서버에는 많은 deadlock이 있습니다. 특히 비즈니스 기능적으로 중요한 몇 개의 테이블에서 자주 발생합니다. 데드락이 생기는 쿼리는 복잡하고, 많은 경우에 큰 데이터를 읽습니다. 대부분 오래 진행되는 트랜잭션에서 데드락이 발생할 수 있고, 짧은 쿼리에서 하나의 row에서 발생하기도 합니다. 많은 트랜잭션 시스템에서 데드락은 일상 생활입니다. 어플리케이션은 반드시 데드락을 다룰 수 있어야 합니다. 그 밖에도, 유저 트리거와 유저가 시도하는 것들을 포기해야 하더라도 작업이 종료될 필요가 있습니다. 종종 실패하기도 하고, 성공 할 때까지 재 시도를 하기도 합니다. 이 교착 상태 프로세스에 소요되는 시간에 따라, 그 낭비 작업의 엄청난 금액을 나타낼 수 있습니다. 여러번 재시작을 하려..