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 같은 프로그램으로 내용을 보면 한글이 잘 뜹니다.

다음은 서버 환경입니다.

Quote:
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 맞췄습니다.

Quote:
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 선에서 해결 가능한 방법 없을까요?

lacovnk의 이미지

my.cnf

[mysqld]
init_connect = 'set names euckr'

이러면 일일이 수정할 필요 없습니다. DB가 euckr로 해놓아도, 연결에서 얻어오는 값들이 utf8로 날아오는 것 같습니다.

기억에 좀더 깔끔한 설정이 있긴 한데... :(

망치의 이미지

이 방법도 이미 사용해봤답니다. ㅡ.,ㅡ;
ibin 님 얘기 들으니 더욱 암울해지는군요..

---------------------------------------
http://www.waitfor.com/
http://www.textmud.com/

ibin의 이미지

mysql 4.15 이전버젼에서는 윗분 말씀처럼 my.cnf 를 설정하는게 가장 간단한 방법입니다.

저도 이 방법을 많은 서버에 적용했었는데 유독 CentOS 4.3 의 기본으로 설치된 mysql에서만 위 옵션이 먹히지 않더군요.

그래서 결국 PHP소스를 수정해서 사용중인데요.

망치님은 어떻게 되었는지 결과를 올려주셨으면 합니다.

망치의 이미지

mysql 을 밀어버리고 4.1.20 RPM 직접 받아다 설치해봤는데도 같은 증상입니다. (mysql.com 에 RHEL 4 용 RPM ..)
혹시 MySQL 말고 다른데서 문제가 있는게 아닌가 싶기도 하고..

아니면 CentOS 4 에선 별도의 설정이 필요한건지..
아아.. 답답합니다 -_;

또 컴파일해서 쓰긴 귀찮은데..

---------------------------------------
http://www.waitfor.com/
http://www.textmud.com/

망치의 이미지

VMWare 이용하다가 한가지 의문이 생겼는데.. SnapShot 이 현재 상태를 보관했다가 나중에 그대로 복원해주는 기능 아닌가요?
4.1.20 설치전에 take snapshot 해뒀었는데.. 지금 그 snapshot 으로 restore 했는데도 여전히 4.1.20 이 설치된 상태네요 -_-;;

당황스러워라;;

질문을 새 글로 올려야되려나?;;

---------------------------------------
http://www.waitfor.com/
http://www.textmud.com/

ibin의 이미지

역시 안되시나보네요.

제 경우에는 해당 서버에서 수정해야될 소스가 하나뿐이라 그냥 소스 수정으로 해결을 했습니다만...

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/

salpoosi의 이미지

제가 사용하고 있는 설정입니다 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

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

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.