>  기사  >  백엔드 개발  >  Go에서 AWS Elastic File System(EFS) 사용: 전체 가이드

Go에서 AWS Elastic File System(EFS) 사용: 전체 가이드

PHPz
PHPz원래의
2023-06-17 14:19:371676검색

클라우드 컴퓨팅 기술과 컨테이너화된 애플리케이션이 광범위하게 적용됨에 따라 배포 및 운영을 위해 기존 물리적 서버에서 클라우드 환경으로 애플리케이션을 마이그레이션하는 기업이 점점 더 많아지고 있습니다. 클라우드 환경에서 고성능 스토리지 시스템을 사용하는 것은 매우 중요한 문제이며, AWS Elastic File System(EFS)은 고가용성, 고성능, 서버리스 및 확장성을 제공할 수 있는 강력한 분산 파일 시스템입니다.

EFS는 여러 EC2 인스턴스에서 실시간으로 파일에 액세스하고 공유할 수 있으며 용량 및 성능 요구 사항에 맞게 자동으로 확장됩니다. 이 기사에서는 Go에서 AWS Elastic File System(EFS)을 사용하는 방법에 대해 자세히 살펴보겠습니다.

환경 설정

EFS를 사용하기 전에 먼저 올바른 환경을 설정해야 합니다. AWS 계정, Go용 AWS SDK 및 Go 로케일이 필요합니다.

Go용 AWS SDK 설치

다음 명령을 사용하여 Go용 AWS SDK를 설치할 수 있습니다.

$ go get github.com/aws/aws-sdk-go/aws
$ go get github.com/aws/aws-sdk-go/aws/session

AWS SDK가 올바르게 설치되었는지 확인하려면 다음 테스트 프로그램을 작성할 수 있습니다.

package main

import (
    "fmt"

    "github.com/aws/aws-sdk-go/aws"
    "github.com/aws/aws-sdk-go/aws/session"
)

func main() {
    // Specify the AWS Region to use.
    sess, err := session.NewSessionWithOptions(session.Options{
        Config: aws.Config{
            Region: aws.String("us-west-2"),
        },
    })

    if err != nil {
        fmt.Println(err)
        return
    }

    // Create an S3 service client.
    s3 := NewS3(sess)

    // Verify the client by listing all buckets
    buckets, err := s3.ListBuckets(nil)
    if err != nil {
        fmt.Println(err)
        return
    }

    fmt.Println("Buckets:")
    for _, b := range buckets.Buckets {
        fmt.Printf("* %s created on %s
",
            aws.StringValue(b.Name), aws.TimeValue(b.CreationDate))
    }
}

모든 것이 제대로 진행되면, 출력에는 S3 버킷의 AWS 목록이 포함됩니다.

EFS 파일 시스템 생성

EFS를 사용하기 전에 파일 시스템을 생성해야 합니다. 다음 단계에 따라 EFS 파일 시스템을 생성합니다.

  1. AWS 콘솔에 로그인합니다.
  2. 서비스 목록에서 EFS(Elastic File System)를 선택하세요.
  3. 파일 시스템 생성 버튼을 클릭하세요.
  4. 파일 시스템 생성 페이지에서 VPC와 서브넷을 선택합니다(모든 EC2 인스턴스를 연결하려면 EFS용 퍼블릭 서브넷 중 하나를 선택해야 함).
  5. 보안 그룹 섹션에서 EC2 인스턴스의 모든 인바운드 및 아웃바운드 트래픽을 허용해야 하는 보안 그룹을 선택합니다.
  6. 파일 시스템 및 성능 모드 섹션에서 기본 옵션을 선택하세요.
  7. 파일 시스템 생성을 클릭하세요.

파일 시스템을 생성할 때 시스템은 VPC의 모든 데이터 트래픽을 허용하기 위해 EFS 전용 보안 그룹을 자동으로 생성합니다. 자체 보안 그룹 규칙으로 이 옵션을 재정의할 수 있습니다.

EFS 드라이버 설치

Go 애플리케이션을 EFS와 통합하려면 AWS EFS 드라이버를 설치해야 합니다. Amazon Linux 또는 RHEL에서는 다음 단계에 따라 EFS 드라이버를 설치할 수 있습니다.

  1. 다음 명령을 실행하여 EFS 드라이버 종속성을 설치합니다.
$ sudo yum install gcc libstdc++-devel gcc-c++ fuse fuse-devel automake openssl-devel git
  1. EFS 드라이버를 다운로드하고 빌드합니다.
$ git clone https://github.com/aws-efs-utils/efs-utils
$ cd efs-utils
$ ./build-deb.sh
  1. 설치 EFS 드라이버 절차:
$ sudo yum install ./build/amazon-efs-utils*rpm
  1. EFS 드라이버가 올바르게 설치되었는지 확인합니다. 이는 다음 명령으로 확인할 수 있습니다.
$ sudo mount -t efs fs-XXXXX:/ /mnt/efs

여기서 fs-XXXXX는 EFS 파일 시스템의 ID입니다. 출력에 오류 메시지가 없으면 설치가 성공한 것입니다.

EFS 사용

EFS 드라이버를 설치하고 EFS 파일 시스템을 생성한 후 Go 애플리케이션을 EFS 파일 시스템에 연결할 수 있습니다. 다음은 EFS 사용에 대한 몇 가지 모범 사례입니다.

프로그램에서 운영 체제 표준 라이브러리를 통해 EFS 파일 시스템을 사용합니다. Go 언어 환경에서는 syscall 패키지 또는 os 패키지를 사용하여 EFS 파일 시스템에 연결할 수 있습니다.

다음은 EFS에 연결하기 위한 샘플 프로그램 조각입니다.

package main

import (
    "fmt"
    "os"
    "syscall"
)

func main() {
    // Mount EFS.
    if err := syscall.Mount("fs-XXXXX.efs.us-west-2.amazonaws.com:/", "/mnt/efs", "nfs4", 0, "rsize=1048576,wsize=1048576,hard,timeo=600,retrans=2"); err != nil {
        fmt.Println("Unable to mount EFS file system:", err)
        os.Exit(1)
    }

    // List the files in the EFS file system.
    if files, err := os.ReadDir("/mnt/efs"); err != nil {
        fmt.Println("Unable to read files in EFS:", err)
    } else {
        fmt.Println("Files in EFS:")
        for _, file := range files {
            fmt.Println(file.Name())
        }
    }

    // Unmount EFS when done.
    if err := syscall.Unmount("/mnt/efs", 0); err != nil {
        fmt.Println("Unable to unmount EFS file system:", err)
        os.Exit(1)
    }
}

위 코드 조각에서는 시스템 호출을 사용하여 EFS 파일 시스템을 마운트하고 그 안에 있는 파일을 나열했습니다. 프로그램이 끝나면 시스템 호출을 사용하여 파일 시스템을 마운트 해제했습니다.

EFS는 RESTful API이므로 파일 생성, 읽기, 쓰기 및 삭제와 같은 모든 표준 파일 시스템 작업을 지원합니다. Go 언어 환경에서는 os 패키지의 기능을 사용하여 이러한 작업을 수행할 수 있습니다.

다음은 EFS에 파일을 생성하는 샘플 프로그램입니다.

package main

import (
    "fmt"
    "os"
)

func main() {
    // Create a new file in EFS.
    if file, err := os.Create("/mnt/efs/myfile.txt"); err != nil {
        fmt.Println("Unable to create file:", err)
        os.Exit(1)
    } else {
        defer file.Close()
        fmt.Println("File created successfully.")
    }
}

위의 예에서는 os 패키지의 Create 함수를 사용하여 EFS 파일 시스템에 새 파일을 생성합니다. 프로그램이 종료되기 전에 이 파일을 닫아야 합니다.

결론

AWS Elastic File System(EFS)은 고가용성, 성능, 서버리스 및 확장성을 제공하는 강력한 분산 파일 시스템입니다. Go 언어 환경에서는 syscall 패키지 또는 표준 라이브러리의 os 패키지를 사용하여 EFS 파일 시스템에 연결하고 모든 기능을 사용할 수 있습니다. 이 문서의 지침을 통해 EFS 사용에 대한 몇 가지 모범 사례가 이미 있으므로 Go 언어 환경에서 EFS 기능을 완전히 활용할 수 있습니다.

위 내용은 Go에서 AWS Elastic File System(EFS) 사용: 전체 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.