원본출처 : http://mong2.speedinline.com/ing_board/freeview.html?n_mark=ing_board&uid=42&list_no=41&page=0&block=0&key=&keyfield=
갑작스런 이유로 S서버의 db에 특정 table이 말썽을 일으켰다...--
mysql> select * from TEST;
ERROR 1016: Can\t open file: \TEST.MYD\. (errno: 145)
이런식으로... --
원인이야 다양하겠지만... S서버의 경우 mysql 데이타가 저장되는 곳의 디렉토리가 100%로
꽉차 있어서... 위와같은 문제가 발생하였다...-,.^
일단 디렉토리를 널널하게 정리한후... 뻑(?)난 테이블 복구를 시도했다.
# myisamchk -r TEST.MYI
이런식으로 테이블을 복구하고 나니... 문제없이 작동되었다...^^
더 자세한 정보는 men page를 참조하도록 하자...: )
# myisamchk
Description, check and repair of ISAM tables.
Used without options all tables on the command will be checked for errors
Usage: myisamchk [OPTIONS] tables[.MYI]
:
:
참고로 여기저기 찾다보니... 유용한 정보가 있어... 긁어왔스빈다.
출처: database.sarang.net
-------------------------------------------------------------------------------------
linux.sarang.net의 김주현씨가 쓴 글을 퍼왔습니다.
갑작스런 정전이나 하드웨어의 오류 기타 어떠한 이유로 table file이
손상될 수 있습니다.
이 경우 Myisamchk 나 check table명령어를 사용하여 수동으로 복구하여야
하는데 자동으로 복구하는 방법도 있어서 소개해드립니다.
이 기능은 MySQL기동시 table 이 crash marking이 되어 있는지 혹은 적절히 close 되지 않
았는지 체크하는 기능으로 mysqld 의 파라메터로 지정해주도록 되어 있습니다.
--myisam-recover = {default | backup | force | quick }
DEFAULT : 이 옵션은 아무 옵션도 주지 않은 것과 동일한 의미로 자동 복구를 사용하지 않
는다는 의미입니다.
BACKUP : 추천하는 옵션으로 복구중 변경되는 테이블은 BAK확장자를 붙여서
백업을 해놓고 복구에 들어간다는 옵션입니다.
이를테면 table_name.MYD 의 table_name-datetime.BAK 백업 파일이
만들어지고 자동 복구에 들어갑니다.
FORCE : 복구시 테이타 손실이 일어나거나 말거나 강제로 복구하는 옵션입니다.
QUICK: 만약 테이블에 어떠한 삭제된 블락도 없다면 table에 row를 점검하지
않습니다. 속도는 빠르지만 완벽한 복구는 보장할 수 없습니다.
/etc/rc.d/init.d/mysql 같은 startup script에 아래 부분을 수정해주시고 MySQL을 재시작
하시면 됩니다.
.
.
.
case \$mode\ in
\start\)
# Start daemon
if test -x $bindir/safe_mysqld
then
$bindir/safe_mysqld --myisam-recover=backup (수정할 부분)
~~~~~~~~~~~~~~~~~~~~~~~
.
.
.
service mysql stop (MySQL중단)
service mysql start (MySQL재시작)
|