주:

동기화를 사용하여 Oracle Cloud Infrastructure에서 영역 간 양방향 동기화 수행

소개

영역 간 오브젝트 스토리지 동기화는 데이터 백업, 재해 복구 및 다중 영역 액세스를 포함한 다양한 클라우드 워크로드에 필수적입니다. Oracle Cloud Infrastructure(OCI)는 OCI Object Storage용 복제 기능을 제공하지만 기본 양방향 동기화 솔루션은 제공하지 않습니다. 이러한 제한으로 인해 사용자는 커스텀 구현에 의존하여 여러 지역에 걸쳐 파일을 동기화해야 합니다.

오픈 소스 분산 파일 동기화 도구인 Syncthing은 실시간으로 작동하는 연속적인 양방향 동기화를 제공합니다. 객체 복제를 위한 이벤트 기반 모델을 사용하는 OCI Functions와 달리 Syncthing은 로컬 및 OCI Object Storage 마운트 디렉토리를 지원하면서 가상 머신(VM) 간에 전체 파일 구조를 효율적으로 동기화합니다.

이 사용지침서에서는 OCI Resource Manager 스택을 사용하여 OCI Compute 인스턴스에 Syncthing을 배포하여 로컬 VM 스토리지와 OCI Object Storage 마운트 디렉토리 간에 자동 양방향 동기화를 수행할 예정입니다.

고려사항

s3fs를 사용하여 OCI Object Storage와 Syncthing을 마운트하는 경우:

동기화는 언제 좋은 아이디어입니까?

목표

필요 조건

작업 1: VM 배치에 필요한 정보 준비

  1. OCI Resource Manager 스택을 다운로드합니다. 이 스택은 VM.Standard.E5에서 Oracle Linux 8을 실행하는 VM의 배치를 자동화합니다. 가변 구성입니다. CloudInit를 사용하여 Syncthing을 설치하고, 기존 OCI 버킷을 마운트하며, s3fs를 사용하여 액세스를 구성합니다. VM은 SSH 액세스, 공용 IP로 프로비저닝되며 쉽게 식별할 수 있도록 태그가 지정됩니다. 자세한 내용은 OCI Resource Manager 스택을 참고하세요.

  2. 두 대상 영역에서 퍼블릭 서브넷으로 VCN을 생성합니다.

    양방향 영역 간 스토리지 동기화를 위해 동기화를 사용하는 VM을 프로비전하기 위해 스택이 두 위치에 배치됩니다. 배포된 후에는 VM의 공용 IP를 사용하여 브라우저에서 동기화에 액세스할 수 있습니다.

  3. 테스트가 수행될 각 지역에 OCI Object Storage 버킷이 존재하는지 확인합니다. 버킷의 가시성은 비공개일 수 있습니다.

  4. s3fs 마운트에 대한 고객 암호 키를 만듭니다. 고객 암호 키는 OCI Object Storage 액세스에 사용됩니다.

    1. OCI 콘솔에 로그인하여 프로파일로 이동하고 사용자 이름 및 고객 암호 키를 누릅니다.

      프로파일 - 고객 암호 키

    2. 비밀 키 생성을 누르고 이름(예: s3fs-access)을 입력합니다.

    3. 생성된 키는 나중에 작업 2에서 사용되므로 복사해야 합니다.

      고객 보안 액세스 키

    4. 액세스 키를 누르고 나중에 작업 2에서 사용할 대로 값을 복사합니다.

      고객 보안 액세스 키

    5. 나중에 작업 2에서 사용할 버킷 세부정보 페이지에서 네임스페이스를 복사합니다.

      오브젝트 스토리지 버킷 네임스페이스

작업 2: 스택 적용

  1. OCI 콘솔에 로그인하여 개발자 서비스, 리소스 관리자로 이동하고 스택을 누릅니다.

    OCI 리소스 관리자 스택

  2. Terraform OCI Resource Manager 스택을 생성합니다. 자세한 내용은 Creating a Stack from a Zip File를 참조하십시오.

    1. 스택 생성을 누릅니다.

    2. .zip 파일을 선택하고 스택을 추가합니다.

    3. 태그 키를 입력합니다.

    4. 다음을 누릅니다.

  3. 변수 구성 페이지에서 다음 정보를 입력합니다.

    • 구획: 구획을 입력합니다.
    • VCN 및 서브넷: 기존 VCN 및 공용 서브넷을 선택합니다.
    • 원하는 경우 VM 표시 이름을 수정합니다.
    • 공용 SSH 키: VM에 대한 공용 SSH 키를 입력합니다.
    • 가용성 도메인: 가용성 도메인을 선택합니다.
    • 고객 암호 키 OCID 및 고객 암호 액세스 키: 작업 1에서 생성된 고객 암호 키 OCID 및 고객 암호 액세스 키를 입력합니다.
    • 버킷 이름: 버킷 이름을 입력합니다.
    • 오브젝트 스토리지 네임스페이스: 오브젝트 스토리지 네임스페이스를 선택합니다.
  4. 다음을 누르고 정보를 검토합니다. 모든 항목이 정상이면 적용 실행을 선택하고 생성을 누릅니다.

    OCI ORM 적용 스택

    적용 작업이 성공적으로 완료되면 새로 생성된 VM의 공용(public) 및 전용(private) IP를 반환해야 합니다.

    ORM 스택 출력

  5. 보조 영역의 단계를 반복하여 두번째 VM을 만듭니다.

  6. 다음 명령을 사용하여 SSH를 통해 접속하여 OCI Object Storage 버킷이 VM 레벨에서 /home/opc/logging에 마운트되었는지 확인합니다.

    mount | grep s3fs
    

    버킷이 성공적으로 마운트되면 다음과 유사한 출력이 표시됩니다.

    마운트 버킷 정보

    그러면 s3fs가 VM의 /home/opc/logging에 버킷을 마운트했음을 확인합니다.

태스크 3: 동기화 구성

두 VM이 두 영역에 모두 배치되면 아래 단계에 따라 각 VM에 동기화를 구성하여 VM 간에 스토리지를 동기화합니다.

  1. 첫번째 영역에서 VM의 공용 IP를 복사하고 브라우저에서 사용하여 동기화 인터페이스에 액세스합니다. 다음 URL을 입력합니다.

    http://<vm1-public-ip>:8384
    
  2. 인터페이스에 액세스하면 다음 이미지와 유사한 동기화 인터페이스가 표시됩니다. 폴더원격 장치는 다음 단계에서 동기화를 위해 구성할 영역입니다.

    동기화 화면

    주: GUI 섹션 아래의 설정에서 사용자 이름비밀번호를 설정하여 경고를 제거할 수 있습니다.

  3. 폴더 섹션에서 폴더 추가를 눌러 동기화 관리 인터페이스에 로컬 VM 폴더를 생성하거나 포함합니다.

    동기화 추가 폴더

  4. 다음 정보를 입력하여 로컬 폴더를 구성하고 저장을 누릅니다.

    • 폴더 레이블: 폴더를 식별하는 사용자에게 친숙한 이름입니다. 예: local_VM1.
    • 폴더 경로: 로컬 폴더의 디렉토리 경로입니다. 예: ~/local_VM1.

    로컬 폴더 동기화

    VM 터미널에서 새 폴더 local_VM1이 생성되었는지 확인할 수 있습니다.

  5. 보조 영역의 VM에서 1-4단계를 반복하고 VM2 동기화 인터페이스에 local_VM2 폴더를 추가합니다.

  6. VM1부터 두 VM 간에 영역 간 동기화 연결을 구성합니다.

    1. 첫번째 동기화 VM의 Remote Devices(원격 장치) 섹션에서 Add Remote Device(원격 장치 추가)를 눌러 두번째 영역의 원격 폴더를 포함합니다.

      원격 기기 추가하기

    2. 일반에 다음 정보를 입력합니다.

      • 장치 ID: 두번째 동기화 장치의 ID입니다. VM2에서 동기화 인터페이스를 열고 작업, ID 표시로 이동하여 표시된 값을 복사하고 이 필드에 붙여넣습니다.

        원격 장치 - 표시 ID

      • 장치 이름: 관련 이름(예: remote_VM2)을 입력합니다.

        원격 장치 - 일반 탭

    3. 공유에서 원격 장치와 공유할 local_VM1을 선택합니다.

      원격 기기 - 공유 탭

    4. 고급에서 주소tcp://<vm2-public-ip>:22000를 입력하고, 22000는 동기화 데이터에 사용되는 TCP 포트입니다.

    5. Save를 누릅니다.

  7. 이때 VM1 Syncthing에서 로컬 폴더 local_VM1가 녹색 Up to Date로 표시되고 원격 장치 remote_VM2Disconnected가 표시됩니다.

    연결을 완료하려면 VM1 동기화에서 수집된 동등한 데이터를 사용하여 VM2 동기화에 대해 동일한 단계를 수행하고 장치 ID, tcp://<vm1-public-ip>:22000주소로 입력하고 장치 이름(예: remote_VM1)을 입력합니다.

    주: 22000 포트가 VCN의 보안 목록에 열려 있는지 확인하십시오.

  8. 동일한 구성 후에 각 동기화 인터페이스에서 원격 폴더 추가를 수락하라는 메시지가 표시됩니다. 추가를 누릅니다.

    원격 폴더 받아들이기

  9. 특정 세부 정보와 함께 로컬에 저장하라는 메시지가 표시됩니다. 예를 들어, VM1에서 수신 local_VM2를 저장하라는 메시지가 표시되면 VM1에서 해당 이름을 remote_VM2로 변경하여 더 명확한 표시를 할 수 있습니다. 또한 로컬 VM1 경로에 매핑할 수도 있습니다. 경로일 수 있습니다. 새 폴더가 없는 경우 새 폴더가 생성됩니다. ~/local_VM1을 선택할 수도 있습니다. 즉, 두 VM의 두 폴더 콘텐츠가 동일한 위치에 병합됩니다. 이 예에서는 ~/remote_VM2 경로를 입력합니다.

  10. 수신 local_VM1 폴더를 기준으로 VM2에서 동일한 단계를 수행하고 remote_VM1로 매핑합니다.

  11. 이제 두 VM이 동기화되어 있고 Syncthing에서 관리하는 폴더가 있어야 합니다. VM1에서는 local_VM1remote_VM2, VM2에서는 local_VM2remote_VM1입니다.

    폴더 동기화됨

작업 4: 로컬 저장소의 동기화 테스트

동기화 동기화를 테스트하려면 SSH를 사용하여 각 VM에 로그인합니다. opc 홈 디렉토리 안에 두 개의 폴더가 있습니다.

동기화를 확인하기 위해 한 VM의 로컬 폴더에 파일을 추가하거나 수정하고 변경 사항이 원격 VM의 해당 폴더에 나타나는지 확인합니다. 또한 동기화 인터페이스 또는 로그를 모니터링하여 두 OCI 리전 간의 성공적인 동기화를 확인합니다.

  1. SSH를 VM1로 설정합니다.

    ssh opc@<vm1-public-ip>
    
  2. 다음 명령을 실행하여 로컬 Syncthing 공유 local_VM1 폴더로 이동합니다.

    cd ~/local_VM1
    
  3. 다음 명령을 실행하여 테스트 파일을 만듭니다.

    echo "testing sync" > testVM1.txt
    
  4. 새 터미널을 열고 SSH를 사용하여 VM2로 이동합니다.

    ssh opc@<vm2-public-ip>
    
  5. 다음 명령을 실행하여 VM2의 공유 폴더로 이동합니다.

    cd ~/remote_VM1
    
  6. 다음 명령을 실행하여 파일이 나타나는지 확인합니다.

    ls -l
    cat testVM1.txt
    
  7. VM2에서 동일한 단계를 수행하고 파일이 remote_VM2 폴더의 VM1에 나타나는지 확인합니다.

  8. 동기화 인터페이스에서 동기화 상태를 확인합니다. 브라우저에서 http://<vm1-public-ip>:8384http://<vm2-public-ip>:8384를 열어 로그 및 동기화 상태를 확인합니다.

    동기화된 파일

작업 5: OCI 오브젝트 스토리지 버킷 콘텐츠 동기화 테스트

버킷은 /home/opc/logging 디렉토리에 배치된 VM에 마운트됩니다. 마운트된 버킷에 있는 파일을 테스트하고 동기화하려면 이전 단계를 재실행하여 logging VM 디렉토리를 로컬 폴더로 추가한 다음 원격 장치에서 공유해야 합니다. 다음과 유사한 내용이 표시됩니다.

그런 다음 logging 디렉토리에 파일을 생성하여 OCI 버킷에 표시되도록 하고, 올바르게 구성된 경우 VM2 logging 디렉토리로 동기화합니다. 따라서 영역 간 두번째 버킷에도 동기화됩니다.

버킷 동기화

작업 6: 몇 가지 추가 테스트 수행

이전에 구성한 것과 동일한 폴더 및 공유 장치로 쉽게 테스트할 수 있는 두 가지 사항이 있습니다.

확인

추가 학습 자원

docs.oracle.com/learn에서 다른 실습을 탐색하거나 Oracle Learning YouTube 채널에서 더 많은 무료 학습 콘텐츠에 액세스하세요. 또한 Oracle Learning Explorer가 되려면 education.oracle.com/learning-explorer을 방문하십시오.

제품 설명서는 Oracle Help Center를 참조하십시오.