Tag Archives: db

[CentOS] MySQL to MariaDB Migration

기존에 MySQL을 5년이상 운영해오던 개인서버의 DB를 MariaDB로 변경하기로 하였습니다. 정말 신기할 정도로 다양한 MySQL기반의 웹서비스들을 구동중이던 서버에서 아무런 사이드이펙트 없이 마이그레이션이 가능했습니다. yum 기반에서 운영중인 CentOS를 기준으로 글을 작성하였습니다.

스크린샷 2014-01-06 오후 9.49.10

[링크]에 방문하여 자신의 배포본에 적당한 yum 설정을 찾은 뒤 /etc/yum.repos.d/ 안에 MariaDB.repo 파일을 생성하여 내용을 붙여넣기 합니다.

# MariaDB 5.5 CentOS repository list - created 2014-01-06 12:49 UTC
# http://mariadb.org/mariadb/repositories/
[mariadb]
name = MariaDB
baseurl = http://yum.mariadb.org/5.5/centos5-x86
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1

이제 기존에 설치된 mysql을 삭제합니다. APM 환경일 경우 의존성이 있는 mysql-devel, php-mysql도 함께 삭제 됩니다.

$ yum remove mysql mysql-manual

삭제시에 기존의 설정파일인 /etc/my.cnf파일이 /etc/my.cnf.rpmsave로 바뀌어 저장되므로 /etc/my.cnf로 되돌려 줍니다. 이후에 필요한 MariaDB 패키지들을 설치해줍니다.

$ yum install MariaDB-client MariaDB-common MariaDB-compat MariaDB-devel MariaDB-server MariaDB-shared php-mysql

위의 명령을 통해 모든 필요한 MariaDB 패키지들의 설치가 완료됩니다. 기존의 MySQL에서 사용했던 설정파일을 그대로 사용해도 MariaDB에서 문제 없이 동작합니다. 하지만 한가지 생각해 볼 부분이 있는데 MariaDB는 내부 스토리지 엔진으로 MyISAM대신에 Aria를 사용합니다.

그러므로 기존의 설정의 key_buffer_size(key_buffer)와 동일한 값으로 aria-pagecache-buffer-size의 값을 설정해줄 필요가 있습니다. 만약 기존에 MyISAM 테이블을 사용하지 않고 있었다면 key_buffer_size64K정도의 매우 낮은 값으로 설정해 두길 권장합니다.

이제 MariaDB를 구동해봅시다. 이상하리만치 MySQL의 그것과 동일합니다.

$ /etc/init.d/mysql start

MariaDB 콘솔에 접속해 봅시다.  그 명령어조차 mysql입니다.

$ mysql
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 3662205
Server version: 5.5.34-MariaDB MariaDB Server

Copyright (c) 2000, 2013, Oracle, Monty Program Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]>

일반적으로 아무런 문제없이 마이그레이션 작업이 끝납니다만 작은 오류가 발생할수도 있는데 이경우 mysql_upgrade를 실행해 주면 테이블 포맷등의 변동 사항을 업그레이드해줍니다.

참고 자료

정말 좋은 무료 모델링 툴 DB Designer

오늘 소개해드릴 프로그램은 정말 괜찮은 GPL라이센스를 가진 모델링 툴을 하나 소개할까 합니다.

바로 DB Designer라는 프로그램인데요. fabFORCE(http://www.fabforce.net/)라는 회사에서 만든 프로그램입니다.

MySQL기반 모델링의 경우 쓸만한 툴이 없는것이 현실이었습니다. ER-Win이라던가 엔코아컨설팅에서 만든 DA#의 경우도 모두 MySQL은 배제되어있습니다.

요즘은 MySQL도 많이 사용하는것으로 알고 있는데요. 아마도 엔터프라이즈급 고객이 아니면 신경쓰지 않겠다라는 생각들을 가지고 있다거나 혹은 아직도 MySQL은 애들 장난할때 쓰는 DB다라고 생각하고 있는것일지도요.

너무 열악한 써드파티의 지원을 받고 있는 MySQL은 슬펐는지 WorkBench라는 프로그램을 내놓았습니다. 현재 알파버젼이고요 크게 좋은것 없어 보이는 프로그램입니다.

그러던중 이렇게 좋은 프로그램을 알게 되었습니다. 인터페이스도 심플하고요, 디자인도 깔끔합니다.

무엇보다 한글 지원이 문제 없이 됩니다.

사용자 삽입 이미지
완벽하진 않지만 DB에 직접 접속하여 테이블 정보를 가져와 ERD를 그리는 리버스엔지니어링까지 지원합니다.

상용라이센스가 아니기때문에 업체측에서 사용해도 전혀 문제될것이 없겠죠.

설치 프로그램과 한글패치 올립니다. 한글패치의 출처는 http://www.yashalog.net/61 입니다.

1277862750.xxx1379791538.zip
하지만 사용시에 문제점을 하나 발견하였습니다. MySQL 4.1이상은 접속이 안되는 문제가 발생하더군요.

4.1이후로 바뀐 패스워드 체계때문인데 ODBC드라이버를 사용하는 방향으로 해도 되지만 근본적인 문제점을 해결하는 방법을 적어보겠습니다.

1. /etc/my.cnf 파일에 Old Password를 사용하겠다는 옵션을 추가합시다. 추가후에 MySQL 재시작을 합니다.
[code][mysqld]
…중략…
old_passwords = 1[/code]

2. mysql에 root로 접속하여 사용하고자 하는 계정의 패스워드를 Old Password체계로 변경합시다.
[code]mysql> UPDATE mysql.user SET Password = OLD_PASSWORD(‘password’) WHERE User = ‘eye’;
mysql> FLUSH PRIVILEGES;[/code]

3. 만약에 localhost에서만 접근가능하도록 설정되어있는 계정이라면 외부의 접근을 허가해 봅시다.
[code]mysql> UPDATE mysql.user SET Host = ‘%’ WHERE User = ‘eye’;
mysql> FLUSH PRIVILEGES;[/code]

%는 외부의 모든 접근을 허가한다는 옵션입니다. 특정 호스트만을 허가하고 싶다면 아이피를 적어주시면 됩니다.