실수로 삭제한 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에서 해주시기 바랍니다.
| 번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|---|
| 5396 | 기타 |
슈퍼스타맨
|
4개월 전 | 355 | |
| 5395 | PHP |
untitled
|
5개월 전 | 824 | |
| 5394 | MySQL |
선택과집중
|
6개월 전 | 601 | |
| 5393 | 웹서버 |
techstar
|
8개월 전 | 865 | |
| 5392 |
|
1년 전 | 1222 | ||
| 5391 | 10개월 전 | 1122 | |||
| 5390 | 10개월 전 | 908 | |||
| 5389 | 9개월 전 | 876 | |||
| 5388 | 9개월 전 | 978 | |||
| 5387 | 8개월 전 | 811 | |||
| 5386 | JavaScript |
nekoieye
|
8개월 전 | 974 | |
| 5385 | 웹서버 | 8개월 전 | 990 | ||
| 5384 | JavaScript |
|
9개월 전 | 821 | |
| 5383 | 기타 | 10개월 전 | 1131 | ||
| 5382 | 기타 |
|
10개월 전 | 580 | |
| 5381 | JavaScript | 10개월 전 | 911 | ||
| 5380 | 기타 |
|
10개월 전 | 698 | |
| 5379 | JavaScript | 10개월 전 | 696 | ||
| 5378 | 11개월 전 | 1200 | |||
| 5377 | 기타 |
|
11개월 전 | 764 | |
| 5376 | jQuery |
|
11개월 전 | 579 | |
| 5375 | jQuery |
techstar
|
11개월 전 | 732 | |
| 5374 | 기타 |
|
11개월 전 | 785 | |
| 5373 | MySQL |
|
1년 전 | 813 | |
| 5372 | 기타 |
|
1년 전 | 1017 | |
| 5371 | JavaScript |
|
1년 전 | 730 | |
| 5370 | JavaScript |
|
1년 전 | 735 | |
| 5369 | PHP |
|
1년 전 | 1245 | |
| 5368 | PHP | 1년 전 | 1411 | ||
| 5367 | 기타 |
nekoieye
|
1년 전 | 1287 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기