MySQL Replication 설정

MySQL 백업 및 분산처리를 위해 replication 설정이 필요한 경우 종종 발생하게 된다.
설정 방법은 그리 복잡하거나 어렵지 않으니 쉽게 적용 가능하다.

Master / slave 설정의 시작은 my.cnf 수정을 먼저하는데 id는 중복되어서는 않되며 Master는 CRUD를 모두 사용하며, slave 서버들은 읽기전용으로 사용 가능하다. my.cnf 파일을 열어 아래와 같이 수정한다.

# master
[mysqld]
server-id = 1
log-bin = mysql-bin
# log-bin은 지정하지 않고, log-bin 만 적어도 된다.
expire_log_days = 7
# bin 로그가 무한정 쌓이는 것을 방지하기 위해 위 옵션을 추가하는 것을 추천한다.

# slave1
[mysqld]
server-id = 2
read_only

# slave2
[mysqld]
server-id = 3
read_only

이제 Master 서버에 Replication에서 사용할 계정을 생성한다. ( 필자는 “moongk”로 생성)
~]# GRANT REPLICATION SLAVE ON *.* TO 'moongk'@'192.168.100.100' IDENTIFIED BY '비밀번호';
위와 같이 계정을 만들고 나면 시작 위치를 맞춰야 한다. 그러기 위해서는 Master DB 백업이 완료되기 전까지 DB접속을 차단하거나 LOCK걸어 두는 방법도 있다.
mysql> show master status\G
만약을 대비하여 File과 Position 값을 기록해 두는 것이 좋다.

이제 Slave 서버들 설정 진행할 차례로 Master 서버의 Dump를 복원한다. 복원한 후 Slave 서버들의 시작 위치를 설정한다.

mysql> CHANGE MASTER TO MASTER_HOST='192.168.100.1', MASTER_USER='moongk', MASTER_PASSWORD='비밀번호', MASTER_LOG_FILE='mysql-bin.000000', MASTER_LOG_POS=120;

mysql> start slave;
mysql> show slave status\G
 

CentOS7 SVN(Subversion) 설 치 및 설정

CentOS7 기준으로 yum 기본 repository에는 1.7.x 버전이 설치 된다.
특별한 이유가 없다면, 1.7를 그대로 설치하도록 하겠다. 설치 방법은 아래와 같이 아주 간단히 설치 할 수 있다.

~]# yum install subversion

이제 설치가 되었으면, 저장소를 만들고 실행할 차례로 /home/svn 아래 설치하도록 하겠다.

가장 먼저 svn저장소를 생성하고, svnserve 파일에 옵션을 변경(기본 디렉토리 지정)한 뒤, 저장소 생성을 진행하도록 하겠다.

~]# mkdir /home/svn
~]# vi /etc/sysconfig/svnserve
/etc/sysconfig/svnserve 파일 수정한 모습

다음으로, SVN 서비스를 외부에서 이용할 수 있도록 방화벽 정책을 추가한다.
firewall-cmd --permanent --zone=public --add-port=3690/tcp
firewall-cmd --reload
firewall-cmd --list-all

방화벽 정책을 추가하고, 다시 로드 후 최종 등록확인까지 진행한 모습

또 다른 확인 방법은,
ps -ef | grep svn : SVN의 프로세스가 동작하는 것을 확인 할 수 있으며,
netstat -anp | grep svnserve : SVN의 포트를 확인할 수 있다. ( 기본 포트 3690 )


이제 저장소를 생성하고, SVN를 실행할 차례이다.

~]# svnadmin create --fs-type fsfs moongk
~]# chmod -R g+ws moongk

이제 저장소 생성이 되었으나 바로 사용할 수 있는 상태는 아니다.
사용가능하도록 저장소 설정을 해야 하는데, 설정 내용은 저장소에 접근할 수 있는 권한을 관리하는 파일들이다.

가장 먼저 svnserve.conf 파일을 수정해야 하는데, 위치는 위에서 추가한 저장소 하위 /conf/svnserve.conf 에 위치하고 있다. 주요 수정사항은 아래와 같다.
19line 부근: anon-access = read => none
27line 부근: password-db = passwd (주석처리 되어있으면 주석 해제)
34line 부근: authz-db = authz (주석처리 되어 있으면 해제 / 생략 가능)

다음으로 27, 34 라인 부근에서 지정하였던 passwd, authz를 지정하면 되는데 해당 설정은 파일을 열어 보면 쉽게 이해할 수 있을 것이라 생각되어 생략하도록 하겠다.

저장소 확인 명령은 svn list svn://127.0.0.1/moongk 와 같은 방법으로 확인 할 수 있으며, 서비스의 시작과 종료는 아래와 같이 할 수 있다.

~]# systemctl start svnserve #실행
~]# systemctl stop svnserve #중지
~]# systemctl restart svnserve #재실행
~]# systemctl enable svnserve #부팅시 자동 실행 지정

MySQL5.6 character-set 변경

MySQL를 설치하면 latin으로 되어 있어 utf-8로 변경하고자 한다면 /etc/my.cnf 파일 아래와 같이 수정하고 데몬을 다시 구동하면 된다.

# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.6/en/server-configuration-defaults.html

[mysql]
default-character-set = utf8

[mysqld]
#
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
#
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
#
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M

character-set-client-handshake=FALSE
init_connect="SET collation_connection = utf8_general_ci"
init_connect="SET NAMES utf8"
character-set-server = utf8
collation-server = utf8_general_ci

datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock

# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0

# Recommended in standard MySQL setup
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 

[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

[client]
default-character-set = utf8