문제해결

MySQL 업데이트 이후 Data Dictionary initialization failed. 문제

MySQL Data Dictionary initialization failed. 문제 해결


MySQL을 업데이트한 이후 서비스를 시작하려하면 다음과 같이 문제가 발생하며 실행되지 않는 경우가 있습니다.

 

문제의 원인 파악을 위해서 MySQL의 로그 파일(/var/log/mysql.log)을 열어보았습니다.

2019-04-30T12:18:15.152802Z 0 [System] [MY-010116] [Server] /usr/sbin/mysqld (mysqld 8.0.16) starting as process 3129
2019-04-30T12:18:15.154526Z 0 [Warning] [MY-013242] [Server] --character-set-server: 'utf8' is currently an alias for the character set UTF8MB3, but will be an alias for UTF8MB4 in a future release. Please consider using UTF8MB4 in order to be unambiguous.
2019-04-30T12:18:15.154551Z 0 [Warning] [MY-013244] [Server] --collation-server: 'utf8_unicode_ci' is a collation of the deprecated character set UTF8MB3. Please consider using UTF8MB4 with an appropriate collation instead.
2019-04-30T12:18:15.358253Z 1 [System] [MY-011090] [Server] Data dictionary upgrading from version '80014' to '80016'.
2019-04-30T12:18:15.758363Z 1 [ERROR] [MY-013178] [Server] Execution of server-side SQL statement 'UPDATE mysql.index_partitions ip JOIN mysql.tablespaces ts ON ts.id = ip.tablespace_id JOIN mysql.table_partitions p ON p.id = ip.partition_id JOIN mysql.tables t ON t.id = p.table_id JOIN mysql.indexes i ON i.table_id = t.id SET ts.options=CONCAT(IFNULL(ts.options,''), IF(LOWER(GET_DD_PROPERTY_KEY_VALUE(t.options,'encrypt_type'))='y' , 'encryption=Y;','encryption=N;')) WHERE t.tablespace_id IS NULL AND i.tablespace_id IS NULL AND p.tablespace_id IS NULL AND ts.engine='InnoDB' AND GET_DD_PROPERTY_KEY_VALUE(t.options,'encrypt_type') IS NOT NULL AND GET_DD_PROPERTY_KEY_VALUE(ts.options,'encryption') IS NULL ' failed with error code = 1267, error message = 'Illegal mix of collations (utf8_general_ci,COERCIBLE) and (utf8_unicode_ci,COERCIBLE) for operation '=''.
2019-04-30T12:18:15.771602Z 0 [ERROR] [MY-010020] [Server] Data Dictionary initialization failed.
2019-04-30T12:18:15.771832Z 0 [ERROR] [MY-010119] [Server] Aborting
2019-04-30T12:18:17.390228Z 0 [System] [MY-010910] [Server] /usr/sbin/mysqld: Shutdown complete (mysqld 8.0.16)  MySQL Community Server - GPL.

내용이 조금 많지만 여기에서 대략 문자셋(Character-Set)의 설정란에 의해 문제가 발생한 것이라고 추측해볼 수 있었습니다.

에러 메세지를 해석하면 MySQL 설정 파일 내에서 utf8mb3라는 명칭을 줄여서 표현한(Alias) utf8 이라는 문자셋은 더 이상 사용되지 않는다는 내용입니다.

 

 

해결 방법


해결 방법은 간단합니다. 먼저 MySQL 설정 파일을 편집해야 합니다. 대부분의 경우 다음 경로를 사용합니다 : /etc/my.cnf

[root@localhost ~]# vim /etc/my.cnf

 

파일이 열렸다면 문자셋 설정 부분에 utf8로 입력된 부분을 모두 찾습니다. 예를 들면 다음과 같습니다.

[mysqld]
init_connect="SET collation_connection=utf8_general_ci"
init_connect="SET NAMES utf8"

collation-server = utf8_unicode_ci
character-set-server = utf8

[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

도중에 다른 내용이 끼어있을 수 있으니 character-set 이나 utf8이 입력된 부분을 잘 살펴보셔야 합니다.

 

utf8utf8mb3의 줄임말이자 별명(Alias)입니다. 여기서 mb3은 문자셋이 3바이트의 문자 저장 공간을 사용한다는 것입니다. 마찬가지로 mb4를 사용하면 4바이트를 사용하겠다는 의미입니다.

설정 파일에 선언된 utf8MySQL 이전 버전에서 utf8mb3을 가리켰지만 이제는 utf8mb4를 가리키게 되면서 혼란을 방지하고자 서비스 재시작을 막은 것입니다. 따라서 애매모호한 별명을 utf8mb3 또는 utf8mb4로 명확하게 지정해야 합니다. 여기서는 utf8mb4로 변경해보겠습니다. (이렇게한다고 데이터베이스 내 데이터가 변동되는 것은 아닙니다.)

 

위 설정 파일에서 utf8을 아래와 같이 바꾸었습니다.

[mysqld]
init_connect="SET collation_connection=utf8mb4_general_ci"
init_connect="SET NAMES utf8mb4"

collation-server = utf8mb4_unicode_ci
character-set-server = utf8mb4

[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4

변경이 완료되었다면 파일을 저장하고 빠져나옵니다.

 

이제 서비스를 다시 시작해보도록 하겠습니다. 다음 명령어 중 하나를 입력하여 MySQL Server의 서비스를 재시작해줍니다. (운영체제 및 패키지 버전에 따라 서비스명이 mysqld가 아닐 수 있음)

[root@localhost ~]# service mysqld restart
또는
[root@localhost ~]# systemctl restart mysqld

 

 

참조링크


JooTC

안녕하세요. 테크놀로지에 관심이 많은 블로거입니다.

Recent Posts

[iOS] Xcode ‘You do not have required contracts to perform an operation’ 해결

Xcode에서 iOS 애플리케이션을 빌드(Archive)하고 App Store Connect에 앱을 업로드하는 도중, 아래와 같은 에러가 발생하면서 더…

2개월 ago

[안드로이드] INSTALL_FAILED_INSUFFICIENT_STORAGE 해결

INSTALL_FAILED_INSUFFICIENT_STORAGE 문제 안드로이드 스튜디오에서 에뮬레이터를 실행하고 개발중인 애플리케이션을 실행하려 하면 로그 창에 아래와 같이 표시되면서…

8개월 ago

Zalgo 텍스트와 이를 방지하는 방법

인터넷 커뮤니티 사이트에서 게시글이나 댓글에 간혹 장난을 목적으로 작성된 특이한 글자를 볼 수 있습니다. 위…

10개월 ago

리눅스 kill, killall 명령어 – 특정 프로세스 종료하기

리눅스 명령어 - kill, killall 리눅스 kill 명령어는 특정 프로세스를 종료해주는 명령어입니다. 백그라운드에서 실행되고 있는…

10개월 ago

JavaScript typeof null이 ‘object’인 이유

JavaScript는 역사가 긴 스크립트 프로그래밍 언어입니다. 세월이 흐르면서 많은 자바스크립트 표준이 만들어졌고, 현재는 많은 문법적…

10개월 ago

Mocha Error: Resolution method is overspecified. 해결 방법

NodeJS 테스트 프레임워크인 Mocha는 비동기 테스트를 지원합니다. 간혹 특정 테스트 스크립트를 작성하고 실행하면 아래와 같이…

10개월 ago