mysql 4.1 에서 euckr 출력에 문제가 있습니다. 소스 수정없이 my.cnf 선에서 해결 가능한 방법을 찾습니다..
OS는 CentOS 4.3 이고, Apache, PHP, MySQL 은 모두 Yum 을 이용해 설치했습니다.
기존에 가지고 있는 사이트 (RH9기반) 데이터를 가져다가 VMWare 에 설치한 CentOS 4.3 에서 사이트를 그대로 복사해보는데서 문제가 생겼습니다.
기존 RH9 의 MySQL 은 4.1.14 버젼이고 charset 을 직접 euckr 로 주고 소스 컴파일해서 구동중인데 문제가 생긴게 그 차이때문인지도 모르겠습니다.
사이트가 뜨긴 하는데 HTML 파일에 그대로 적혀있는 한글은 잘 뜨지만 MySQL 쿼리를 통해 가져오는 문자열들은 모두 물음표(????) 로 표시가 돼버립니다.
그런데 PHPMyAdmin 같은 프로그램으로 내용을 보면 한글이 잘 뜹니다.
다음은 서버 환경입니다.
Server version: 4.1.12
Protocol version: 10
Connection: Localhost via UNIX socket
Server characterset: euckr
Db characterset: euckr
Client characterset: euckr
Conn. characterset: euckr
UNIX socket: /var/lib/mysql/mysql.sock
Uptime: 15 sec
my.cnf 에 각 항목마다 다음과 같이 명시를 해줘서 서버 환경을 euckr 맞췄습니다.
character-sets-dir=/usr/share/mysql/charsets
default-character-set=euckr
이것저것 삽질해가면서 구글링을 하다보니 해결 방법을 찾긴 찾았습니다.
아래 링크에 명시된것처럼 DB 접속후에 mysql_query("set session character_set_connection=euckr;"); 등으로 쿼리를 날려주니 한글이 제대로 보이더군요.
http://ktc.kunsan.ac.kr/~unfusion/word/?p=113
임시방편으로나마 저런식으로 해결이 가능하긴 한데 이렇게 되면 원래 사이트에 있는 파일 및 DB 자료를 그대로 가져와서 사용하질 못하는 깔끔치 못한 문제가 생깁니다.. 소스 수정없이 my.cnf 선에서 해결 가능한 방법 없을까요?
my.cnf [mysqld] init_connect
my.cnf
[mysqld]
init_connect = 'set names euckr'
이러면 일일이 수정할 필요 없습니다. DB가 euckr로 해놓아도, 연결에서 얻어오는 값들이 utf8로 날아오는 것 같습니다.
기억에 좀더 깔끔한 설정이 있긴 한데... :(
이 방법도 이미
이 방법도 이미 사용해봤답니다. ㅡ.,ㅡ;
ibin 님 얘기 들으니 더욱 암울해지는군요..
---------------------------------------
http://www.waitfor.com/
http://www.textmud.com/
mysql 4.15
mysql 4.15 이전버젼에서는 윗분 말씀처럼 my.cnf 를 설정하는게 가장 간단한 방법입니다.
저도 이 방법을 많은 서버에 적용했었는데 유독 CentOS 4.3 의 기본으로 설치된 mysql에서만 위 옵션이 먹히지 않더군요.
그래서 결국 PHP소스를 수정해서 사용중인데요.
망치님은 어떻게 되었는지 결과를 올려주셨으면 합니다.
mysql 을 밀어버리고
mysql 을 밀어버리고 4.1.20 RPM 직접 받아다 설치해봤는데도 같은 증상입니다. (mysql.com 에 RHEL 4 용 RPM ..)
혹시 MySQL 말고 다른데서 문제가 있는게 아닌가 싶기도 하고..
아니면 CentOS 4 에선 별도의 설정이 필요한건지..
아아.. 답답합니다 -_;
또 컴파일해서 쓰긴 귀찮은데..
---------------------------------------
http://www.waitfor.com/
http://www.textmud.com/
VMWare 이용하다가
VMWare 이용하다가 한가지 의문이 생겼는데.. SnapShot 이 현재 상태를 보관했다가 나중에 그대로 복원해주는 기능 아닌가요?
4.1.20 설치전에 take snapshot 해뒀었는데.. 지금 그 snapshot 으로 restore 했는데도 여전히 4.1.20 이 설치된 상태네요 -_-;;
당황스러워라;;
질문을 새 글로 올려야되려나?;;
---------------------------------------
http://www.waitfor.com/
http://www.textmud.com/
역시
역시 안되시나보네요.
제 경우에는 해당 서버에서 수정해야될 소스가 하나뿐이라 그냥 소스 수정으로 해결을 했습니다만...
mysql.com 에서 RPM으로 받아 설치한 경우에는 문제가 없었던 듯 합니다만...
4.1.20 버젼이라면 my.cnf 에서 skip-character-set-client-handshake=1 옵션을 주고 테스트해보셨나요?
그리고 VMWare 에 snapshot 이란 기능이 있었다니 멋지네요~
방금 파일을 생성해서 테스트해보니 생성하기 이전 상태로 되돌아가는게 가능하군요.
헛..
헛.. skip-character-set-client-handshake=1 옵션 줬더니 단방에 해결되는군요. -_-;;
감사합니다;;
4.1.20 만세;
---------------------------------------
http://www.waitfor.com/
http://www.textmud.com/
환경이 UTF8이지만..
제가 사용하고 있는 설정입니다 UTF8환경이지만 UTF8이라고 적혀 있는 부분을 바꾸어 주시면 됩니다.
같은 Centos 4.3 환경입니다.
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
# Default to using old password format for compatibility with mysql 3.x
# clients (those using the mysqlclient10 compatibility package).
old_passwords=1
init_connect=SET collation_connection = utf8_general_ci
init_connect=SET NAMES utf8
default-character-set=utf8
character-set-server=utf8
collation-server=utf8_general_ci
[mysql.server]
user=mysql
basedir=/var/lib
default-character-set=utf8
[mysqld_safe]
err-log=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
[mysqldump]
default-character-set=utf8
댓글 달기