실수로 삭제한 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>
댓글 3개
19년 전
헐 날아가서 다시설치했는데
아쉽네요.
어쨌든 좋으네요.
아쉽네요.
어쨌든 좋으네요.
19년 전
어떤 버전부터 가능한가요?
17년 전
버젼보다는 컴파일시에 또는 설정시 로그를 남기도록 해야 합니다.
게시글 목록
| 번호 | 제목 |
|---|---|
| 719 | |
| 17823 | |
| 717 | |
| 716 | |
| 715 |
JavaScript
vim 의 들여쓰기 + 색상 눈 덜피곤 c++ php 등.. (리눅스용)
|
| 714 |
JavaScript
vim 의 간단한 사용법
|
| 713 |
JavaScript
[자바스크립트] 상태표시줄 제어 + 간단한 복사 제어
|
| 710 |
Linux
/etc 디렉토리 아래의 파일들
2
|
| 709 |
기타
shadow 잠금 해제
|
| 708 | |
| 707 |
JavaScript
yum 업데이트 되는곳 7.3 or 페도라
|
| 706 |
MySQL
mysql 링크하기
|
| 705 | |
| 704 |
MySQL
mysql.sock 삭제 하였을 경우
|
| 703 | |
| 702 | |
| 701 |
JavaScript
ps 시 화면 짤리는부분 보이게 하기
|
| 700 | |
| 699 | |
| 698 |
기타
chmod 의 스틱키
|
| 697 |
JavaScript
tripwire 의 twr 파일 보기
|
| 696 |
JavaScript
최근 사용자 접속 리스트 보기
|
| 695 | |
| 694 | |
| 693 |
JavaScript
atd 데몬
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기