실수로 삭제한 mysql DB 복구방법
delete나 truncate 같은 명령으로 데이터를 지웠을때 복구하는 방법입니다.
mysql의 모든 명령들은 로그를 남기기때문에 가능합니다.
일단 mysql의 DB가 쌓이는 디렉토리로 이동합니다.
대게 /usr/local/mysql/data /usr/local/mysql/var 등으로 설정해 놓으셨을겁니다.
해당 디렉토리로 이동하면 xxx-bin.001 xxx-bin.002 같은 바이너리 파일들이 존재할겁니다.
이게 바로 DB를 첨 생성할때부터 지금까지 쌓여온 로그인데요 이 파일을 활용하시면 삭제된 데이터도 살릴수 있습니다.
바이너리 파일이기때문에 그냥 접근하시면 이상한 문자들이 보이구요
mysqlbinlog 명령을 이용하셔서 사용해야 합니다.
다음은 예제입니다.
일단 DB 디렉토리로 이동한다.
# cd /usr/local/mysql/data
바이너리 파일을 소스파일로 변환한다.
# ../mysqlbinlog leopit-bin.002 > rescue.sql
필요한 구문만 가져온다.
# grep "insert" rescue.sql > rescue1.sql
이렇게 하시면 rescue1.sql은 지금까지의 인서트구문이 다 들어옵니다.
여기서 필요없는 부분은 지우세요
이제 최종적으로 DB에 삽입만 하시면 됩니다.
# mysql -u 계정아이디 -p DB이름 < rescue1.sql<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:27:00 MySQL에서 이동 됨]</div>
mysql의 모든 명령들은 로그를 남기기때문에 가능합니다.
일단 mysql의 DB가 쌓이는 디렉토리로 이동합니다.
대게 /usr/local/mysql/data /usr/local/mysql/var 등으로 설정해 놓으셨을겁니다.
해당 디렉토리로 이동하면 xxx-bin.001 xxx-bin.002 같은 바이너리 파일들이 존재할겁니다.
이게 바로 DB를 첨 생성할때부터 지금까지 쌓여온 로그인데요 이 파일을 활용하시면 삭제된 데이터도 살릴수 있습니다.
바이너리 파일이기때문에 그냥 접근하시면 이상한 문자들이 보이구요
mysqlbinlog 명령을 이용하셔서 사용해야 합니다.
다음은 예제입니다.
일단 DB 디렉토리로 이동한다.
# cd /usr/local/mysql/data
바이너리 파일을 소스파일로 변환한다.
# ../mysqlbinlog leopit-bin.002 > rescue.sql
필요한 구문만 가져온다.
# grep "insert" rescue.sql > rescue1.sql
이렇게 하시면 rescue1.sql은 지금까지의 인서트구문이 다 들어옵니다.
여기서 필요없는 부분은 지우세요
이제 최종적으로 DB에 삽입만 하시면 됩니다.
# mysql -u 계정아이디 -p DB이름 < rescue1.sql<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:27:00 MySQL에서 이동 됨]</div>
댓글 4개
20년 전
헐 날아가서 다시설치했는데
아쉽네요.
어쨌든 좋으네요.
아쉽네요.
어쨌든 좋으네요.
19년 전
어떤 버전부터 가능한가요?
17년 전
버젼보다는 컴파일시에 또는 설정시 로그를 남기도록 해야 합니다.
16년 전
ㄳㄳ
게시판 목록
개발자팁
개발과 관련된 유용한 정보를 공유하세요.
질문은 QA에서 해주시기 바랍니다.
질문은 QA에서 해주시기 바랍니다.
| 번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|---|
| 506 | PHP | 19년 전 | 3896 | ||
| 505 | JavaScript |
|
19년 전 | 4570 | |
| 504 | 기타 |
|
19년 전 | 8189 | |
| 503 | 기타 |
|
19년 전 | 3003 | |
| 502 | Flash | 19년 전 | 3435 | ||
| 501 | Flash |
|
19년 전 | 4160 | |
| 500 | Flash |
|
19년 전 | 6031 | |
| 499 | 기타 | 19년 전 | 4013 | ||
| 498 | JavaScript | 19년 전 | 3727 | ||
| 497 | JavaScript |
|
19년 전 | 4516 | |
| 496 | MySQL | 19년 전 | 3997 | ||
| 495 | PHP | 19년 전 | 6222 | ||
| 494 | MySQL | 19년 전 | 5884 | ||
| 493 | JavaScript |
|
19년 전 | 3496 | |
| 492 | Flash |
|
19년 전 | 6572 | |
| 491 | Flash | 19년 전 | 8263 | ||
| 490 | 기타 | 19년 전 | 3939 | ||
| 489 | 기타 | 19년 전 | 3016 | ||
| 488 | MySQL | 19년 전 | 4346 | ||
| 487 | MySQL | 19년 전 | 5291 | ||
| 486 | 기타 | 19년 전 | 4629 | ||
| 485 | JavaScript | 19년 전 | 3896 | ||
| 484 | PHP |
|
19년 전 | 8418 | |
| 483 | MySQL |
|
19년 전 | 6813 | |
| 482 | JavaScript |
|
19년 전 | 7403 | |
| 481 | Flash |
|
19년 전 | 4009 | |
| 480 | Flash |
|
19년 전 | 3852 | |
| 479 | Flash |
|
19년 전 | 3451 | |
| 478 | Flash |
|
19년 전 | 3284 | |
| 477 | 기타 | 19년 전 | 6741 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기