리눅스 Rsync 명령어

Rsync (Remote Sync) 는 네트워크를 통해 파일과 디렉터리를 효율적으로 동기화하는 백업 방식입니다.

전체 데이터를 매번 복사하는 대신 변경된 부분만 증분 방식으로 전송하여 빠르고 안정적인 동기화를 지원합니다.

또한 다양한 옵션을 통해 압축, 암호화, 권한 유지, 삭제 동기화 등 세밀한 제어가 가능하며, 백업과 서버 간 데이터 전송에 널리 사용됩니다. 특히 네트워크 대역폭을 절약하고, 재 전송 부담을 줄여 대규모 데이터 이전에 적합합니다.

  • rsync(Remote Sync:원격 동기화) 특징
  • samba의 핵심 개발자인 Andrew Tridgell 이 만든 로컬과 리모트간에 데이타 동기화를 위한 유틸리티
  • rsync Protocol: TCP / UDP 878 포트 사용
  • 델타 인코딩 알고리즘(delta encoding algorithm)의 사용으로 rcp, scp보다 효율적인 데이터 동기화를 진행
  • Links, 소유자, 그룹, 퍼미션에 대한 Copy 허용
  • root 권한을 요구하지 않으며, 일반 계정에서도 사용 가능.
  • 익명 및 인증 rsync 서버 지원으로 미러링에 이상적임.

✅ 리눅스 rsync 설치 및 리모트 설정하기

1. rsync 패키지 설치 여부 확인

~]# rpm -qa | grep rsync

2. 패키지가 없을 경우 설치 진행

yum -y install rsync
dnf -y install rsync
apt-get install rsync

# 록키 리눅스 9 이상에서는 rsync-daemon 데몬 설치가 필요함. 
dnf  -y install rsync-daemon
Last metadata expiration check: 3:38:37 ago on Sat Jan 27 13:41:19 2024.
Dependencies resolved.
=========================================================================================================================================================
 Package                               Architecture                    Version                                  Repository                          Size
====================================================================================================== 
----- 생략 -----
록키리눅스 9 이상의 버전부터 xinetd 버전이 사용되지 않기 때문에 systemd 소켓 서비스를 설정해야 합니다.

~]# systemctl status rsyncd
rsyncd.service - fast remote file copy program daemon
     Loaded: loaded (/usr/lib/systemd/system/rsyncd.service; disabled; preset: disabled)
     Active: inactive (dead)

~]#  systemctl start rsyncd
~]# systemctl enable rsyncd
~]# systemctl status rsyncd
rsyncd.service - fast remote file copy program daemon
     Loaded: loaded (/usr/lib/systemd/system/rsyncd.service; enabled; preset: disabled)
     Active: active (running) since Sat 20xx-01-27 17:21:09 UTC; 2s ago
   Main PID: 6883 (rsync)
      Tasks: 1 (limit: 10823)
     Memory: 688.0K
        CPU: 2ms
     CGroup: /system.slice/rsyncd.service
             └─6883 /usr/bin/rsync --daemon --no-detach

3. rynsc 설정 파일 작성

~]# vi /etc/rsyncd.conf 
## 초기 설정 화면 
# /etc/rsyncd: configuration file for rsync daemon mode

# See rsyncd.conf man page for more options.

# configuration example:

# uid = nobody
# gid = nobody
# use chroot = yes
# max connections = 4
# pid file = /var/run/rsyncd.pid
# exclude = lost+found/
# transfer logging = yes
# timeout = 900
# ignore nonreadable = yes
# dont compress   = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2

# [ftp]
#        path = /home/ftp
#        comment = ftp export area

## 설명 ##
log file = /var/log/rsync.log            # 로그 파일 경로
[source]                                 # 부르고 싶은 명칭
path = /var/www/omeka1/files             # 소스 디렉토리 설정
uid = root                               # rsync 사용 가능한 사용자
gid = root                               # rsync 사용 가능한 그룹
use chroot = yes                         # chroot 사용여부
host allow = x.x.x.x                     # 연결한 호스트: 해당 호스트 아이피만 접근 가능
max connection = 100                     # 최대 연결 개수
timeout 300                              # 타임아웃 시간 설정(초)

### 설정 예시 ###
[myhome]
path=/home
uid = root
gid = root
use chroot = yes
read only = yes
hosts allow = 222.222.123.123
max connections = 3
timeout 30

[dbdata]
path=/var/lib/mysql/
uid = root
gid = root
use chroot = yes
read only = yes
hosts allow = 222.222.123.123
max connections = 3
timeout 30
## 설정 예시 ###

✅ 록키 리눅스 포함 8이하 버전 xinetd 데몬 설치 및 구동

yum -y install xinetd
dnf -y install xinetd
apt-get install rsync

# 등록된 서비스를 확인 
systemctl list-unit-files --type=service 
  • systemctl list-unit-files –type=service 명령어는 lessvi 명령어의 옵션과 동일하게 검색 기능을 사용할 수 있음.
vi /etc/xinetd.d/rsync

service rsync
{ 
        disable = no
        flags           = IPv6
        socket_type     = stream
        wait            = no
        user            = root
        server          = /usr/bin/rsync
        server_args     = --daemon
        log_on_failure  += USERID
        
#xinetd 데몬 재구동
service xinetd restart

✅ 방화벽 포트 규칙 추가

iptables 포트 규칙을 추가합니다.

~]# vi /etc/sysconfig/iptables 

-A INPUT -m state --state NEW -m tcp -p tcp --dport 873 -j ACCEPT
-A INPUT -m state --state NEW -m udp -p udp --dport 873 -j ACCEPT

servicie iptables restart

방화벽을 오픈했지만 연결이 안될 경우 SeLinux를 중지합니다.

✅ 리눅스 Rsync 명령어 옵션

기본 사용 방법은 다음과 같습니다.

rsync -옵션 [백업할원본주소:경로] [백업받을경로]
rsync -옵션 [SOURCE] [DESTINATION]
rsync -옵션 [[USER]@[HOST]:[PATH] [TARGET]
  • cp 명령과 동일하게 [백업할원본의주소:경로] [백업받을경로] 순서로 파일의 경로를 설정합니다.

✅ rsync 명령어 사용 예시: 디렉토리 복사 및 동기화

-avh 옵션 중 -a 옵션은 필수 옵션인 디렉토리 복사와 동기화를 진행할 수 있게 해 줍니다.

1. 로컬에서 로컬로 복사

rsync -avh /home/testuser /backup/home

2. 로컬에서 리모트로 복사

rsync -avh /home/testuser remote_user@remotehost:/home/
## SSH 포트 번호가 다른 경우
rsync -avh -e "ssh -p 123" /home/testuser remote_user@remotehost:/home/

3. 리모트에서 로컬로 가져오기

rsync -avh remote_user@remotehost:/home/testuser /home/testuser
리눅스(펜과 안경)

Similar Posts

  • [Linux] ip 명령어 : 네트워크 인터페이스 및 설정 관리

    ip 명령어는 리눅스에서 네트워크를 관리할 때 사용되는 주요 도구로, 다양한 네트워크 작업을 수행할 수 있습니다. ip 명령어는 네트워크 인터페이스의 상태를 확인하거나 활성화 및 비활성화 할 수 있으며, IP 주소를 확인하거나 수동으로 추가 및 삭제하는 작업도 가능합니다. 또한 라우팅 테이블을 조회하고 경로를 추가하거나 제거하는 등의 라우팅 관리, ARP 테이블 확인 및 수정, 터널링 설정…

  • 리눅스 명령행 인자(Command-Line Argument)와 명령어 옵션

    ‘리눅스 명령행 인자(Command-Line Argument)‘는 ‘리눅스 명령어 인수‘, ‘명령 인자‘ 등으로도 불리며, 리눅스 커맨드 라인에서 명령어를 실행할 때 프로그램에 전달하는 매개변수를 뜻 합니다. 리눅스에서 “매개변수(Parameters)”는 일반적으로 프로그램이나 함수에 전달되는 값을 가리킵니다. 이 값은 해당 프로그램이나 함수가 실행될 때 필요한 입력 값으로 사용됩니다. 컴퓨터 프로그래밍에서 “매개변수(Parameters)”는 함수에 전달되는 값을 받아들이는 변수를 의미합니다. 이는 함수 정의에…

  • [Linux] stat 명령어 : 파일&파일 시스템 확인

    리눅스 stat 명령어는 파일 및 파일 시스템의 상태를 보여주는 명령어입니다. 파일에 대한 자세한 정보가 필요할 때 사용합니다. 목차✅ 리눅스 rsync 설치 및 리모트 설정하기1. rsync 패키지 설치 여부 확인2. 패키지가 없을 경우 설치 진행3. rynsc 설정 파일 작성✅ 록키 리눅스 포함 8이하 버전 xinetd 데몬 설치 및 구동✅ 방화벽 포트 규칙 추가✅ 리눅스…

  • 리눅스 host 명령어 | DNS 조회 명령어

    host 명령어는 DNS(Domain Name System) 조회를 할 때 사용하는 명령어입니다. 호스트 이름에 해당하는 IP 주소를 찾거나, 반대로 IP 주소를 호스트 이름으로 변환하는 데 사용됩니다. 네트워크 연결 문제를 해결하거나 호스트 이름과 IP 주소 간의 매핑을 확인하는 데 유용합니다. 목차✅ 리눅스 rsync 설치 및 리모트 설정하기1. rsync 패키지 설치 여부 확인2. 패키지가 없을 경우 설치…

  • 리눅스 head 명령어 & tail 명령어

    리눅스 head 명령어는 파일의 처음 10줄을 보여주는 명령어이며, tail 명령어는 파일의 마지막 10줄을 보여주는 명령어입니다. 옵션 없이 사용할 경우 각각의 머리와 꼬리 부분을 보여주는 것을 알 수 있습니다. head와 tail 명령어는 보통 서버의 access_log를 볼 때 주로 많이 사용됩니다. 두 명령어의 사용법과 테스트 서버에서 access_log를 각각의 명령어를 통해 확인 해 보겠습니다. 목차✅ 리눅스…

  • [Linux] localectl 명령어

    CentOS 7 버전부터 많은 명령어들이 통합되어 제공됩니다. 로케일 및 키보드 관련 부문은 localectl 명령어에서 제공합니다. locale은 원래 지역이나 장소를 의미하지만, IT 환경에서는 언어 및 지역 설정을 지칭합니다. 리눅스에서는 문자 인코딩, 언어, 날짜/시간, 숫자 등의 지역화 설정을 locale 문자열로 정의합니다. 대부분의 유닉스 및 리눅스 배포판은 POSIX 기반이며, 이는 Red Hat 및 Debian 계열도 포함됩니다….

답글 남기기

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다

Prove your humanity: 5   +   6   =