대용량 InnoDB백업을 위한 솔루션을 찾다가 발견한 솔루션 입니다.

· 12년 전 · 5430 · 1

대용량 InnoDB백업을 위한 솔루션을 찾다가 발견한 솔루션 입니다.
아직 테스트가 안되서 뭐라고 직접 사용기를 올리기는 좀 그렇고
http://www.percona.com/docs/wiki/percona-xtrabackup:xtrabackup:how_to_recipes
위 페이지 기준으로 간략하게 사용법을 만들어 봤습니다.

영어실력이 미천한지라 잘못 해석된 부분이 있을 수 있으니 이점 참고 하시고
좋은 솔루션 인것은 확실한것 같으니 이 솔루션에 대해서 필요하신분은 써 보시고
테스트 해서 결과를 도출 해 보고 싶네요 ㅎ


* Percona XtraBackup 사용법

# Full Backup

    1. my.cnf 설정
      [mysqld]
      datadir=/var/lib/mysql/            => MySql 데이터 디렉토리
     
      [xtrabackup]
      target_dir=/data/baclup/mysql/    => 백업 데이터 디렉토리

    2. 백업 방법
        - xtrabackup --backup            => my.cnf 설정대로 백업
        - xtrabackup --prepare            => 복원을 위한 준비
        - xtrabackup --prepare            => 새로운 innoDB 로그파일 생성을 위해 다시한번 실행
   
    3. 백업의 성공기준
        - xtrabackup 의 종료 상태값이 0 인경우.
        - 두번째 '--prepare'시 로그파일이 생성된뒤 이어서 "Log file ./ib_logfile0 did not exist: new to be created" 와 같은
           메시지를 확인 해야함.
   
    4. 서버에 충분한 메모리가 있다면 '--use-memmory' 옵션을 통해서 버퍼풀을 지정할 수 있다.

 


# Incremental Backup

    ※ 증분백업을 위서는 '--prepare'가 실행되기전 Full 백업이 필요하다.

    1. 백업 방법(월요일에 Full Backup이 실행 되었다고 가정)
        - 명령어
            # xtrabackup --backup --target-dir=/data/backups/inc/tue/ \        => 화요일 증분 백업
                     --incremental-basedir=/data/backups/mysql/
           
            # xtrabackup --backup --target-dir=/data/backups/inc/wed/ \        => 수요일 증분 백업
                     --incremental-dir=/data/backups/inc/wed/

    2. Prepare
        - 명령어
            # xtrabackup --prepare --apply-log-only --target-dir=/data/backups/mysql/        => 월요일 기준 데이터로 복원 준비
 
            # xtrabackup --prepare --apply-log-only --target-dir=/data/backups/mysql/ \        => 화요일 기준 데이터로 복원 준비
                 --incremental-dir=/data/backups/inc/tue/
           
            # xtrabackup --prepare --apply-log-only --target-dir=/data/backups/mysql/ \        => 수요일 기준 데이터로 복원 준비
                 --incremental-dir=/data/backups/inc/tue/

 

# Restoring the Backup
   
    ※ xtrabackup 은 MyISAM 파일을 복사하지 않기때문에 '.frm' 파일들과 나머지 데이터베이스 파일들은 따로 백업을 해야 한다.
    
    1. 복원
        - InnoDB 복원은 간단하다 Preparing 후 아래와 같은방법으로 복원할 수 있다.
            # cd /data/backups/mysql
            # rsync -rvt --exclude 'xtrabackup_checkpoints' --exclude 'xtrabackup_logfile' \
                     ./ /var/lib/mysql
            # chown -R mysql:mysql /var/lib/mysql/

|

댓글 1개

댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
12년 전 조회 2,381
12년 전 조회 2,797
12년 전 조회 2,212
12년 전 조회 1,489
12년 전 조회 2,710
12년 전 조회 2,297
12년 전 조회 8,657
12년 전 조회 3,184
12년 전 조회 2,981
12년 전 조회 3,041
12년 전 조회 3,580
12년 전 조회 1,670
12년 전 조회 4,774
12년 전 조회 2,421
12년 전 조회 7,527
12년 전 조회 2,057
12년 전 조회 2,056
12년 전 조회 2,115
12년 전 조회 1,726
12년 전 조회 3,995
12년 전 조회 2,505
12년 전 조회 2,546
12년 전 조회 2,077
12년 전 조회 3,737
12년 전 조회 2,717
12년 전 조회 1,503
12년 전 조회 4,604
12년 전 조회 2,062
12년 전 조회 1,837
12년 전 조회 2,244
12년 전 조회 6,582
12년 전 조회 2,211
12년 전 조회 3,807
12년 전 조회 3,280
12년 전 조회 1,497
12년 전 조회 3,944
12년 전 조회 2,420
12년 전 조회 2,346
12년 전 조회 2,392
12년 전 조회 4,317
12년 전 조회 3,111
12년 전 조회 4,750
12년 전 조회 9,630
12년 전 조회 5,211
12년 전 조회 4,815
12년 전 조회 2,383
12년 전 조회 2,453
12년 전 조회 4,176
12년 전 조회 5,032
12년 전 조회 5,431
12년 전 조회 2,642
12년 전 조회 2,329
12년 전 조회 1,908
12년 전 조회 1,993
12년 전 조회 3,783
12년 전 조회 3,779
12년 전 조회 2,293
12년 전 조회 3,828
12년 전 조회 2,326
12년 전 조회 9,450
12년 전 조회 2,582
12년 전 조회 4,825
12년 전 조회 7,441
12년 전 조회 2,625
12년 전 조회 3,882
12년 전 조회 1,590
12년 전 조회 2,295
12년 전 조회 2,166
12년 전 조회 2,338
12년 전 조회 4,352
12년 전 조회 2,117
12년 전 조회 2,859
12년 전 조회 2,289
12년 전 조회 1,937
12년 전 조회 2,395
12년 전 조회 3,094
12년 전 조회 2,378
12년 전 조회 2,183
12년 전 조회 2,728
12년 전 조회 1.6만
12년 전 조회 1,988
12년 전 조회 1,766
12년 전 조회 3,616
12년 전 조회 9,865
12년 전 조회 2,160
12년 전 조회 2,108
12년 전 조회 2,554
12년 전 조회 2,038
12년 전 조회 2,208
12년 전 조회 4,461
12년 전 조회 2,377
12년 전 조회 3,045
12년 전 조회 2,042
12년 전 조회 2,230
12년 전 조회 3,938
12년 전 조회 1,771
12년 전 조회 2,250
12년 전 조회 2,594
12년 전 조회 3,032
12년 전 조회 3,134