실수로 삭제한 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에서 해주시기 바랍니다.
| 번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|---|
| 416 | 기타 |
개발자관리자
|
19년 전 | 3892 | |
| 415 | 기타 |
개발자관리자
|
19년 전 | 4896 | |
| 414 | Flash |
|
19년 전 | 4428 | |
| 413 | Flash |
|
19년 전 | 3473 | |
| 412 | Flash |
|
19년 전 | 6629 | |
| 411 | Flash |
|
19년 전 | 4102 | |
| 410 | JavaScript | 19년 전 | 3871 | ||
| 409 | Flash |
|
19년 전 | 4656 | |
| 408 | Flash |
|
19년 전 | 3995 | |
| 407 | Flash |
|
19년 전 | 5320 | |
| 406 | Flash |
|
19년 전 | 3387 | |
| 405 | Flash |
|
19년 전 | 5552 | |
| 404 | Flash |
|
19년 전 | 5360 | |
| 403 | Flash |
|
19년 전 | 7358 | |
| 402 | Flash |
|
19년 전 | 5132 | |
| 401 | 기타 |
스마일미디어
|
19년 전 | 4416 | |
| 400 | JavaScript |
스마일미디어
|
19년 전 | 4281 | |
| 399 | JavaScript |
스마일미디어
|
19년 전 | 3512 | |
| 398 | 기타 |
스마일미디어
|
19년 전 | 3560 | |
| 397 | 기타 |
스마일미디어
|
19년 전 | 3989 | |
| 396 | MySQL | 19년 전 | 4737 | ||
| 395 | JavaScript |
|
19년 전 | 4045 | |
| 394 | Flash |
|
19년 전 | 4110 | |
| 393 | 정규표현식 |
sjsjin
|
19년 전 | 4174 | |
| 392 | JavaScript |
sjsjin
|
19년 전 | 5812 | |
| 391 | 기타 |
sjsjin
|
19년 전 | 3881 | |
| 390 | Flash | 19년 전 | 5351 | ||
| 389 | 기타 | 19년 전 | 5129 | ||
| 388 | JavaScript | 19년 전 | 5619 | ||
| 387 | 기타 | 19년 전 | 4448 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기