기본 콘텐츠로 건너뛰기

Command RSYNC

rsync 10가지 사용 예제들

출처 : http://www.joinc.co.kr

1. rsync

  • rsync(Remoe Sync)는 원격에 있는 파일과 디렉토리를 복사하고 동기화 하기 위해서 사용하는 툴이며 동시에 네트워크 프로토콜이다.
  • 리눅스와 유닉스에서는 백업용도로 (아마도)가장 널리 사용하는 툴일 것이다(윈도우와 애플에도 포팅됐다).
  • rsync는 CLI툴로, 커맨드 라인의 옵션들을 이용해서 배치 프로그램을 개발하기 쉬다는 장점이 있다.
  • 이 스크립트를 cron 등에 올리는 걸로 간단하게 백업 혹은 미러(mirror) 시스템을 구축할 수 있다.

2. rsync의 기능상 장점들

  • 원격 시스템으로 부터 파일을 효율적으로 복사하거나 동기화 할 수 있다.
  • Link, device, 파일의 소유자와 그룹 권한(permissions)등 파일의 부가정보도 복사할 수 있다.
  • scp보다 빠르다. rsync는 remote-update 프로토콜을 이용해서 차이가 있는 파일만 복사한다.
  • 처음에는 모든 파일과 디렉토리를 복사하겠지만, 다음부터는 차이가 있는 파일만 복사하기 때문에 더 빠르고 효율적으로 작동한다.
  • 데이터를 압축해서 송/수신하기 때문에 더 적은 대역폭을 사용한다.

3. rsync의 동기화 알고리즘

3.1 파일 전송 결정

  • 기본적으로 rsync는 파일의 크기와 수정 시간(modification)을 비교하는 것으로 파일을 전송할지 말지를 결정한다. 이 방법은 아주 작은 CPU 자원을 소모하지만 실수가 발생할 수 있다. 일반적으로 파일의 내용을 변경하면 크기와 수정시간이 변하지만 항상 그렇다고 단정할 수는 없기 때문이다.
  • —checksum 옵션을 이용하면 비교 방법을 개선할 수 있다. 이 옵션을 켜면, 파일의 checksum을 비교한다. 크기/시간을 이용한 비교 방법보다 안전하지만 더 느리고 더 많은 자원을 사용한다.

3.2 전송할 파일 부분의 결정

  • 파일 전송을 결정했다고 가정해보자. 파일을 전송하기 위한 간단한 방법은 “전체 파일을 그대로 복사”해버리는 거다. 쉬운 방법이긴 한데, (특히 파일의 크기가 클 경우) 효율적이지는 않다. 1G 크기의 파일이 있다고 가정해보자. 여기에서 바뀐 부분이 1k 라고 할 때, 1k 때문에 1G를 복사하게 될거다.
  • rsync는 파일의 변경된 부분만 효과적으로 복사하기 위한 알고리즘을 가지고 있다.
  • rsync는 파일을 고정 크기를 가지는 청크(chunk)로 나눈다음에 checksum을 계산한다. 이 checksum을 서로 계산해서, 다를 경우 해당 부분의 청크만을 복사한다.
  • 만약 파일의 앞 부분의 정보가 수정돼서 정보들이 밀린다면 모든 청크의 checksum이 어긋날 것이다. 이 문제를 피하기 위해서 “Rolling hash”를 사용한다. (참고 : Rolling hash

4. 기본 사용 법

# rsync options source destination

5. 주요 옵션들

  • -v : verbose
  • -r : Recursively 데이터 복사
  • -a : archive mode. 이 모드를 이용하면 심볼릭 링크, 파일 유저/그룹 권한, timestamp도 복사한다.
  • -z : 파일 데이터 압축. 대역폭수 있다. 물론 시간도

6. rsync 설치하기

모든 배포판에서 패키지 형태로 제공한다. CentOS는 yum, Ubuntu는 apt-get으로 설치 끝.
# yum install rsync
# apt-get install rsync

7. 테스트 환경

  • 로컬 시스템 : 우분투 리눅스 데스크탑 13.04
  • 원격 시스템 : 우분투 리눅스 서버 13.04
  • Virtualbox : Virtualbox로 우분투 리눅스 서버를 띄운다음 테스트를 진행했다.

8. 로컬 컴퓨터에서 파일과 디렉토리 복사 및 동기화

8.1 로컬 컴퓨터에서 파일 복사 및 동기화

원격 파일 복사 프로그램이지만 로컬 컴퓨터에서 사용도 문제 없다.
# rsync -zvh backup.tar /tmp/backups/backup.tar

sent 6.56K bytes  received 31 bytes  13.18K bytes/sec
total size is 6.48K  speedup is 0.98
만약 목적지 디렉토리가 없다면, 자동으로 디렉토리를 만든다.

8.2 로컴 컴퓨터에서 디렉토리 복사 및 동기화

디렉토리를 로컬의 다른 위치로 복사할 수 있다. moniwiki 디렉토리를 /tmp/backups디렉토리로 복사했다.
# rsync -avzh moniwiki/ /tmp/backups/
....
....
wikiseed/WikiSlide
wikiseed/WikiWikiWeb
wikiseed/WordIndex

sent 2.19M bytes  received 23.72K bytes  885.45K bytes/sec
total size is 5.70M  speedup is 2.57
moniwiki 디렉토리를 다시 한번 복사해봤다. rsync에 대한 설명이 맞다면, 복사하는 파일이 없어야 할 거다.
# rsync -avzh moniwiki/ /tmp/backups/
sending incremental file list

sent 27.16K bytes  received 119 bytes  54.56K bytes/sec
total size is 5.70M  speedup is 208.89
파일을 하나 추가해서, 추가된 파일만 복사되는지 확인해보자. README.txt 파일을 만든 다음rsync를 실행했다.
# touch moniwiki/README.txt
# rsync -avzh moniwiki/ /tmp/backups/
sending incremental file list
./
README.txt

sent 27.22K bytes  received 141 bytes  54.73K bytes/sec
total size is 5.70M  speedup is 208.23
예상대로 잘 작동한다.
README.txt 파일을 수정한 다음 rsync를 실행했다.
# echo "hello world" >> moniwiki/README.txt
 rsync -avzh moniwiki/ /tmp/backups/
sending incremental file list
./
README.txt

sent 27.24K bytes  received 141 bytes  54.76K bytes/sec
total size is 5.70M  speedup is 208.11

9. 서버로부터 파일과 디렉토리를 복사 혹은 동기화 하기

9.1 로컬 서버에서 원격 서버로 디렉토리 복사하기

로컬 컴퓨터에 있는 moniwiki 디렉토리를 원격 컴퓨터로 복사하는 예제다.
# rsync -avz moniwiki/ yundream@192.168.56.101:/home/yundream/backups
......
......
wikiseed/WikiSlide
wikiseed/WikiWikiWeb
wikiseed/WordIndex

sent 2189995 bytes  received 23737 bytes  491940.44 bytes/sec
total size is 5698359  speedup is 2.57

9.2 원격 서버의 디렉토리를 로컬 서버로 복사하기

# rsync -avzh yundream@192.168.56.101:/home/yundream/backups ./
backups/wikiseed/WikiSlide
backups/wikiseed/WikiWikiWeb
backups/wikiseed/WordIndex

sent 23.74K bytes  received 2.19M bytes  885.51K bytes/sec
total size is 5.70M  speedup is 2.57

10. SSH 위에서 rsync 사용

  • rsync는 -e 옵션을 이용해서 ssh, rsh와 같은 remote shell 프로그램을 선택할 수 있다.
  • 보통 안전한 통신을 보장해주는 ssh를 이용한다.
  • -e 옵션이 없다면 ssh를 사용한다.

11. rsync server 모드로 사용

11.1 rsync 데몬 프로그램 설정

—daemon옵션을 이용, 서버모드로 작동할 수 있다. xinetd를 이용해서 시스템 서비스로 등록했다.
xinetd 패키지를 설치하자.
# apt-get install xinetd

/etc/xinetd.d/rsync 설정 파일을 만들자.
# cat /etc/xinetd.d/rsync
service rsync
{
    disable = no
    socket_type = stream
    wait = no
    user = root
    server = /usr/bin/rsync
    server_args = --daemon
    log_on_failure += USERID
    flags = IPv6
}
rsync 설정파일은 /etc/rsyncd.conf 이다. 설정파일이 없는 경우 직접 만들어줘야 한다.
max connections = 2
log file = /var/log/rsync.log
timeout = 300

[share]
comment = Public Share
path = /home/share
read only = no
list = yes
uid = nobody
gid = nogroup
auth users = yundram
secrets file = /etc/rsyncd.secrets
  • 복사(동기화) 디렉토리로 /home/share를 선택했다.
  • 읽기/쓰기 모두 가능하게 했다.
  • 디렉토리에 대한 소유자는 nobody.nogroup로 했다. /home/share 소유자를 nobody.nogroup로 변경한다.
  • 접속 허용 유저로 yundream을 추가했다.
  • auth users에 대한 설정파일은 /etc/rsyncd.secrets에 저장한다.
/etc/rsyncd.serets 파일에 접속유저이름과 패스워드를 지정할 수 있다. 패스워드는 plain/text 다.
# cat /etc/rsyncd.secrets
yundream:mypassword
읽기 테스트를 해보자.
$ rsync yundream@192.168.56.101::share
쓰기 테스트를 해보자.
# rsync -avz HelloWorld yundream@192.168.56.101::share
Password:
sending incremental file list
HelloWorld/
HelloWorld/HelloWorld.desktop
HelloWorld/HelloWorld.pro
HelloWorld/HelloWorld.pro.user
HelloWorld/HelloWorld.svg
...
sent 17798 bytes  received 252 bytes  7220.00 bytes/sec
total size is 46543  speedup is 2.58

12. 데이터 복사 진행 상황 확인하기

—progesss 옵션을 키면, 진행정도를 화면에 출력한다.
# rsync -avzh --progress yundream@192.168.56.101:/home/yundream/backups ./
......
......
backups/wikiseed/WikiWikiWeb
         944 100%    1.64kB/s    0:00:00 (xfer#1225, to-check=1/1334)
backups/wikiseed/WordIndex
          34 100%    0.06kB/s    0:00:00 (xfer#1226, to-check=0/1334)

sent 23.74K bytes  received 2.19M bytes  885.51K bytes/sec
total size is 5.70M  speedup is 2.57

13. include, exclude 옵션

include와 exclude’옵션을 이용해서 복사할 파일을 추가하거나 제외할 수 있다.
data 디렉토리를 복사에서 제외한다.
# rsync -avz  --exclude 'data' yundream@192.168.56.101:/home/yundream/backups ./
별표(*)도 사용할 수 있다.
# rsync -avz  --exclude '*.bak' yundream@192.168.56.101:/home/yundream/backups ./

14. delete 옵션

rsync는 파일이나 디렉토리가 없으면 새로 만든다. 그러나 파일이나 디렉토리가 존재할 경우 삭제하고 싶을 때도 있을 거다.
이럴때 —delete 옵션을 사용한다.
로컬 서버에 “text.txt”파일이 있으면 삭제한 후 복사하는 예제다.
# touch test.txt
# rsync -avz --delete yundream@192.168.56.101:/home/yundream/backups ./
receiving file list ... done
deleting test.txt

....
....

15. 전송할 파일의 최대 크기 정하기

—max-size옵션을 이용해서 전송할 파일의 최대 크기를 정할 수 있다. 아래는 10k 이내의 파일만 복사하는 예제다.
# rsync -avz --max-size='10k' yundream@192.168.56.101:/home/yundream/backups ./

16. 성공적으로 전송한 후 원본파일 지우기

“—remove-source-files”를 이용하면, 전송이 끝난 후 원본파일을 삭제한다.
# rsync --remove-source-files -zvh backup.tar /tmp/backups/backup.tar

sent 14.71M bytes  received 31 bytes  4.20M bytes/sec
total size is 16.18M  speedup is 1.10

# ll backup.tar
ls: backup.tar: No such file or directory

17. Bandwidth 제한 설정

—bwlimit 옵션을 이용해서 파일전송에 사용할 네트워크 대역폭을 제한할 수 있다. 인터넷 서비중인 서버에서, 다른 서비스에 영향을 주지 않는 범위내에서 파일 복사를 원할 경우 유용하게 사용할 수 있다.
bwlimit를 사용해서 대역폭을 제한했다.
# rsync --bwlimit=100 -avzhe ssh  /var/lib/rpm/  root@192.168.56.101:/root/tmprpm/
root@192.168.0.100's password:
sending incremental file list
sent 324 bytes  received 12 bytes  61.09 bytes/sec
total size is 38.08M  speedup is 113347.05

18. 참고

  • wikipedia - Rsync
  • Rsync : 10 Practical Examples of Rsync Command in Linux
  • 우분투 리눅스 문서 - rsync

댓글

이 블로그의 인기 게시물

Qt Framework를 사용하여 라즈베리파이 응용프로그램 개발 #04

How To build QtSDK for Raspberry-Pi On Windows 1. 최우선적으로 각각의 작업을 진행하는 디렉토리를 설정 한다 . Toolchain directory : d:\toolchains\raspberry-pi Qt SDK install directory : d:\qt Qt source directory : d:\qt-src Qt Build directory : d:\build-qt 2. 빌드하기 위한 추가적 패키지 설치 윈도우에서 qt 를 빌드하기 위해서는 python 과 perl 이 필요하다 . 이것은 http://doc.qt.io/qt-5/windows-building.html 이 문서를 보고 해당 패키지를 설치 하도록 한다 . 3. QtSDK 설치 추가적으로 qtsdk 는 기존 빌드된 실행파일을 https://www.qt.io/download-open-source 에서 내려받아 설치를 진행한다 . QtSDK 는 d:\qt 에 설치를 한다 . 4. 라즈베리파이용 툴체인 설치 http://gnutoolchains.com/raspberry/ 에서 라즈베리파이용 툴체인을 내려 받아 설치 한다 . 설치 위치는 자신에 환경에 맞게 설정해준다 . 여기서는 d:\toolchains\raspberry-pi 에 설치를 한다 . 5. Qt source 내려받기 Q t 소스는 이전에 포스팅한 것을 참고 하여 해당 디렉토리에 소스를 내려 받도록 한다 . git-bash 를 실행하여 다음과 같이 명령을 내린다 . cd /d git clone git://code.qt.io/qt/qt5.git -b 5.8 qt-src cd qt-src ./init-repository 6. Qt 빌드하기 Qt 5.8 for Deskto...

Qt Framework를 사용하여 라즈베리파이 응용프로그램 개발 #02

Qt5를 사용하기 위한 라즈베리안 설치 및 설정 1. 라즈베리안 이미지 내려받기 wget http://downloads.raspberrypi.org/raspbian_latest -O raspbian-latest.zip 2. 라즈베리안 이미지 설치 https://etcher.io/ 에서 이미지 버너를 내려받아 사용하면 된다. 윈도우, 리눅스, 맥에서 모두 동작하므로 사용하기 용의 하다. 3. 라즈베리안 부트 옵션 설정 이미지를  sdcard에 설치를 한후 boot파티션에 있는 config.txt 파일을 수정하여 기본설정을 한다. lcd_rotate : 라즈베리파이에서 사용하는 LCD 패널을 회전 시킬 때 사용하며, 0~3 까지 사용가능 하다. 해당 1의 단위는 90도의 각도를 의미한다. gpu_mem : 라즈베리파이에서 사용하는 GPU의 메모리를 설정한다. 1의 단위는 MB를 사용한다. enable_uart : 라즈베리파이의 UART Port를 기본 콘솔로 사용하기 위해서는 해당 기능을 활성화 시켜야 한다. disable_splash : 부팅 초기에 표시되는 4색 컬러를 표시 하지 않도록 한다. 다음과 같이 해당 항목을 추가 하면 된다. # LCD Display config rotate 180 lcd_rotate=2 # GPU Memory gpu_mem=256 # Enable UART enable_uart=1 # Disable Splash disable_splash=1 4. 라즈베리안 설정 변경 라즈베리안에서 Qt를 사용하기 위해서는 기본적으로 X-Windows 시스템을 사용하지 않도록 해야하며, 경우에 따라서는 계정정보 역시 변경을 해야한다. 해당 정보는 raspi-config 명령을 통해서 변경이 가능하다. (raspi-config명령은 sudo명령을 통하여 루트권한으로 실행해야 한다.) 계정 정보 변경 보안을 위해서 추후 계정 정보를 변경해야 한...

Qt Framework를 사용하여 라즈베리파이 응용프로그램 개발 #01

라즈베리파이에 Qt5 SDK 빌드 개요 이문서는 RaspberryPi3에 Qt 5.6 혹은 5.8를 사용하여 응용프로그램을 개발하는 방법을 소개한다. 브로드컴에서 제공하는 EGL/GLES 를 사용하도록 qmake.conf 가 기존에 작성이 되어 있기 떄문에 해당 기능을 활용하여 빌드를 진행한다 . 개발환경은 우분투 혹은 데비안 그리고 맥 OS 에서 구성이 가능하며 , 이문서는 https://wiki.qt.io/RaspberryPi_Beginners_Guide 와 https://wiki.qt.io/RaspberryPi2EGLFS 를 기반으로 하여 작성이 되었다 . 기본 개발환경은 우분투/데비안을 기준으로 사용하고 macOS의 경우 다음에 기회가 된다면 추가적으로 기술하도록 한다. 작업흐름은 다음과 같은 순서로 진행을 한다 . Qt5를 사용하기 위한 라즈베리안 설치 및 설정 을 참조하여 필요한 설정 및 패키지 설치를 진행한다 . 작업 디렉토리를 정의 한다 . 라즈베리파이용 컴파일러를 내려받아 설치한다 . 라즈베리파이용 교차개발 도구를 내려받아 설치한다 . Qt5 소스코드를 내려받는다 . Qt5 필수 패키지 설치 ( 참조한 문서에서는 QtBase, QtImageFormats 패키지만을 우선적으로 빌드하여 사용하고 필요한 패키지가 추가적으로 있을시에 해당 대상만 빌드를 하도록 되어 있다 .) 빌드된 패키지를 포함한 라즈베리파이에 설치 한다 . 테스트 앱을 빌드하여 정상적으로 동작하는지 확인 한다 .