RadarURL

웹 프로그래밍
2013.03.19 08:26

XE는 무조건 InnoDB

조회 수 3783 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
Mysql에서 기본으로 사용되는 스토리지 엔진은 보통 MyISAM다. 전통적으로 많이 사용되어 온 형태로, 데이터 변경이 크게 없고 읽기가 많은 경우-즉 혼자 글을 쓰고 공개하는 블로그 등에서 효율적이며, CPU나 메모리의 성능보다는 스토리지의 성능에 더 영향을 받는다고 한다. 그리고 InnoDB는 트랜잭션이니 뭐니 여러 기능이 추가/향상되어 나온 엔진으로, CPU와 메모리에 비례해 성능이 향상되며 읽고 쓰기가 많은 경우에 유용하다. 가장 큰 차이는 트랜잭션의 지원 유무지만, xe를 쓰는 우리에게 있어서 가장 중요한 차이점은 DB에서 데이터를 변경할 경우 테이블 단위로 락을 거는 MyISAM과 달리 행 단위(row-Level)로 락을 건다는 것.

 사실 제로보드4 시절엔 DB 상태가 어쩌고에 관심도 없었고, 그런 거 몰라도 빠릿빠릿하게 잘 굴러가던 게 제로보드라 신경 쓸 필요도 없었다. 그렇다 보니 제로보드의 게시물/덧글 db가 어떻게 되어있었는지는 모르겠는데, 최근 xe의 속도를 이야기하며 가장 문제시되는 부분이 게시물/덧글을 xe_comments와 xe_documents 테이블 하나씩에 그대로 전부 때려박는다는 것이다. 그래서 앞서 말한 MyISAM의 table-level lock, 테이블 단위 락이 여기서 문제가 된다. DB에서 테이블의 데이터를 변경하는 경우, 동시에 다른 사용자가 해당 데이터를 변경하거나 해서 오류가 발생하지 않도록 데이터를 잠그게 되는데, xe는 모든 걸 하나의 테이블에 때려박아둔 덕분에 이 큰 테이블 자체가 잠겨버리게 된다. 대다수의 세션이 Lock wait 상태에 빠질 수 있는 것. 실제로 게시물도 유동인구도 몇 안되는 절대넷마져도 간간히 접속이 끔찍하게 늦어지는 상태였고, 실제 슬로우 쿼리 로그도 xe_documents의 겨우 게시판 두 개에 쿼리 날리는 와중에 걸리는 부하였다.

 이를 해결하기 위해 게시물 카운트를 자른다거나 무슨 캐시를 먹인다거나 여러 복잡한 방법도 시도도 많은 모양인데, 웹이고 디비고 뭐고 지식이 전무하다 보니 봐도 쫓아갈 수가 없었고, 가장 간단해보이는 해결책이 DB엔진을 InnoDB로 변경하는 것이었다. InnoDB는 데이터 변경에 대해 테이블 자체를 잠궈버리는 MyISAM과 달리 row-Level, 행 단위로만 데이터를 잠그기 때문에 테이블에 데이터 변경이 일어나고 있어도 동시에 다른 데이터 액세스가 가능하다. 물론 그 덕분에 처리해야 할 양이 상당히 늘어나는 게 부담이긴 하지만, 위젯 출석 로또 글쓰기 등 다양한 쓰기 활동이 동시에 일어나는 상황에서는 훨씬 유용하다고 생각한다. 게다가 그렇게 큰 규모도 아니고.

 사용하던 MySIAM 테이블을 InnoDB로 변경하는 건 간단했다. 혹시를 대비해 일단 디비 전체를 백업해두고, phpmyadmin의 쿼리 메뉴에서
alter table 테이블명 type=InnoDB;
을 날려서 변경했다. 그리고 xe의 디비 설정도 수정해야 한다. /files/config/db.config.php 를 열어서
$db_info->master_db = array('db_type' => 'mysql_innodb','db_port' => '3306','db_hostname' => 'localhost','db_password' => '암호','db_database' => '이름','db_userid' => '이름','db_table_prefix' => 'xe_');
$db_info->slave_db = array(array('db_type' => 'mysql_innodb','db_port' => '3306','db_hostname' => 'localhost','db_password' => '암호','db_database' => '이름','db_userid' => '이름','db_table_prefix' => 'xe_'));
db_type 부분도 mysql_innodb로 수정한다.


 좀 지켜봐야 알겠지만, 지금 당장은 꽤 빠른 듯한 착각이 좀 든다. 아참, 내부 게시판을 포함해 30~40MB 남짓했던 걸로 기억하는 DB 용량이 엔진 변경 후 갑자기 90MB 가까이 뛰어 깜짝 놀랐는데, InnoDB의 특성이라는 것 같다. 약 2배 정도 몸집이 불어난다.

 

 

출처 : http://zettaisya.egloos.com/2988412

TAG •
?

공부 게시판

공부에 도움되는 글을 올려주세요.

  1. [공지] 공부 게시판 입니다.

    Date2003.08.18 By처누 Views928098
    read more
  2. 메모리 부족 현상 (allowed memory size of 134217728 bytes..)

    Date2023.08.01 Category웹 프로그래밍 ByJaeSoo Views2207
    Read More
  3. Guzzle - cURL error 60: SSL certificate problem: unable to get local issuer certificate 문제 해결

    Date2023.07.30 Category웹 프로그래밍 ByJaeSoo Views2188
    Read More
  4. XE 캐시파일 재성생후 404 Oops, Sorry. Page is not found! 나올때

    Date2023.07.29 Category웹 프로그래밍 ByJaeSoo Views2117
    Read More
  5. XE - " Fatal error: Class 'Object' not found in " / class 낫파운드 오류

    Date2023.03.20 Category웹 프로그래밍 ByJaeSoo Views147
    Read More
  6. iOS 앱 개발을 위한 인증서 생성 및 관리

    Date2023.01.18 Category웹 프로그래밍 ByJaeSoo Views218
    Read More
  7. PHP 파서 이해하기 (<?php의 php를 생략하고 간단히 <? 태그 와 ?> 태그를 사용하는 방법)

    Date2016.08.10 Category웹 프로그래밍 ByJaeSoo Views322
    Read More
  8. XE 비회원 글쓰기 항목 지우기

    Date2016.04.28 Category웹 프로그래밍 ByJaeSoo Views499
    Read More
  9. 오른쪽 마우스 금지 소스 / 드래그 금지 소스

    Date2016.01.20 Category웹 프로그래밍 ByJaeSoo Views475
    Read More
  10. Strict standards and C5 support errors

    Date2015.12.02 Category웹 프로그래밍 ByJaeSoo Views524
    Read More
  11. ICT노트 :: 반응형웹을 만드는 기술은?

    Date2015.09.26 Category웹 프로그래밍 ByJaeSoo Views489
    Read More
  12. [번역] 2014년 가장 인기있는 5가지 프론트엔드 프레임워크 비교

    Date2015.09.25 Category웹 프로그래밍 ByJaeSoo Views862
    Read More
  13. 최고의 반응형 CSS 프레임워크 18선 (2013년 7월기준)

    Date2015.09.25 Category웹 프로그래밍 ByJaeSoo Views586
    Read More
  14. 가장 진보된 반응형 웹을 위한 프레임워크 UIkit

    Date2015.09.25 Category웹 프로그래밍 ByJaeSoo Views559
    Read More
  15. 반응형 웹을 위한 프론트-엔드 프레임 워크 (front-end framework for developing responsive web)

    Date2015.09.25 Category웹 프로그래밍 ByJaeSoo Views739
    Read More
  16. 한국형 반응형웹 프레임웍을 찾아서 - 왜 우리는 IE 7,8때문에 고통받아야 하는가?

    Date2015.09.25 Category웹 프로그래밍 ByJaeSoo Views611
    Read More
  17. 한국을 위한 CSS 그리드 디자인 프레임워크

    Date2015.09.25 Category웹 프로그래밍 ByJaeSoo Views531
    Read More
  18. 과연 반응형 웹 디자인만이 해답일까?

    Date2015.09.25 Category웹 프로그래밍 ByJaeSoo Views535
    Read More
  19. 반응형 웹 디자인의 단점

    Date2015.09.25 Category웹 프로그래밍 ByJaeSoo Views567
    Read More
  20. 웹디자인 신기술 트렌드 및 적용 사례

    Date2015.07.28 Category웹 프로그래밍 ByJaeSoo Views510
    Read More
  21. 제이쿼리(jQuery) 튜토리얼(Tutorial) 모음

    Date2015.07.28 Category웹 프로그래밍 ByJaeSoo Views1253
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 15 Next
/ 15


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너