mariabackup 을 이용한 MariaDB 10.6.9 Replication 구성하기
percona-xtrabackup 패키지는 MySQL 또는 MariaDB 서버의 서비스 중지 없이 Replication 을 구성하기 위한 명령어 입니다.
아래 내용은 CentOS 8 환경에서 MariaDB 10.6.9 버전으로 테스트 하였습니다.
사용자 계정이나 패스워드, 디렉토리 등은 사용자 환경에 따라 다르므로 명령 실행시 확인 후 실행하시기 바랍니다.
- master 서버 : 192.168.10.2
- slave 서버 : 192.168.10.3
- 참고1 : percona-xtrabackup 패키지는 MySQL 과 MariaDB 둘 다 가능합니다. 다만 설치 버전에 따라 지원가능한 DB 버전이 다르며 MySQL 은 xtrabackup, MariaDB 는 mariabackup 이라는 명령을 사용하는것이 큰 차이점 입니다.
(redo 로그를 기록하는 파일이 다름)
- LINK : xtrabackup 을 이용한 MySQL 8.0.28 Replication 구성하기
1. 설치
(인터넷 연결 가능할 경우)
master 서버와 slave 서버에 xtrabackup 을 설치 합니다.
# yum -y install https://repo.percona.com/yum/percona-release-latest.noarch.rpm
# yum -y install percona-xtrabackup-24
(인터넷 연결 불가의 경우)
사설망에서 DB를 운영할 경우 서버에 없는 패키지는 설치 파일을 다운 받아 복사하여 설치하면 됩니다.
서버 환경에 따라 필요한 패키지가 다를 수 있으며 이는 아래 rpm 명령으로 의존성 확인이 가능합니다.
# wget https://vault.centos.org/centos/8/AppStream/x86_64/os/Packages/libev-4.24-6.el8.x86_64.rpm
# wget https://vault.centos.org/centos/8/BaseOS/x86_64/os/Packages/perl-DBI-1.641-1.el8.x86_64.rpm
# wget https://vault.centos.org/centos/8/AppStream/x86_64/os/Packages/perl-DBD-MySQL-4.046-3.module_el8.3.0+419+c2dec72b.x86_64.rpm
# wget https://vault.centos.org/centos/8/BaseOS/x86_64/os/Packages/rsync-3.1.3-12.el8.x86_64.rpm
# wget https://repo.percona.com/yum/release/8/RPMS/x86_64/percona-xtrabackup-80-8.0.28-21.1.el8.x86_64.rpm
필요한 패키지를 다운로드 한 후 DB 서버로 옮깁니다. (scp 또는 rsync 등으로 복사하면 됩니다. 방법은 생략)
그리고 아래 순서에 따라 설치합니다.
# rpm -ivh libev-4.24-6.el8.x86_64.rpm
# rpm -ivh perl-DBI-1.641-1.el8.x86_64.rpm
# rpm -ivh perl-DBD-MySQL-4.046-3.module_el8.3.0+419+c2dec72b.x86_64.rpm
# rpm -ivh rsync-3.1.3-12.el8.x86_64.rpm
# rpm -ivh percona-xtrabackup-80-8.0.28-21.1.el8.x86_64.rpm
2. 원본 데이터 백업
(master 서버에서)
# mariabackup --defaults-file=/etc/my.cnf --backup --user=root --password=12345678 --target-dir=/mariabackup --no-lock --port=3306 --socket=/tmp/mysql.sock
백업이 완료되면 /mariabackup 디렉토리가 생성되며 하단에 백업 파일들이 존재하게 됩니다.
data 디렉토리 내 파일들과 mariabackup 관련된 로그가 있습니다.
3. 데이터 이전
(master 서버에서)
master 서버에 백업된 데이터를 slave 서버로 복사합니다.
# rsync -avzPog /mariabackup root@192.168.10.3:/
4. 데이터 복원
(slave 서버에서)
mysqld 데몬을 중지하고 기존 data 디렉토리를 삭제 합니다. (mv 명령으로 디렉토리 이름 변경 권장)
가져온 데이터를 복구하는 과정에서 기존 data 디렉토리내 파일이 있으면 실행이 되지 않기 때문입니다.
백업중 작성된 redo 로그를 데이터에 적용합니다.
# mariabackup --prepare --target-dir=/mariabackup
> --use-memory=10G 와 같이 본 작업에 사용할 시스템 메모리양을 어느정도 할당 해주면 빠른처리가 가능합니다.
> redo 로그 적용 도중에 아래와 같은 에러 메세지가 출력 될 경우 --innodb_force_recovery=1 옵션을 추가 합니다.
2022-10-14 8:47:54 0 [Note] InnoDB: Set innodb_force_recovery=1 to ignore corrupted pages.
2022-10-14 8:47:54 0 [ERROR] InnoDB: Plugin initialization aborted with error Generic error
[00] FATAL ERROR: 2022-10-14 08:47:54 mariabackup: innodb_init() returned 11 (Generic error).
하지만 백업 과정에서 문제가 생겼을 수 있으므로 master 서버에서 몇 번 더 백업을 반복 시도해 보는것도 좋습니다.
백업 파일을 이동합니다. (--copy-back 를 사용하면 복사)
# mariabackup --move-back --datadir=/usr/local/mysql/data --target-dir=/mariabackup
root 로 복원하였기 때문에 복원된 파일의 권한이 root 로 되어 있습니다.
mysql 가동을 위해 data 디렉토리의 권한을 설정을 합니다.
# chmod 755 /usr/local/mysql/data
# chown mysql.mysql -R /usr/local/mysql/data
# systemctl start mysqld
5. 로그 포지션 설정 및 동기화 시작
백업본의 xtrabackup_binlog_info 에 있는 mysql-bin 파일명과 position 값 참고하여
replication 을 적용합니다.
(slave 서버에서)
# cat /usr/local/mysql/data/xtrabackup_info |grep binlog_pos
binlog_pos = filename 'binlog.000002', position '943' // 출력된 내용을 참고
# mysql -p
mysql> stop slave;
mysql> reset slave;
mysql> change master to master_host='192.168.10.2', master_user='repl',
master_password='12345678', master_log_file='binlog.000002',
master_log_pos=943;
mysql> start slave;
정상적으로 동기화 된 것을 확인할 수 있습니다.
mysql> show slave status \G;
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
'리눅스 > MySQL' 카테고리의 다른 글
PostgreSQL 13.7 Replication 설정 (RockyLinux 9.0) (0) | 2023.03.10 |
---|---|
MySQL (MariaDB) 로그들 logrotate 설정하기 (0) | 2022.10.07 |
Rocky Linux 8.6 에서 MariaDB 10.9.2 소스 설치하기 (with InnoDB 이노디비 설정) (0) | 2022.09.13 |
sysbench 1.0.20 를 이용한 MySQL 성능 (performance) 테스트 (0) | 2022.09.01 |
Rocky Linux 8.6 에서 MySQL 8.0.30 소스 설치하기 (with InnoDB 이노디비 설정) (0) | 2022.08.11 |