LSYNCD 서버 파일 동기화 시키기
웹서버의 이미지나 데이터 파일을 다른 원격지 서버에 실시간 동기화를 원할 때 lsyncd 데몬을 사용하면 간단히 파일 동기화가 가능합니다.
그리고 같은 서버내 다른 디렉토리에도 백업이 가능하고 특정 폴더나 특정 파일을 제외하는 것도 가능합니다.
lsyncd.conf 설정 옵션에 대해서 알아보겠습니다.
▶ LSYNCD 설치
# yum install lsyncd lua rsync
lsyncd 와 lua 를 설치하여야 한다.
rsync 는 기본적으로 설치가 되어있겠지만 안되어 있다면 설치를 해주면 된다.
▶ 데몬 동작 설정
# systemctl enable lsyncd
# systemctl start lsyncd
6.x 버전은
# chkconfig --level 2345 lsyncd on
# service lsyncd start
아직 설정전이라 에러가 발생할겁니다.
이제 설정파일을 설정해보겠습니다.
▶ 같은 서버에 파일 동기화 설정 ( vi /etc/lsyncd.conf )
settings {
logfile="/tmp/lsyncd.log",
statusFile="/tmp/lsyncd-status.log"
}
sync {
default.rsync,
source="/var/www/html",
target="/var/www/html_backup"
}
▶ 동작 테스트
# touch /var/www/html/test.{1..5}
# ls -l /var/www/html_backup/
-rw-r--r-- 1 root root 0 12월 23 13:51 test.1
-rw-r--r-- 1 root root 0 12월 23 13:51 test.2
-rw-r--r-- 1 root root 0 12월 23 13:51 test.3
-rw-r--r-- 1 root root 0 12월 23 13:51 test.4
-rw-r--r-- 1 root root 0 12월 23 13:51 test.5
파일이 동기화가 안되어 있다면 몇 초 후에 재확인 해보세요.
그래도 파일이 동기화가 안된다면 /var/log/message 로그 파일을 확인해 보고 에러를 잡아주면 됩니다.
/etc/lsyncd.conf 파일에 설정이 잘 못 되었을 가능성이 큽니다.
이번엔 원격지 서버에 파일을 동기화 시키는 방법에 대해서 알아보겠습니다.
먼저 ssh 암호 입력 없이 접속이 가능하도록 만들어 주어야 합니다.
▶ 암호키 생성 및 복사
# ssh-keygen
# ssh-copy-id -p포트번호 root@192.168.1.3
에러가 나면 scp ./.ssh/id_rsa.pub root@192.168.1.3:~/.ssh/authorized_keys 이렇게 복사를 하면 됩니다.
원격지에 다른서버의 key값이 있다면 덥어쓰면 안되니깐 아래의 방법을 사용하여야 합니다.
cat ./.ssh/id_rsa.pub | ssh -p포트번호 root@192.168.1.3 "mkdir -p ~/.ssh && cat >> ~/.ssh/authorized_keys"
ssh-copy-id 명령어를 사용하면 덥어쓰지 않고 추가가 됩니다.
▶ 원격지 서버에 파일 동기화 설정 ( vi /etc/lsyncd.conf )
settings {
logfile="/tmp/lsyncd.log",
statusFile="/tmp/lsyncd-status.log"
}
sync {
default.rsyncssh,
source="/var/www/html",
host="192.168.1.3",
targetdir="/var/www/html"
}
▶ 로컬 및 원격지 서버에 파일 동기화 설정 ( vi /etc/lsyncd.conf )
settings {
logfile="/tmp/lsyncd.log",
statusFile="/tmp/lsyncd-status.log"
}
sync {
default.rsync,
source="/var/www/html",
target="/var/www/html_backup"
}
sync {
default.rsyncssh,
source="/var/www/html",
host="192.168.1.3",
targetdir="/var/www/html"
}
이렇게 하면 이중으로 백업이 가능합니다.
▶ 기타 설정
settings {
logfile="/tmp/lsyncd.log",
statusFile="/tmp/lsyncd-status.log"
}
sync {
default.rsyncssh,
source="/var/www/html",
host="192.168.1.3",
targetdir="/var/www/html",
delay = 1,
delete = true,
exclude = {
'/test1' ,
'/test3' ,
'*.tmp' ,
'*.swp'
},
ssh = {
port = 10022
},
rsync = {
archive = true,
compress = false,
verbose = false
}
}
delay : 동기화 작동 시점을 초단위로 조절할 수 있습니다. 디폴트는 15초 입니다.
delete :
원본에서 파일 삭제시 타겟까지 삭제하는 옵션입니다.
false 면 삭제를 하지 않습니다.
exclude :
/var/www/html/test1 폴더를 제외하려면 위에 처럼 exclude 옵션을 사용하면 됩니다.
source 폴더가 루트로 보고 적어주면 됩니다.
파일을 제외 하려면 *.swp 처럼 적어주면 됩니다.
ssh :
ssh 포트를 설정할 수 있습니다.
rsync :
archive 소유권까지 동일하게 복사가 됩니다.
compress 압축여부을 지정할 수 있습니다.
verbose 로그를 상세하게 보여주는 옵션입니다.
▶ lsyncd.log 에러
Wed Mar 15 14:05:54 2017 Normal: --- TERM signal, fading ---
Wed Mar 15 14:05:56 2017 Error: Terminating since out of inotify watches.
Consider increasing /proc/sys/fs/inotify/max_user_watches
동기화 시키려는 파일이 많은 때는 위와 같은 에러가 발생합니다.
이럴때는 max_user_watches 수를 증가시켜 주면 됩니다.
# echo 65536 > /proc/sys/fs/inotify/max_user_watches
이제 lsyncd 를 재시작 하면 됩니다.
MySQL DB 동기화는 https://ivps.tistory.com/217 여기를 참고하세요.